@charset "UTF-8";:root,[data-theme=dark]{--bg-primary: #0a0a0a;--bg-primary-rgb: 10, 10, 10;--bg-secondary: #111111;--bg-secondary-rgb: 17, 17, 17;--bg-card: #161616;--bg-card-rgb: 22, 22, 22;--bg-elevated: #1e1e1e;--bg-elevated-rgb: 30, 30, 30;--text-primary: #efefef;--text-primary-rgb: 239, 239, 239;--text-secondary: #9a9a9a;--text-muted: #555555;--shadow-light: rgba(255, 255, 255, .03);--shadow-dark: rgba(0, 0, 0, .65);--neu-raised: 6px 6px 12px var(--shadow-dark), -4px -4px 10px var(--shadow-light);--neu-inset: inset 4px 4px 8px var(--shadow-dark), inset -3px -3px 6px var(--shadow-light);--neu-subtle: 3px 3px 6px var(--shadow-dark), -2px -2px 4px var(--shadow-light);--overlay-rgb: 255, 255, 255;--shadow-rgb: 0, 0, 0;--accent-blue: #00b4ff;--accent-blue-rgb: 0, 180, 255;--accent-green: #39ff14;--accent-green-rgb: 57, 255, 20;--accent-yellow: #ffe600;--accent-yellow-rgb: 255, 230, 0;--accent-red: #ff1744;--accent-red-rgb: 255, 23, 68;--accent-orange: #ff6d00;--accent-orange-rgb: 255, 109, 0;--accent-purple: #e040fb;--accent-purple-rgb: 224, 64, 251;--accent-cyan: #00e5ff;--accent-cyan-rgb: 0, 229, 255;--accent-blue-hover: #1abfff;--accent-green-hover: #5fff3d;--accent-orange-hover: #ff8a33}[data-theme=light]{--bg-primary: #faf6ef;--bg-primary-rgb: 250, 246, 239;--bg-secondary: #f2ece2;--bg-secondary-rgb: 242, 236, 226;--bg-card: #fffdf8;--bg-card-rgb: 255, 253, 248;--bg-elevated: #f7f2ea;--bg-elevated-rgb: 247, 242, 234;--text-primary: #3a3028;--text-primary-rgb: 58, 48, 40;--text-secondary: #6b5e52;--text-muted: #a89a8c;--shadow-light: rgba(255, 252, 245, .8);--shadow-dark: rgba(120, 100, 70, .1);--neu-raised: 3px 3px 8px rgba(120, 100, 70, .1), -2px -2px 6px rgba(255, 252, 245, .7);--neu-inset: inset 2px 2px 6px rgba(120, 100, 70, .08), inset -2px -2px 4px rgba(255, 252, 245, .6);--neu-subtle: 2px 2px 5px rgba(120, 100, 70, .08), -1px -1px 3px rgba(255, 252, 245, .6);--overlay-rgb: 80, 65, 45;--shadow-rgb: 120, 100, 70;--accent-blue: #5b8fb9;--accent-blue-rgb: 91, 143, 185;--accent-green: #5a9e63;--accent-green-rgb: 90, 158, 99;--accent-yellow: #d4a830;--accent-yellow-rgb: 212, 168, 48;--accent-red: #cc4e4e;--accent-red-rgb: 204, 78, 78;--accent-orange: #d4854a;--accent-orange-rgb: 212, 133, 74;--accent-purple: #9b7bb8;--accent-purple-rgb: 155, 123, 184;--accent-cyan: #4a9e9e;--accent-cyan-rgb: 74, 158, 158;--accent-blue-hover: #6a9ec5;--accent-green-hover: #68ad71;--accent-orange-hover: #de9460}.stat-card{display:flex;align-items:center;gap:16px;padding:16px}.stat-card__icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:12px;background:var(--bg-secondary);box-shadow:var(--neu-inset)}.stat-card__body{display:flex;flex-direction:column}.stat-card__value{font-size:1.5rem;font-weight:700;line-height:1.2}.stat-card__label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.stat-card--skeleton{height:80px;background:var(--bg-card);animation:pulse 1.5s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.station-grid{display:flex;flex-direction:column;gap:10px}.sc{--sc-color: var(--text-muted);position:relative;background:linear-gradient(135deg,rgba(var(--bg-card-rgb),.95),rgba(var(--bg-card-rgb),.98));border:1px solid rgba(var(--overlay-rgb),.07);box-shadow:0 2px 12px rgba(var(--shadow-rgb),.12);border-radius:16px;padding:16px 18px;cursor:pointer;display:flex;flex-direction:column;gap:12px;transition:all .2s ease;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;outline:none}.sc:hover{background:linear-gradient(135deg,rgba(var(--bg-elevated-rgb),.95),rgba(var(--bg-elevated-rgb),.98));border-color:rgba(var(--overlay-rgb),.1);box-shadow:0 4px 20px rgba(var(--shadow-rgb),.4)}.sc--selected{background:linear-gradient(135deg,rgba(var(--bg-elevated-rgb),.95),rgba(var(--bg-elevated-rgb),.98));border-color:rgba(var(--overlay-rgb),.12);box-shadow:0 4px 24px rgba(var(--shadow-rgb),.5),0 0 0 1px rgba(var(--overlay-rgb),.05)}.sc__top{display:flex;align-items:center;justify-content:space-between;gap:8px}.sc__identity{display:flex;align-items:center;gap:8px;min-width:0}.sc__dot{width:7px;height:7px;border-radius:50%;background:var(--sc-color);flex-shrink:0;opacity:.45;transition:all .3s ease}.sc__dot--on{opacity:1;box-shadow:0 0 6px var(--sc-color),0 0 12px rgba(var(--accent-green-rgb),.2);animation:dotPulse 2.5s ease-in-out infinite}@keyframes dotPulse{0%,to{box-shadow:0 0 6px var(--sc-color),0 0 12px rgba(var(--accent-green-rgb),.15)}50%{box-shadow:0 0 8px var(--sc-color),0 0 18px rgba(var(--accent-green-rgb),.3)}}@keyframes livePulse{0%,to{opacity:1;box-shadow:0 0 4px rgba(var(--accent-green-rgb),.6)}50%{opacity:.4;box-shadow:0 0 8px rgba(var(--accent-green-rgb),.3)}}.sc__title{font-family:"DM Serif Display",Georgia,serif;font-size:.875rem;font-weight:400;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.sc__subtitle{font-size:.75rem;color:var(--text-muted);white-space:nowrap;letter-spacing:.3px}.sc__subtitle:before{content:"·";margin-right:6px;color:rgba(var(--overlay-rgb),.15)}.sc__meta{display:flex;align-items:center;gap:6px;flex-shrink:0}.sc__alert{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:10px;background:rgba(var(--accent-orange-rgb),.1);border:1px solid rgba(var(--accent-orange-rgb),.15);color:var(--accent-orange);font-size:10px;font-weight:700}.sc__ws-live{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:12px;background:rgba(var(--accent-green-rgb),.12);border:1px solid rgba(var(--accent-green-rgb),.25);color:var(--accent-green);font-size:10px;font-weight:700;letter-spacing:.8px;text-shadow:0 0 6px rgba(var(--accent-green-rgb),.4);box-shadow:0 0 8px rgba(var(--accent-green-rgb),.1)}.sc__ws-live:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent-green);box-shadow:0 0 6px var(--accent-green);animation:livePulse 1.5s ease-in-out infinite}.sc__ws-live svg{display:none}.sc__settings{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border:none;border-radius:6px;background:transparent;color:var(--text-muted);cursor:pointer;transition:all .15s ease}.sc__settings:hover{background:rgba(var(--overlay-rgb),.06);color:var(--text-secondary)}.sc__readings{display:flex;align-items:stretch;gap:6px;flex-wrap:wrap}@media(min-width:768px){.sc__readings{flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;scrollbar-width:none}.sc__readings::-webkit-scrollbar{display:none}}.sc__no-data{font-size:.75rem;color:var(--text-muted);font-style:italic;padding:6px 0}.sc__offline-msg{font-size:.75rem;color:var(--text-muted);font-style:italic;padding:6px 0;opacity:.6}.sc--skeleton{background:var(--bg-card);border:1px solid rgba(var(--overlay-rgb),.03);border-left:3px solid rgba(var(--overlay-rgb),.04);border-radius:12px;height:80px;cursor:default;animation:pulse 1.5s infinite}.sc--skeleton:before{display:none}.sc--empty{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:8px;padding:32px;color:var(--text-muted);cursor:default;font-size:.875rem;border-left-color:rgba(var(--overlay-rgb),.04)}.sc--empty:hover{background:inherit;box-shadow:none}.sc--empty:before{display:none}.sc:focus,.sc:focus-visible{outline:none;box-shadow:0 0 0 1px rgba(var(--overlay-rgb),.1)}.sv{--sv-color: var(--text-muted);display:flex;align-items:center;justify-content:space-between;-webkit-tap-highlight-color:transparent;flex:1 1 100%;min-width:0;padding:10px 12px;border-radius:8px;background:rgba(var(--overlay-rgb),.025);gap:8px;transition:background .15s ease}.sv--clickable{cursor:pointer}.sv--clickable:hover{background:rgba(var(--overlay-rgb),.06)}@media(min-width:768px){.sv{flex:1 1 0}}.sv__info{display:flex;flex-direction:column;gap:4px;flex:0 0 auto;width:120px;min-width:120px}.sv__header{display:flex;align-items:center;gap:4px}.sv__icon{display:flex;align-items:center;flex-shrink:0;color:var(--sv-color);opacity:.5}.sv__label{font-size:9px;color:var(--text-primary);letter-spacing:.15px;line-height:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sv__value-row{display:flex;align-items:baseline;gap:3px;white-space:nowrap}.sv__num{font-size:1rem;font-weight:700;font-variant-numeric:tabular-nums;color:var(--sv-color);line-height:1}.sv__unit{font-size:9px;color:var(--text-primary);font-weight:400}.sv__trend{display:inline-flex;align-items:center;margin-left:2px;opacity:.7}.sv__trend--up{color:var(--accent-green)}.sv__trend--down{color:var(--accent-red)}.sv__trend--stable{color:var(--text-muted)}.sv__dash{font-size:1rem;color:var(--text-muted);line-height:1}.sv__spark{flex:1 1 0;min-width:0;display:flex;align-items:center;opacity:.85}.detail-hdr{display:flex;align-items:center;gap:8px;margin-bottom:24px;padding:8px 16px;border-radius:8px;background:var(--bg-card);border:1px solid rgba(var(--overlay-rgb),.05)}.detail-hdr__back{display:flex;align-items:center;gap:4px;padding:4px 10px;border:1px solid rgba(var(--overlay-rgb),.06);border-radius:6px;background:rgba(var(--overlay-rgb),.03);color:var(--text-secondary);font-family:DM Sans,Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:.75rem;cursor:pointer;transition:all .15s ease;white-space:nowrap;flex-shrink:0}.detail-hdr__back:hover{background:rgba(var(--overlay-rgb),.06);color:var(--text-primary)}.detail-hdr__back:active{transform:scale(.96)}.detail-hdr__separator{width:1px;height:20px;background:rgba(var(--overlay-rgb),.08);flex-shrink:0}.detail-hdr__station{display:flex;align-items:baseline;gap:6px;min-width:0}.detail-hdr__code{font-size:.875rem;font-weight:700;color:var(--text-primary);letter-spacing:.3px;white-space:nowrap}.detail-hdr__name{font-size:.875rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.detail-hdr__right{display:flex;align-items:center;gap:8px;margin-left:auto;flex-shrink:0}.detail-hdr__location{display:none}@media(min-width:768px){.detail-hdr__location{display:flex;align-items:center;gap:3px;font-size:11px;color:var(--text-muted)}}.error-banner{background:rgba(var(--accent-red-rgb),.1);border:1px solid var(--accent-red);border-radius:8px;padding:16px;margin-bottom:16px;color:var(--accent-red);font-size:.875rem}.sensor-grid{display:grid;grid-template-columns:1fr;gap:10px;width:100%}@media(min-width:576px){.sensor-grid{grid-template-columns:repeat(2,1fr);gap:14px}}@media(min-width:768px){.sensor-grid{grid-template-columns:repeat(3,1fr);gap:16px}}@media(min-width:1024px){.sensor-grid{grid-template-columns:repeat(4,1fr);gap:18px;max-width:1100px}}@media(min-width:1280px){.sensor-grid{grid-template-columns:repeat(4,1fr);gap:20px;max-width:1200px}}.sensor-card{--sensor-color: var(--text-muted);position:relative;display:flex;flex-direction:column;align-items:flex-start;gap:4px;padding:14px 14px 10px;background:var(--bg-card);border-radius:14px;border:1px solid rgba(var(--overlay-rgb),.04);overflow:visible;cursor:pointer;box-shadow:0 1px 2px rgba(var(--shadow-rgb),.04),0 4px 12px rgba(var(--shadow-rgb),.03);transition:transform .22s cubic-bezier(.25,.46,.45,.94),box-shadow .22s ease,border-color .22s ease;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;outline:none}@media(min-width:576px){.sensor-card{gap:6px;padding:16px 16px 12px;border-radius:16px}}@media(min-width:768px){.sensor-card{gap:8px;padding:18px 20px 14px}}.sensor-card:before{content:"";position:absolute;top:0;left:12px;right:12px;height:3px;background:var(--sensor-color);border-radius:0 0 3px 3px;opacity:.85;transition:opacity .2s,left .2s,right .2s}@media(min-width:768px){.sensor-card:before{left:16px;right:16px}}.sensor-card:after{content:"";position:absolute;top:0;left:0;right:0;height:60%;border-radius:14px 14px 0 0;background:linear-gradient(180deg,var(--sensor-color) 0%,transparent 100%);opacity:.03;pointer-events:none;transition:opacity .2s}.sensor-card:hover{transform:translateY(-2px);border-color:rgba(var(--overlay-rgb),.06);box-shadow:0 2px 4px rgba(var(--shadow-rgb),.05),0 8px 24px rgba(var(--shadow-rgb),.06)}.sensor-card:hover:before{left:0;right:0;opacity:1;border-radius:14px 14px 0 0}.sensor-card:hover:after{opacity:.05}.sensor-card:active{transform:translateY(0);transition-duration:.06s}.sensor-card--selected{border-color:rgba(var(--overlay-rgb),.06);box-shadow:0 2px 4px rgba(var(--shadow-rgb),.04),0 6px 20px rgba(var(--shadow-rgb),.05)}.sensor-card--skeleton{background:var(--bg-card);animation:pulse 1.8s ease-in-out infinite;box-shadow:0 1px 2px rgba(var(--shadow-rgb),.03);border-color:transparent}.sensor-card--skeleton:before,.sensor-card--skeleton:after{display:none}.sensor-card{animation:sensorFadeIn .35s cubic-bezier(.25,.46,.45,.94) both}.sensor-card:nth-child(1){animation-delay:.05s}.sensor-card:nth-child(2){animation-delay:.1s}.sensor-card:nth-child(3){animation-delay:.15s}.sensor-card:nth-child(4){animation-delay:.2s}.sensor-card:nth-child(5){animation-delay:.25s}.sensor-card:nth-child(6){animation-delay:.3s}.sensor-card:nth-child(7){animation-delay:.35s}.sensor-card:nth-child(8){animation-delay:.4s}.sensor-card:nth-child(9){animation-delay:.45s}.sensor-card:nth-child(10){animation-delay:.5s}.sensor-card:nth-child(11){animation-delay:.55s}.sensor-card:nth-child(12){animation-delay:.6s}.sensor-card__edit{position:absolute;top:10px;right:8px;display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:8px;border:none;background:transparent;color:var(--text-muted);cursor:pointer;opacity:0;transition:all .2s;z-index:2}.sensor-card:hover .sensor-card__edit{opacity:.5}.sensor-card__edit:hover{opacity:1!important;background:rgba(var(--overlay-rgb),.04);color:var(--sensor-color)}.sensor-card__header{display:flex;flex-direction:column;width:100%;gap:8px;position:relative;z-index:1}@media(max-width:576px){.sensor-card__header{align-items:center;gap:6px}}@media(min-width:768px){.sensor-card__header{flex-direction:row;align-items:baseline;justify-content:space-between;gap:12px}}.sensor-card__label{font-family:DM Sans,Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:.68rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.sensor-card__value{display:flex;align-items:baseline;gap:4px;white-space:nowrap;min-width:0;flex-shrink:0;position:relative;z-index:1}@media(max-width:576px){.sensor-card__value{justify-content:center;width:100%}}@media(min-width:576px){.sensor-card__value{margin-left:auto}}.sensor-card__num{font-family:DM Sans,Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:3.5rem;font-weight:700;color:var(--sensor-color);line-height:1;letter-spacing:-.8px;font-variant-numeric:tabular-nums}@media(min-width:576px){.sensor-card__num{font-size:3.5rem}}@media(min-width:768px){.sensor-card__num{font-size:3rem}}@media(min-width:1024px){.sensor-card__num{font-size:2.5rem}}.sensor-card__unit{font-size:.85rem;color:var(--text-secondary);font-weight:500;letter-spacing:-.2px}@media(min-width:576px){.sensor-card__unit{font-size:.72rem}}.sensor-card__unit-toggle{display:inline-flex;align-items:center;gap:2px;font-family:DM Sans,Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:.68rem;font-weight:600;color:var(--text-muted);background:rgba(var(--overlay-rgb),.02);border:1px solid rgba(var(--overlay-rgb),.05);border-radius:6px;padding:2px 7px;cursor:pointer;transition:all .15s}.sensor-card__unit-toggle:hover{background:rgba(var(--overlay-rgb),.05);border-color:rgba(var(--overlay-rgb),.1);color:var(--sensor-color)}.sensor-card__dash{font-size:1.5rem;color:var(--text-muted);line-height:1;opacity:.3}.sensor-card__spark{position:relative;width:calc(100% + 28px);margin-left:-14px;margin-top:auto;padding-top:6px;z-index:1}@media(min-width:576px){.sensor-card__spark{width:calc(100% + 32px);margin-left:-16px}}@media(min-width:768px){.sensor-card__spark{width:calc(100% + 40px);margin-left:-20px;padding-top:8px}}.sensor-card__spark{opacity:.45;transition:opacity .25s ease}.sensor-card:hover .sensor-card__spark{opacity:.85}.sensor-card__spark-range{position:absolute;bottom:-2px;right:14px;font-size:.6rem;font-weight:500;color:var(--text-secondary);opacity:.7;letter-spacing:.2px}.sensor-card__gauge{width:100%;display:flex;flex-direction:column;gap:2px;margin-top:auto;padding-top:4px;position:relative;z-index:1}.sensor-card__gauge-track{position:relative;height:4px;background:rgba(var(--overlay-rgb),.04);border-radius:2px;overflow:visible}.sensor-card__gauge-zone{position:absolute;top:0;height:100%;background:rgba(var(--overlay-rgb),.05);border-radius:2px}.sensor-card__gauge-zone:before,.sensor-card__gauge-zone:after{content:"";position:absolute;top:-2px;bottom:-2px;width:1px;background:rgba(var(--overlay-rgb),.1);border-radius:1px}.sensor-card__gauge-zone:before{left:0}.sensor-card__gauge-zone:after{right:0}.sensor-card__gauge-marker{position:absolute;top:50%;width:8px;height:8px;border-radius:50%;transform:translate(-50%,-50%);border:1.5px solid var(--bg-card);box-shadow:0 0 0 1px rgba(var(--overlay-rgb),.06),0 1px 3px rgba(var(--shadow-rgb),.1);transition:left .5s cubic-bezier(.25,.46,.45,.94)}.sensor-card__gauge-labels{position:relative;height:11px}.sensor-card__gauge-lbl{position:absolute;top:0;font-size:.52rem;color:var(--text-muted);font-variant-numeric:tabular-nums;transform:translate(-50%);white-space:nowrap;opacity:.7}.sensor-card__gauge-opt{position:absolute;top:0;left:50%;transform:translate(-50%);font-size:.48rem;color:var(--text-muted);opacity:.5;white-space:nowrap;letter-spacing:.3px;font-style:italic}.sensor-card__footer{display:flex;align-items:center;gap:6px;position:relative;z-index:1}@media(max-width:576px){.sensor-card__footer{width:100%;justify-content:center}}@media(min-width:768px){.sensor-card__footer{gap:8px}}.sensor-card__trend{font-size:.8rem;font-weight:700;line-height:1}.sensor-card__trend--up{color:var(--accent-red)}.sensor-card__trend--down{color:var(--accent-blue)}.sensor-card__trend--flat{color:var(--text-muted);opacity:.3}.sensor-card__time{position:absolute;top:8px;right:10px;font-size:.58rem;color:var(--text-muted);opacity:.6;letter-spacing:.1px;z-index:2}@keyframes sensorFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.slist{display:flex;flex-direction:column;gap:4px}.srow{display:grid;grid-template-columns:1fr 1fr 1fr auto;align-items:center;gap:10px;padding:8px 12px;border-left:3px solid var(--text-muted);border-radius:8px;background:var(--bg-card);cursor:pointer;transition:background .15s ease,box-shadow .15s ease}.srow:hover{background:var(--bg-elevated)}.srow--selected{background:var(--bg-elevated);box-shadow:inset 0 0 0 1px rgba(var(--overlay-rgb),.08)}.srow--no-edit{grid-template-columns:1fr 1fr 1fr}.srow--skeleton{height:42px;background:var(--bg-card);border-left:3px solid rgba(var(--overlay-rgb),.04);border-radius:8px;animation:pulse 1.5s infinite}.srow__title{display:flex;align-items:center;gap:8px;min-width:0}.srow__icon{display:flex;align-items:center;flex-shrink:0}.srow__name{font-size:.875rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.srow__gauge{display:flex;flex-direction:column;gap:4px;cursor:default;align-self:center}.srow__gauge-track{height:6px;background:rgba(var(--overlay-rgb),.04);border-radius:3px;position:relative;overflow:visible}.srow__gauge-track--empty{border:1px dashed rgba(var(--overlay-rgb),.06)}.srow__gauge-danger{position:absolute;height:100%;top:0;border-radius:3px;background:rgba(var(--accent-red-rgb),.14);pointer-events:none}.srow__gauge-zone{position:absolute;height:100%;border-radius:3px;background:rgba(var(--accent-green-rgb),.12);border:1px solid rgba(var(--accent-green-rgb),.2);box-sizing:border-box;top:0;pointer-events:none}.srow__gauge-tick{position:absolute;top:-3px;height:calc(100% + 6px);width:1px;background:rgba(var(--overlay-rgb),.2);transform:translate(-50%);pointer-events:none}.srow__gauge-marker{position:absolute;top:50%;width:10px;height:10px;border-radius:50%;transform:translate(-50%,-50%);border:2px solid #0a0a0a;transition:left .4s ease,background .3s ease,box-shadow .3s ease}.srow__gauge-labels{position:relative;height:10px;pointer-events:none}.srow__gauge-lbl{position:absolute;font-size:9px;color:#3a3a3a;transform:translate(-50%);white-space:nowrap;top:0;line-height:1}.srow__value{display:flex;align-items:center;gap:5px;justify-self:center;justify-content:center;white-space:nowrap}.srow__val{font-size:1.15rem;font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:-.3px}.srow__unit{font-size:11px;color:var(--text-primary);font-weight:500}.srow__dash{font-size:.875rem;color:var(--text-muted)}.srow__trend{font-size:12px;font-weight:700;line-height:1}.srow__trend--up{color:#39ff14}.srow__trend--down{color:#ff5252}.srow__trend--flat{color:#444}.srow__conn{display:flex;flex-direction:column;align-items:center;gap:3px;min-width:32px}.srow__edit-btn{display:flex;align-items:center;justify-content:center;padding:2px;border:none;background:transparent;color:#333;border-radius:3px;cursor:pointer;opacity:0;transition:opacity .15s,color .15s}.srow__edit-btn:hover{color:var(--text-secondary)}.srow:hover .srow__edit-btn{opacity:1}.srow__dot{flex-shrink:0;width:8px;height:8px;border-radius:50%;display:inline-block}.srow__dot--online{background:var(--accent-green);box-shadow:0 0 6px rgba(var(--accent-green-rgb),.55)}.srow__dot--offline{background:var(--text-muted);box-shadow:0 0 6px rgba(var(--overlay-rgb),.45)}.srow__dot--maintenance{background:var(--accent-yellow);box-shadow:0 0 6px rgba(var(--accent-yellow-rgb),.45)}.srow__time{font-size:9px;color:#383838;white-space:nowrap;text-align:center}.srow:focus,.srow:focus-visible{outline:none;box-shadow:inset 0 0 0 1px rgba(var(--overlay-rgb),.1)}.alert-panel{display:flex;flex-direction:column;gap:8px}.alert-panel--empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:48px;color:var(--text-muted)}.alert-item{padding:16px;border-left:3px solid transparent}.alert-item--info{border-left-color:var(--accent-blue)}.alert-item--warning{border-left-color:var(--accent-yellow)}.alert-item--critical{border-left-color:var(--accent-red)}.alert-item__header{display:flex;align-items:center;gap:8px;margin-bottom:4px;flex-wrap:wrap}.alert-item__header svg{color:var(--text-muted);flex-shrink:0}.alert-item__sensor{font-weight:600;font-size:.875rem}.alert-item__message{font-size:.875rem;color:var(--text-secondary);margin-bottom:8px;line-height:1.4}.alert-item__footer{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}.alert-item__time{display:flex;align-items:center;gap:4px;font-size:.75rem;color:var(--text-muted)}.alert-item__actions{display:flex;gap:4px}.chart-card{--sensor-color: var(--text-muted);position:relative;background:var(--bg-card);border:1px solid rgba(var(--overlay-rgb),.04);border-radius:14px;padding:16px;box-shadow:0 1px 2px rgba(var(--shadow-rgb),.04),0 4px 12px rgba(var(--shadow-rgb),.03)}@media(min-width:768px){.chart-card{border-radius:16px;padding:18px 20px}}.chart-card{pointer-events:auto;cursor:default;outline:none}.chart-card:focus,.chart-card:focus-visible,.chart-card *:focus,.chart-card *:focus-visible{outline:none!important}.chart-card .recharts-wrapper,.chart-card .recharts-surface{outline:none!important;border:none!important}.chart-card .recharts-cartesian-grid-horizontal line{stroke:rgba(var(--overlay-rgb),.05)!important}.chart-card__header{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}@media(min-width:768px){.chart-card__header{flex-direction:row;align-items:center;justify-content:space-between}}.chart-card__title-row{display:flex;align-items:center;gap:10px;min-width:0}.chart-card__sensor-icon{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:10px;background:rgba(var(--overlay-rgb),.03);flex-shrink:0}.chart-card__title-text{display:flex;flex-direction:column;gap:2px;min-width:0}.chart-card__title{font-family:"DM Serif Display",Georgia,serif;font-size:1rem;font-weight:400;color:var(--text-primary);line-height:1.2;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media(min-width:768px){.chart-card__title{font-size:1.125rem}}.chart-card__subtitle{font-size:.68rem;color:var(--text-muted);letter-spacing:.1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chart-card__estimate{font-style:italic;opacity:.6}.chart-card__chart-wrap{margin:0 -8px}@media(min-width:768px){.chart-card__chart-wrap{margin:0 -16px}}.chart-card--empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:16px}.chart-card__empty-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:12px;background:rgba(var(--overlay-rgb),.03);color:var(--text-muted)}.chart-card__empty-text{font-size:.875rem;color:var(--text-muted);text-align:center}.chart-card__shimmer{display:flex;flex-direction:column;gap:16px;padding:16px 0}.chart-card__shimmer-bar{height:16px;width:40%;border-radius:6px;background:linear-gradient(90deg,rgba(var(--overlay-rgb),.03) 25%,rgba(var(--overlay-rgb),.06),rgba(var(--overlay-rgb),.03) 75%);background-size:200% 100%;animation:shimmer 1.6s ease-in-out infinite}.chart-card__shimmer-area{height:240px;border-radius:10px;background:linear-gradient(90deg,rgba(var(--overlay-rgb),.02) 25%,rgba(var(--overlay-rgb),.04),rgba(var(--overlay-rgb),.02) 75%);background-size:200% 100%;animation:shimmer 1.6s ease-in-out infinite}.chart-range{display:flex;align-items:center;gap:2px;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch}.chart-range::-webkit-scrollbar{display:none}.chart-range{padding:3px;border-radius:10px;background:rgba(var(--overlay-rgb),.03)}@media(min-width:768px){.chart-range{flex-shrink:0}}.chart-range__btn{display:inline-flex;align-items:center;justify-content:center;padding:5px 11px;border:none;border-radius:7px;background:transparent;color:var(--text-muted);font-size:.68rem;font-weight:600;font-family:DM Sans,Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;cursor:pointer;transition:all .15s ease;white-space:nowrap;flex-shrink:0}.chart-range__btn:hover{background:rgba(var(--overlay-rgb),.05);color:var(--text-secondary)}.chart-range__btn--active{font-weight:700;color:#fff;box-shadow:0 1px 4px rgba(var(--shadow-rgb),.12)}.chart-stats{display:flex;gap:1px;margin-bottom:16px;padding:3px;border-radius:10px;background:rgba(var(--overlay-rgb),.025);overflow-x:auto}.chart-stats__item{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 8px;border-radius:8px;min-width:0;transition:background .15s}.chart-stats__item:hover{background:rgba(var(--overlay-rgb),.03)}.chart-stats__item--highlight{background:rgba(var(--overlay-rgb),.04)}.chart-stats__label{display:flex;align-items:center;gap:3px;font-size:.6rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.7px;white-space:nowrap}.chart-stats__label svg{flex-shrink:0;opacity:.5}.chart-stats__value{font-size:.875rem;font-weight:700;color:var(--text-primary);display:flex;align-items:baseline;gap:2px;white-space:nowrap;font-variant-numeric:tabular-nums}.chart-stats__unit{font-size:.55rem;font-weight:400;color:var(--text-muted)}.chart-tooltip{background:var(--bg-card);border:1px solid rgba(var(--overlay-rgb),.06);border-radius:10px;padding:10px 14px 10px 12px;box-shadow:0 4px 16px rgba(var(--shadow-rgb),.1),0 1px 3px rgba(var(--shadow-rgb),.06);min-width:110px}.chart-tooltip__time{display:flex;align-items:center;gap:4px;font-size:.62rem;color:var(--text-muted);margin-bottom:4px;letter-spacing:.2px}.chart-tooltip__value{font-size:1.25rem;font-weight:700;line-height:1.2;display:flex;align-items:baseline;gap:3px}.chart-tooltip__unit{font-size:.75rem;font-weight:400;color:var(--text-secondary)}.chart-tooltip__range{font-size:.6rem;color:var(--text-muted);margin-top:3px;opacity:.7}.unit-toggle{display:inline-flex;align-items:center;gap:3px;padding:1px 6px;border:1px solid rgba(var(--overlay-rgb),.1);border-radius:4px;background:rgba(var(--overlay-rgb),.04);color:var(--text-muted);font-size:10px;font-weight:600;font-family:DM Sans,Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;cursor:pointer;transition:all .15s ease;white-space:nowrap;line-height:1.3;vertical-align:middle}.unit-toggle svg{opacity:.4;transition:opacity .15s ease;flex-shrink:0}.unit-toggle:hover{background:rgba(var(--overlay-rgb),.08);border-color:rgba(var(--overlay-rgb),.18);color:var(--text-secondary)}.unit-toggle:hover svg{opacity:.9}.unit-toggle:active{transform:scale(.95)}.unit-toggle--inline{padding:0 4px;border:none;background:transparent;color:var(--text-muted);font-size:inherit;font-weight:inherit;text-decoration:underline;text-decoration-style:dotted;text-underline-offset:2px}.unit-toggle--inline:hover{background:transparent;border:none;color:var(--text-secondary)}@keyframes livePulse{0%,to{opacity:1;box-shadow:0 0 4px currentColor}50%{opacity:.5;box-shadow:0 0 8px currentColor}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.chart-container{min-height:320px}.chart-container__header{font-size:.875rem;font-weight:600;color:var(--text-secondary);margin-bottom:16px}.chart-container--empty{display:flex;align-items:center;justify-content:center}.modal-overlay{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:rgba(var(--shadow-rgb),.7);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:16px;animation:modalFadeIn .2s ease}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.modal{width:100%;max-width:520px}.modal--compact{max-width:360px}.modal{max-height:90vh;display:flex;flex-direction:column;background:var(--bg-card);border:1px solid rgba(var(--overlay-rgb),.08);border-radius:12px;box-shadow:0 24px 80px rgba(var(--shadow-rgb),.6);animation:modalSlideIn .25s ease;overflow:hidden}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-bottom:1px solid rgba(var(--overlay-rgb),.06)}.modal__header-left{display:flex;align-items:center;gap:8px;color:var(--accent-cyan)}.modal__header-left h2{font-size:1rem;font-weight:700;color:var(--text-primary)}.modal__close{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:8px;background:transparent;color:var(--text-muted);cursor:pointer;transition:all .15s ease}.modal__close:hover{background:rgba(var(--overlay-rgb),.06);color:var(--text-primary)}.modal__body{flex:1;overflow-y:auto;padding:24px;display:flex;flex-direction:column;gap:24px}.modal__section{display:flex;flex-direction:column;gap:8px}.modal__section-header{display:flex;align-items:center;justify-content:space-between}.modal__section-title{display:flex;align-items:center;gap:6px;font-size:.875rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.modal__field{display:flex;flex-direction:column;gap:4px}.modal__field--flex{flex:1;min-width:0}.modal__field--narrow{flex:0 0 110px}.modal__field--tiny{flex:1}.modal__row{display:flex;gap:8px}.modal__field-row{display:flex;gap:16px}.modal__field-row .modal__field{flex:1}.modal__hint{font-size:11px;color:var(--text-muted);margin:2px 0 0}.modal__label{display:flex;align-items:center;gap:4px;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px}.modal__label-sm{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px}.modal__input{width:100%;padding:8px 10px;border:1px solid rgba(var(--overlay-rgb),.08);border-radius:6px;background:rgba(var(--overlay-rgb),.03);color:var(--text-primary);font-size:.875rem;font-family:inherit;outline:none;transition:border-color .15s ease;color-scheme:dark}.modal__input::placeholder{color:var(--text-muted)}.modal__input:focus{border-color:rgba(var(--accent-cyan-rgb),.4)}.modal__input--sm{padding:5px 8px;font-size:.75rem}.modal__textarea{resize:vertical;min-height:48px}.modal__select{flex:1;padding:6px 8px;border:1px solid rgba(var(--overlay-rgb),.08);border-radius:6px;background:var(--bg-elevated);color:var(--text-primary);font-size:.875rem;font-family:inherit;outline:none;cursor:pointer;color-scheme:dark}.modal__select:focus{border-color:rgba(var(--accent-cyan-rgb),.4)}.modal__select option{background:var(--bg-card);color:var(--text-primary)}.modal__sensors{display:flex;flex-direction:column;gap:4px}.modal__sensor-row{display:flex;flex-direction:column;gap:6px;padding:8px 10px;border-left:3px solid var(--text-muted);border-radius:8px;background:rgba(var(--overlay-rgb),.02);border-top:1px solid rgba(var(--overlay-rgb),.04);border-right:1px solid rgba(var(--overlay-rgb),.04);border-bottom:1px solid rgba(var(--overlay-rgb),.04)}.modal__sensor-top{display:flex;align-items:center;gap:8px}.modal__sensor-icon{display:flex;align-items:center;flex-shrink:0}.modal__sensor-unit{font-size:11px;color:var(--text-muted);white-space:nowrap;flex-shrink:0}.modal__sensor-thresholds{display:flex;gap:8px;padding-left:28px}.modal__remove-btn{display:flex;align-items:center;justify-content:center;width:26px;height:26px;margin-left:auto;border:none;border-radius:4px;background:transparent;color:var(--text-muted);cursor:pointer;transition:all .15s ease;flex-shrink:0}.modal__remove-btn:hover{background:rgba(var(--accent-red-rgb),.12);color:var(--accent-red)}.modal__add-btn{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border:1px solid rgba(var(--accent-cyan-rgb),.25);border-radius:4px;background:rgba(var(--accent-cyan-rgb),.06);color:var(--accent-cyan);font-size:12px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .15s ease}.modal__add-btn:hover{background:rgba(var(--accent-cyan-rgb),.12);border-color:rgba(var(--accent-cyan-rgb),.4)}.modal__empty{text-align:center;font-size:.875rem;color:var(--text-muted);padding:16px}.modal__error{padding:8px 12px;border-radius:6px;background:rgba(var(--accent-red-rgb),.08);border:1px solid rgba(var(--accent-red-rgb),.2);color:var(--accent-red);font-size:.875rem}.modal__info-bar{display:flex;flex-wrap:wrap;gap:6px}.modal__info-chip{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:4px;background:rgba(var(--overlay-rgb),.03);border:1px solid rgba(var(--overlay-rgb),.06);font-size:11px;color:var(--text-secondary)}.modal__info-chip strong{color:var(--text-muted);font-weight:500}.modal__danger-zone{display:flex;flex-direction:column;gap:8px;padding:16px;border-radius:8px;border:1px solid rgba(var(--accent-red-rgb),.15);background:rgba(var(--accent-red-rgb),.03)}.modal__danger-header{display:flex;align-items:center;gap:6px;font-size:.875rem;font-weight:600;color:var(--accent-red)}.modal__danger-text{font-size:.75rem;color:var(--text-muted);line-height:1.5}.modal__btn--warning{align-self:flex-start;background:transparent;color:var(--text-muted);border:1px solid rgba(var(--overlay-rgb),.08)}.modal__btn--warning:hover{background:rgba(var(--accent-orange-rgb),.08);color:var(--accent-orange);border-color:rgba(var(--accent-orange-rgb),.2)}.modal__btn--warning-confirm{background:rgba(var(--accent-orange-rgb),.12)!important;color:var(--accent-orange)!important;border-color:rgba(var(--accent-orange-rgb),.3)!important;animation:dangerPulse 1s infinite}.modal__btn--danger{align-self:flex-start;background:transparent;color:var(--text-muted);border:1px solid rgba(var(--overlay-rgb),.08)}.modal__btn--danger:hover{background:rgba(var(--accent-red-rgb),.08);color:var(--accent-red);border-color:rgba(var(--accent-red-rgb),.2)}.modal__btn--danger-confirm{background:rgba(var(--accent-red-rgb),.12)!important;color:var(--accent-red)!important;border-color:rgba(var(--accent-red-rgb),.3)!important;animation:dangerPulse 1s infinite}@keyframes dangerPulse{0%,to{box-shadow:0 0 rgba(var(--accent-red-rgb),.2)}50%{box-shadow:0 0 8px 2px rgba(var(--accent-red-rgb),.15)}}.modal__success{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:48px 24px}.modal__success p{font-size:1rem;font-weight:600;color:var(--text-primary)}.modal__success-icon{display:flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:50%;background:rgba(var(--accent-green-rgb),.1);color:var(--accent-green);animation:successPop .3s ease}@keyframes successPop{0%{transform:scale(.5);opacity:0}70%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}.modal__footer{display:flex;align-items:center;justify-content:flex-end;gap:8px;padding:16px 24px;border-top:1px solid rgba(var(--overlay-rgb),.06)}.modal__btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:none;border-radius:6px;font-size:.875rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all .15s ease}.modal__btn--ghost{background:transparent;color:var(--text-secondary)}.modal__btn--ghost:hover{background:rgba(var(--overlay-rgb),.04);color:var(--text-primary)}.modal__btn--primary{background:rgba(var(--accent-green-rgb),.12);color:var(--accent-green);border:1px solid rgba(var(--accent-green-rgb),.25)}.modal__btn--primary:hover:not(:disabled){background:rgba(var(--accent-green-rgb),.2);border-color:rgba(var(--accent-green-rgb),.4);box-shadow:0 0 12px rgba(var(--accent-green-rgb),.15)}.modal__btn--primary:disabled{opacity:.4;cursor:not-allowed}.spin{animation:spinAnim .8s linear infinite}@keyframes spinAnim{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.drill-tabs{display:flex;gap:2px;margin:16px 0 24px;background:var(--bg-secondary);border-radius:12px;padding:3px}.drill-tabs__btn{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 16px;border:none;border-radius:8px;background:transparent;color:var(--text-secondary);font-size:.875rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.drill-tabs__btn:hover{color:var(--text-primary);background:rgba(var(--overlay-rgb),.04)}.drill-tabs__btn--active{background:var(--bg-card);color:var(--text-primary);box-shadow:var(--neu-subtle)}.drill-tabs__badge{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;font-size:10px;line-height:1}.drill-tabs__badge--ok{background:rgba(var(--accent-green-rgb),.15);color:var(--accent-green)}.drill-tabs__badge--warn{background:rgba(var(--accent-orange-rgb),.15);color:var(--accent-orange)}.sc__risk{display:flex;align-items:center;gap:8px;padding:8px 16px 0;margin-top:2px;border-top:1px solid rgba(var(--overlay-rgb),.04)}.sc__risk--clickable{cursor:pointer;border-radius:8px;transition:background .15s}.sc__risk--clickable:hover{background:rgba(var(--overlay-rgb),.06)}.sc__risk-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.sc__risk-status{font-size:11px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.sc__last-seen{display:flex;align-items:center;gap:4px;padding-top:4px;border-top:1px solid rgba(var(--overlay-rgb),.04);font-size:10px;color:var(--text-primary)}.sc__last-seen svg{opacity:.6}.sc__last-seen-label{color:var(--accent-orange);font-size:10px}.sc__last-seen-date{color:var(--text-primary);font-size:10px}.sc__last-seen-time{color:var(--accent-blue);font-size:10px}.bio-insights{background:var(--bg-card);border-radius:12px;border:1px solid rgba(var(--overlay-rgb),.06);overflow:hidden;box-shadow:0 4px 24px rgba(var(--shadow-rgb),.3)}.bio-insights__header{display:flex;align-items:center;gap:16px;padding:16px;cursor:pointer;-webkit-tap-highlight-color:transparent;border-bottom:1px solid rgba(var(--overlay-rgb),.04)}.bio-insights__header:hover{background:rgba(var(--overlay-rgb),.02)}.bio-insights__score{display:flex;align-items:baseline;gap:2px;flex-shrink:0;line-height:1}.bio-insights__score-num{font-size:28px;font-weight:800;letter-spacing:-1px;font-variant-numeric:tabular-nums}.bio-insights__score-den{font-size:11px;font-weight:500;opacity:.45}.bio-insights__risk-bar{flex:1;display:flex;flex-direction:column;gap:5px;min-width:0}.bio-insights__risk-meta{display:flex;align-items:center;justify-content:space-between;gap:8px}.bio-insights__risk-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.bio-insights__risk-track{width:100%;height:7px;background:rgba(var(--overlay-rgb),.06);border-radius:4px;overflow:hidden}.bio-insights__risk-fill{height:100%;border-radius:4px;transition:width .6s cubic-bezier(.4,0,.2,1)}.bio-insights__risk-pill{display:inline-flex;align-items:center;padding:1px 8px;border-radius:8px;border:1px solid currentColor;font-size:10px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;white-space:nowrap;flex-shrink:0;background:transparent;opacity:.9}.bio-insights__header-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.bio-insights__toggle{color:var(--text-muted);font-size:10px;flex-shrink:0}.bio-insights__details{padding:0 16px 16px;display:flex;flex-direction:column;gap:16px}.bio-insights__section{display:flex;flex-direction:column;gap:4px}.bio-insights__section-title{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.bio-insights__thresholds{display:flex;flex-direction:column;gap:4px}.bio-insights__thresh-row{display:grid;grid-template-columns:1fr 80px 80px;gap:8px;font-size:.75rem;color:var(--text-secondary);padding:4px 0}.bio-insights__thresh-row span:first-child{color:var(--text-primary)}.bio-insights__thresh-row span:not(:first-child){text-align:right;font-variant-numeric:tabular-nums}.bio-insights__confidence{display:flex;align-items:center;gap:8px;font-size:.75rem;color:var(--text-secondary)}.bio-insights__confidence-bar{flex:1;height:4px;background:var(--bg-secondary);border-radius:2px;overflow:hidden}.bio-insights__confidence-fill{height:100%;border-radius:2px;background:var(--accent-blue);transition:width .5s ease}.bio-indicators{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;padding:8px 16px}.bio-indicators__chip{display:flex;flex-direction:column;gap:2px;padding:6px 8px;border-radius:8px;background:rgba(var(--overlay-rgb),.03);border:1px solid rgba(var(--overlay-rgb),.05);transition:border-color .2s ease}.bio-indicators__chip[data-level=none],.bio-indicators__chip[data-level=low]{border-color:rgba(var(--accent-green-rgb),.2)}.bio-indicators__chip[data-level=mild],.bio-indicators__chip[data-level=moderate],.bio-indicators__chip[data-level=medium]{border-color:rgba(var(--accent-orange-rgb),.2)}.bio-indicators__chip[data-level=high],.bio-indicators__chip[data-level=critical]{border-color:rgba(var(--accent-red-rgb),.2)}.bio-indicators__chip-label{font-size:9px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bio-indicators__chip-value{font-size:.875rem;font-weight:700}.bio-indicators__chip[data-level=none] .bio-indicators__chip-value,.bio-indicators__chip[data-level=low] .bio-indicators__chip-value{color:var(--accent-green)}.bio-indicators__chip[data-level=mild] .bio-indicators__chip-value,.bio-indicators__chip[data-level=moderate] .bio-indicators__chip-value,.bio-indicators__chip[data-level=medium] .bio-indicators__chip-value{color:var(--accent-orange)}.bio-indicators__chip[data-level=high] .bio-indicators__chip-value,.bio-indicators__chip[data-level=critical] .bio-indicators__chip-value{color:var(--accent-red)}.bio-indicators__chip[data-level=unknown] .bio-indicators__chip-value{color:var(--text-muted)}.bio-indicators__chip-detail{font-size:9px;font-weight:400;opacity:.65}.bio-suggestion{display:flex;flex-direction:column;gap:4px;padding:8px 16px;border-radius:8px;background:rgba(var(--overlay-rgb),.02);border:1px solid rgba(var(--overlay-rgb),.04);border-left:3px solid transparent}.bio-suggestion--main{margin:0 16px 8px}.bio-suggestion__top{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.bio-suggestion__urgency{display:inline-flex;align-items:center;padding:1px 7px;border-radius:6px;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;white-space:nowrap;flex-shrink:0}.bio-suggestion__urgency[data-urgency=low]{background:rgba(var(--accent-green-rgb),.12);color:var(--accent-green)}.bio-suggestion__urgency[data-urgency=medium]{background:rgba(var(--accent-orange-rgb),.12);color:var(--accent-orange)}.bio-suggestion__urgency[data-urgency=high]{background:rgba(var(--accent-red-rgb),.12);color:var(--accent-red)}.bio-suggestion__urgency[data-urgency=critical]{background:rgba(var(--accent-purple-rgb),.15);color:var(--accent-purple)}.bio-suggestion__title{font-size:.875rem;font-weight:600;color:var(--text-primary)}.bio-suggestion__reason{font-size:11px;color:var(--text-secondary);line-height:1.45;min-width:0}.bio-suggestion__action{font-size:11px;color:var(--accent-cyan);line-height:1.45;padding-top:2px}.bio-suggestion__action strong{color:var(--text-primary);font-weight:600}.bio-trend{font-size:14px;font-weight:700;flex-shrink:0;line-height:1;transition:color .4s ease}.bio-prediction{display:flex;align-items:center;gap:8px;margin:0 16px 8px;padding:8px 16px;border-radius:8px;background:rgba(var(--accent-orange-rgb),.12);border:1px solid rgba(var(--accent-orange-rgb),.3);font-size:.875rem;color:var(--accent-orange)}.bio-prediction__icon{flex-shrink:0;width:14px;height:14px}.bio-prediction--urgent{background:rgba(var(--accent-red-rgb),.15);border-color:rgba(var(--accent-red-rgb),.4);color:var(--accent-red);animation:bio-pulse 1.5s ease-in-out infinite}@keyframes bio-pulse{0%,to{opacity:1}50%{opacity:.65}}.bio-breakdown{display:flex;flex-direction:column;gap:7px;padding:8px 16px;border-bottom:1px solid rgba(var(--overlay-rgb),.04)}.bio-breakdown__item{display:grid;grid-template-columns:140px 1fr 36px;align-items:center;gap:8px}.bio-breakdown__label{font-size:11px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bio-breakdown__track{height:7px;background:rgba(var(--overlay-rgb),.05);border-radius:4px;overflow:hidden}.bio-breakdown__bar{height:100%;border-radius:4px;transition:width .5s cubic-bezier(.4,0,.2,1),background-color .4s ease;min-width:2px}.bio-breakdown__pct{font-size:11px;font-weight:600;text-align:right;font-variant-numeric:tabular-nums}.cw{background:var(--bg-card);border-radius:12px;border:1px solid rgba(var(--overlay-rgb),.06);padding:24px;display:flex;flex-direction:column;gap:16px}.cw__title-bar{display:flex;align-items:center;gap:8px;color:var(--accent-cyan)}.cw__title-bar h3{font-size:1rem;font-weight:700;color:var(--text-primary);margin:0}.cw__active-card{background:rgba(var(--accent-green-rgb),.04);border:1px solid rgba(var(--accent-green-rgb),.15);border-radius:8px;padding:16px;display:flex;flex-direction:column;gap:8px}.cw__active-header{display:flex;align-items:center;gap:6px;font-size:.75rem;font-weight:600;color:var(--accent-green);text-transform:uppercase;letter-spacing:.5px}.cw__active-formula{font-family:SF Mono,Fira Code,monospace;font-size:.875rem;color:var(--text-primary);background:rgba(var(--shadow-rgb),.2);padding:6px 10px;border-radius:4px;display:inline-block;align-self:flex-start}.cw__active-meta{display:flex;gap:16px;font-size:.75rem;color:var(--text-muted)}.cw__active-actions{display:flex;gap:8px;margin-top:4px}.cw__active-warn{display:flex;align-items:center;gap:6px;font-size:.75rem;color:var(--accent-orange);margin:0;line-height:1.4}.cw__msg{display:flex;align-items:center;gap:6px;padding:8px 16px;border-radius:8px;font-size:.875rem}.cw__msg--error{background:rgba(var(--accent-red-rgb),.08);border:1px solid rgba(var(--accent-red-rgb),.2);color:var(--accent-red)}.cw__msg--success{background:rgba(var(--accent-green-rgb),.08);border:1px solid rgba(var(--accent-green-rgb),.2);color:var(--accent-green)}.cw__offline{display:flex;align-items:center;gap:8px;padding:24px;color:var(--text-muted);font-size:.875rem;justify-content:center}.cw__instructions{font-size:.875rem;color:var(--text-secondary);line-height:1.6;background:rgba(var(--overlay-rgb),.02);border-radius:8px;padding:16px}.cw__instructions p{margin:0 0 6px}.cw__instructions ol{margin:0;padding-left:20px}.cw__instructions ol li{margin-bottom:2px}.cw__live-bar{display:flex;gap:24px;padding:16px;background:rgba(var(--shadow-rgb),.15);border-radius:8px;border:1px solid rgba(var(--overlay-rgb),.04)}.cw__live-item{display:flex;align-items:center;gap:6px;color:var(--text-muted)}.cw__live-label{font-size:.75rem;color:var(--text-muted)}.cw__live-val{font-size:.875rem;font-weight:700;color:var(--text-primary);font-variant-numeric:tabular-nums}.cw__live-val--ec{color:var(--accent-cyan)}.cw__input-group{display:flex;align-items:flex-end;gap:8px}.cw__input-field{flex:1;display:flex;flex-direction:column;gap:4px}.cw__input-field label{font-size:.75rem;color:var(--text-muted);font-weight:500}.cw__input-field input{padding:10px 12px;border:1px solid rgba(var(--overlay-rgb),.1);border-radius:8px;background:rgba(var(--overlay-rgb),.03);color:var(--text-primary);font-size:1rem;font-family:inherit;outline:none;transition:border-color .15s;color-scheme:dark}.cw__input-field input::placeholder{color:rgba(var(--overlay-rgb),.2)}.cw__input-field input:focus{border-color:rgba(var(--accent-cyan-rgb),.4);box-shadow:0 0 0 2px rgba(var(--accent-cyan-rgb),.1)}.cw__progress{display:flex;align-items:center;gap:8px}.cw__progress-bar{flex:1;height:4px;background:rgba(var(--overlay-rgb),.06);border-radius:2px;overflow:hidden}.cw__progress-fill{height:100%;background:var(--accent-cyan);border-radius:2px;transition:width .3s ease}.cw__progress-text{font-size:.75rem;color:var(--text-muted);white-space:nowrap}.cw__table{border:1px solid rgba(var(--overlay-rgb),.06);border-radius:8px;overflow:hidden}.cw__table-head,.cw__table-row{display:grid;grid-template-columns:32px 1fr 1fr 32px;gap:8px;padding:8px 16px;font-size:.75rem;align-items:center}.cw__table-head{background:rgba(var(--overlay-rgb),.03);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.cw__table-row{color:var(--text-primary);border-top:1px solid rgba(var(--overlay-rgb),.04);font-variant-numeric:tabular-nums}.cw__table-del{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;background:none;color:var(--text-muted);cursor:pointer;border-radius:4px;transition:all .15s}.cw__table-del:hover{background:rgba(var(--accent-red-rgb),.1);color:var(--accent-red)}.cw__btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:8px;font-size:.875rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all .15s ease;border:1px solid transparent}.cw__btn:disabled{opacity:.4;cursor:not-allowed}.cw__btn--add{background:rgba(var(--accent-cyan-rgb),.1);border-color:rgba(var(--accent-cyan-rgb),.25);color:var(--accent-cyan);white-space:nowrap}.cw__btn--add:hover:not(:disabled){background:rgba(var(--accent-cyan-rgb),.18);border-color:rgba(var(--accent-cyan-rgb),.4)}.cw__btn--save{width:100%;justify-content:center;padding:12px 24px;background:rgba(var(--accent-green-rgb),.1);border-color:rgba(var(--accent-green-rgb),.25);color:var(--accent-green)}.cw__btn--save:hover:not(:disabled){background:rgba(var(--accent-green-rgb),.18);border-color:rgba(var(--accent-green-rgb),.4);box-shadow:0 0 12px rgba(var(--accent-green-rgb),.1)}.cw__btn--danger{background:rgba(var(--accent-red-rgb),.06);border-color:rgba(var(--accent-red-rgb),.2);color:var(--accent-red);font-size:.75rem}.cw__btn--danger:hover:not(:disabled){background:rgba(var(--accent-red-rgb),.12);border-color:rgba(var(--accent-red-rgb),.4)}.cw__btn--danger-confirm{background:rgba(var(--accent-red-rgb),.15);border-color:var(--accent-red)}.cw__btn--ghost{background:transparent;border-color:rgba(var(--overlay-rgb),.1);color:var(--text-muted);font-size:.75rem}.cw__btn--ghost:hover{color:var(--text-primary);border-color:rgba(var(--overlay-rgb),.2)}.calib-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:8px;font-size:11px}.calib-badge--active{background:rgba(var(--accent-green-rgb),.08);border:1px solid rgba(var(--accent-green-rgb),.2);color:var(--accent-green)}.calib-badge__icon{font-weight:700}.calib-badge__text{font-variant-numeric:tabular-nums}.sensor-visibility-list{display:flex;flex-direction:column;gap:2px}.sensor-visibility-row{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;border-radius:6px;background:rgba(var(--overlay-rgb),.03);transition:opacity .15s ease}.sensor-visibility-row--hidden{opacity:.45}.sensor-visibility-row__info{display:flex;align-items:center;gap:8px;min-width:0}.sensor-visibility-row__icon{display:flex;align-items:center;flex-shrink:0}.sensor-visibility-row__label{font-size:.875rem;color:var(--text-primary);font-weight:500}.sensor-visibility-row__unit{font-size:.75rem;color:var(--text-muted)}.sensor-visibility-row__toggle{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:6px;background:rgba(var(--overlay-rgb),.04);color:var(--text-muted);cursor:pointer;transition:all .15s ease;flex-shrink:0}.sensor-visibility-row__toggle:hover{background:rgba(var(--overlay-rgb),.08)}.sensor-visibility-row__toggle--active{color:var(--accent-green)}.sensor-visibility-row__toggle:disabled{cursor:wait;opacity:.5}.modal__section-loading{font-size:.875rem;color:var(--text-muted);padding:8px 0}.access-list{display:flex;flex-direction:column;gap:4px}.access-list__row{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:8px;background:rgba(var(--overlay-rgb),.02);border:1px solid rgba(var(--overlay-rgb),.05)}.access-list__username{flex:1;min-width:0;font-size:.875rem;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.access-list__role-select{padding:4px 6px;border:1px solid rgba(var(--overlay-rgb),.08);border-radius:4px;background:var(--bg-elevated);color:var(--text-primary);font-size:.75rem;font-family:inherit;cursor:pointer;outline:none;color-scheme:dark}.access-list__role-select:focus{border-color:rgba(var(--accent-cyan-rgb),.4)}.access-list__role-select option{background:var(--bg-card);color:var(--text-primary)}.access-list__remove{display:flex;align-items:center;justify-content:center;width:24px;height:24px;flex-shrink:0;border:none;border-radius:4px;background:transparent;color:var(--text-muted);cursor:pointer;transition:all .15s ease}.access-list__remove:hover{background:rgba(var(--accent-red-rgb),.1);color:var(--accent-red)}.access-list__empty{font-size:.875rem;color:var(--text-muted);font-style:italic;padding:4px 0}.access-list__add{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:4px}.access-list__add-btn{flex-shrink:0}.access-list__user-select{flex:1;min-width:120px;background:var(--bg-elevated);color-scheme:dark}.access-list__user-select option{background:var(--bg-card);color:var(--text-primary)}.sib{display:flex;align-items:center;gap:8px;padding:5px 16px;border-bottom:1px solid rgba(var(--overlay-rgb),.04);flex-wrap:wrap}.sib__item--live{display:flex;align-items:center;gap:5px;font-size:11px;color:#555}.sib__dot{width:6px;height:6px;border-radius:50%;background:#39ff14;animation:sib-pulse 2s infinite;flex-shrink:0}@keyframes sib-pulse{0%,to{opacity:1;box-shadow:0 0 rgba(var(--accent-green-rgb),.4)}50%{opacity:.6;box-shadow:0 0 0 4px rgba(var(--accent-green-rgb),0)}}.sib__chip{display:inline-flex;align-items:center;gap:4px;font-size:11px;padding:2px 7px;border-radius:10px;background:rgba(var(--overlay-rgb),.03);border:1px solid rgba(var(--overlay-rgb),.06);color:#555;white-space:nowrap}.sib__chip--alert{color:#ffa726;border-color:rgba(var(--accent-orange-rgb),.2)}.sib__chip--fw{color:#444;font-family:monospace;letter-spacing:.2px}.diag__empty{display:flex;flex-direction:column;align-items:center;gap:8px;padding:48px 24px;color:var(--text-muted);text-align:center}.diag__empty p{font-size:1rem;font-weight:600;color:var(--text-secondary)}.diag__empty span{font-size:.875rem}.diag__status-bar{display:flex;align-items:center;gap:8px;padding:16px;background:var(--bg-card);border-radius:12px;box-shadow:var(--neu-raised);margin-bottom:16px}.diag__status-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.diag__status-dot--ok{background:var(--accent-green);box-shadow:0 0 8px rgba(var(--accent-green-rgb),.5)}.diag__status-dot--warn{background:var(--accent-yellow);box-shadow:0 0 8px rgba(var(--accent-yellow-rgb),.5)}.diag__status-dot--crit{background:var(--accent-red);box-shadow:0 0 8px rgba(var(--accent-red-rgb),.5);animation:pulse-glow 1.5s infinite}.diag__status-text{font-size:.875rem;font-weight:600;color:var(--text-primary)}.diag__station-code{margin-left:auto;font-size:.75rem;color:var(--text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.diag__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px}.diag__card{display:flex;flex-direction:column;gap:4px;padding:16px;text-align:center}.diag__card-header{display:flex;align-items:center;justify-content:center;gap:4px;font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-weight:500}.diag__card-value{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.diag__card-value--ok{color:var(--accent-green)}.diag__card-value--warn{color:var(--accent-yellow)}.diag__card-value--crit{color:var(--accent-red)}.diag__card-sub{font-size:.75rem;color:var(--text-muted);font-weight:500}.diag__bar-wrap{height:4px;background:rgba(var(--overlay-rgb),.06);border-radius:2px;overflow:hidden;margin-top:4px}.diag__bar{height:100%;border-radius:2px;transition:width .5s ease}@keyframes pulse-glow{0%,to{opacity:1}50%{opacity:.5}}.sensor-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.sensor-nav__label{font-weight:700;font-size:1rem;color:var(--text-primary)}.audit-log{display:flex;flex-direction:column;gap:2px}.audit-log--loading,.audit-log--error,.audit-log--empty{display:flex;align-items:center;gap:8px;padding:16px;font-size:.875rem;color:var(--text-muted);border-radius:8px;background:rgba(var(--overlay-rgb),.02)}.audit-log--error{color:var(--accent-red);background:rgba(var(--accent-red-rgb),.04)}.audit-log__row{display:flex;align-items:baseline;flex-wrap:wrap;gap:8px;padding:7px 10px;border-radius:8px;border:1px solid transparent;font-size:.75rem;transition:background .1s ease}.audit-log__row:hover{background:rgba(var(--overlay-rgb),.02);border-color:rgba(var(--overlay-rgb),.04)}.audit-log__action{font-weight:700;font-size:10px;text-transform:uppercase;letter-spacing:.4px;flex-shrink:0}.audit-log__user{color:var(--text-secondary);flex-shrink:0}.audit-log__time{color:var(--text-muted);font-size:10px;margin-left:auto;font-variant-numeric:tabular-nums;white-space:nowrap}.audit-log__changes{width:100%;display:flex;flex-wrap:wrap;gap:4px;padding-top:4px;border-top:1px solid rgba(var(--overlay-rgb),.04);margin-top:2px}.audit-log__change{display:inline-flex;align-items:center;gap:4px;padding:2px 6px;border-radius:3px;background:rgba(var(--overlay-rgb),.03);font-size:10px;color:var(--text-secondary)}.audit-log__change strong{color:var(--text-muted);font-weight:500}.admin{min-height:100vh;background:#faf8f5;font-family:DM Sans,Inter,sans-serif;color:#2d3436;display:flex;flex-direction:column}.admin:before{content:"";position:fixed;top:0;left:0;right:0;height:300px;background:linear-gradient(180deg,rgba(158,197,224,.08) 0%,rgba(181,204,176,.05) 40%,transparent 100%);pointer-events:none;z-index:0}.admin__header{position:sticky;top:0;z-index:100;display:flex;align-items:center;gap:12px;padding:16px 20px;background:#faf8f5d9;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid #ece8e1}.admin__back,.admin__detail-back{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:12px;border:1px solid #ece8e1;background:#fff;color:#6b6560;cursor:pointer;transition:all .15s ease;flex-shrink:0}.admin__back:hover,.admin__detail-back:hover{background:#f5f0eb;color:#2d3436;box-shadow:0 2px 24px #b4aa9b21}.admin__title{font-family:"DM Serif Display",Georgia,serif;font-size:1.35rem;font-weight:400;color:#2d3436;letter-spacing:-.3px;flex:1}.admin__subtitle{font-size:.8rem;color:#a09a94}.admin__content{flex:1;position:relative;z-index:1;padding:20px 16px 40px;max-width:700px;margin:0 auto;width:100%}@media(min-width:768px){.admin__content{padding:28px 24px 48px}}.admin__grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}@media(min-width:768px){.admin__grid{gap:18px}}.admin-card{background:#fff;border-radius:20px;border:1px solid #ece8e1;box-shadow:0 2px 24px #b4aa9b21;padding:18px;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;gap:12px;aspect-ratio:1;overflow:hidden;position:relative}.admin-card:hover{transform:translateY(-2px);box-shadow:0 6px 32px #b4aa9b33;border-color:#e2dcd1}.admin-card:active{transform:translateY(0)}.admin-card:after{content:"";position:absolute;bottom:-20px;right:-20px;width:80px;height:80px;border-radius:50%;background:radial-gradient(circle,rgba(158,197,224,.08) 0%,transparent 70%);pointer-events:none}.admin-card__header{display:flex;align-items:center;gap:8px}.admin-card__dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.admin-card__dot--online{background:#9bc4a0;box-shadow:0 0 6px #9bc4a066}.admin-card__dot--offline{background:#e8a0a0;opacity:.7}.admin-card__dot--maintenance{background:#e8d590}.admin-card__code{font-size:.7rem;font-weight:600;color:#a09a94;letter-spacing:.5px;text-transform:uppercase}.admin-card__name{font-family:"DM Serif Display",Georgia,serif;font-size:1.05rem;color:#2d3436;line-height:1.3;letter-spacing:-.2px}.admin-card__users{flex:1;display:flex;flex-direction:column;gap:6px;overflow-y:auto;min-height:0}.admin-card__users::-webkit-scrollbar{width:3px}.admin-card__users::-webkit-scrollbar-track{background:transparent}.admin-card__users::-webkit-scrollbar-thumb{background:#ece8e1;border-radius:3px}.admin-card__user{display:flex;align-items:center;gap:8px;min-height:28px}.admin-card__avatar,.admin__access-avatar{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.6rem;font-weight:700;color:#fff;flex-shrink:0;text-transform:uppercase}.admin-card__username{font-size:.78rem;color:#6b6560;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-card__role{font-size:.6rem;font-weight:600;padding:2px 8px;border-radius:20px;white-space:nowrap;letter-spacing:.3px;text-transform:uppercase;flex-shrink:0}.admin-card__role--manager{background:#b8a9d440;color:#7255a9}.admin-card__role--editor{background:#9ec5e040;color:#3a83b5}.admin-card__role--viewer{background:#e8d59033;color:#b99926}.admin-card__empty{font-size:.75rem;color:#a09a94;font-style:italic;padding:8px 0}.admin-card__footer{font-size:.68rem;color:#a09a94;border-top:1px solid rgba(236,232,225,.6);padding-top:8px;margin-top:auto}.admin-card--skeleton{background:#fff;border:1px solid #ece8e1;border-radius:20px;aspect-ratio:1;animation:admin-pulse 1.8s ease-in-out infinite}@keyframes admin-pulse{0%,to{opacity:1}50%{opacity:.5}}.admin__detail{display:flex;flex-direction:column;gap:20px}.admin__detail-header{display:flex;align-items:center;gap:12px}.admin__detail-info{flex:1}.admin__detail-name{font-family:"DM Serif Display",Georgia,serif;font-size:1.3rem;color:#2d3436}.admin__detail-code{font-size:.75rem;color:#a09a94;letter-spacing:.5px;text-transform:uppercase}.admin__access-list{display:flex;flex-direction:column;gap:8px}.admin__access-row{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#fff;border:1px solid #ece8e1;border-radius:12px;box-shadow:0 1px 8px #b4aa9b14;transition:box-shadow .15s ease}.admin__access-row:hover{box-shadow:0 2px 24px #b4aa9b21}.admin__access-avatar{width:32px;height:32px;font-size:.7rem}.admin__access-username{flex:1;font-size:.88rem;font-weight:500;color:#2d3436}.admin__access-select,.admin__access-form-select{font-family:DM Sans,Inter,sans-serif;font-size:.78rem;padding:5px 10px;border-radius:10px;border:1px solid #ece8e1;background:#faf8f5;color:#2d3436;cursor:pointer;outline:none;transition:border-color .15s}.admin__access-select:focus,.admin__access-form-select:focus{border-color:#9ec5e0}.admin__access-remove{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:8px;border:1px solid transparent;background:transparent;color:#a09a94;cursor:pointer;transition:all .15s}.admin__access-remove:hover{background:#e8a0a01f;border-color:#e8a0a04d;color:#d44e4e}.admin__access-empty{text-align:center;padding:32px 16px;color:#a09a94;font-style:italic;font-size:.9rem}.admin__access-form{display:flex;align-items:center;gap:8px;padding:14px 16px;background:#b5ccb014;border:1px dashed rgba(181,204,176,.35);border-radius:12px;flex-wrap:wrap}.admin__access-form-select{flex:1;min-width:120px}.admin__access-form-btn{display:flex;align-items:center;gap:6px;font-family:DM Sans,Inter,sans-serif;font-size:.8rem;font-weight:600;padding:7px 14px;border-radius:10px;border:none;background:#9bc4a0;color:#fff;cursor:pointer;transition:all .15s;white-space:nowrap}.admin__access-form-btn:hover:not(:disabled){background:#81b588;box-shadow:0 2px 12px #9bc4a04d}.admin__access-form-btn:disabled{opacity:.5;cursor:not-allowed}.admin__error{padding:10px 14px;background:#e8a0a01a;border:1px solid rgba(232,160,160,.25);border-radius:12px;color:#cf3939;font-size:.82rem}.admin-card{animation:admin-fadeIn .35s ease both}.admin-card:nth-child(1){animation-delay:.05s}.admin-card:nth-child(2){animation-delay:.1s}.admin-card:nth-child(3){animation-delay:.15s}.admin-card:nth-child(4){animation-delay:.2s}.admin-card:nth-child(5){animation-delay:.25s}.admin-card:nth-child(6){animation-delay:.3s}.admin-card:nth-child(7){animation-delay:.35s}.admin-card:nth-child(8){animation-delay:.4s}.admin-card:nth-child(9){animation-delay:.45s}.admin-card:nth-child(10){animation-delay:.5s}.admin-card:nth-child(11){animation-delay:.55s}.admin-card:nth-child(12){animation-delay:.6s}.admin-card:nth-child(13){animation-delay:.65s}.admin-card:nth-child(14){animation-delay:.7s}.admin-card:nth-child(15){animation-delay:.75s}.admin-card:nth-child(16){animation-delay:.8s}.admin-card:nth-child(17){animation-delay:.85s}.admin-card:nth-child(18){animation-delay:.9s}.admin-card:nth-child(19){animation-delay:.95s}.admin-card:nth-child(20){animation-delay:1s}@keyframes admin-fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.uv{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;background:var(--bg-primary);overflow:auto}.uv__loading{flex:1;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:.875rem}.uv__header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;flex-shrink:0;border-bottom:1px solid rgba(var(--overlay-rgb),.06);background:rgba(var(--bg-secondary-rgb),.5);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.uv__header-left{display:flex;align-items:center;gap:10px}.uv__station-name{font-family:"DM Serif Display",Georgia,serif;font-size:1.1rem;color:var(--text-primary)}.uv__status{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:2px 8px;border-radius:10px}.uv__status--on{color:var(--accent-green);background:rgba(var(--accent-green-rgb),.1)}.uv__status--off{color:var(--text-muted);background:rgba(var(--overlay-rgb),.06)}.uv__header-right{display:flex;align-items:center;gap:8px}.uv__ws{color:var(--text-muted)}.uv__ws--on{color:var(--accent-green)}.uv__back-btn{font-family:DM Sans,Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:.72rem;font-weight:500;color:var(--text-secondary);background:rgba(var(--overlay-rgb),.04);border:1px solid rgba(var(--overlay-rgb),.08);border-radius:8px;padding:4px 10px;cursor:pointer;transition:all .15s}.uv__back-btn:hover{background:rgba(var(--overlay-rgb),.08);color:var(--text-primary)}.uv__theme-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:8px;border:1px solid rgba(var(--overlay-rgb),.08);background:transparent;color:var(--text-secondary);cursor:pointer;transition:all .15s}.uv__theme-btn:hover{background:rgba(var(--overlay-rgb),.06);color:var(--text-primary)}.uv__logout-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:8px;border:1px solid rgba(var(--overlay-rgb),.08);background:transparent;color:var(--text-muted);cursor:pointer;transition:all .15s}.uv__logout-btn:hover{background:rgba(var(--accent-red-rgb),.08);color:var(--accent-red)}.uv__grid{display:grid;gap:12px;padding:12px;grid-template-columns:1fr;grid-auto-rows:auto}.uv__grid .sensor-card{overflow:hidden}.uv__grid .sensor-card__num{font-size:clamp(1.2rem,3.5vw,2.5rem)}.uv__grid .sensor-card__value,.uv__grid .sensor-card__header{max-width:100%;overflow:hidden}.uv__grid[data-count="2"],.uv__grid[data-count="3"]{grid-template-columns:1fr}.uv__grid[data-count="4"],.uv__grid[data-count="5"],.uv__grid[data-count="6"]{grid-template-columns:1fr 1fr}@media(min-width:576px){.uv__grid{gap:14px;padding:14px}.uv__grid[data-count="2"]{grid-template-columns:1fr 1fr}.uv__grid[data-count="3"]{grid-template-columns:1fr 1fr 1fr}}@media(min-width:768px){.uv__grid{gap:16px;padding:20px}.uv__grid[data-count="4"]{grid-template-columns:repeat(2,1fr);grid-template-rows:1fr 1fr}.uv__grid[data-count="5"],.uv__grid[data-count="6"]{grid-template-columns:repeat(3,1fr)}}.station-picker{min-height:100vh;min-height:100dvh;background:var(--bg-primary);display:flex;justify-content:center;padding:24px 16px 40px}@media(min-width:768px){.station-picker{padding:48px 24px 60px;align-items:flex-start}}.station-picker__inner{width:100%;max-width:600px;display:flex;flex-direction:column;gap:24px}@media(min-width:768px){.station-picker__inner{max-width:700px;gap:32px}}.station-picker__header{display:flex;flex-direction:column;gap:4px}.station-picker__title{font-family:"DM Serif Display",Georgia,serif;font-size:1.6rem;font-weight:400;color:var(--text-primary);letter-spacing:-.5px}@media(min-width:768px){.station-picker__title{font-size:2rem}}.station-picker__subtitle{font-size:.8rem;color:var(--text-muted)}.station-picker__grid{display:grid;grid-template-columns:1fr;gap:12px}@media(min-width:576px){.station-picker__grid{grid-template-columns:1fr 1fr;gap:14px}}.station-picker__card{display:flex;flex-direction:column;gap:10px;padding:18px 20px;background:var(--bg-card);border-radius:14px;border:1px solid rgba(var(--overlay-rgb),.04);box-shadow:0 1px 2px rgba(var(--shadow-rgb),.04),0 4px 12px rgba(var(--shadow-rgb),.03);cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.station-picker__card:hover{transform:translateY(-2px);box-shadow:0 2px 4px rgba(var(--shadow-rgb),.05),0 8px 24px rgba(var(--shadow-rgb),.06);border-color:rgba(var(--accent-green-rgb),.15)}.station-picker__card:active{transform:translateY(0);transition-duration:.06s}.station-picker__card--offline{opacity:.65}.station-picker__card--offline:hover{border-color:rgba(var(--overlay-rgb),.08)}.station-picker__card{animation:stationPickerIn .35s ease both}.station-picker__card:nth-child(1){animation-delay:.06s}.station-picker__card:nth-child(2){animation-delay:.12s}.station-picker__card:nth-child(3){animation-delay:.18s}.station-picker__card:nth-child(4){animation-delay:.24s}.station-picker__card:nth-child(5){animation-delay:.3s}.station-picker__card:nth-child(6){animation-delay:.36s}.station-picker__card:nth-child(7){animation-delay:.42s}.station-picker__card:nth-child(8){animation-delay:.48s}.station-picker__card-top{display:flex;align-items:center;gap:8px}.station-picker__dot{width:8px;height:8px;border-radius:50%;background:var(--text-muted);flex-shrink:0}.station-picker__dot--on{background:var(--accent-green);box-shadow:0 0 6px rgba(var(--accent-green-rgb),.3)}.station-picker__code{font-family:DM Sans,Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:.7rem;font-weight:600;color:var(--text-muted);letter-spacing:.5px;text-transform:uppercase}.station-picker__badge{margin-left:auto;font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.4px;padding:2px 8px;border-radius:8px;color:var(--text-muted);background:rgba(var(--overlay-rgb),.04)}.station-picker__card:not(.station-picker__card--offline) .station-picker__badge{color:var(--accent-green);background:rgba(var(--accent-green-rgb),.08)}.station-picker__card-name{font-family:"DM Serif Display",Georgia,serif;font-size:1.25rem;font-weight:400;color:var(--text-primary);letter-spacing:-.3px;line-height:1.3}.station-picker__card-meta{display:flex;align-items:center;gap:12px;font-size:.7rem;color:var(--text-muted)}.station-picker__alert{color:var(--accent-orange);font-weight:600}.station-picker__logout{align-self:center;font-family:DM Sans,Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:.75rem;font-weight:500;color:var(--text-muted);background:none;border:none;cursor:pointer;padding:8px 16px;border-radius:8px;transition:all .15s}.station-picker__logout:hover{color:var(--accent-red);background:rgba(var(--accent-red-rgb),.06)}.uv__chart-overlay{position:fixed;inset:0;z-index:200;background:rgba(var(--shadow-rgb),.15);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:flex-end;justify-content:center;animation:uvOverlayIn .2s ease;padding:0}@media(min-width:768px){.uv__chart-overlay{align-items:center;padding:24px}}.uv__chart-panel{position:relative;width:100%;max-width:800px;max-height:90vh;overflow-y:auto;background:var(--bg-card);border:1px solid rgba(var(--overlay-rgb),.04);border-radius:14px 14px 0 0;box-shadow:0 1px 2px rgba(var(--shadow-rgb),.04),0 4px 12px rgba(var(--shadow-rgb),.03),0 -2px 20px rgba(var(--shadow-rgb),.06);padding:16px 14px 20px;animation:uvPanelSlideUp .25s cubic-bezier(.25,.46,.45,.94)}.uv__chart-panel:before{content:"";position:absolute;top:0;left:16px;right:16px;height:3px;background:var(--sensor-color, var(--text-muted));border-radius:0 0 3px 3px;opacity:.85}@media(min-width:768px){.uv__chart-panel{border-radius:16px;padding:20px 24px 24px;animation:uvPanelScaleIn .2s cubic-bezier(.25,.46,.45,.94);box-shadow:0 1px 2px rgba(var(--shadow-rgb),.04),0 8px 32px rgba(var(--shadow-rgb),.08)}.uv__chart-panel:before{left:20px;right:20px}}.uv__chart-panel::-webkit-scrollbar{width:4px}.uv__chart-panel::-webkit-scrollbar-track{background:transparent}.uv__chart-panel::-webkit-scrollbar-thumb{background:rgba(var(--overlay-rgb),.08);border-radius:2px}.uv__chart-close{position:absolute;top:10px;right:10px;display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:8px;border:none;background:transparent;color:var(--text-muted);cursor:pointer;transition:all .15s;z-index:1}.uv__chart-close:hover{background:rgba(var(--overlay-rgb),.04);color:var(--text-primary)}@keyframes uvOverlayIn{0%{opacity:0}to{opacity:1}}@keyframes uvPanelSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes uvPanelScaleIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes stationPickerIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent}body{font-family:DM Sans,Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg-primary);color:var(--text-primary);min-height:100vh;line-height:1.5}#root{min-height:100vh}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--bg-elevated);border-radius:3px}.neu-card{background:var(--bg-card);border-radius:12px;box-shadow:var(--neu-raised);padding:24px;transition:box-shadow .2s ease,transform .2s ease}.neu-card:hover{transform:translateY(-1px);box-shadow:8px 8px 16px var(--shadow-dark),-5px -5px 12px var(--shadow-light)}.neu-inset{background:var(--bg-secondary);border-radius:8px;box-shadow:var(--neu-inset);padding:16px}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 10px;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.badge--online{background:rgba(var(--accent-green-rgb),.15);color:var(--accent-green)}.badge--offline{background:rgba(var(--overlay-rgb),.15);color:var(--text-muted)}.badge--maintenance{background:rgba(var(--accent-yellow-rgb),.15);color:var(--accent-yellow)}.badge--error{background:rgba(var(--accent-red-rgb),.15);color:var(--accent-red)}.badge--info{background:rgba(var(--accent-blue-rgb),.15);color:var(--accent-blue)}.badge--warning{background:rgba(var(--accent-yellow-rgb),.15);color:var(--accent-yellow)}.badge--critical{background:rgba(var(--accent-red-rgb),.15);color:var(--accent-red)}.badge--resolved{background:rgba(var(--accent-green-rgb),.15);color:var(--accent-green)}.badge--ack{background:rgba(var(--accent-orange-rgb),.15);color:var(--accent-orange)}.badge--open{background:rgba(var(--accent-red-rgb),.15);color:var(--accent-red)}.app{display:flex;flex-direction:column;min-height:100vh}.header{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:8px 16px;background:rgba(var(--bg-secondary-rgb),.8);-webkit-backdrop-filter:blur(20px) saturate(1.2);backdrop-filter:blur(20px) saturate(1.2);border-bottom:1px solid rgba(var(--overlay-rgb),.08)}@media(min-width:576px){.header{padding:16px 24px}}.header__brand{display:flex;align-items:center;gap:8px;min-width:0}.header__logo{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,rgba(var(--accent-cyan-rgb),.15),rgba(var(--accent-blue-rgb),.08));border:1px solid rgba(var(--accent-cyan-rgb),.15);color:var(--accent-cyan);flex-shrink:0}.header__brand-text{display:flex;flex-direction:column;gap:0;min-width:0}.header__title{font-family:"DM Serif Display",Georgia,serif;font-size:1rem;font-weight:400;color:var(--text-primary);letter-spacing:-.3px;line-height:1.2;white-space:nowrap;margin:0}@media(min-width:768px){.header__title{font-size:1.125rem}}.header__subtitle{display:none;font-size:10px;color:var(--text-muted);letter-spacing:.5px;text-transform:uppercase}@media(min-width:576px){.header__subtitle{display:block}}.header__stats{display:none}@media(min-width:768px){.header__stats{display:flex;align-items:center;gap:16px;padding:4px 16px;border-radius:12px;background:rgba(var(--overlay-rgb),.02);border:1px solid rgba(var(--overlay-rgb),.04)}}.header__stat{display:flex;flex-direction:column;align-items:center;gap:0;min-width:52px}.header__stat-value{font-size:1rem;font-weight:700;color:var(--text-primary);line-height:1.2}.header__stat-label{font-size:9px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.6px}.header__stat-divider{width:1px;height:24px;background:rgba(var(--overlay-rgb),.06)}.header__actions{display:flex;align-items:center;gap:4px}@media(min-width:576px){.header__actions{gap:8px}}.header__time{display:none}@media(min-width:576px){.header__time{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--text-muted);font-variant-numeric:tabular-nums}}.header .header__invite-btn,.header .header__theme-btn,.header .header__logout-btn,.header .header__admin-btn,.header .header__add-btn,.header .header__refresh-btn,.header .header__install-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;cursor:pointer;transition:all .15s ease;flex-shrink:0}.header .header__invite-btn:active,.header .header__theme-btn:active,.header .header__logout-btn:active,.header .header__admin-btn:active,.header .header__add-btn:active,.header .header__refresh-btn:active,.header .header__install-btn:active{transform:scale(.92)}.header .header__invite-btn:disabled,.header .header__theme-btn:disabled,.header .header__logout-btn:disabled,.header .header__admin-btn:disabled,.header .header__add-btn:disabled,.header .header__refresh-btn:disabled,.header .header__install-btn:disabled{opacity:.5;cursor:not-allowed}.header__install-btn{border:1px solid rgba(var(--accent-cyan-rgb),.3);background:rgba(var(--accent-cyan-rgb),.08);color:var(--accent-cyan);animation:install-pulse 2.5s ease-in-out infinite}.header__install-btn:hover{background:rgba(var(--accent-cyan-rgb),.15);border-color:rgba(var(--accent-cyan-rgb),.5);box-shadow:0 0 10px rgba(var(--accent-cyan-rgb),.2)}.header__refresh-btn{border:1px solid rgba(var(--overlay-rgb),.06);background:rgba(var(--overlay-rgb),.03);color:var(--text-secondary)}.header__refresh-btn:hover{background:rgba(var(--overlay-rgb),.06);color:var(--text-primary);border-color:rgba(var(--overlay-rgb),.1)}.header__add-btn{border:1px solid rgba(var(--accent-green-rgb),.3);background:rgba(var(--accent-green-rgb),.08);color:var(--accent-green)}.header__add-btn:hover{background:rgba(var(--accent-green-rgb),.15);border-color:rgba(var(--accent-green-rgb),.5);box-shadow:0 0 8px rgba(var(--accent-green-rgb),.2)}.header__admin-btn{border:1px solid rgba(var(--accent-purple-rgb),.25);background:rgba(var(--accent-purple-rgb),.06);color:var(--accent-purple)}.header__admin-btn:hover{background:rgba(var(--accent-purple-rgb),.12);border-color:rgba(var(--accent-purple-rgb),.4);box-shadow:0 0 8px rgba(var(--accent-purple-rgb),.15)}.header__logout-btn{border:1px solid rgba(var(--overlay-rgb),.2);background:transparent;color:var(--text-muted)}.header__logout-btn:hover{background:rgba(var(--accent-red-rgb),.08);border-color:rgba(var(--accent-red-rgb),.3);color:var(--accent-red)}.header__divider{display:none;width:1px;height:20px;background:rgba(var(--overlay-rgb),.07);flex-shrink:0}@media(min-width:576px){.header__divider{display:block}}.header__theme-btn{border:1px solid rgba(var(--overlay-rgb),.06);background:rgba(var(--overlay-rgb),.03);color:var(--text-secondary)}.header__theme-btn:hover{background:rgba(var(--accent-yellow-rgb),.1);border-color:rgba(var(--accent-yellow-rgb),.3);color:var(--accent-yellow)}.header__invite-wrap{position:relative}.header__invite-btn{border:1px solid rgba(var(--accent-purple-rgb),.3);background:rgba(var(--accent-purple-rgb),.08);color:var(--accent-purple)}.header__invite-btn:hover{background:rgba(var(--accent-purple-rgb),.15);border-color:rgba(var(--accent-purple-rgb),.5);box-shadow:0 0 8px rgba(var(--accent-purple-rgb),.2)}.invite-popover{position:absolute;top:calc(100% + 8px);right:0;z-index:200;background:var(--bg-elevated);border:1px solid rgba(var(--accent-purple-rgb),.2);border-radius:12px;box-shadow:var(--neu-raised);padding:16px;min-width:320px}.invite-popover__label{font-size:.75rem;color:var(--text-muted);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.invite-popover__row{display:flex;align-items:center;gap:8px;background:var(--bg-secondary);border-radius:8px;padding:4px 8px;border:1px solid rgba(var(--overlay-rgb),.05)}.invite-popover__link{flex:1;font-size:.75rem;color:var(--accent-cyan);word-break:break-all;font-family:monospace}.invite-popover__copy{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;border-radius:8px;background:rgba(var(--accent-purple-rgb),.15);color:var(--accent-purple);cursor:pointer;transition:all .15s ease}.invite-popover__copy:hover{background:rgba(var(--accent-purple-rgb),.25)}@keyframes install-pulse{0%,to{box-shadow:0 0 rgba(var(--accent-cyan-rgb),0)}50%{box-shadow:0 0 8px 2px rgba(var(--accent-cyan-rgb),.2)}}@keyframes wsPulse{0%,to{opacity:1}50%{opacity:.5}}.main{flex:1;padding:16px;max-width:1280px;width:100%;margin:0 auto}@media(min-width:768px){.main{padding:24px}}@media(min-width:1024px){.main{padding:32px}}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:24px}@media(min-width:768px){.stats-grid{grid-template-columns:repeat(3,1fr)}}@media(min-width:1024px){.stats-grid{grid-template-columns:repeat(5,1fr)}}.dashboard-grid{display:grid;grid-template-columns:1fr;gap:24px}@media(min-width:1024px){.dashboard-grid{grid-template-columns:1fr 1fr}}.section-header{display:flex;align-items:center;gap:8px;margin-bottom:16px;font-size:1rem;font-weight:600;color:var(--text-secondary)}.section-header svg{width:18px;height:18px}.loading{display:flex;align-items:center;justify-content:center;padding:48px;color:var(--text-muted)}.spinner{width:32px;height:32px;border:3px solid var(--bg-elevated);border-top-color:var(--accent-cyan);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.btn{display:inline-flex;align-items:center;gap:4px;padding:8px 16px;border:none;border-radius:8px;font-family:DM Sans,Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s ease;box-shadow:var(--neu-subtle)}.btn:active{box-shadow:var(--neu-inset);transform:scale(.97)}.btn--primary{background:var(--accent-blue);color:var(--bg-primary)}.btn--primary:hover{background:var(--accent-blue-hover)}.btn--success{background:var(--accent-green);color:var(--bg-primary)}.btn--success:hover{background:var(--accent-green-hover)}.btn--warning{background:var(--accent-orange);color:var(--bg-primary)}.btn--warning:hover{background:var(--accent-orange-hover)}.btn--small{padding:4px 8px;font-size:.75rem}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:var(--bg-primary)}.login-card{width:100%;max-width:380px;background:var(--bg-card);border-radius:16px;box-shadow:var(--neu-raised);padding:48px 32px}.login-card__brand{display:flex;flex-direction:column;align-items:center;gap:8px;margin-bottom:48px}.login-card__logo{display:flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:12px;background:linear-gradient(135deg,rgba(var(--accent-cyan-rgb),.15),rgba(var(--accent-blue-rgb),.08));border:1px solid rgba(var(--accent-cyan-rgb),.2);color:var(--accent-cyan)}.login-card__title{font-size:1.5rem;font-weight:700;color:var(--text-primary);letter-spacing:-.5px;margin:0}.login-card__subtitle{font-size:.875rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px}.login-card__form{display:flex;flex-direction:column;gap:16px}.login-card__field{display:flex;flex-direction:column;gap:4px}.login-card__label{font-size:.875rem;color:var(--text-secondary);font-weight:500}.login-card__input-wrap{position:relative;display:flex;align-items:center}.login-card__input-wrap .login-card__input{flex:1;padding-right:40px}.login-card__pw-toggle{position:absolute;right:10px;display:flex;align-items:center;justify-content:center;background:none;border:none;padding:0;color:var(--text-muted);cursor:pointer;transition:color .15s ease}.login-card__pw-toggle:hover{color:var(--text-primary)}.login-card__input{background:var(--bg-secondary);border:1px solid rgba(var(--overlay-rgb),.06);border-radius:8px;box-shadow:var(--neu-inset);color:var(--text-primary);font-family:DM Sans,Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:1rem;padding:8px 16px;outline:none;transition:border-color .15s ease;width:100%}.login-card__input:focus{border-color:rgba(var(--accent-cyan-rgb),.4)}.login-card__input:disabled{opacity:.5;cursor:not-allowed}.login-card__error{font-size:.875rem;color:var(--accent-red);background:rgba(var(--accent-red-rgb),.08);border:1px solid rgba(var(--accent-red-rgb),.2);border-radius:8px;padding:8px 16px}.login-card__submit{margin-top:8px;padding:16px;background:rgba(var(--accent-cyan-rgb),.12);border:1px solid rgba(var(--accent-cyan-rgb),.25);border-radius:8px;color:var(--accent-cyan);font-family:DM Sans,Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:1rem;font-weight:600;cursor:pointer;transition:all .15s ease;box-shadow:var(--neu-subtle)}.login-card__submit:hover:not(:disabled){background:rgba(var(--accent-cyan-rgb),.2);border-color:rgba(var(--accent-cyan-rgb),.4);box-shadow:0 0 12px rgba(var(--accent-cyan-rgb),.2)}.login-card__submit:active:not(:disabled){box-shadow:var(--neu-inset);transform:scale(.98)}.login-card__submit:disabled{opacity:.5;cursor:not-allowed}.login-card__footer{margin-top:24px;text-align:center;font-size:.875rem;color:var(--text-muted)}.login-card__link{background:none;border:none;color:var(--accent-cyan);font-family:DM Sans,Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:.875rem;font-weight:600;cursor:pointer;padding:0;transition:color .15s ease}.login-card__link:hover{color:var(--accent-cyan-hover, var(--accent-cyan));text-decoration:underline}
