@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap";:root{--bg-primary:#e2e8f0;--bg-secondary:#cbd5e1;--bg-card:#fff;--bg-card-hover:#f8fafc;--border-color:#00000014;--border-hover:#2c6ca166;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--accent-blue:#2c6ca1;--accent-blue-light:#4893cc;--accent-blue-glow:#2c6ca11a;--status-ok:#10b981;--status-warning:#f59e0b;--status-danger:#ef4444;--status-offline:#64748b;--gradient-card:linear-gradient(135deg, #ffffff03 0%, #ffffff08 100%);--gradient-header:linear-gradient(135deg, #0f1c2999 0%, #09131e99 100%);--font:"Inter", system-ui, -apple-system, sans-serif;--radius:12px;--radius-lg:20px;--shadow-card:0 20px 25px -5px #00000026, 0 10px 10px -5px #0000001a, 0 1px 3px 0 #0000000d;--shadow-glow:0 0 25px #2c6ca114;--transition:.25s cubic-bezier(.4, 0, .2, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth;font-size:16px}body{font-family:var(--font);color:var(--text-primary);background-color:#e2e8f0;min-height:100vh;line-height:1.6}#root{min-height:100vh}img,svg{max-width:100%;display:block}button,input,select,textarea{font-family:inherit}a{color:var(--accent-blue-light);text-decoration:none}a:hover{text-decoration:underline}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#3b82f64d;border-radius:999px}::-webkit-scrollbar-thumb:hover{background:#3b82f680}.page-title{color:var(--text-primary);letter-spacing:-.02em;margin:0 0 4px;font-size:1.75rem;font-weight:800;line-height:1.2}.page-subtitle{color:var(--text-secondary);margin:0;font-size:.875rem}.btn{border-radius:var(--radius);cursor:pointer;transition:all var(--transition);white-space:nowrap;border:1px solid #0000;align-items:center;gap:8px;padding:10px 20px;font-size:.875rem;font-weight:600;text-decoration:none;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--primary{background:var(--accent-blue);color:#fff;border-color:var(--accent-blue);box-shadow:0 0 20px #3b82f640}.btn--primary:hover:not(:disabled){background:#2563eb;transform:translateY(-1px);box-shadow:0 0 28px #3b82f666}.btn--secondary{color:var(--accent-blue-light);background:#3b82f61a;border-color:#3b82f64d}.btn--secondary:hover:not(:disabled){border-color:var(--accent-blue);background:#3b82f633}.btn--ghost{color:var(--text-secondary);border-color:var(--border-color);background:0 0}.btn--ghost:hover:not(:disabled){color:var(--text-primary);border-color:var(--border-hover);background:#0000000a}.btn--danger{color:var(--status-danger);background:#ef44441a;border-color:#ef44444d}.btn--danger:hover:not(:disabled){border-color:var(--status-danger);background:#ef444433}.btn--success{color:#059669;background:#10b9811f;border-color:#10b98159}.btn--success:hover:not(:disabled){background:#10b98138;border-color:#10b981;transform:translateY(-1px);box-shadow:0 4px 12px #10b98133}.btn--sm{border-radius:8px;padding:6px 14px;font-size:.8rem}.ciclo-badge{border-radius:999px;align-items:center;gap:6px;padding:4px 10px;font-size:.75rem;font-weight:600;display:inline-flex}.ciclo-badge--activo{color:#059669;background:#10b9811f;border:1px solid #10b9814d}.ciclo-badge__dot{background:#10b981;border-radius:50%;width:7px;height:7px;animation:1.4s ease-in-out infinite pulse-dot}.card,.stat-card,.device-card,.summary-card,.detail__chart-container,.detail__table-container,.alert-item,.modal-content,.role-card{border-radius:var(--radius);transition:transform var(--transition), box-shadow var(--transition);--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--border-color:#00000014;--border-hover:#2c6ca166;--bg-card-hover:#ffffffd9;--bg-secondary:#00000008;border:1px solid #0000000f;padding:24px;background:var(--bg-card)!important;box-shadow:var(--shadow-card)!important;background-image:none!important}.card{border-radius:var(--radius-lg);padding:24px}.form-group{flex-direction:column;gap:6px;display:flex}.form-label{color:var(--text-secondary);font-size:.8rem;font-weight:600}.form-label__opt{color:var(--text-muted);font-size:.75rem;font-weight:400}.form-input-wrapper{align-items:center;display:flex;position:relative}.form-input-icon{color:var(--text-muted);pointer-events:none;align-items:center;display:flex;position:absolute;left:12px}.form-input-toggle{color:var(--text-muted);cursor:pointer;transition:color var(--transition);background:0 0;border:none;align-items:center;padding:4px;display:flex;position:absolute;right:10px}.form-input-toggle:hover{color:var(--text-primary)}.form-input{border-radius:var(--radius);width:100%;color:var(--text-primary);transition:border-color var(--transition), box-shadow var(--transition), background var(--transition);appearance:none;background:#ffffff08;border:1px solid #ffffff1a;outline:none;padding:10px 14px;font-size:.875rem}.form-input-wrapper .form-input{padding-left:42px;padding-right:42px}.form-input:focus{border-color:var(--accent-blue-light);background:#ffffff0f;box-shadow:0 0 0 3px #4893cc33}.form-input--error{border-color:var(--status-danger)!important;box-shadow:0 0 0 2px #ef444426!important}.form-input::placeholder{color:var(--text-muted)}.form-select{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238899bb' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}.form-select option{background:var(--bg-secondary);color:var(--text-primary)}.form-error{color:var(--status-danger);font-size:.75rem}.form-hint{color:var(--text-muted);font-size:.72rem}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.85)}}@keyframes spinner-rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.card .form-input,.device-card .form-input,.modal-content .form-input,.role-card .form-input{color:#0f172a!important;background:#ffffff73!important;border:1px solid #0000001f!important}.card .form-input:focus,.device-card .form-input:focus,.modal-content .form-input:focus,.role-card .form-input:focus{border-color:var(--accent-blue-light)!important;background:#ffffffbf!important;box-shadow:0 0 0 3px #4893cc2e!important}.card .form-input::placeholder,.device-card .form-input::placeholder,.modal-content .form-input::placeholder,.role-card .form-input::placeholder{color:#707782!important}.card select,.modal-content select{color:#0f172a!important;background-color:#ffffff73!important;border-color:#0000001f!important}.recharts-cartesian-grid line{stroke:var(--border-color)!important;stroke-opacity:1!important}.recharts-cartesian-axis-line{stroke:var(--border-color)!important}.recharts-legend-item-text{color:var(--text-secondary)!important}.recharts-text{fill:var(--text-muted)!important}.spinner-wrapper{flex-direction:column;justify-content:center;align-items:center;gap:12px;display:flex}.spinner-ring{display:inline-block;position:relative}.spinner-sm .spinner-ring{width:24px;height:24px}.spinner-md .spinner-ring{width:40px;height:40px}.spinner-lg .spinner-ring{width:64px;height:64px}.spinner-ring div{box-sizing:border-box;border:3px solid #0000;border-top-color:var(--accent-blue);border-radius:50%;width:100%;height:100%;animation:1.2s cubic-bezier(.5,0,.5,1) infinite spinner-rotate;display:block;position:absolute}.spinner-ring div:first-child{animation-delay:-.45s}.spinner-ring div:nth-child(2){animation-delay:-.3s}.spinner-ring div:nth-child(3){animation-delay:-.15s}.spinner-texto{color:var(--text-secondary);margin:0;font-size:.875rem}.sidebar{z-index:100;--text-primary:#0f172a;--text-secondary:#334155;--text-muted:#64748b;--border-color:#0000000f;background:#fff;border-right:1px solid #0000000f;flex-direction:column;width:240px;height:100vh;transition:width .3s;display:flex;position:fixed;top:0;left:0;box-shadow:6px 0 30px #00000014}.sidebar--collapsed{width:64px}.sidebar__brand{border-bottom:1px solid var(--border-color);align-items:center;gap:10px;min-height:72px;padding:20px 16px;transition:min-height .3s,padding .3s;display:flex;overflow:hidden}.sidebar--collapsed .sidebar__brand{justify-content:center;padding:20px 0}.sidebar:not(.sidebar--collapsed) .sidebar__brand{flex-direction:column;justify-content:center;align-items:center;min-height:160px;padding:20px 12px}.sidebar__brand-logo{filter:drop-shadow(0 2px 4px #00000026)}.sidebar__brand-logo--large{object-fit:contain;filter:drop-shadow(0 4px 10px #0003);width:160px;height:auto;transition:width .3s}.sidebar__brand-icon{flex-shrink:0;font-size:1.6rem}.sidebar__brand-text{flex:1;min-width:0;overflow:hidden}.sidebar__brand-name{color:var(--text-primary);white-space:nowrap;background:linear-gradient(90deg, var(--accent-blue-light), #a78bfa);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:.95rem;font-weight:800;display:block}.sidebar__brand-sub{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:.65rem;display:block;overflow:hidden}.sidebar__toggle{width:26px;height:26px;color:var(--text-muted);cursor:pointer;transition:all var(--transition);z-index:110;background:#fff;border:1px solid #0000001a;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:23px;right:-13px;box-shadow:0 2px 6px #0000001a}.sidebar__toggle:hover{color:var(--accent-blue);border-color:var(--accent-blue-light);background:#00000005;transform:scale(1.1)}.sidebar__nav{flex-direction:column;flex:1;gap:4px;padding:16px 8px;display:flex;overflow-y:auto}.sidebar__link{border-radius:var(--radius);color:#475569;transition:all var(--transition);white-space:nowrap;align-items:center;gap:12px;padding:10px 12px;font-size:.875rem;font-weight:500;text-decoration:none;display:flex;position:relative}.sidebar__link:hover{color:#0f172a;background:#2c6ca114}.sidebar__link--active{color:var(--accent-blue);background:#2c6ca11f;border:1px solid #2c6ca133}.sidebar__badge{background:var(--status-danger);color:#fff;border-radius:999px;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 3px;font-size:.6rem;font-weight:700;animation:2s ease-in-out infinite pulse-dot;display:flex;position:absolute;top:-5px;right:-5px}.sidebar__badge-inline{background:var(--status-danger);color:#fff;border-radius:999px;justify-content:center;align-items:center;min-width:18px;height:18px;margin-left:auto;padding:0 4px;font-size:.65rem;font-weight:700;display:inline-flex}.sidebar__footer{border-top:1px solid var(--border-color);text-align:center;padding:16px}.sidebar--collapsed .sidebar__footer{display:none}.sidebar__version{color:var(--text-muted);font-size:.7rem}.layout{background:0 0;min-height:100vh;display:flex}.layout__main{flex-direction:column;flex:1;min-height:100vh;margin-left:240px;transition:margin-left .3s;display:flex}.layout--collapsed .layout__main{margin-left:64px}.layout__header{z-index:50;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--border-color:#0000000f;--border-hover:#2c6ca166;background:#fff;border-bottom:1px solid #0000000f;justify-content:space-between;align-items:center;height:64px;padding:0 24px;display:flex;position:sticky;top:0;box-shadow:0 6px 25px #0000000f}.layout__header-left{flex:1}.layout__header-right{align-items:center;gap:16px;display:flex}.layout__alerts-indicator{color:var(--status-danger);background:#ef44441a;border:1px solid #ef44444d;border-radius:999px;align-items:center;gap:6px;padding:4px 12px;font-size:.8rem;font-weight:600;display:flex}.layout__alerts-dot{background:var(--status-danger);width:8px;height:8px;box-shadow:0 0 6px var(--status-danger);border-radius:50%;animation:1.5s ease-in-out infinite pulse-dot}.layout__user{align-items:center;gap:8px;display:flex}.layout__user-avatar{background:linear-gradient(135deg, var(--accent-blue), var(--accent-blue-light));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.875rem;font-weight:700;display:flex}.layout__user-name{color:var(--text-secondary);font-size:.875rem;font-weight:600}.layout__content{box-sizing:border-box;flex:1;width:100%;max-width:1400px;margin:0 auto;padding:28px 24px}@media (width<=768px){.layout__main{margin-left:64px}.layout__user-name,.layout__alerts-indicator span:last-child{display:none}}.login-page{background-color:#f1f5f9;justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex;position:relative;overflow:hidden}.login-bg{background-image:linear-gradient(#0b151940,#060d148c),url(/bg-pattern.png);background-position:50%;background-size:cover;position:absolute;inset:0}.login-particle{background:#ffffff59;border-radius:50%;width:3px;height:3px;animation:linear infinite float-particle;position:absolute}@keyframes float-particle{0%{opacity:0;transform:translateY(0)scale(1)}10%{opacity:.8}90%{opacity:.8}to{opacity:0;transform:translateY(-120px)scale(.3)}}.login-card{-webkit-backdrop-filter:blur(20px);border-radius:var(--radius-lg);--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--border-color:#00000014;--border-hover:#2c6ca166;--bg-card-hover:#00000005;--bg-secondary:#00000005;background:#ffffffa6;border:1px solid #ffffff73;width:100%;max-width:440px;padding:40px 36px;animation:.5s fadeInUp;position:relative;box-shadow:0 20px 40px #00000026,inset 0 1px #ffffff80}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-logo{text-align:center;flex-direction:column;justify-content:center;align-items:center;margin-bottom:24px;display:flex}.login-logo__img{object-fit:contain;width:180px;height:auto;animation:3s ease-in-out infinite float-icon}@keyframes float-icon{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.login-card__heading{color:var(--text-primary);text-align:center;margin:0 0 6px;font-size:1.25rem;font-weight:700}.login-card__desc{color:var(--text-secondary);text-align:center;margin:0 0 24px;font-size:.825rem;line-height:1.5}.login-form{flex-direction:column;gap:20px;display:flex}.login-error{border-radius:var(--radius);color:var(--status-danger);background:#ef44441a;border:1px solid #ef44444d;align-items:center;gap:8px;padding:12px 14px;font-size:.85rem;animation:.3s shake;display:flex}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-6px)}75%{transform:translate(6px)}}.login-btn{justify-content:center;gap:8px;width:100%;height:48px;margin-top:4px;font-size:1rem}.login-btn__spinner{border:2px solid #0000001a;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.8s linear infinite spinner-rotate}.gauge-container{flex-direction:column;gap:6px;display:flex}.gauge-value{color:var(--status-ok);font-variant-numeric:tabular-nums;font-size:1.1rem;font-weight:700}.gauge-value--fallo{color:var(--status-danger);letter-spacing:.05em;font-size:.875rem}.gauge-value--nd{color:var(--text-muted);font-size:.875rem}.gauge-bar-wrapper{flex-direction:column;gap:4px;display:flex}.gauge-bar{background:#00000014;border-radius:999px;height:6px;position:relative;overflow:visible}.gauge-zone-ok{background:#10b98140;border-radius:999px;height:100%;position:absolute;top:0}.gauge-indicator{border:2px solid #fff;border-radius:50%;width:12px;height:12px;transition:left .4s;position:absolute;top:50%;transform:translate(-50%,-50%);box-shadow:0 1px 3px #0003}.gauge-labels{color:var(--text-muted);justify-content:space-between;font-size:.7rem;display:flex}.device-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:transform var(--transition), box-shadow var(--transition), border-color var(--transition);background-image:var(--gradient-card);cursor:default;flex-direction:column;gap:16px;padding:20px;display:flex;position:relative}.device-card:hover{box-shadow:var(--shadow-card), var(--shadow-glow);border-color:var(--border-hover);transform:translateY(-3px)}.device-card--ok{border-top:2px solid var(--status-ok)}.device-card--alerta{border-top:2px solid var(--status-warning)}.device-card--fallo{border-top:2px solid var(--status-danger)}.device-card--sin_datos{border-top:2px solid var(--status-offline)}.device-card__alert-badge{background:var(--status-danger);color:#fff;width:22px;height:22px;box-shadow:0 0 10px var(--status-danger);border-radius:50%;justify-content:center;align-items:center;font-size:.7rem;font-weight:700;animation:1.5s ease-in-out infinite pulse-dot;display:flex;position:absolute;top:-8px;right:16px}.device-card__header{align-items:center;gap:12px;display:flex}.device-card__icon{flex-shrink:0;font-size:1.8rem;line-height:1}.device-card__info{flex:1;min-width:0}.device-card__nombre{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:1rem;font-weight:700;overflow:hidden}.device-card__tipo{color:var(--text-secondary);font-size:.75rem;font-weight:500}.device-card__sensores{flex-direction:column;gap:12px;display:flex}.device-card__sensor{border-radius:var(--radius);background:#00000005;border:1px solid #0000000d;padding:12px}.device-card__sensor-header{align-items:center;gap:8px;margin-bottom:8px;display:flex}.device-card__sensor-nombre{color:var(--text-secondary);flex:1;font-size:.8rem;font-weight:600}.device-card__sensor-warning{color:var(--status-warning);font-size:.7rem;font-weight:600}.device-card__sensor-error{color:var(--status-danger);font-size:.7rem;font-weight:600}.device-card__sin-limite,.device-card__sin-sensores{color:var(--text-muted);margin:0;font-size:.8rem;font-style:italic}.device-card__footer{border-top:1px solid var(--border-color);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-top:4px;padding-top:12px;display:flex}.device-card__last-seen{color:var(--text-muted);font-size:.75rem}.device-card__actions{gap:8px;display:flex}.dashboard__header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:24px;display:flex}.dashboard__stats{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius);transition:border-color var(--transition);flex-direction:column;gap:4px;padding:16px 20px;display:flex}.stat-card--ok{border-left:3px solid var(--status-ok)}.stat-card--warning{border-left:3px solid var(--status-warning)}.stat-card--danger{border-left:3px solid var(--status-danger)}.stat-card__value{color:var(--text-primary);font-variant-numeric:tabular-nums;font-size:2rem;font-weight:800;line-height:1}.stat-card__label{color:var(--text-secondary);font-size:.775rem;font-weight:500}.dashboard__grid{grid-template-columns:repeat(2,1fr);gap:20px;display:grid}.dashboard__loading{justify-content:center;padding:80px 0;display:flex}.dashboard__error{text-align:center;flex-direction:column;align-items:center;gap:12px;padding:60px 0;display:flex}.dashboard__error-icon{font-size:3rem}.dashboard__error p{color:var(--text-secondary);margin:0;font-size:.95rem}.dashboard__empty{text-align:center;flex-direction:column;align-items:center;gap:12px;padding:80px 24px;display:flex}.dashboard__empty-icon{filter:grayscale();opacity:.5;font-size:4rem}.dashboard__empty h2{color:var(--text-primary);margin:0;font-size:1.25rem}.dashboard__empty p{color:var(--text-secondary);margin:0;font-size:.9rem}@media (width<=900px){.dashboard__grid{grid-template-columns:1fr}.dashboard__stats{grid-template-columns:repeat(2,1fr)}}@media (width<=500px){.dashboard__stats{grid-template-columns:1fr 1fr}}.detail{flex-direction:column;gap:20px;display:flex}.detail__header{flex-wrap:wrap;align-items:center;gap:16px;display:flex}.detail__title-group{align-items:center;gap:12px;display:flex}.detail__icon{font-size:2rem}.detail__sensor-tabs{-webkit-backdrop-filter:blur(12px);background:#ffffff38;border:1px solid #ffffff40;border-radius:10px;gap:4px;padding:4px;display:inline-flex}.detail__sensor-tab{color:#fff;cursor:pointer;transition:all var(--transition);background:0 0;border:none;border-radius:8px;align-items:center;gap:8px;padding:8px 16px;font-size:.85rem;font-weight:600;display:flex}.detail__sensor-tab:hover{color:#fff;background:#ffffff26}.detail__sensor-tab--active{box-shadow:0 2px 6px #0000001a;color:#0f172a!important;background:#ffffffd9!important}.detail__controls{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.detail__controls-label{color:var(--text-secondary);font-size:.875rem;font-weight:600}.detail__range-btns{flex-wrap:wrap;gap:6px;display:flex}.detail__summary{grid-template-columns:repeat(6,1fr);gap:12px;display:grid}.summary-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius);flex-direction:column;gap:6px;padding:14px 16px;display:flex}.summary-card--actual{background:#3b82f60a;border-color:#3b82f64d}.summary-card--danger{background:#ef44440f;border-color:#ef44444d}.summary-card__label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.72rem;font-weight:600}.summary-card__value{color:var(--text-primary);font-variant-numeric:tabular-nums;font-size:1.2rem;font-weight:800}.summary-card__value--blue{color:var(--accent-blue-light)}.summary-card__value--red{color:var(--status-danger)}.summary-card__value--warning{color:var(--status-warning)}.summary-card__value--ok{color:var(--status-ok)}.detail__custom-range-form{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border-color);flex-wrap:wrap;align-items:center;gap:12px;padding:6px 12px;display:flex}.form-group-horizontal{align-items:center;gap:6px;display:flex}.form-input--sm{border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-primary);border-radius:6px;outline:none;padding:6px 10px;font-family:inherit;font-size:.85rem}.form-input--sm:focus{border-color:var(--accent-blue-light)}.detail__chart-container{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:24px}.detail__chart-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.detail__chart-title{color:var(--text-primary);margin:0;font-size:1rem;font-weight:700}.detail__chart-empty{height:200px;color:var(--text-muted);justify-content:center;align-items:center;font-size:.9rem;display:flex}.chart-tooltip{border:1px solid var(--border-hover);border-radius:var(--radius);background:#fffffff2;padding:12px 14px;font-size:.8rem;box-shadow:0 4px 20px #00000014}.chart-tooltip__time{color:var(--text-secondary);border-bottom:1px solid var(--border-color);margin:0 0 8px;padding-bottom:6px;font-weight:600}.chart-tooltip__row{align-items:center;gap:8px;padding:2px 0;display:flex}.chart-tooltip__dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.chart-tooltip__name{color:var(--text-secondary);flex:1}.chart-tooltip__val{color:var(--text-primary);font-variant-numeric:tabular-nums;font-weight:700}.detail__table-container{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);flex-direction:column;gap:16px;padding:24px;display:flex}.detail__table-wrapper{overflow-x:auto}.detail__table{border-collapse:collapse;width:100%;font-size:.85rem}.detail__table th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border-color);padding:10px 14px;font-size:.72rem;font-weight:700}.detail__table td{border-bottom:1px solid var(--border-color);color:var(--text-secondary);font-variant-numeric:tabular-nums;padding:10px 14px}.detail__table tr:last-child td{border-bottom:none}.detail__table tr:hover td{color:var(--text-primary);background:#00000005}.row-fallo td{color:var(--status-danger)!important}.row-alerta td{color:var(--status-warning)!important}.badge-ok{color:var(--status-ok);font-weight:600}.badge-alerta{color:var(--status-warning);font-weight:600}.badge-fallo{color:var(--status-danger);font-weight:600}.detail-error{text-align:center;color:var(--text-secondary);flex-direction:column;align-items:center;gap:16px;padding:80px 0;display:flex}.detail-no-sensor{text-align:center;color:var(--text-muted);padding:40px}@media (width<=1100px){.detail__summary{grid-template-columns:repeat(3,1fr)}}@media (width<=600px){.detail__summary{grid-template-columns:repeat(2,1fr)}.detail__header{flex-direction:column;align-items:flex-start}}.device-form-page__header{align-items:center;gap:16px;margin-bottom:24px;display:flex}.device-form-layout{grid-template-columns:1fr 380px;align-items:flex-start;gap:24px;display:grid}.device-form{flex-direction:column;gap:20px;display:flex}.device-form__section-title{color:var(--text-primary);border-bottom:1px solid var(--border-color);margin:0 0 4px;padding-bottom:12px;font-size:.95rem;font-weight:700}.form-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.form-error-global{border-radius:var(--radius);color:var(--status-danger);background:#ef44441a;border:1px solid #ef44444d;padding:12px 16px;font-size:.875rem}.device-form__actions{border-top:1px solid var(--border-color);justify-content:flex-end;gap:12px;padding-top:8px;display:flex}.provisioning-card,.provisioning-steps{flex-direction:column;gap:16px;display:flex}.provisioning-step{align-items:flex-start;gap:12px;display:flex}.provisioning-step__num{border:1px solid var(--accent-blue);width:28px;height:28px;color:var(--accent-blue-light);background:#3b82f633;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.8rem;font-weight:700;display:flex}.provisioning-step strong{color:var(--text-primary);margin-bottom:4px;font-size:.875rem;display:block}.provisioning-step p{color:var(--text-secondary);margin:0;font-size:.8rem;line-height:1.5}.provisioning-step code{color:var(--accent-blue-light);background:#0000000d;border-radius:4px;padding:1px 5px;font-family:Courier New,monospace;font-size:.8em}.provisioning-info{border-radius:var(--radius);background:#f59e0b14;border:1px solid #f59e0b40;align-items:flex-start;gap:10px;padding:12px 14px;display:flex}.provisioning-info__icon{flex-shrink:0;font-size:1.1rem}.provisioning-info p{color:var(--text-secondary);margin:0;font-size:.8rem;line-height:1.5}.provisioning-info strong{color:var(--status-warning)}@media (width<=1024px){.device-form-layout{grid-template-columns:1fr}}@media (width<=600px){.form-grid{grid-template-columns:1fr}}.limits-page__header{align-items:center;gap:16px;margin-bottom:24px;display:flex}.limits-sensor-tabs{flex-wrap:wrap;gap:8px;margin-bottom:24px;display:flex}.limits-sensor-tab{border-radius:var(--radius);border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);padding:8px 20px;font-size:.875rem;font-weight:500}.limits-sensor-tab:hover{border-color:var(--border-hover);color:var(--text-primary)}.limits-sensor-tab--active{border-color:var(--accent-blue);color:var(--accent-blue-light);background:#3b82f626}.limits-layout{grid-template-columns:1fr 360px;align-items:flex-start;gap:24px;display:grid}.limits-form{flex-direction:column;gap:20px;display:flex}.limits-form__desc{color:var(--text-secondary);margin:0;font-size:.85rem}.limits-form__fields{grid-template-columns:1fr 1fr;gap:16px;display:grid}.limits-preview{border-radius:var(--radius);background:#3b82f60f;border:1px solid #3b82f633;flex-direction:column;gap:12px;padding:16px;display:flex}.limits-preview__title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin:0;font-size:.85rem;font-weight:700}.limits-preview__values{align-items:center;gap:12px;display:flex}.limits-preview__val{flex-direction:column;flex-shrink:0;gap:4px;display:flex}.limits-preview__val-label{color:var(--text-muted);font-size:.7rem}.limits-preview__val-num{font-variant-numeric:tabular-nums;font-size:1rem;font-weight:700}.limits-preview__val--inf .limits-preview__val-num{color:var(--accent-blue-light)}.limits-preview__val--sup .limits-preview__val-num{color:var(--status-danger)}.limits-preview__bar{flex:1}.limits-preview__bar-track{background:#10b98133;border:1px solid #10b98166;border-radius:999px;height:8px;overflow:hidden}.limits-preview__bar-fill{background:linear-gradient(90deg, var(--accent-blue), var(--status-ok), var(--status-danger));border-radius:999px;width:100%;height:100%}.limits-preview__bar-labels{color:var(--text-muted);justify-content:space-between;margin-top:4px;font-size:.65rem;display:flex}.limits-preview__corr{color:var(--status-warning);margin:0;font-size:.8rem}.limits-history,.limits-history__list{flex-direction:column;gap:12px;display:flex}.limits-history__item{border:1px solid var(--border-color);border-radius:var(--radius);background:#00000005;flex-direction:column;gap:6px;padding:14px;display:flex;position:relative}.limits-history__item--current{background:#3b82f60d;border-color:#3b82f64d}.limits-history__badge{background:var(--accent-blue);color:#fff;border-radius:999px;padding:2px 8px;font-size:.65rem;font-weight:700;position:absolute;top:-8px;right:12px}.limits-history__row{justify-content:space-between;align-items:center;gap:8px;display:flex}.limits-history__label{color:var(--text-muted);font-size:.75rem}.limits-history__val{color:var(--text-secondary);font-variant-numeric:tabular-nums;font-size:.8rem;font-weight:600}.limits-history__val--eff{color:var(--status-ok)}.limits-empty-text{color:var(--text-muted);text-align:center;padding:20px 0;font-size:.85rem}.limits-empty{text-align:center;color:var(--text-muted);padding:40px}@media (width<=1024px){.limits-layout{grid-template-columns:1fr}}@media (width<=600px){.limits-form__fields{grid-template-columns:1fr}.limits-preview__values{flex-direction:column;align-items:stretch}}.alert-item{background:var(--bg-card);border:1px solid var(--border-color);border-left:3px solid var(--alert-color,var(--accent-blue));border-radius:var(--radius);transition:background var(--transition), border-color var(--transition);align-items:flex-start;gap:14px;padding:16px;display:flex}.alert-item:hover{background:var(--bg-card-hover);border-color:var(--alert-color,var(--border-hover))}.alert-item--reconocida{opacity:.55}.alert-item__icon{flex-shrink:0;margin-top:2px;font-size:1.4rem}.alert-item__content{flex:1;min-width:0}.alert-item__header{align-items:center;gap:12px;margin-bottom:4px;display:flex}.alert-item__tipo{color:var(--alert-color,var(--text-primary));font-size:.875rem;font-weight:600}.alert-item__valor{color:var(--text-primary);background:#00000008;border-radius:4px;padding:2px 8px;font-size:.875rem;font-weight:700}.alert-item__mensaje{color:var(--text-secondary);margin:0 0 8px;font-size:.825rem;line-height:1.4}.alert-item__meta{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.alert-item__device,.alert-item__sensor{color:var(--text-muted);align-items:center;gap:4px;font-size:.775rem;display:flex}.alert-item__time{color:var(--text-muted);margin-left:auto;font-size:.775rem}.alert-item__btn{border:1px solid var(--status-ok);width:32px;height:32px;color:var(--status-ok);cursor:pointer;transition:all var(--transition);background:#10b9811a;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;font-size:1rem;font-weight:700;display:flex}.alert-item__btn:hover:not(:disabled){background:var(--status-ok);color:#fff}.alert-item__btn:disabled{opacity:.5;cursor:not-allowed}.alert-item__reconocida-badge{color:var(--text-muted);border:1px solid var(--border-color);background:#00000008;border-radius:999px;flex-shrink:0;align-self:flex-start;padding:3px 8px;font-size:.7rem}.alerts-page__header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.alerts-tabs{-webkit-backdrop-filter:blur(12px);background:#ffffff38;border:1px solid #ffffff40;border-radius:10px;gap:4px;margin-bottom:20px;padding:4px;display:inline-flex}.alerts-tab{color:#fff;cursor:pointer;transition:all var(--transition);background:0 0;border:none;border-radius:8px;align-items:center;gap:8px;padding:8px 16px;font-size:.85rem;font-weight:600;display:flex}.alerts-tab:hover{color:#fff;background:#ffffff26}.alerts-tab--active{box-shadow:0 2px 6px #0000001a;color:#0f172a!important;background:#ffffffd9!important}.alerts-tab__badge{background:var(--status-danger);color:#fff;text-align:center;border-radius:999px;min-width:18px;padding:1px 6px;font-size:.65rem;font-weight:700}.alerts-list{flex-direction:column;gap:8px;display:flex}.alerts-loading,.alerts-error{color:var(--text-secondary);flex-direction:column;align-items:center;gap:12px;padding:60px 0;display:flex}.alerts-error p{margin:0}.alerts-empty{text-align:center;flex-direction:column;align-items:center;gap:12px;padding:80px 24px;display:flex}.alerts-empty__icon{font-size:4rem}.alerts-empty h2{color:var(--text-primary);margin:0;font-size:1.2rem}.alerts-empty p{color:var(--text-secondary);margin:0;font-size:.9rem}.alerts-pagination{border-top:1px solid var(--border-color);justify-content:center;align-items:center;gap:16px;margin-top:24px;padding-top:20px;display:flex}.alerts-pagination__info{color:var(--text-secondary);font-size:.875rem}.users-page{flex-direction:column;gap:20px;display:flex}.users-page__header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}.users-page__actions{gap:12px;display:flex}.users-page__loading{color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:80px 0;display:flex}.users-page__error{border-radius:var(--radius);color:var(--status-danger);background:#ef44441a;border:1px solid #ef44444d;justify-content:space-between;align-items:center;padding:16px;display:flex}.users-tabs{background:#0000000a;border:1px solid #00000014;border-radius:10px;gap:4px;margin-bottom:16px;padding:4px;display:inline-flex}.users-tab{color:#475569;cursor:pointer;transition:all var(--transition);background:0 0;border:none;border-radius:8px;align-items:center;gap:8px;padding:8px 16px;font-size:.85rem;font-weight:600;display:flex}.users-tab:hover{color:#0f172a;background:#00000005}.users-tab--active{box-shadow:0 2px 6px #0000001a;color:#fff!important;background:var(--accent-blue)!important}.users-list-card{padding:24px}.users-table-wrapper{overflow-x:auto}.users-table{border-collapse:collapse;width:100%;font-size:.85rem}.users-table th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border-color);padding:12px 16px;font-size:.72rem;font-weight:700}.users-table td{border-bottom:1px solid var(--border-color);color:var(--text-secondary);vertical-align:middle;padding:14px 16px}.users-table tr:last-child td{border-bottom:none}.users-table tr:hover td{color:var(--text-primary);background:#00000003}.user-td-name{align-items:center;gap:12px;display:flex}.user-avatar{background:linear-gradient(135deg, var(--accent-blue), #8b5cf6);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.875rem;font-weight:700;display:flex}.user-name{color:var(--text-primary);font-weight:600}.current-user-badge{color:var(--accent-blue-light);background:#3b82f61a;border-radius:4px;margin-left:6px;padding:2px 6px;font-size:.65rem;font-weight:600}.role-badge{border-radius:999px;padding:3px 8px;font-size:.72rem;font-weight:600;display:inline-block}.role-badge--admin{color:#7c3aed;background:#8b5cf61a}.role-badge--operator{color:var(--accent-blue-light);background:#3b82f61a}.status-pill{border-radius:6px;padding:3px 8px;font-size:.72rem;font-weight:600;display:inline-block}.status-pill--active{color:var(--status-ok);background:#10b9811a}.status-pill--inactive{color:var(--status-offline);background:#64748b1a}.user-actions{justify-content:flex-end;gap:8px;display:flex}.btn-icon{border-radius:var(--radius);border:1px solid var(--border-color);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition);background:#fff;justify-content:center;align-items:center;display:flex}.btn-icon:hover{background:var(--bg-secondary);color:var(--text-primary);border-color:var(--border-hover)}.btn-icon--danger{color:var(--status-danger)}.btn-icon--danger:hover{border-color:var(--status-danger);color:var(--status-danger);background:#ef44440d}.roles-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;display:grid}.role-card{flex-direction:column;gap:16px;padding:20px;display:flex}.role-card__header{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.role-card__title-grp{align-items:center;gap:12px;display:flex}.role-card__icon{border-radius:var(--radius);background:#3b82f614;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.25rem;display:flex}.role-card__icon--admin{background:#8b5cf614}.role-card__name{color:var(--text-primary);margin:0;font-size:1rem;font-weight:700}.role-card__code{color:var(--text-muted);text-transform:uppercase;font-family:monospace;font-size:.65rem}.role-card__actions{gap:6px;display:flex}.role-card__body{border-top:1px solid var(--border-color);flex-direction:column;flex:1;gap:8px;padding-top:14px;display:flex}.role-card__perm-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.72rem;font-weight:700}.role-card__all-perms{background:linear-gradient(135deg, var(--accent-blue-light), #7c3aed);color:#fff;border-radius:var(--radius);text-align:center;letter-spacing:.05em;margin-top:4px;padding:8px 12px;font-size:.75rem;font-weight:700}.role-card__perms-list{flex-wrap:wrap;gap:6px;margin-top:4px;display:flex}.role-perm-tag{border:1px solid var(--border-color);color:var(--text-secondary);background:#00000008;border-radius:6px;padding:2px 8px;font-size:.68rem;font-weight:600}.role-card__no-perms{color:var(--text-muted);font-size:.75rem;font-style:italic}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0f172a66;justify-content:center;align-items:center;padding:16px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal-content{border-radius:var(--radius-lg);border:1px solid var(--border-color);background:#fff;flex-direction:column;width:100%;max-width:480px;max-height:90vh;animation:.25s slideUp;display:flex;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.modal-content--lg{max-width:760px}.modal-header{border-bottom:1px solid var(--border-color);background:var(--bg-secondary);border-top-left-radius:var(--radius-lg);border-top-right-radius:var(--radius-lg);justify-content:space-between;align-items:center;padding:16px 24px;display:flex}.modal-header h3{color:var(--text-primary);margin:0;font-size:1.1rem;font-weight:700}.modal-close{color:var(--text-muted);cursor:pointer;transition:color var(--transition);background:0 0;border:none;align-items:center;padding:4px;display:flex}.modal-close:hover{color:var(--text-primary)}.modal-body{flex-direction:column;flex:1;gap:16px;padding:24px;display:flex;overflow-y:auto}.modal-footer{border-top:1px solid var(--border-color);background:var(--bg-secondary);border-bottom-left-radius:var(--radius-lg);border-bottom-right-radius:var(--radius-lg);justify-content:flex-end;gap:12px;padding:16px 24px;display:flex}.form-grid-2{grid-template-columns:1fr 1fr;gap:16px;display:grid}.toggle-switch{cursor:pointer;align-items:center;gap:10px;display:inline-flex}.toggle-switch input{display:none}.toggle-slider{width:40px;height:22px;transition:background var(--transition);background:#00000014;border-radius:999px;position:relative}.toggle-slider:before{content:"";width:18px;height:18px;transition:transform var(--transition);background:#fff;border-radius:50%;position:absolute;top:2px;left:2px;box-shadow:0 1px 3px #0003}.toggle-switch input:checked+.toggle-slider{background:var(--status-ok)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(18px)}.toggle-label{color:var(--text-primary);font-size:.85rem;font-weight:500}.role-permissions-section{border-top:1px solid var(--border-color);margin-top:8px;padding-top:16px}.admin-permissions-banner{color:#6d28d9;border-radius:var(--radius);text-align:center;background:#8b5cf614;border:1px solid #8b5cf633;padding:16px;font-size:.85rem;line-height:1.5}.perm-table-wrapper{border:1px solid var(--border-color);border-radius:var(--radius);overflow-x:auto}.perm-table{border-collapse:collapse;width:100%;min-width:500px;font-size:.8rem}.perm-table th{background:var(--bg-secondary);text-align:center;color:var(--text-secondary);border-bottom:1px solid var(--border-color);padding:10px 12px;font-weight:600}.perm-table th:first-child{text-align:left}.perm-table td{text-align:center;border-bottom:1px solid var(--border-color);padding:10px 12px}.perm-table tr:last-child td{border-bottom:none}.perm-table-feature{color:var(--text-primary);font-weight:600;text-align:left!important}.perm-checkbox{border:1px solid var(--border-color);cursor:pointer;border-radius:4px;width:16px;height:16px}@media (width<=640px){.form-grid-2{grid-template-columns:1fr}}
