@import "https://fonts.googleapis.com/css2?family=Exo+2:wght@500;700&family=Rajdhani:wght@500;600;700&display=swap";@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:.6}50%{opacity:.9}}.animate-fade-in{animation:.4s ease-out fadeIn}.animate-slide-in{animation:.4s ease-out slideIn}.animate-scale-in{animation:.3s ease-out scaleIn}.animate-delay-100{animation-delay:.1s}.animate-delay-200{animation-delay:.2s}.animate-delay-300{animation-delay:.3s}.smooth-transition{transition:all .3s}.smooth-transition-fast{transition:all .15s}.hover-lift{transition:transform .2s,box-shadow .2s}.hover-lift:hover{transform:translateY(-2px);box-shadow:0 6px 16px #00000026}.hover-lift:active{transform:translateY(0)}.login-page{background-color:var(--app-bg);background-image:radial-gradient(circle at 18% 14%, #38bdf829 0%, transparent 42%), radial-gradient(circle at 82% 86%, #0ea5e91f 0%, transparent 46%), linear-gradient(#38bdf81a 1px, transparent 1px), linear-gradient(90deg, #38bdf81a 1px, transparent 1px), linear-gradient(135deg, var(--page-grad-start) 0%, var(--page-grad-end) 100%);background-position:0 0,0 0,0 0,0 0,0 0;background-size:auto,auto,36px 36px,36px 36px,auto;justify-content:center;align-items:center;min-height:100vh;padding:16px;animation:18s linear infinite cyber-grid-shift;display:flex;position:relative;overflow:hidden}.login-page:after{content:"";pointer-events:none;mix-blend-mode:screen;opacity:.35;background:linear-gradient(#0000 0%,#38bdf824 48%,#0000 100%);animation:4.8s ease-in-out infinite cyber-scan;position:absolute;top:0;bottom:0;left:0;right:0}@keyframes cyber-grid-shift{0%{background-position:0 0,0 0,0 0,0 0,0 0}to{background-position:0 0,0 0,36px 36px,-36px 36px,0 0}}@keyframes cyber-scan{0%,to{transform:translateY(-105%)}55%{transform:translateY(105%)}}.login-container{z-index:1;width:100%;max-width:450px;position:relative}.login-card{background:color-mix(in srgb, var(--surface-1) 86%, #020617 14%);box-shadow:var(--shadow-strong), 0 0 32px #38bdf829;border:1px solid color-mix(in srgb, var(--border-1) 60%, #22d3ee 40%);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border-radius:16px;padding:32px 24px}.login-logo{text-align:center;margin-bottom:20px}.login-logo img{filter:brightness(0)saturate()invert(32%)sepia(89%)saturate(1588%)hue-rotate(175deg)brightness(91%)contrast(101%);width:180px;max-width:100%;height:auto;margin:0 auto;display:block}.login-header{text-align:center;margin-bottom:28px}.login-header h1{color:var(--text-1);margin:0 0 8px;font-size:1.75rem;font-weight:700}.login-header p{color:var(--text-2);margin:0;font-size:.9rem}.login-password-wrap{align-items:center;display:flex;position:relative}.login-password-wrap input{flex:1;padding-right:44px!important}.login-toggle-senha{cursor:pointer;color:var(--text-2);-webkit-user-select:none;-moz-user-select:none;user-select:none;background:0 0;border:none;padding:0;font-size:1.1rem;line-height:1;position:absolute;right:12px}.login-toggle-senha:hover{color:var(--text-1)}.form-group input{border:2px solid var(--border-1);background:var(--surface-0);width:100%;color:var(--text-1);-webkit-appearance:none;-moz-appearance:none;appearance:none;border-radius:8px;padding:14px 16px;font-size:1rem;transition:all .3s}.form-group input:focus{border-color:var(--brand-500);outline:none;box-shadow:0 0 0 3px #00a4e61a}.form-group input::placeholder{color:var(--text-3)}.btn-login{background:linear-gradient(135deg, var(--brand-500) 0%, var(--brand-600) 100%);color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;border-radius:8px;width:100%;margin-top:8px;padding:16px;font-size:1.05rem;font-weight:700;transition:transform .2s,box-shadow .2s}.btn-login:disabled{opacity:.65;cursor:not-allowed;transform:none}.login-error{color:#ff6b6b;background:#dc35451f;border:1px solid #dc354559;border-radius:6px;margin-bottom:4px;padding:10px 14px;font-size:.9rem}.btn-login:hover{transform:translateY(-2px);box-shadow:0 8px 20px #00a4e666}.btn-login:active{transform:translateY(0)}.login-footer{text-align:center;border-top:1px solid var(--border-1);margin-top:28px;padding-top:20px}.login-footer .support{color:var(--text-2);margin:0 0 8px;font-size:.9rem;font-weight:500}.login-footer .brand{color:var(--text-3);margin:0;font-size:.85rem;font-weight:400}.login-version{color:var(--text-3);opacity:.6;margin:6px 0 0;font-size:.75rem}:root[data-theme=dark] .login-logo img{filter:brightness(0)saturate()invert(88%)sepia(11%)saturate(716%)hue-rotate(165deg)brightness(104%)contrast(93%)}@media (min-width:768px){.login-card{padding:40px 32px}.login-logo img{width:200px}.login-header h1{font-size:2rem}}@media (max-width:360px){.login-card{padding:24px 20px}.login-logo img{width:150px}.login-header h1{font-size:1.5rem}}@media (prefers-reduced-motion:reduce){.login-page,.login-page:before,.login-page:after{animation:none}}.noc-v2{--bg0:#030a19;--bg1:#091328;--line:#33528a8c;--txt:#d8e8ff;min-height:100%;background:radial-gradient(1000px 600px at 8% -20%, #0e64ff33, transparent 55%), radial-gradient(900px 420px at 80% -10%, #06b6d42e, transparent 54%), linear-gradient(180deg, var(--bg1), var(--bg0));min-height:100dvh;color:var(--txt);grid-template-columns:minmax(0,1fr) 320px;gap:12px;padding:12px;display:grid}.noc-v2-main{border:1px solid var(--line);background:linear-gradient(#071024d1,#040916e6);border-radius:12px;flex-direction:column;gap:12px;min-width:0;padding:12px;display:flex;box-shadow:inset 0 1px #6f9aff29,0 16px 40px #00000059}.noc-v2-headline{border-bottom:1px solid #39507e73;justify-content:space-between;align-items:flex-start;gap:14px;padding-bottom:10px;display:flex}.noc-v2-headline h1{color:#edf4ff;margin:0;font-family:"Exo 2",sans-serif;font-size:1.7rem;line-height:1}.noc-v2-headline p{color:#7ea2db;margin:6px 0 0;font-family:Rajdhani,sans-serif;font-size:1rem}.noc-v2-head-tools{align-items:center;gap:12px;display:flex}.noc-v2-search{background:#070f22cc;border:1px solid #5981cb73;border-radius:10px;align-items:center;gap:8px;min-width:260px;padding:8px 10px;display:flex}.noc-v2-search span{color:#6e95ce;white-space:nowrap;font-family:Rajdhani,sans-serif;font-size:.92rem}.noc-v2-search input{color:#f8fbff;background:0 0;border:0;outline:none;width:100%;font-family:Rajdhani,sans-serif;font-size:.96rem}.noc-v2-search input::placeholder{color:#9bb4e6a6}.noc-v2-clock{flex-direction:column;align-items:flex-end;gap:2px;min-width:130px;display:flex}.noc-v2-clock strong{color:#dce9ff;font-family:"Exo 2",sans-serif;font-size:1.7rem;line-height:1}.noc-v2-clock small{color:#84a6d6;font-family:Rajdhani,sans-serif;font-size:.95rem}.noc-v2-kpis{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;margin-top:12px;display:grid}.noc-v2-kpi-range{flex-wrap:wrap;grid-column:1/-1;align-items:center;gap:6px;display:flex}.noc-v2-kpi-range-label{color:#8cafe6d1;white-space:nowrap;margin-right:2px;font-family:Rajdhani,sans-serif;font-size:.85rem}.noc-v2-kpi-range-info{color:#78a0dcb8;white-space:nowrap;margin-left:auto;font-family:Rajdhani,sans-serif;font-size:.82rem}.noc-v2-kpi-range-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;color:#d6e5ffe6;cursor:pointer;background:#081737a6;border:1px solid #78aaff73;border-radius:999px;padding:4px 10px;font-family:Rajdhani,sans-serif;font-size:.9rem;line-height:1;transition:background .2s,border-color .2s,transform .2s}.noc-v2-kpi-range-btn:hover{background:#0d234fbf;border-color:#a0cdffbf;transform:translateY(-1px)}.noc-v2-kpi-range-btn.is-active{color:#f3fbff;background:#104988b8;border-color:#8be0ffe6;box-shadow:0 0 10px #50b4ff59}.noc-v2-kpi{border:1px solid #6f9aff61;border-radius:10px;flex-direction:column;min-width:0;min-height:118px;padding:10px 12px;transition:transform .2s;display:flex;position:relative;overflow:hidden;box-shadow:inset 0 1px #ffffff29,0 8px 28px #00000057,0 0 14px #588cec33}.noc-v2-kpi:hover{transform:translateY(-2px)}.noc-v2-kpi-top span{color:#b5d0ff;font-family:Rajdhani,sans-serif;font-size:1rem}.noc-v2-kpi-top{align-items:flex-start;min-height:2.4rem;padding-right:50px;display:flex}.noc-v2-kpi-icon{color:#e2f0fff2;background:#07142e80;border:1px solid #a0c2ff6b;border-radius:8px;justify-content:center;align-items:center;width:38px;height:38px;display:inline-flex;position:absolute;top:8px;right:8px;box-shadow:inset 0 0 12px #adc9ff33,0 0 10px #6f9aff4d}.noc-v2-kpi-icon svg{filter:drop-shadow(0 0 5px #d1e7ff99);width:26px;height:26px}.noc-v2-kpi-icon img{object-fit:contain;filter:drop-shadow(0 0 5px #d1e7ff99);width:26px;height:26px}.noc-v2-kpi-icon svg *{fill:none;stroke:currentColor;stroke-width:1.8px;stroke-linecap:round;stroke-linejoin:round}.noc-v2-kpi-value{color:#f8fbff;text-shadow:0 0 8px #deecff4d;margin-top:auto;font-family:"Exo 2",sans-serif;font-size:2rem;font-weight:700;line-height:1}.noc-v2-kpi-foot{color:#dbe6ffe6;margin-top:4px;font-family:Rajdhani,sans-serif;font-size:.92rem}.noc-v2-kpi>svg{border-radius:0 0 10px 10px;width:100%;height:44px;position:absolute;top:auto;bottom:0;left:0;right:0;overflow:hidden}.noc-v2-kpi>svg polygon{stroke:none;filter:none;fill:#ffffff14}.noc-v2-kpi>svg polyline{fill:none;stroke:#ffffffe6;stroke-width:2px;stroke-linecap:round;stroke-linejoin:round;filter:drop-shadow(0 0 6px #ffffff80)}.noc-v2-kpi>svg rect{fill:#ffffff8c;filter:drop-shadow(0 0 3px #ffffff4d)}.noc-v2-kpi-cyan{background:linear-gradient(170deg,#093f7fe0,#081e4ae6);border-color:#22d3ee61;box-shadow:inset 0 1px #99f4ff3d,0 8px 28px #00000059,0 0 18px #22d3ee40}.noc-v2-kpi-violet{background:linear-gradient(170deg,#6731a8e6,#421d7aed);border-color:#e879f975;box-shadow:inset 0 1px #f4bfff38,0 8px 28px #00000059,0 0 18px #e879f93d}.noc-v2-kpi-amber{background:linear-gradient(170deg,#7c460de6,#462406eb);border-color:#fbbf246b;box-shadow:inset 0 1px #ffd89038,0 8px 28px #00000059,0 0 18px #fbbf243b}.noc-v2-kpi-green{background:linear-gradient(170deg,#096747e0,#063c2beb);border-color:#10b9816e;box-shadow:inset 0 1px #a1ffdc33,0 8px 28px #00000059,0 0 18px #10b98140}.noc-v2-kpi-red{background:linear-gradient(170deg,#77172ce0,#400817eb);border-color:#fb718570;box-shadow:inset 0 1px #ffaebf33,0 8px 28px #00000059,0 0 18px #fb718540}.noc-v2-kpi-cyan .noc-v2-kpi-icon{background:#082d5a73;border-color:#22d3ee99;box-shadow:inset 0 0 12px #22d3ee4d,0 0 12px #22d3ee73}.noc-v2-kpi-cyan>svg polygon{fill:#59ecff38}.noc-v2-kpi-violet>svg polygon{fill:#ecafff38}.noc-v2-kpi-amber>svg polygon{fill:#ffd58238}.noc-v2-kpi-green>svg polygon{fill:#87ffd338}.noc-v2-kpi-red>svg polygon{fill:#ffaabc38}.noc-v2-kpi-cyan>svg polyline{stroke:#59ecff;stroke-width:2px;filter:drop-shadow(0 0 7px #46e9ffd9)}.noc-v2-kpi-violet .noc-v2-kpi-icon{background:#56248875;border-color:#e879f9ad;box-shadow:inset 0 0 12px #e879f94d,0 0 12px #e879f96b}.noc-v2-kpi-violet>svg polyline{stroke:#f5b8ff;stroke-width:2px;filter:drop-shadow(0 0 7px #e879f9d9)}.noc-v2-kpi-amber .noc-v2-kpi-icon{background:#5c330880;border-color:#fbbf24a6;box-shadow:inset 0 0 12px #fbbf244d,0 0 12px #fbbf2473}.noc-v2-kpi-amber>svg polyline{stroke:#ffd582;stroke-width:2px;filter:drop-shadow(0 0 7px #ffc454d9)}.noc-v2-kpi-green .noc-v2-kpi-icon{background:#07473173;border-color:#10b981a6;box-shadow:inset 0 0 12px #10b9814d,0 0 12px #10b98173}.noc-v2-kpi-green>svg polyline{stroke:#87ffd3;stroke-width:2px;filter:drop-shadow(0 0 7px #52f7b9d9)}.noc-v2-kpi-red .noc-v2-kpi-icon{background:#5c14277a;border-color:#fb7185a3;box-shadow:inset 0 0 12px #fb71854d,0 0 12px #fb718570}.noc-v2-kpi-red>svg polyline{stroke:#ffaabc;stroke-width:2px;filter:drop-shadow(0 0 7px #ff819bd9)}.noc-v2-kpi-amber>svg rect{fill:#ffd582b3;filter:drop-shadow(0 0 4px #ffc45499)}.noc-v2-kpi-red>svg rect{fill:#ffaabcb3;filter:drop-shadow(0 0 4px #ff819b99)}.noc-v2-toolbar{gap:8px;margin-top:10px;display:flex}.noc-v2-pill{color:#b3cbf5;background:#081228cc;border:1px solid #567abf73;border-radius:8px;min-height:34px;padding:6px 10px;font-family:Rajdhani,sans-serif;font-size:.95rem}button.noc-v2-pill{cursor:pointer}.noc-v2-pill.is-active{color:#deebff;background:#142b54eb;border-color:#78a7f6c7}.noc-v2-pill-select-wrap{align-items:center;gap:8px;display:inline-flex}.noc-v2-pill-select-wrap span{color:#89aee0;font-size:.86rem}.noc-v2-pill-select{color:#dceaff;cursor:pointer;background:0 0;border:0;outline:none;min-width:140px;font-family:Rajdhani,sans-serif;font-size:.95rem}.noc-v2-pill-select option{color:#dceaff;background:#081226}.noc-v2-olt-list{flex-direction:column;gap:10px;max-height:calc(100vh - 300px);margin-top:10px;padding-right:4px;display:flex;overflow:auto}.noc-v2-olt-card{background:linear-gradient(165deg,#071a42cc,#040e24eb);border:1px solid #4f6fae85;border-radius:10px;grid-template-columns:245px minmax(0,1fr) auto;grid-template-areas:"summary panel toggle";align-items:start;gap:10px;padding:10px;transition:border-color .2s;display:grid;position:relative}.noc-v2-olt-card:hover{border-color:#6f96dcb3}.noc-v2-olt-summary{flex-direction:column;grid-area:summary;gap:8px;padding-right:20px;display:flex}.noc-v2-pon-panel{grid-area:panel}.noc-v2-olt-head-row{align-items:flex-start;gap:8px;display:flex}.noc-v2-olt-title-row{min-width:0}.noc-v2-olt-title-row.is-expanded{display:block}.noc-v2-olt-title-row.is-collapsed{align-items:center;gap:8px;display:flex}.noc-v2-olt-title-row.is-collapsed h3{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.noc-v2-olt-title-row.is-collapsed .noc-v2-state{flex-shrink:0;margin-top:0}.noc-v2-health-dot{background:currentColor;border-radius:999px;flex-shrink:0;width:10px;min-width:10px;height:10px;min-height:10px;margin-top:4px;display:flex;box-shadow:0 0 8px}.noc-v2-health-dot.is-online{color:#00d084}.noc-v2-health-dot.is-offline{color:#ff5c6a}.noc-v2-health-dot.is-unknown{color:#fbbf24}.noc-v2-olt-summary h3{color:#eaf2ff;margin:0;font-family:"Exo 2",sans-serif;font-size:1.12rem}.noc-v2-state{letter-spacing:.03em;border-radius:6px;margin-top:4px;padding:3px 8px;font-family:Rajdhani,sans-serif;font-size:.84rem;display:inline-block}.noc-v2-state.is-online{color:#66ffc6;background:#00d08426;border:1px solid #00d08466}.noc-v2-state.is-offline{color:#ff8a9c;background:#ff5c6a24;border:1px solid #ff5c6a61}.noc-v2-state.is-unknown{color:#ffd486;background:#fbbf2429;border:1px solid #fbbf2466}.noc-v2-olt-summary dl{grid-template-columns:repeat(3,minmax(0,1fr));gap:6px;display:flex}.noc-v2-olt-summary dt{color:#82a8de;font-family:Rajdhani,sans-serif;font-size:.8rem}.noc-v2-olt-summary dd{color:#f4f8ff;margin:0;font-family:"Exo 2",sans-serif;font-size:1rem}.noc-v2-olt-stats>div{background:#0816329e;border:1px solid #5278bd59;border-radius:8px;padding:5px 8px}.noc-v2-toggle-pons-btn{z-index:2;color:#d8ebff;cursor:pointer;background:linear-gradient(#112f5df0,#081834e6);border:1px solid #4469aaad;border-radius:9px;grid-area:toggle;justify-content:center;place-self:start end;align-items:center;width:34px;height:34px;transition:transform .22s,background .2s,box-shadow .2s;display:inline-flex;position:relative}.noc-v2-toggle-pons-btn:hover{background:linear-gradient(#114ca4f5,#01112beb)}.noc-v2-toggle-pons-btn svg{width:17px;height:17px;transition:transform .26s cubic-bezier(.4,0,.2,1)}.noc-v2-toggle-pons-btn svg path{fill:none;stroke:currentColor;stroke-width:2.2px;stroke-linecap:round;stroke-linejoin:round}.noc-v2-toggle-pons-btn.is-collapsed svg{transform:rotate(180deg)}.noc-v2-toggle-pons-btn.is-expanded svg{transform:rotate(0)}.noc-v2-olt-card.is-expanded{grid-template-columns:245px minmax(0,1fr) auto;grid-template-areas:"summary panel toggle";align-items:start}.noc-v2-olt-card.is-expanded .noc-v2-olt-summary{flex-direction:column;gap:8px}.noc-v2-olt-card.is-expanded .noc-v2-pon-panel{display:block}.noc-v2-olt-card.is-collapsed{--collapsed-stats-col:clamp(240px, 26vw, 300px);--collapsed-state-col:clamp(84px, 9vw, 92px);--collapsed-card-pad-y:6px;padding:var(--collapsed-card-pad-y) 10px;grid-template-columns:1fr auto;grid-template-areas:"summary toggle";align-items:center}.noc-v2-olt-card.is-collapsed .noc-v2-toggle-pons-btn{align-self:center}.noc-v2-olt-card.is-collapsed .noc-v2-olt-summary{flex-wrap:nowrap;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:6px;padding-right:0;display:grid}.noc-v2-olt-card.is-collapsed .noc-v2-olt-stats{grid-template-columns:54px 68px 100px;justify-self:end;align-items:center;gap:4px;display:grid}.noc-v2-olt-card.is-collapsed .noc-v2-olt-head-row{grid-template-columns:10px minmax(0, 1fr) var(--collapsed-state-col);align-items:center;column-gap:6px;min-width:0;display:grid;overflow:visible}.noc-v2-olt-card.is-collapsed .noc-v2-olt-title-row.is-collapsed{display:contents}.noc-v2-olt-card.is-collapsed .noc-v2-olt-title-row.is-collapsed .noc-v2-state{width:var(--collapsed-state-col);text-align:center;grid-column:3;justify-self:end}.noc-v2-olt-card.is-collapsed .noc-v2-olt-title-row.is-collapsed h3{grid-column:2;min-width:0}.noc-v2-olt-card.is-collapsed .noc-v2-olt-head-row>div:last-child{min-width:0;overflow:hidden}.noc-v2-olt-card.is-collapsed .noc-v2-olt-head-row h3{white-space:nowrap;text-overflow:ellipsis;font-size:.95rem;overflow:hidden}.noc-v2-olt-card.is-collapsed .noc-v2-state{white-space:nowrap;white-space:nowrap;order:1;margin-top:0;padding:1px 6px;font-size:.72rem}.noc-v2-olt-card.is-collapsed .noc-v2-olt-stats>div{white-space:nowrap;justify-content:center;align-items:center;gap:4px;padding:2px 6px;display:flex;overflow:hidden}.noc-v2-olt-card.is-collapsed .noc-v2-olt-stats dt{color:#6b92c6;font-size:.68rem}.noc-v2-olt-card.is-collapsed .noc-v2-olt-stats dd{white-space:nowrap;font-size:.84rem}.noc-v2-olt-card.is-collapsed .noc-v2-pon-panel{display:none}.noc-v2-pon-grid{grid-template-columns:repeat(auto-fill,minmax(92px,92px));grid-auto-rows:52px;place-content:start;align-self:start;align-items:start;gap:8px;height:-webkit-fit-content;height:-moz-fit-content;height:fit-content;display:grid}.noc-v2-pon-empty{color:#8fb1e0;background:#0814308c;border:1px dashed #7095d86b;border-radius:8px;grid-column:1/-1;justify-content:center;align-items:center;min-height:52px;font-family:Rajdhani,sans-serif;font-size:.9rem;display:flex}.noc-v2-pon-chip{text-align:center;border:1px solid #4f72b37a;border-radius:8px;flex-direction:column;justify-content:center;align-self:start;align-items:center;gap:1px;height:52px;min-height:52px;max-height:52px;padding:2px 8px;transition:transform .16s,box-shadow .16s;display:flex}.noc-v2-pon-chip:hover{transform:translateY(-1px)}.noc-v2-pon-chip-dot{border-radius:999px;flex-shrink:0;width:7px;min-width:7px;height:7px;min-height:7px;margin-bottom:1px;display:block;box-shadow:0 0 6px}.noc-v2-pon-chip-dot.is-ok{color:#66ffc6;background:#66ffc6}.noc-v2-pon-chip-dot.is-warn{color:#ffd486;background:#ffd486}.noc-v2-pon-chip-dot.is-down{color:#ff9caa;background:#ff9caa}.noc-v2-pon-chip b{color:#e6f0ff;white-space:nowrap;text-overflow:ellipsis;font-family:"Exo 2",sans-serif;font-size:.79rem;line-height:1.05;overflow:hidden}.noc-v2-pon-chip span{font-family:Rajdhani,sans-serif;font-size:.8rem}.noc-v2-pon-chip.is-ok{background:#00d0841f;border-color:#00d0847a}.noc-v2-pon-chip.is-ok span{color:#66ffc6}.noc-v2-pon-chip.is-warn{background:#fbbf241f;border-color:#fbbf2473}.noc-v2-pon-chip.is-warn span{color:#ffd486}.noc-v2-pon-chip.is-down{background:#ff5c6a21;border-color:#ff5c6a75}.noc-v2-pon-chip.is-down span{color:#ff9caa}.noc-v2-pon-summary{grid-template-columns:repeat(3,minmax(0,1fr));align-content:start;gap:6px;display:grid}.noc-v2-pon-summary-item{text-align:center;border:1px solid #5072b280;border-radius:8px;justify-content:center;align-items:center;gap:1px;min-height:44px;padding:6px;display:flex}.noc-v2-pon-summary-item i{border-radius:999px;width:6px;height:6px;box-shadow:0 0 6px}.noc-v2-pon-summary-item b{color:#b7d0f4;letter-spacing:.05em;font-family:Rajdhani,sans-serif;font-size:.7rem;font-weight:700;line-height:1}.noc-v2-pon-summary-item span{color:#e9f3ff;font-family:"Exo 2",sans-serif;font-size:1rem;line-height:1}.noc-v2-pon-summary-item.is-ok{background:#00d0841f;border-color:#00d08470}.noc-v2-pon-summary-item.is-ok span{color:#74ffd0}.noc-v2-pon-summary-item.is-ok i{color:#74ffd0;background:#74ffd0}.noc-v2-pon-summary-item.is-warn{background:#fbbf241f;border-color:#fbbf2473}.noc-v2-pon-summary-item.is-warn span{color:#ffd28d}.noc-v2-pon-summary-item.is-warn i{color:#ffd28d;background:#ffd28d}.noc-v2-pon-summary-item.is-down{background:#ff5c6a1f;border-color:#ff5c6a75}.noc-v2-pon-summary-item.is-down span{color:#ff9dac}.noc-v2-pon-summary-item.is-down i{color:#ff9dac;background:#ff9dac}.auth-layout.sidebar-collapsed .noc-v2-pon-grid{grid-auto-rows:52px!important;align-content:start!important;align-self:start!important;align-items:start!important;height:-webkit-fit-content!important;height:-moz-fit-content!important;height:fit-content!important}.auth-layout.sidebar-collapsed .noc-v2-pon-chip{align-self:start!important;height:52px!important;min-height:52px!important;max-height:52px!important}.noc-v2-alerts{background:linear-gradient(#091126eb,#060b17f0);border:1px solid #5d83cb80;border-radius:12px;flex-direction:column;min-height:100%;padding:10px;display:flex;box-shadow:inset 0 1px #8baaea24,0 14px 30px #00000057}.noc-v2-alerts-head{flex-direction:column;align-items:stretch;gap:8px;margin-bottom:8px;display:flex}.noc-v2-alerts-head-main{justify-content:space-between;align-items:center;gap:8px;display:flex}.noc-v2-alerts-bell{color:#bed2ffd9;filter:drop-shadow(0 0 5px #78aaff80);flex-shrink:0}.noc-v2-alerts-head h2{color:#eef5ff;flex:1;margin:0;font-family:"Exo 2",sans-serif;font-size:1.08rem}.noc-v2-alerts-head-main span{color:#ff9fac;background:#7e14233d;border:1px solid #ff5d6ca6;border-radius:999px;justify-content:center;align-items:center;min-width:26px;height:24px;font-family:"Exo 2",sans-serif;display:inline-flex}.noc-v2-alerts-mute-btn{color:#deebff8c;cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;padding:0;transition:all .2s;display:flex}.noc-v2-alerts-mute-btn:hover{color:#deebffd9;background:#6496ff1a}.noc-v2-alerts-mute-btn.is-muted{color:#ffa064b3}.noc-v2-alerts-mute-btn.is-muted:hover{color:#ffb478e6;background:#ffa06426}.noc-v2-alerts-mute-btn svg{width:18px;height:18px;overflow:visible}.noc-v2-alerts ul{flex-direction:column;flex:1;gap:8px;margin:0;padding:0 4px 0 0;list-style:none;display:flex;overflow:auto}.noc-v2-alert{background:#0b142acc;border:1px solid #617bb573;border-radius:9px;flex-direction:column;gap:6px;padding:9px 10px;display:flex}.noc-v2-alert-top{align-items:center;gap:6px;display:flex}.noc-v2-alert-badge{letter-spacing:.06em;color:#90afdf;background:#1e376e59;border:1px solid #617bb566;border-radius:4px;padding:1px 5px;font-family:"Exo 2",sans-serif;font-size:.68rem;font-weight:700}.noc-v2-alert.is-critico .noc-v2-alert-badge{color:#ff9dab;background:#640a1966;border-color:#ff5c6a8c}.noc-v2-alert.is-atencao .noc-v2-alert-badge{color:#ffd088;background:#64370566;border-color:#f59e0b8c}@keyframes noc-bell-pulse{0%,to{opacity:.7;transform:scale(1)}50%{opacity:1;transform:scale(1.18)}}@keyframes noc-bell-pulse-critico{0%,to{opacity:.72;filter:drop-shadow(0 0 3px #ff506480);transform:scale(1)}50%{opacity:1;filter:drop-shadow(0 0 10px #ff5064f2)drop-shadow(0 0 20px #ff506480);transform:scale(1.18)}}@keyframes noc-bell-pulse-atencao{0%,to{opacity:.72;filter:drop-shadow(0 0 3px #f59e0b80);transform:scale(1)}50%{opacity:1;filter:drop-shadow(0 0 10px #f59e0bf2)drop-shadow(0 0 20px #f59e0b80);transform:scale(1.18)}}.noc-v2-alert-bell{color:#90afdfb3;flex-shrink:0;animation:2.5s ease-in-out infinite noc-bell-pulse}.noc-v2-alert.is-critico .noc-v2-alert-bell{color:#ff5c6ae6;animation:2.5s ease-in-out infinite noc-bell-pulse-critico}.noc-v2-alert.is-atencao .noc-v2-alert-bell{color:#fbab34e6;animation:2.5s ease-in-out infinite noc-bell-pulse-atencao}.noc-v2-alert-time{color:#90afdf99;margin-left:auto;font-family:Rajdhani,sans-serif;font-size:.75rem}.noc-v2-alert-title{color:#f0f6ff;margin:0;font-family:"Exo 2",sans-serif;font-size:.92rem;font-weight:600;line-height:1.3}.noc-v2-alert-meta{background:#ffffff08;border:1px solid #506eaa33;border-radius:6px;flex-direction:column;gap:2px;margin:0;padding:6px 8px;display:flex}.noc-v2-alert-meta>div{align-items:baseline;gap:5px;min-width:0;display:flex}.noc-v2-alert-meta dt{color:#90afdf99;text-transform:uppercase;letter-spacing:.04em;flex-shrink:0;min-width:46px;font-family:Rajdhani,sans-serif;font-size:.68rem;font-weight:600}.noc-v2-alert-meta dd{color:#cfe0ff;white-space:normal;word-break:break-word;min-width:0;margin:0;font-family:Rajdhani,sans-serif;font-size:.82rem}.noc-v2-alert-serial{letter-spacing:.02em;white-space:normal;word-break:break-all;text-overflow:unset;overflow:visible;color:#b4d2ffbf!important;font-family:"Exo 2",monospace!important;font-size:.76rem!important}.noc-v2-alert-foot{justify-content:space-between;align-items:center;gap:6px;margin-top:2px;display:flex}.noc-v2-alert-ratio{color:#90afdf;font-family:"Exo 2",sans-serif;font-size:.82rem}.noc-v2-alert.is-critico .noc-v2-alert-ratio{color:#ff9dab}.noc-v2-alert.is-atencao .noc-v2-alert-ratio{color:#ffd088}.noc-v2-alert-link{color:#d5e6ff;white-space:nowrap;background:#132c5899;border:1px solid #6696e273;border-radius:6px;padding:2px 8px;font-family:Rajdhani,sans-serif;font-size:.8rem;text-decoration:none;transition:background .15s,border-color .15s}.noc-v2-alert-link:hover{background:#1b3c74e6;border-color:#8fb3efd1}.noc-v2-alert.is-critico{background:linear-gradient(160deg,#500d1c59,#140b22d6);border-color:#ff5c6a8c}.noc-v2-alert.is-critico .noc-v2-alert-meta{background:#500a1440;border-color:#ff5c6a2e}.noc-v2-alert.is-atencao{background:linear-gradient(160deg,#5b2e0757,#160d1fdb);border-color:#f59e0b94}.noc-v2-alert.is-atencao .noc-v2-alert-meta{background:#502d0540;border-color:#f59e0b2e}.noc-v2-alerts-btn{color:#b9d2fb;cursor:pointer;background:#0a1936e6;border:1px solid #5176bc99;border-radius:8px;margin-top:8px;padding:8px 10px;font-family:Rajdhani,sans-serif;font-size:.95rem;transition:background .18s,border-color .18s}.noc-v2-alerts-btn:hover{background:#0f2246f2;border-color:#789cddc7}@media (max-width:1360px){.noc-v2{grid-template-columns:minmax(0,1fr)}.noc-v2-alerts{min-height:auto}.noc-v2-alerts ul{max-height:300px}}@media (max-width:1024px){.noc-v2-headline{flex-direction:column}.noc-v2-head-tools{justify-content:space-between;width:100%}.noc-v2-search{width:100%;max-width:360px;min-width:unset}.noc-v2-olt-card{grid-template-columns:1fr auto;grid-template-areas:"summary toggle""panel panel"}.noc-v2-olt-list{max-height:none}}@media (max-width:640px){.noc-v2{grid-template-columns:1fr;gap:8px;padding:8px}.noc-v2-main{padding:10px}.noc-v2-headline h1{font-size:1.25rem}.noc-v2-headline p{font-size:.9rem}.noc-v2-head-tools{flex-direction:column;align-items:stretch;gap:8px}.noc-v2-search{width:100%;max-width:none;min-width:unset}.noc-v2-clock{flex-direction:row;justify-content:space-between;align-items:center;width:100%}.noc-v2-clock strong{font-size:1.35rem}.noc-v2-kpis{gap:8px}.noc-v2-kpi-range{gap:5px}.noc-v2-kpi-range-btn{padding:3px 8px;font-size:.82rem}.noc-v2-kpi{min-height:80px;padding:8px 10px 22px}.noc-v2-kpi-value{font-size:1.45rem}.noc-v2-toolbar{flex-wrap:wrap}.noc-v2-olt-card{padding:8px}.noc-v2-olt-card.is-collapsed{--collapsed-stats-col:100%;--collapsed-state-col:clamp(80px, 24vw, 92px);--collapsed-card-pad-y:5px}.noc-v2-olt-card.is-collapsed .noc-v2-olt-summary{grid-template-columns:minmax(0,1fr);row-gap:6px}.noc-v2-olt-card.is-collapsed .noc-v2-olt-stats{justify-self:stretch;width:100%}.noc-v2-olt-card.is-collapsed .noc-v2-olt-head-row{column-gap:6px}.noc-v2-olt-summary dl{grid-template-columns:repeat(2,minmax(0,1fr))}.noc-v2-pon-grid{grid-template-columns:repeat(3,minmax(0,1fr));grid-auto-rows:44px;align-content:start}.noc-v2-pon-chip{height:44px;min-height:44px;padding:5px 6px}.noc-v2-alerts{min-height:auto}.noc-v2-alerts ul{max-height:none}}@media (max-width:400px){.noc-v2-pon-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.noc-v2-headline h1{font-size:1.1rem}}:root[data-theme=light] .noc-v2{--bg0:#edf3fc;--bg1:#dceaf8;--line:#648cc859;--txt:#1a2a4a;background:radial-gradient(1000px 600px at 8% -20%, #0e64ff14, transparent 55%), radial-gradient(900px 420px at 80% -10%, #06b6d412, transparent 54%), linear-gradient(180deg, var(--bg1), var(--bg0))}:root[data-theme=light] .noc-v2-main{background:linear-gradient(#ffffffe0,#f0f8fff2);border-color:#6496dc4d;box-shadow:inset 0 1px #6f9aff1a,0 8px 24px #00000014}:root[data-theme=light] .noc-v2-headline{border-bottom-color:#648cc84d}:root[data-theme=light] .noc-v2-headline h1{color:#0f1f3a}:root[data-theme=light] .noc-v2-headline p{color:#3a5a8a}:root[data-theme=light] .noc-v2-search{background:#ffffffd9;border-color:#5082d266}:root[data-theme=light] .noc-v2-search span{color:#3a6090}:root[data-theme=light] .noc-v2-search input{color:#0f1f3a}:root[data-theme=light] .noc-v2-search input::placeholder{color:#3c64a080}:root[data-theme=light] .noc-v2-clock strong{color:#0f1f3a}:root[data-theme=light] .noc-v2-clock small{color:#3a6090}:root[data-theme=light] .noc-v2-kpi-range-label{color:#28508cd9}:root[data-theme=light] .noc-v2-kpi-range-info{color:#325a96bf}:root[data-theme=light] .noc-v2-kpi-range-btn{color:#1a3a6a;background:#f0f8ffd9;border-color:#5082c873}:root[data-theme=light] .noc-v2-kpi-range-btn:hover{background:#dceeffe6;border-color:#3c78c8b3}:root[data-theme=light] .noc-v2-kpi-range-btn.is-active{color:#002a6a;background:#d2e8fff2;border-color:#0064c8b3;box-shadow:0 0 8px #0078ff33}:root[data-theme=light] .noc-v2-kpi{box-shadow:inset 0 1px #fffc,0 4px 16px #00000014}:root[data-theme=light] .noc-v2-kpi-top span{color:#2a4a8a}:root[data-theme=light] .noc-v2-kpi-value{color:#0a1a3a;text-shadow:none}:root[data-theme=light] .noc-v2-kpi-foot{color:#14326ed9}:root[data-theme=light] .noc-v2-kpi-icon{color:#1e46a0f2;background:#dceeff99;border-color:#508ce659;box-shadow:inset 0 0 10px #50a0ff1f,0 0 8px #3c82e62e}:root[data-theme=light] .noc-v2-kpi-cyan .noc-v2-kpi-icon{color:#00a8d2f7;background:#d2f6ffbf;border-color:#00c0e894;box-shadow:inset 0 0 12px #00d2f538,0 0 12px #00c3e859}:root[data-theme=light] .noc-v2-kpi-violet .noc-v2-kpi-icon{color:#a43fc9f7;background:#fbeaffc7;border-color:#bd54e394;box-shadow:inset 0 0 12px #d67bf43d,0 0 12px #c158e359}:root[data-theme=light] .noc-v2-kpi-amber .noc-v2-kpi-icon{color:#ac7000f7;background:#fff4d2bf;border-color:#cd8c0094;box-shadow:inset 0 0 12px #e69e0038,0 0 12px #cd8a0059}:root[data-theme=light] .noc-v2-kpi-green .noc-v2-kpi-icon{color:#008e5af7;background:#d2ffecbf;border-color:#00aa6c94;box-shadow:inset 0 0 12px #00be7838,0 0 12px #00a56459}:root[data-theme=light] .noc-v2-kpi-red .noc-v2-kpi-icon{color:#c62c48f7;background:#ffe4eabf;border-color:#dc3a5894;box-shadow:inset 0 0 12px #eb466438,0 0 12px #d2325059}:root[data-theme=light] .noc-v2-kpi-cyan{background:linear-gradient(170deg,#d2f4fff7,#beecffed);border-color:#00bee68c;box-shadow:inset 0 1px #00dcff38,0 4px 16px #00000012,0 0 18px #00bee62e}:root[data-theme=light] .noc-v2-kpi-violet{background:linear-gradient(170deg,#f9e4fff7,#f2d2fded);border-color:#b954e38c;box-shadow:inset 0 1px #efb4ff3d,0 4px 16px #00000012,0 0 18px #b954e32e}:root[data-theme=light] .noc-v2-kpi-amber{background:linear-gradient(170deg,#fff6daf7,#ffedc0ed);border-color:#d294008c;box-shadow:inset 0 1px #ffdc5038,0 4px 16px #00000012,0 0 18px #d294002e}:root[data-theme=light] .noc-v2-kpi-green{background:linear-gradient(170deg,#d2ffeef7,#bef8deed);border-color:#00ac6e8c;box-shadow:inset 0 1px #50ffbe38,0 4px 16px #00000012,0 0 18px #00ac6e2e}:root[data-theme=light] .noc-v2-kpi-red{background:linear-gradient(170deg,#ffe4e8f7,#ffd2daed);border-color:#dc37558c;box-shadow:inset 0 1px #ff96aa38,0 4px 16px #00000012,0 0 18px #dc37552e}:root[data-theme=light] .noc-v2-kpi>svg polygon{fill:#0000000f}:root[data-theme=light] .noc-v2-kpi>svg polyline{stroke:#1e50b4cc;filter:drop-shadow(0 0 4px #1e50b466)}:root[data-theme=light] .noc-v2-kpi>svg rect{fill:#1e50b480}:root[data-theme=light] .noc-v2-kpi-cyan>svg polyline{stroke:#00a0c8e6;filter:drop-shadow(0 0 4px #00b4dc66)}:root[data-theme=light] .noc-v2-kpi-violet>svg polyline{stroke:#ac43d2eb;filter:drop-shadow(0 0 4px #ba53e36b)}:root[data-theme=light] .noc-v2-kpi-amber>svg polyline{stroke:#b46e00e6;filter:drop-shadow(0 0 4px #c8820066)}:root[data-theme=light] .noc-v2-kpi-green>svg polyline{stroke:#008c5ae6;filter:drop-shadow(0 0 4px #00a06466)}:root[data-theme=light] .noc-v2-kpi-red>svg polyline{stroke:#c82846e6;filter:drop-shadow(0 0 4px #dc3c5a66)}:root[data-theme=light] .noc-v2-kpi-amber>svg rect{fill:#b46e0099;filter:drop-shadow(0 0 3px #c8820066)}:root[data-theme=light] .noc-v2-kpi-red>svg rect{fill:#c8284699;filter:drop-shadow(0 0 3px #dc3c5a66)}:root[data-theme=light] .noc-v2-pill{color:#1a3a6a;background:#f0f8ffd9;border-color:#5082c866}:root[data-theme=light] .noc-v2-pill.is-active{color:#002a6a;background:#d2e8ffe6;border-color:#0064c899}:root[data-theme=light] .noc-v2-pill-select-wrap span{color:#2a5080}:root[data-theme=light] .noc-v2-pill-select{color:#0a1a3a}:root[data-theme=light] .noc-v2-pill-select option{color:#0a1a3a;background:#e8f0fb}:root[data-theme=light] .noc-v2-olt-card{background:linear-gradient(165deg,#f0f8fff2,#e1f0ffeb);border-color:#5a8cd266}:root[data-theme=light] .noc-v2-olt-card:hover{border-color:#3278d2a6}:root[data-theme=light] .noc-v2-olt-summary h3{color:#0f1f3a}:root[data-theme=light] .noc-v2-olt-summary dt{color:#3a6090}:root[data-theme=light] .noc-v2-olt-summary dd{color:#0f1f3a}:root[data-theme=light] .noc-v2-olt-stats>div{background:#c8e1ff99;border-color:#5a8cd24d}:root[data-theme=light] .noc-v2-olt-card.is-collapsed .noc-v2-olt-stats dt{color:#3a6090}:root[data-theme=light] .noc-v2-toggle-pons-btn{color:#0f2860;background:linear-gradient(#dceefff2,#c8e4ffe6);border-color:#508cdc8c}:root[data-theme=light] .noc-v2-toggle-pons-btn:hover{background:linear-gradient(#c8e4fffa,#b4d7ffeb)}:root[data-theme=light] .noc-v2-pon-empty{color:#3a6090;background:#d2e6ff80;border-color:#5a8cd266}:root[data-theme=light] .noc-v2-state.is-online{color:#0a6630;background:#00b4641a;border-color:#00b46459}:root[data-theme=light] .noc-v2-state.is-offline{color:#a01020;background:#dc283c14;border-color:#dc283c4d}:root[data-theme=light] .noc-v2-state.is-unknown{color:#7a5000;background:#c896001a;border-color:#c8960059}:root[data-theme=light] .noc-v2-kpi-icon svg{filter:drop-shadow(0 0 4px #1e50c859)}:root[data-theme=light] .noc-v2-kpi-cyan .noc-v2-kpi-icon svg{filter:drop-shadow(0 0 5px #00c3e880)}:root[data-theme=light] .noc-v2-kpi-violet .noc-v2-kpi-icon svg{filter:drop-shadow(0 0 5px #ba53e380)}:root[data-theme=light] .noc-v2-kpi-amber .noc-v2-kpi-icon svg{filter:drop-shadow(0 0 5px #c8870080)}:root[data-theme=light] .noc-v2-kpi-green .noc-v2-kpi-icon svg{filter:drop-shadow(0 0 5px #00a86480)}:root[data-theme=light] .noc-v2-kpi-red .noc-v2-kpi-icon svg{filter:drop-shadow(0 0 5px #d2325080)}:root[data-theme=light] .noc-v2-alerts{background:linear-gradient(#ffffffe6,#f0f8fff2);border-color:#5a8cd259;box-shadow:inset 0 1px #fffc,0 8px 20px #00000012}:root[data-theme=light] .noc-v2-alerts-bell{color:#1e50a0e6;filter:drop-shadow(0 0 3px #326ed259)}:root[data-theme=light] .noc-v2-alert-bell{color:#5078b4b3}:root[data-theme=light] .noc-v2-alert.is-critico .noc-v2-alert-bell{color:#c8283ce6;filter:drop-shadow(0 0 3px #c8283c80)}:root[data-theme=light] .noc-v2-alert.is-atencao .noc-v2-alert-bell{color:#b46e00e6;filter:drop-shadow(0 0 3px #b46e0080)}:root[data-theme=light] .noc-v2-alerts-head h2{color:#0f1f3a}:root[data-theme=light] .noc-v2-alerts-head-main span{color:#b00020;background:#c81e3214;border-color:#c81e3266}:root[data-theme=light] .noc-v2-alerts-mute-btn{color:#1e3c788c}:root[data-theme=light] .noc-v2-alerts-mute-btn:hover{color:#1e3c78d9;background:#3c6ec814}:root[data-theme=light] .noc-v2-alerts-mute-btn.is-muted{color:#b46414b3}:root[data-theme=light] .noc-v2-alert{background:#f0f8ffd9;border-color:#5a8cd259}:root[data-theme=light] .noc-v2-alert-time{color:#5a7aa0}:root[data-theme=light] .noc-v2-alert-badge{color:#3a5a8a;background:#d2e8ff80;border-color:#5082c866}:root[data-theme=light] .noc-v2-alert-title{color:#0a1a3a}:root[data-theme=light] .noc-v2-alert-meta{background:#d2e8ff4d;border-color:#5a8cd233}:root[data-theme=light] .noc-v2-alert-meta dt{color:#5a7aa0}:root[data-theme=light] .noc-v2-alert-meta dd{color:#0f2040}:root[data-theme=light] .noc-v2-alert-serial{color:#1e3c6eb3!important}:root[data-theme=light] .noc-v2-alert-ratio{color:#3a5a8a}:root[data-theme=light] .noc-v2-alert-link{color:#1a3a6a;background:#d2e8ffb3;border-color:#5082d273}:root[data-theme=light] .noc-v2-alert-link:hover{background:#bedcffe6;border-color:#326ec8b3}:root[data-theme=light] .noc-v2-alert.is-critico{background:linear-gradient(160deg,#ffe1e6e6,#fff0f2f2);border-color:#c8283c73}:root[data-theme=light] .noc-v2-alert.is-critico .noc-v2-alert-badge{color:#900020;background:#ffc8d280;border-color:#c8283c80}:root[data-theme=light] .noc-v2-alert.is-critico .noc-v2-alert-meta{background:#ffd2da33;border-color:#c8283c33}:root[data-theme=light] .noc-v2-alert.is-critico .noc-v2-alert-ratio{color:#a0001a}:root[data-theme=light] .noc-v2-alert.is-atencao{background:linear-gradient(160deg,#fff8dce6,#fffcebf2);border-color:#b4780073}:root[data-theme=light] .noc-v2-alert.is-atencao .noc-v2-alert-badge{color:#7a4a00;background:#ffebaa80;border-color:#b4780080}:root[data-theme=light] .noc-v2-alert.is-atencao .noc-v2-alert-meta{background:#ffebb433;border-color:#b4780033}:root[data-theme=light] .noc-v2-alert.is-atencao .noc-v2-alert-ratio{color:#7a4a00}:root[data-theme=light] .noc-v2-alerts-btn{color:#1a3a6a;background:#e6f2ffe6;border-color:#5082c873}:root[data-theme=light] .noc-v2-alerts-btn:hover{background:#d2e8fff2;border-color:#326ec8a6}:root[data-theme=light] .noc-v2-pon-chip{background:#dceeffcc;border-color:#5a8cd266}:root[data-theme=light] .noc-v2-pon-chip b{color:#0a1a3a}:root[data-theme=light] .noc-v2-pon-chip-dot.is-ok{color:#00a864;background:#00a864}:root[data-theme=light] .noc-v2-pon-chip-dot.is-warn{color:#b87800;background:#b87800}:root[data-theme=light] .noc-v2-pon-chip-dot.is-down{color:#cc2030;background:#cc2030}:root[data-theme=light] .noc-v2-pon-chip.is-ok{background:#00a86414;border-color:#00a86459}:root[data-theme=light] .noc-v2-pon-chip.is-warn{background:#b4780014;border-color:#b4780059}:root[data-theme=light] .noc-v2-pon-chip.is-down{background:#c8203014;border-color:#c8203059}:root[data-theme=light] .noc-v2-pon-chip.is-ok span{color:#006a40}:root[data-theme=light] .noc-v2-pon-chip.is-warn span{color:#7a5000}:root[data-theme=light] .noc-v2-pon-chip.is-down span{color:#a01020}.olts-page{background-color:#0d1117;background-image:radial-gradient(circle at 20% 20%,#00a4e612 0%,#0000 50%),radial-gradient(circle at 80% 80%,#0077b60f 0%,#0000 50%),linear-gradient(#00a4e609 1px,#0000 1px),linear-gradient(90deg,#00a4e609 1px,#0000 1px);background-position:0 0;background-repeat:repeat;background-size:auto,auto,44px 44px,44px 44px;background-attachment:scroll;background-origin:padding-box;background-clip:border-box;min-height:100vh;padding:16px 0 32px}.olts-container{max-width:1440px;margin:0 auto;padding:0 16px}.olts-page-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.olts-page-header-text h1{color:#e6f0f8;letter-spacing:-.3px;margin:0;font-size:1.5rem;font-weight:800;line-height:1.2}.olts-page-header-text p{color:#4a6070;margin:4px 0 0;font-size:.8rem}.olts-grid{grid-template-columns:1fr;gap:14px;display:grid}.olts-empty-state{color:#c8d9e6;background:#ffffff08;border:1px solid #00a4e633;border-radius:12px;grid-column:1/-1;justify-content:space-between;align-items:center;gap:12px;padding:18px;display:flex}.olts-empty-state p{margin:0;font-size:.92rem}.olt-card{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);-webkit-tap-highlight-color:transparent;background:#ffffff08;border:1px solid #00a4e626;border-radius:14px;flex-direction:column;align-items:flex-start;gap:10px;min-height:294px;padding:20px 18px;transition:transform .2s,box-shadow .2s,border-color .2s;display:flex;position:relative;overflow:hidden}.olt-card-accent{background:linear-gradient(90deg,#0000,#00a4e699,#0000);border-radius:16px 16px 0 0;height:3px;position:absolute;top:0;left:0;right:0}.olt-card.olt-avail-up .olt-card-accent,.olt-card.olt-avail-warn .olt-card-accent,.olt-card.olt-avail-down .olt-card-accent{background:linear-gradient(90deg,#0000,#00a4e6,#0000)}.olt-card:active{transform:scale(.985)}.olt-card-header{align-items:flex-start;gap:12px;padding-right:52px;display:flex}.olt-icon{color:#00a4e6;background:linear-gradient(135deg,#00a4e633 0%,#0077b62e 100%);border:1px solid #00a4e647;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;min-width:40px;height:40px;display:flex}.olt-title-block{flex-direction:column;flex:1;gap:3px;min-width:0;min-height:52px;display:flex}.olt-card h3{color:#e6f0f8;word-break:break-word;margin:0;font-size:.9rem;font-weight:700;line-height:1.35}.olt-alias{color:#4a6070;margin:0;font-size:.72rem;font-style:italic}.olt-alias.is-empty{visibility:hidden;height:.9rem}.olt-fabricante-badge{position:absolute;top:14px;right:14px}.olt-meta-row{flex-direction:column;align-items:flex-start;gap:6px;width:100%;display:flex}.olt-ip{color:#4a8fa8;background:#00a4e612;border:1px solid #00a4e621;border-radius:6px;margin:0;padding:4px 9px;font-family:Courier New,monospace;font-size:.8rem;font-weight:500}.olt-ip-empty{opacity:0;pointer-events:none}.snmp-badge{letter-spacing:.5px;white-space:nowrap;border-radius:999px;flex-shrink:0;align-items:center;gap:5px;padding:4px 10px;font-size:.68rem;font-weight:700;display:inline-flex}.snmp-badge:before{content:"";border-radius:50%;flex-shrink:0;width:6px;height:6px;display:inline-block}.snmp-badge-online{background:var(--status-online-bg);color:var(--status-online);border:1px solid #00e66440}.snmp-badge-online:before{background:var(--status-online);animation:2s infinite pulse-dot;box-shadow:0 0 6px}.snmp-badge-offline{background:var(--status-offline-bg);color:var(--status-offline);border:1px solid #ff3c3c40}.snmp-badge-offline:before{background:var(--status-offline)}.snmp-badge-unknown{background:var(--status-unknown-bg);color:var(--status-unknown);border:1px solid #64788c33}.snmp-badge-unknown:before{background:var(--status-unknown)}.olt-color-metrics{grid-template-columns:repeat(4,1fr);gap:6px;width:100%;margin-top:auto;display:grid}.olt-color-item{text-align:center;background:#ffffff08;border:1px solid #ffffff0d;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:3px;padding:8px 4px;display:flex}.olt-color-value{white-space:nowrap;font-size:1.05rem;font-weight:800;line-height:1}.olt-color-label{text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;opacity:.85;font-size:.62rem}.olt-color-item.is-online{background:#00e6640f;border-color:#00e6642e}.olt-color-item.is-offline{background:#ff3c3c0f;border-color:#ff3c3c2e}.olt-color-item.is-total{background:#00a4e60f;border-color:#00a4e62e}.olt-color-item.is-percent{background:#94a3b80f;border-color:#94a3b82e}.olt-color-item.is-online .olt-color-value,.olt-color-item.is-online .olt-color-label{color:var(--status-online)}.olt-color-item.is-offline .olt-color-value,.olt-color-item.is-offline .olt-color-label{color:var(--status-offline)}.olt-color-item.is-total .olt-color-value,.olt-color-item.is-total .olt-color-label{color:var(--brand-400,#29b6f6)}.olt-color-item.is-percent .olt-color-value,.olt-color-item.is-percent .olt-color-label{color:#94a3b8}.olt-avail-wrap{flex-direction:column;gap:5px;width:100%;display:flex}.olt-avail-header{justify-content:space-between;align-items:center;display:flex}.olt-avail-label{color:#4a6070;text-transform:uppercase;letter-spacing:.4px;font-size:.68rem}.olt-avail-text{letter-spacing:.2px;font-size:.75rem;font-weight:700}.olt-avail-text.olt-avail-up{color:var(--status-online)}.olt-avail-text.olt-avail-warn{color:#f59e0b}.olt-avail-text.olt-avail-down{color:var(--status-offline)}.olt-avail-track{background:#94a3b826;border-radius:999px;width:100%;height:7px;overflow:hidden}.olt-avail-fill{border-radius:999px;height:100%;transition:width .4s}.olt-avail-fill.olt-avail-up{background:var(--status-online)}.olt-avail-fill.olt-avail-warn{background:#f59e0b}.olt-avail-fill.olt-avail-down{background:var(--status-offline)}.btn-entrar{color:#fff;cursor:pointer;letter-spacing:.3px;-webkit-tap-highlight-color:transparent;background:linear-gradient(135deg,#00a4e6 0%,#0077b6 100%);border:none;border-radius:10px;width:100%;margin-top:auto;padding:11px 16px;font-size:.88rem;font-weight:700;transition:box-shadow .2s,transform .15s}.btn-entrar:active{transform:scale(.975)}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.35}}@media (min-width:576px){.olts-page{padding:24px 0 40px}.olts-container{padding:0 20px}.olts-grid{grid-template-columns:repeat(2,1fr);gap:16px}.olts-page-header-text h1{font-size:1.75rem}}@media (min-width:900px){.olts-page{padding:32px 0 48px}.olts-container{padding:0 24px}.olts-grid{grid-template-columns:repeat(3,1fr);gap:18px}.olts-page-header-text h1{font-size:2rem}.olt-card:hover{border-color:#00a4e666;transform:translateY(-4px);box-shadow:0 10px 36px #00a4e621}.btn-entrar:hover{box-shadow:0 4px 20px #0086e680}}@media (min-width:1280px){.olts-page{padding:40px 0 56px}.olts-grid{grid-template-columns:repeat(4,1fr);gap:20px}.olt-card{padding:20px 18px 18px}.olt-color-value{font-size:1.1rem}}@media (min-width:1700px){.olts-grid{grid-template-columns:repeat(5,1fr)}}@media (min-width:576px) and (max-width:899px){.olt-color-value{font-size:.95rem}.olt-color-label{font-size:.58rem}}:root[data-theme=light] .olts-page{background:var(--app-bg);background-image:radial-gradient(circle at 20% 20%, #00a4e614 0%, transparent 52%), radial-gradient(circle at 80% 80%, #0077b60f 0%, transparent 54%), linear-gradient(#00a4e605 1px, transparent 1px), linear-gradient(90deg, #00a4e605 1px, transparent 1px), linear-gradient(135deg, var(--page-grad-start) 0%, var(--page-grad-end) 100%);background-size:auto,auto,44px 44px,44px 44px}:root[data-theme=light] .olts-page-header-text h1{color:var(--text-1)}:root[data-theme=light] .olts-page-header-text p{color:var(--text-2)}:root[data-theme=light] .olt-card{background:var(--light-panel-bg-strong);border-color:var(--light-panel-border);box-shadow:var(--light-inset-glow), var(--light-panel-shadow)}:root[data-theme=light] .olt-card:hover{border-color:var(--light-panel-border-strong);box-shadow:var(--light-inset-glow), 0 16px 30px #0c366c29}:root[data-theme=light] .olt-icon{background:linear-gradient(135deg,#00a4e629 0%,#0077b621 100%);border-color:#00a4e647}:root[data-theme=light] .olt-card h3{color:#0f172a}:root[data-theme=light] .olt-alias{color:#7a8fa0}:root[data-theme=light] .olt-ip{color:var(--brand-600);background:var(--light-accent-soft);border-color:var(--light-accent-mid)}:root[data-theme=light] .olt-color-item{background:#ebf3fcd1;border-color:#5276aa2e}:root[data-theme=light] .olt-color-item.is-online{background:#00c85012;border-color:#00c85038}:root[data-theme=light] .olt-color-item.is-offline{background:#ff3c3c12;border-color:#ff3c3c38}:root[data-theme=light] .olt-color-item.is-total{background:#00a4e612;border-color:#00a4e638}:root[data-theme=light] .olt-color-item.is-percent{background:#64748b12;border-color:#64748b2e}:root[data-theme=light] .olt-avail-track{background:#244a8029}:root[data-theme=light] .olt-avail-label{color:#607da6}.olt-card{position:relative}.olt-fabricante-badge{color:#fff;text-transform:uppercase;letter-spacing:.5px;border-radius:6px;padding:4px 10px;font-size:.75rem;font-weight:700;position:absolute;top:12px;right:12px;box-shadow:0 2px 6px #00000026}.fabricante-logo-img{width:auto;height:18px;display:block}.pon-info-badges{flex-wrap:wrap;gap:8px;margin-top:8px;display:flex}.pon-fabricante-badge{color:#fff;text-transform:uppercase;letter-spacing:.5px;border-radius:8px;padding:6px 14px;font-size:.85rem;font-weight:700}.fabricante-badge{text-transform:uppercase;letter-spacing:.5px}.toast{background:var(--surface-1);box-shadow:var(--shadow-soft);border:1px solid var(--border-1);z-index:1000;border-radius:10px;align-items:center;gap:12px;max-width:400px;padding:14px 20px;animation:.3s ease-out slideIn;display:flex;position:fixed;bottom:24px;right:24px}.toast-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:14px;font-weight:700;display:flex}.toast-success{border-left:4px solid #00a4e6}.toast-success .toast-icon{color:#fff;background:#00a4e6}.toast-error{border-left:4px solid #e74c3c}.toast-error .toast-icon{color:#fff;background:#e74c3c}.toast-info{border-left:4px solid #5a7184}.toast-info .toast-icon{color:#fff;background:#5a7184}.toast-message{color:var(--text-1);font-size:.95rem;font-weight:500}@media (max-width:600px){.toast{max-width:none;bottom:16px;left:16px;right:16px}}.olt-config-page{background-color:var(--app-bg);background-image:radial-gradient(circle at 20% 20%, #00a4e612 0%, transparent 50%), radial-gradient(circle at 80% 80%, #0077b60f 0%, transparent 50%), linear-gradient(#00a4e60a 1px, transparent 1px), linear-gradient(90deg, #00a4e60a 1px, transparent 1px), linear-gradient(135deg, var(--page-grad-start) 0%, var(--page-grad-end) 100%);background-size:auto,auto,40px 40px,40px 40px,auto;min-height:100vh;padding:24px 0}.olt-config-container{max-width:1400px;margin:0 auto;padding:0 16px}.config-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:24px;display:flex}.config-header h1{color:var(--text-1);margin:0 0 6px;font-size:1.8rem;font-weight:700}.config-header p{color:var(--text-2);margin:0;font-size:.95rem}.btn-add-olt{color:#fff;cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#00a4e6 0%,#0077b6 100%);border:none;border-radius:10px;align-items:center;gap:8px;padding:12px 24px;font-size:.95rem;font-weight:600;transition:all .2s;display:flex;box-shadow:0 2px 8px #00a4e64d}.btn-add-olt:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00a4e666}.btn-add-olt:active{transform:translateY(0)}.olt-form-card{background:var(--surface-1);box-shadow:var(--shadow-soft);border:1px solid var(--border-1);border-radius:16px;margin-bottom:32px;padding:24px;animation:.3s ease-out fadeIn}.olt-form-card h3{color:var(--text-1);margin:0 0 20px;font-size:1.3rem}.form-group{margin-bottom:20px}.form-group label{color:var(--text-1);margin-bottom:8px;font-size:.9rem;font-weight:600;display:block}.form-group input,.form-group select{border:2px solid var(--border-1);width:100%;color:var(--text-1);background:var(--surface-0);border-radius:8px;padding:12px 16px;font-size:.95rem;transition:all .2s}.form-group input:focus,.form-group select:focus{border-color:#00a4e6;outline:none;box-shadow:0 0 0 3px #00a4e61a}.form-actions{gap:12px;margin-top:24px;display:flex}.btn-save{color:#fff;cursor:pointer;background:linear-gradient(135deg,#00a4e6 0%,#0077b6 100%);border:none;border-radius:8px;flex:1;padding:12px 24px;font-size:.95rem;font-weight:600;transition:all .2s}.btn-save:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00a4e64d}.btn-cancel{background:var(--chip-bg);color:var(--text-1);cursor:pointer;border:none;border-radius:8px;flex:1;padding:12px 24px;font-size:.95rem;font-weight:600;transition:all .2s}.btn-cancel:hover{background:var(--chip-bg-hover)}.olts-list h3{color:var(--text-1);margin-bottom:20px;font-size:1.3rem}.olts-grid-config{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;display:grid}.olt-config-card{background:var(--surface-1);box-shadow:var(--shadow-soft);border:1px solid var(--border-1);border-radius:16px;padding:20px;transition:all .3s;animation:.3s ease-out scaleIn}.olt-config-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px #0000001f}.olt-config-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.olt-badge{color:#fff;text-transform:uppercase;letter-spacing:.5px;border-radius:6px;padding:6px 12px;font-size:.8rem;font-weight:600}.olt-actions{gap:8px;display:flex}.btn-icon{background:var(--chip-bg);cursor:pointer;border:none;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;font-size:.9rem;transition:all .2s;display:flex}.btn-edit-icon:hover{background:var(--chip-bg-hover);transform:scale(1.1)}.btn-delete-icon:hover{background:#f5e0ff;transform:scale(1.1)}.olt-config-card h4{color:var(--text-1);margin:0 0 8px;font-size:1.2rem}.olt-config-card .olt-alias{color:var(--text-3);margin:0 0 4px;font-size:.78rem;font-style:italic}.olt-config-card .olt-ip{color:var(--text-2);margin:0 0 16px;font-family:Courier New,monospace;font-size:.9rem}.snmp-status-chip{border-radius:999px;margin-bottom:8px;padding:6px 10px;font-size:.78rem;font-weight:700;display:inline-block}.snmp-status-online{background:var(--status-online-bg);color:var(--status-online)}.snmp-status-offline{background:var(--status-offline-bg);color:var(--status-offline)}.snmp-status-unknown{background:var(--chip-bg);color:var(--text-2)}.snmp-details{color:var(--text-2);word-break:break-all;margin:0 0 10px;font-size:.8rem}.btn-snmp-refresh{border:1px solid var(--border-1);background:var(--chip-bg);width:100%;color:var(--brand-500);cursor:pointer;border-radius:8px;margin-bottom:10px;padding:9px;font-weight:600}.btn-snmp-refresh:hover{background:var(--chip-bg-hover)}.btn-access{color:#fff;cursor:pointer;background:linear-gradient(135deg,#00a4e6 0%,#0077b6 100%);border:none;border-radius:8px;width:100%;padding:10px;font-weight:600;transition:all .2s}.btn-access:hover{box-shadow:0 4px 12px #00a4e64d}:root[data-theme=dark] .btn-delete-icon:hover{background:#ef444433}@media (max-width:768px){.config-header{flex-direction:column;align-items:stretch}.btn-add-olt{width:100%}.olts-grid-config{grid-template-columns:1fr}.form-actions{flex-direction:column}}@media (min-width:768px){.olt-config-page{padding:32px 0}.olt-config-container{padding:0 20px}}@media (min-width:1024px){.olt-config-page{padding:40px 0}}@media (max-width:600px){.olt-config-page{padding:16px 0}.config-header h1{font-size:1.5rem}.olt-form-card{padding:20px 16px}}.pon-selector-page{background-color:var(--app-bg);background-image:radial-gradient(circle at 20% 20%, #00a4e612 0%, transparent 50%), radial-gradient(circle at 80% 80%, #0077b60f 0%, transparent 50%), linear-gradient(#00a4e60a 1px, transparent 1px), linear-gradient(90deg, #00a4e60a 1px, transparent 1px), linear-gradient(135deg, var(--page-grad-start) 0%, var(--page-grad-end) 100%);background-size:auto,auto,40px 40px,40px 40px,auto;min-height:100vh;padding:24px 0}.pon-selector-container{max-width:1400px;margin:0 auto;padding:0 16px}.page-not-found{min-height:60vh;color:var(--text-1);place-items:center;font-size:1.1rem;font-weight:700;display:grid}.pon-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:24px;display:flex}.pon-header-text{flex:320px;min-width:0}.pon-header-text h1{color:var(--text-1);overflow-wrap:anywhere;word-break:break-word;margin:0 0 4px;font-size:1.5rem;font-weight:700}.pon-header-text p{color:var(--text-2);margin:0;font-size:.85rem}.pon-info-badges{flex-wrap:wrap;flex:0 auto;justify-content:flex-end;align-self:flex-start;align-items:center;gap:8px;display:flex}.pon-info-badge{color:#fff;white-space:nowrap;border-radius:8px;padding:6px 12px;font-size:.8rem;font-weight:600}.btn-back-olts{border:1px solid var(--border-2);color:var(--text-2);cursor:pointer;white-space:nowrap;background:0 0;border-radius:8px;padding:6px 10px;font-size:.76rem;font-weight:600;transition:border-color .2s,color .2s,background-color .2s}.btn-back-olts:hover{color:var(--text-1);background:#00a4e60f;border-color:#00a4e659}.btn-back-olts:focus-visible{outline-offset:2px;outline:2px solid #00a4e659}.ip-badge{background:var(--surface-2);color:var(--text-1)}.model-badge{background:var(--chip-bg);color:var(--text-2);font-family:Courier New,monospace;font-size:.72rem}.pon-loading{color:var(--text-2);align-items:center;gap:12px;padding:48px 0;font-size:.95rem;display:flex}.pon-spinner{border:3px solid var(--border-1);border-top-color:#00a4e6;border-radius:50%;flex-shrink:0;width:22px;height:22px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.pon-error{background:var(--alert-error-bg);border:1px solid var(--alert-error-border);color:var(--alert-error-text);border-radius:10px;flex-wrap:wrap;align-items:center;gap:16px;margin-bottom:24px;padding:16px 20px;font-size:.9rem;display:flex}.pon-error button{color:#fff;cursor:pointer;background:#dc2626;border:none;border-radius:6px;padding:6px 14px;font-size:.85rem;font-weight:600}.pon-offline-warning{color:#fbbf24;background:#fbbf241f;border:1px solid #fbbf2473;border-radius:8px;margin-bottom:16px;padding:10px 16px;font-size:.88rem}.pon-layout{grid-template-columns:1fr;gap:20px;display:grid}.pon-slot-tabs{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.pon-slot-tab{background:var(--chip-bg);color:var(--text-2);cursor:pointer;border:2px solid #0000;border-radius:8px;align-items:center;gap:6px;padding:8px 16px;font-size:.85rem;font-weight:700;transition:all .2s;display:flex}.pon-slot-tab.active{background:var(--surface-1);color:#00a4e6;border-color:#00a4e6;box-shadow:0 2px 8px #00a4e626}.slot-count{background:var(--border-1);color:var(--brand-600);border-radius:999px;padding:2px 7px;font-size:.72rem;font-weight:700}.pon-slot-tab.active .slot-count{background:#00a4e633}.pon-grid-section{background:var(--surface-1);box-shadow:var(--shadow-soft);border:1px solid var(--border-1);border-radius:16px;order:2;padding:16px}.pon-grid{grid-template-columns:repeat(4,1fr);gap:8px;display:grid}.pon-card{background:var(--surface-2);border:2px solid var(--border-1);cursor:pointer;-webkit-tap-highlight-color:transparent;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:4px;min-height:68px;padding:12px 6px;transition:all .2s;display:flex;position:relative}.pon-card:active{transform:scale(.95)}.pon-card.active{color:#fff;background:linear-gradient(135deg,#00a4e6 0%,#0077b6 100%);border-color:#00a4e6;box-shadow:0 4px 12px #00a4e659}.pon-number{font-size:.9rem;font-weight:700}.pon-label{opacity:.65;font-family:Courier New,monospace;font-size:.7rem}.pon-card.active .pon-label{opacity:.9}.pon-state-dot{border:1px solid #ffffff8c;border-radius:50%;width:9px;height:9px;position:absolute;top:8px;right:8px;box-shadow:0 0 0 2px #00000014}.pon-state-dot.on{background:#22c55e}.pon-state-dot.off,.pon-state-dot.all-offline{background:#ef4444}.pon-state-dot.no-clients{background:#f97316}.pon-state-dot.unknown{background:#94a3b8}.pon-sidebar{flex-direction:column;order:1;display:flex}.sidebar-card{background:var(--surface-1);box-shadow:var(--shadow-soft);border:1px solid var(--border-1);border-radius:16px;flex-direction:column;gap:16px;padding:20px;display:flex}.sidebar-item{flex-direction:column;gap:6px;display:flex}.sidebar-item label{color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;font-size:.75rem;font-weight:600}.sidebar-value{color:var(--text-1);font-size:1rem;font-weight:700}.sidebar-value.large{font-size:1.75rem}.sidebar-ifname{color:var(--text-2);word-break:break-all;font-family:Courier New,monospace;font-size:.78rem;font-weight:500}.sidebar-uptime{color:var(--text-2);font-family:Courier New,monospace;font-size:.82rem;font-weight:500}.status-online{color:#10b981;align-items:center;gap:8px;display:flex}.status-offline{color:#ef4444;align-items:center;gap:8px;display:flex}.status-dot{border-radius:50%;flex-shrink:0;width:9px;height:9px}.status-online .status-dot{background:#10b981;animation:2s infinite pulse}.status-offline .status-dot{background:#ef4444}.btn-acessar{color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent;background:linear-gradient(135deg,#00a4e6 0%,#0077b6 100%);border:none;border-radius:8px;width:100%;padding:14px;font-size:1rem;font-weight:700;transition:box-shadow .2s,transform .2s}.btn-acessar:disabled{opacity:.5;cursor:not-allowed}.btn-acessar:not(:disabled):active{transform:scale(.98)}.sidebar-divider{background:var(--border-2);height:1px}@media (min-width:600px){.pon-grid{grid-template-columns:repeat(6,1fr);gap:10px}.pon-card{min-height:72px;padding:14px 8px}}@media (min-width:768px){.pon-selector-page{padding:32px 0}.pon-selector-container{padding:0 20px}.pon-header-text h1{font-size:1.8rem}}@media (min-width:1024px){.pon-selector-page{padding:40px 0}.pon-layout{grid-template-columns:1fr 280px;align-items:start}.pon-grid-section{order:1;padding:20px}.pon-sidebar{order:2;position:-webkit-sticky;position:sticky;top:80px}.pon-grid{grid-template-columns:repeat(8,1fr)}.pon-card:hover:not(.active){color:#fff;background:linear-gradient(135deg,#00a4e6 0%,#0077b6 100%);border-color:#00a4e6;box-shadow:0 4px 12px #00a4e659}.pon-card:hover:not(.active) .pon-label{opacity:.9}.btn-acessar:not(:disabled):hover{box-shadow:0 4px 16px #00a4e673}.pon-header-text h1{font-size:2rem}}@media (max-width:767px){.pon-selector-page{padding:14px 0}.pon-selector-container{padding:0 12px}.pon-header{gap:8px;margin-bottom:14px}.pon-header-text h1{font-size:1.2rem}.pon-header-text p{font-size:.78rem}.pon-info-badges{justify-content:flex-start;gap:6px;width:100%}.pon-info-badge{padding:5px 8px;font-size:.72rem}.btn-back-olts{padding:5px 8px;font-size:.7rem}.pon-layout{gap:12px}.sidebar-card{border-radius:12px;gap:10px;padding:14px}.sidebar-item label{font-size:.68rem}.sidebar-value{font-size:.9rem}.sidebar-value.large{font-size:1.25rem}.sidebar-ifname,.sidebar-uptime{font-size:.72rem}.btn-acessar{padding:11px;font-size:.9rem}.pon-slot-tabs{gap:6px;margin-bottom:12px}.pon-slot-tab{gap:4px;padding:6px 10px;font-size:.75rem}.slot-count{padding:1px 6px;font-size:.65rem}.pon-grid-section{border-radius:12px;padding:12px}.pon-grid{grid-template-columns:repeat(4,1fr);gap:6px}.pon-card{border-radius:8px;gap:3px;min-height:56px;padding:8px 4px}.pon-number{font-size:.78rem}.pon-label{font-size:.6rem}.pon-state-dot{width:7px;height:7px;top:6px;right:6px}}@media (max-width:380px){.pon-grid{grid-template-columns:repeat(3,1fr)}}:root[data-theme=dark] .pon-card:hover:not(.active){box-shadow:0 8px 20px #00a4e659}.btn-edit-label{border:1.5px dashed var(--border-1);width:100%;color:var(--text-2);cursor:pointer;background:0 0;border-radius:8px;padding:8px 12px;font-size:.8rem;font-weight:600;transition:all .2s}.btn-edit-label:hover{color:#00a4e6;background:#00a4e60f;border-color:#00a4e6}.sidebar-edit-label{background:var(--surface-3);border:1px solid var(--border-1);border-radius:10px;flex-direction:column;gap:8px;padding:10px;display:flex}.sidebar-edit-label label{color:var(--text-2);font-size:.78rem;font-weight:600}.sidebar-edit-label input{border:1.5px solid var(--border-1);background:var(--input-bg);color:var(--text-1);border-radius:8px;outline:none;padding:7px 10px;font-size:.9rem;transition:border-color .2s}.sidebar-edit-label input:focus{border-color:#00a4e6}.sidebar-edit-actions{gap:6px;display:flex}.sidebar-edit-actions .btn-save{color:#fff;cursor:pointer;background:linear-gradient(135deg,#00a4e6,#0077b6);border:none;border-radius:8px;flex:1;padding:7px 0;font-size:.8rem;font-weight:600}.sidebar-edit-actions .btn-save:disabled{opacity:.6;cursor:not-allowed}.sidebar-edit-actions .btn-cancel{background:var(--surface-2);color:var(--text-2);border:1px solid var(--border-1);cursor:pointer;border-radius:8px;flex:1;padding:7px 0;font-size:.8rem;font-weight:600}.sidebar-edit-hint{color:var(--text-3);text-align:center;font-size:.7rem}.pon-clients-page{background-color:#f3f6fa;background-image:radial-gradient(circle at 20% 20%,#00a4e60d 0%,#0000 50%),radial-gradient(circle at 80% 80%,#0077b60a 0%,#0000 50%),linear-gradient(#00a4e608 1px,#0000 1px),linear-gradient(90deg,#00a4e608 1px,#0000 1px),linear-gradient(135deg,#f7fbff 0%,#edf3fb 100%);background-size:auto,auto,40px 40px,40px 40px,auto;min-height:100vh;padding:24px 0}.pon-clients-container{width:100%;max-width:1680px;margin:0 auto;padding-left:12px!important;padding-right:12px!important}.clients-logo-container{text-align:center;margin-bottom:20px}.page-logo{filter:brightness(0)saturate()invert(32%)sepia(89%)saturate(1588%)hue-rotate(175deg)brightness(91%)contrast(101%);height:40px}.clients-header{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:linear-gradient(#fffffffa 0%,#f8fbfff5 100%),radial-gradient(circle at 0 0,#3b82f614,#0000 38%),radial-gradient(circle at 100% 0,#10b9810f,#0000 32%);border:1px solid #e5e7eb;border-radius:16px;margin-bottom:14px;padding:12px 14px;font-family:Inter,Segoe UI,sans-serif;box-shadow:0 2px 10px #0000000f,inset 0 1px #ffffffe6}.clients-header-main{flex-wrap:wrap;align-items:stretch;gap:12px 14px;display:flex}.clients-left-actions{flex:auto;align-items:center;gap:8px;min-width:0;display:flex}.clients-header-top{display:contents}.clients-title-compact,.clients-info-card{background:linear-gradient(#fffffffa 0%,#f5f9fff0 100%);border:1px solid #e5e7eb;border-radius:12px;flex-direction:row;align-items:center;gap:10px;min-width:0;min-height:52px;padding:0 14px;display:flex;box-shadow:inset 0 1px #ffffffe6,0 6px 14px #23529814}.clients-info-title,.clients-title-compact h1{color:#102747;letter-spacing:.03em;white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:.86rem;font-weight:800;line-height:1;overflow:hidden}.clients-info-subtitle{color:#4b6f9f;white-space:nowrap;text-overflow:ellipsis;max-width:100%;font-family:Rajdhani,sans-serif;font-size:.84rem;font-weight:700;overflow:hidden}.clients-card-text{flex-direction:column;gap:3px;min-width:0;display:flex}.clients-card-icon{color:#fff;border-radius:9px;flex:none;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.clients-card-icon svg{width:17px;height:17px}.clients-card-icon-pon{background:linear-gradient(135deg,#0ea5e9 0%,#38bdf8 100%);box-shadow:0 2px 8px #0ea5e959}.clients-card-icon-olt{background:linear-gradient(135deg,#8b5cf6 0%,#a78bfa 100%);box-shadow:0 2px 8px #8b5cf659}.clients-metrics-row{flex-wrap:wrap;align-items:stretch;gap:8px;margin-left:auto;display:flex}.clients-metrics-row .metric-badge{text-align:left;border:1px solid #e5e7eb;border-radius:12px;flex-direction:column;justify-content:center;align-items:flex-start;gap:2px;min-width:124px;min-height:52px;padding:8px 12px 8px 50px;font-size:.72rem;display:inline-flex;position:relative;overflow:hidden;box-shadow:inset 0 1px #ffffffe6,0 6px 14px #23529814}.clients-metrics-row .metric-badge.metric-total{background:linear-gradient(#0369a129 0%,#e0f2fef5 100%);border-color:#0e749052}.clients-metrics-row .metric-badge.metric-geo-ok{background:linear-gradient(#05966926 0%,#dcfce7f2 100%);border-color:#0596694d}.clients-metrics-row .metric-badge.metric-geo-missing{background:linear-gradient(#dc262624 0%,#fef2f2f5 100%);border-color:#dc262647}.clients-metrics-row .metric-badge:before{content:"";opacity:.92;background-color:#fffffff5;border-radius:0;width:24px;height:24px;position:absolute;top:50%;left:14px;transform:translateY(-50%);-webkit-mask-position:50%;mask-position:50%;-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat}.clients-metrics-row .metric-badge:after{content:"";opacity:.12;clip-path:polygon(0 100%,12% 78%,24% 84%,38% 52%,54% 64%,70% 26%,86% 38%,100% 0,100% 100%);background:linear-gradient(#0000 0%,#ffffff1a 100%);height:26px;position:absolute;top:auto;bottom:-10%;left:10%;right:-10%}.clients-metrics-row .metric-badge.metric-total:before{-webkit-mask-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='black' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 7.5h16'/%3E%3Cpath d='M7 7.5v9'/%3E%3Cpath d='M12 7.5v9'/%3E%3Cpath d='M17 7.5v9'/%3E%3Crect x='4' y='4.5' width='16' height='14' rx='2.5'/%3E%3C/g%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='black' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 7.5h16'/%3E%3Cpath d='M7 7.5v9'/%3E%3Cpath d='M12 7.5v9'/%3E%3Cpath d='M17 7.5v9'/%3E%3Crect x='4' y='4.5' width='16' height='14' rx='2.5'/%3E%3C/g%3E%3C/svg%3E")}.clients-metrics-row .metric-badge.metric-geo-ok:before{background-color:#10b981;transform:translateY(-50%)scale(.85);-webkit-mask-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 16 16' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M16 1L15 0L0 6V8L7 9L8 16H10L16 1Z'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 16 16' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M16 1L15 0L0 6V8L7 9L8 16H10L16 1Z'/%3E%3C/svg%3E")}.clients-metrics-row .metric-badge.metric-geo-missing:before{background-color:#ef4444;transform:translateY(-50%)scale(.85);-webkit-mask-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 16 16' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M16 1L15 0L0 6V8L7 9L8 16H10L16 1Z'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 16 16' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M16 1L15 0L0 6V8L7 9L8 16H10L16 1Z'/%3E%3C/svg%3E")}.metric-value{color:#102747;letter-spacing:-.03em;font-size:1.22rem;font-weight:800;line-height:1;display:block}.metric-label{color:#224574db;text-transform:uppercase;letter-spacing:.08em;font-size:.62rem;line-height:1;display:block}.clients-header-right{flex-wrap:nowrap;flex:none;justify-content:flex-end;align-items:stretch;gap:8px;min-width:0;margin-left:auto;display:flex}.clients-topbar-search{flex:340px;max-width:360px}.clients-topbar-search-inline{min-height:52px}.clients-info-right .clients-info-card{min-width:230px}.clients-header-main>.clients-topbar-badges{flex-wrap:nowrap;flex:none;margin-left:0}.clients-search-wrap{align-items:center;width:100%;max-width:none;min-height:52px;display:flex;position:relative}.clients-search-icon{pointer-events:none;opacity:.82;background-color:#4b76ab;justify-content:center;align-items:center;width:16px;height:16px;display:inline-flex;position:absolute;top:50%;left:14px;transform:translateY(-50%);-webkit-mask-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 16 16' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='7' cy='7' r='4.75' fill='none' stroke='black' stroke-width='1.6'/%3E%3Cline x1='10.6' y1='10.6' x2='14.25' y2='14.25' stroke='black' stroke-width='1.6' stroke-linecap='round'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 16 16' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='7' cy='7' r='4.75' fill='none' stroke='black' stroke-width='1.6'/%3E%3Cline x1='10.6' y1='10.6' x2='14.25' y2='14.25' stroke='black' stroke-width='1.6' stroke-linecap='round'/%3E%3C/svg%3E");-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat}.clients-search-clear{cursor:pointer;color:var(--text-3);background:0 0;border:none;border-radius:4px;padding:2px 4px;font-size:.8rem;position:absolute;right:10px}.clients-search-clear:hover{color:var(--text-1);background:var(--surface-2)}.clients-search-wrap .search-input.search-input-compact{box-sizing:border-box;-webkit-appearance:none;-moz-appearance:none;appearance:none;color:#102748;background:#fffffff5;border:1px solid #e5e7eb;border-radius:12px;width:100%;min-width:0;min-height:52px;padding:11px 36px 11px 40px;font-size:.86rem;line-height:1.2;display:block;box-shadow:inset 0 1px #ffffffe6,0 6px 14px #23529814}.clients-search-wrap .search-input.search-input-compact::placeholder{color:#3c64a080}.clients-search-wrap .search-input.search-input-compact:focus{border-color:#8be0ffd1;outline:none;box-shadow:0 0 0 3px #50b4ff2e,0 0 18px #50b4ff24}.search-container{width:100%;margin-bottom:20px}.clients-loading,.clients-error{border-radius:10px;width:100%;margin-bottom:16px;padding:12px 14px;font-size:.9rem;font-weight:600}.clients-loading{background:var(--chip-bg);color:var(--text-2);border:1px solid var(--border-1)}.clients-error{color:#c53030;background:#ef44441f;border:1px solid #ef444459}.clients-empty{width:100%;color:var(--text-2);background:#00a4e617;border:1px solid #00a4e640;border-radius:10px;margin-bottom:16px;padding:12px 14px;font-size:.9rem;font-weight:600}.search-input{width:100%;min-height:var(--touch-target-min,42px);border:2px solid var(--border-1);background:var(--surface-0);color:var(--text-1);border-radius:10px;padding:14px 16px;font-size:.95rem;transition:all .2s;box-shadow:0 2px 4px #0000000d}.search-input:focus{border-color:#00a4e6;outline:none;box-shadow:0 0 0 3px #00a4e61a}.search-input::placeholder{color:var(--text-3)}.info-badge{background:var(--surface-2);color:var(--text-1);text-align:center;white-space:nowrap;border:none;border-radius:8px;justify-content:center;align-items:center;padding:6px 12px;font-size:.8rem;font-weight:600;display:inline-flex}.btn-back{white-space:nowrap;text-overflow:ellipsis;color:#1a335d;cursor:pointer;white-space:nowrap;background:linear-gradient(#fffffffa 0%,#f0f6fff0 100%);border:1px solid #d7dfee;border-radius:12px;justify-content:center;align-items:center;gap:8px;min-width:0;min-height:52px;padding:0 18px;font-family:Inter,Segoe UI,sans-serif;font-size:.78rem;font-weight:700;transition:border-color .2s,color .2s,background-color .2s,transform .18s,box-shadow .2s;display:inline-flex;overflow:hidden;box-shadow:inset 0 1px #ffffffe6,0 6px 14px #23529814}.btn-back-inline{grid-area:back;justify-self:start;min-width:110px}.clients-title-compact{grid-area:title}.btn-refresh-compact{grid-area:refresh;width:52px;min-width:52px;padding:0}.btn-refresh-compact.icon{justify-content:center}.btn-refresh-compact .btn-refresh-label{display:none}.btn-refresh-sq{border-radius:12px;flex:none;gap:8px;min-width:110px;min-height:52px;padding:0 16px}.btn-refresh-sq .btn-refresh-label{line-height:1;display:inline-block}.btn-back:hover{color:#0f2d5c;background:linear-gradient(#e6f2fffa 0%,#d6e8fff0 100%);border-color:#5082c873;transform:translateY(-1px);box-shadow:0 0 0 1px #50b4ff14,0 10px 18px #2352981f}.btn-back:focus-visible{outline-offset:2px;outline:2px solid #00a4e659}.clients-header .btn-refresh,.clients-header .btn-back,.clients-header .clients-info-card,.clients-header .clients-search-wrap,.clients-header .metric-badge{flex:none}.clients-header .btn-refresh,.clients-header .btn-back,.clients-header .clients-info-card,.clients-header .clients-search-wrap{height:52px}.clients-header .btn-refresh-icon{justify-content:center;align-items:center;display:inline-flex}.clients-header .btn-refresh-icon svg{width:18px;height:18px}.serial-copy-button{max-width:100%;min-height:40px;color:inherit;font:inherit;font-size:inherit;cursor:pointer;background:0 0;border:1px solid #0000;border-radius:10px;justify-content:flex-start;align-items:center;gap:8px;padding:6px 10px;transition:color .18s;display:inline-flex}.serial-copy-button:hover{background:0 0;border-color:#0000}.serial-copy-button:hover .serial-text{color:var(--brand-500);text-shadow:0 0 10px #00a4e62e}.serial-copy-button:hover .serial-copy-icon{color:var(--brand-500)}.serial-copy-button.is-copied{background:0 0;border-color:#0000}.serial-copy-button.is-copied .serial-text{color:var(--status-online);text-shadow:0 0 10px #10b9812e}.serial-copy-button.is-copied .serial-copy-icon{color:#10b981}.serial-copy-button:focus-visible{outline-offset:2px;outline:2px solid #00a4e647}.serial-text{white-space:nowrap;text-overflow:ellipsis;min-width:0;font-size:inherit;display:block;overflow:hidden}.serial-copy-icon{color:var(--text-3);flex-shrink:0;font-size:.85rem}.fabricante-badge{justify-content:center;align-items:center;display:flex}.fabricante-badge.is-compact{border-radius:999px;min-height:24px;padding:3px 8px}.clients-table-container{background:var(--surface-1);border:1px solid var(--border-1);-webkit-overflow-scrolling:touch;border-radius:12px;overflow-x:auto;box-shadow:0 2px 18px #0000001a}.clients-table{border-collapse:collapse;table-layout:fixed;width:100%;min-width:760px}.clients-table thead{background:var(--surface-2);z-index:10;position:-webkit-sticky;position:sticky;top:0}.clients-table th{text-align:center;color:var(--text-1);text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--border-1);white-space:nowrap;padding:14px 12px;font-size:.8rem;font-weight:700}.clients-table tbody tr{border-bottom:1px solid var(--border-2);transition:background-color .2s}.clients-table tbody tr:active{background-color:var(--surface-2)}.clients-table tbody tr:last-child{border-bottom:none}.clients-table td{color:var(--text-1);vertical-align:middle;text-align:center;padding:14px 12px;font-size:.9rem;line-height:1.2}.clients-table td:first-child{color:var(--brand-500);white-space:nowrap;font-weight:700}.clients-table td:last-child{text-align:center;white-space:nowrap}.clients-table td.clients-col-serial,.clients-table td:nth-child(4){text-align:center}.clients-table th:first-child,.clients-table td:first-child{text-align:center;width:5%;padding-left:8px;padding-right:8px}.clients-table th:nth-child(2),.clients-table td:nth-child(2){text-align:center;width:27%}.clients-table th:nth-child(3),.clients-table td:nth-child(3){text-align:center;width:7%}.clients-table th:nth-child(4),.clients-table td:nth-child(4){width:17%}.clients-table th:nth-child(5),.clients-table td:nth-child(5){text-align:center;width:13%;min-width:190px}.clients-table th:nth-child(6),.clients-table td:nth-child(6){text-align:center;width:12%}.clients-table th:nth-child(7),.clients-table td:nth-child(7){text-align:center;width:14%}.clients-table th:nth-child(8),.clients-table td:nth-child(8){text-align:center;width:5%}@media (min-width:769px){.clients-table{min-width:920px}.clients-table td:nth-child(4){white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.clients-table td.clients-col-name{white-space:normal;text-overflow:clip;line-height:1.35;overflow:visible}.clients-table th:nth-child(4),.clients-table td:nth-child(4){min-width:170px}.clients-table td:nth-child(4){padding-top:10px;padding-bottom:10px}.clients-table td.clients-col-serial,.clients-table td:nth-child(4){vertical-align:middle;text-align:center}.serial-copy-button{border-color:#0000;border-radius:6px;justify-content:center;width:100%;margin:0;padding-left:0;padding-right:0}.serial-copy-button:hover{background:0 0;border-color:#0000}.client-name-text,.serial{white-space:nowrap;text-overflow:ellipsis;max-width:100%;display:block;overflow:hidden}.clients-table td.clients-col-name .client-name-text,.clients-table td.clients-col-name .client-name-button{white-space:normal;text-overflow:clip;overflow-wrap:anywhere;word-break:break-word;text-align:center;overflow:visible}}.serial{color:var(--text-2);font-family:Courier New,monospace;font-size:.85rem;font-weight:500}.attenuation{color:var(--text-2);white-space:nowrap;box-sizing:border-box;border-radius:999px;justify-content:center;align-items:center;min-width:107px;min-height:30px;padding:0 10px;font-family:Courier New,monospace;font-weight:600;display:inline-flex}.attenuation.good{color:var(--att-good);background:#10b98126}.attenuation.warning{color:var(--att-warning);background:#f59e0b29}.attenuation.critical{color:var(--att-critical);background:#ef444424}.attenuation.unknown{background:var(--chip-bg);color:var(--text-2)}.status-badge{white-space:nowrap;border-radius:20px;align-items:center;gap:6px;padding:6px 10px;font-size:.8rem;font-weight:600;display:inline-flex}.status-badge.online{background:var(--status-online-bg);color:var(--status-online)}.status-badge.offline{background:var(--status-offline-bg);color:var(--status-offline)}.clients-col-status{text-align:center}.status-stack{flex-direction:column;justify-content:center;align-items:center;width:172px;min-height:32px;display:inline-flex}.status-loading{color:var(--text-2);box-sizing:border-box;background:#94a3b829;justify-content:center;width:160px;min-height:30px}.status-loading .status-indicator{background:#94a3b8;animation:1.2s ease-in-out infinite pulse}.status-badge.rbx-ip-badge{color:#10b981;cursor:pointer;white-space:nowrap;box-sizing:border-box;text-overflow:ellipsis;background:#10b9811f;border:1px solid #10b98147;justify-content:center;width:160px;min-height:30px;font-size:.78rem;text-decoration:none;transition:background .15s,color .15s;overflow:hidden}.status-badge.rbx-ip-badge:hover{color:#059669;background:#10b98138;text-decoration:none}.status-badge.rbx-ip-badge .rbx-ip-icon{flex-shrink:0;width:13px;height:13px}.status-indicator{border-radius:50%;flex-shrink:0;width:8px;height:8px}.geo-badge{letter-spacing:.01em;border:1px solid #0000;border-radius:999px;justify-content:center;align-items:center;min-width:74px;padding:6px 10px;font-size:.76rem;font-weight:700;display:inline-flex}.geo-badge.geo-ok{color:var(--status-online);background:#10b9811f;border-color:#10b9814d}.geo-badge.geo-missing{color:#c26d0d;background:#f59e0b21;border-color:#f59e0b47}.status-badge.online .status-indicator{background:#10b981;animation:2s infinite pulse}.status-badge.offline .status-indicator{background:#ef4444}.edit-input{width:100%;min-height:var(--touch-target-min,42px);border:2px solid var(--brand-500);background:var(--surface-0);color:var(--text-1);-webkit-appearance:none;-moz-appearance:none;appearance:none;border-radius:6px;padding:10px 12px;font-family:inherit;font-size:.92rem}.edit-input:focus{outline:none;box-shadow:0 0 0 3px #00a4e61a}.edit-actions{flex-wrap:wrap;justify-content:flex-start;gap:6px;display:flex}.name-edit-wrap{border:1px solid var(--border-1);background:var(--surface-0);border-radius:10px;flex-direction:column;gap:8px;width:100%;padding:10px;display:flex}.name-edit-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;display:flex}.name-edit-title{text-transform:uppercase;letter-spacing:.04em;color:var(--text-2);font-size:.78rem;font-weight:700}.edit-validation-indicator{border:1px solid #0000;border-radius:999px;justify-content:center;align-items:center;padding:3px 8px;font-size:.72rem;font-weight:700;display:inline-flex}.edit-validation-indicator.is-valid{color:var(--att-good);background:#10b98126;border-color:#10b98147}.edit-validation-indicator.is-invalid{color:var(--att-warning);background:#f59e0b2b;border-color:#f59e0b47}.geogrid-checkbox-label{color:var(--text-2);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;align-items:center;gap:6px;margin-top:4px;font-size:.82rem;display:flex}.geogrid-checkbox-label input[type=checkbox]{cursor:pointer;width:15px;height:15px;accent-color:var(--primary,#2563eb)}.name-format-tip{color:var(--text-3);margin-top:2px;font-size:.73rem}.name-format-tip code{background:var(--surface-2);color:var(--text-2);border-radius:4px;padding:2px 6px;font-family:Courier New,monospace}@media (min-width:769px){.clients-table td.clients-col-name.is-editing{white-space:normal;vertical-align:top}.name-edit-wrap{border-radius:12px;gap:10px;padding:12px;box-shadow:inset 0 0 0 1px #00a4e614}.name-edit-header{flex-wrap:nowrap;align-items:center}.name-edit-title{white-space:nowrap;font-size:.74rem}.edit-validation-indicator{white-space:nowrap;flex-shrink:0}.edit-input{min-height:44px}.edit-actions{flex-wrap:nowrap;align-items:center}.btn-save,.btn-cancel{min-width:108px}.name-format-tip{line-height:1.35}.name-format-tip code{white-space:nowrap;text-overflow:ellipsis;vertical-align:bottom;max-width:100%;display:inline-block;overflow:hidden}}.client-name-inline{align-items:center;gap:8px;width:100%;min-width:0;max-width:100%;display:flex}.geo-only-icon{background-color:currentColor;flex-shrink:0;width:16px;height:16px;display:inline-block;-webkit-mask-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 16 16' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M16 1L15 0L0 6V8L7 9L8 16H10L16 1Z'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 16 16' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M16 1L15 0L0 6V8L7 9L8 16H10L16 1Z'/%3E%3C/svg%3E");-webkit-mask-position:50%;mask-position:50%;-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat}.geo-only-icon.geo-ok{color:#10b981}.geo-only-icon.geo-missing{color:#ef4444}.clients-col-geo{vertical-align:middle;text-align:center!important}.clients-col-geo .geo-only-icon{vertical-align:middle;margin:0;display:inline-flex}.client-name-text,.client-name-button{text-overflow:ellipsis;white-space:nowrap;min-width:0;color:var(--text-1);font:inherit;font-size:inherit;line-height:inherit;flex:1;overflow:hidden}.client-name-button{cursor:pointer;text-align:left;background:0 0;border:1px solid #0000;border-radius:8px;padding:5px 10px;transition:background .2s,border-color .2s,box-shadow .2s}.client-name-button:hover:not(:disabled){color:var(--brand-500);text-shadow:0 0 10px #00a4e62e;background:#ffffff12;border-color:#ffffff1a;box-shadow:0 1px 6px #0000001a}.client-name-button:disabled{cursor:not-allowed;opacity:.5}.btn-inline-edit,.btn-delete-icon{width:var(--touch-target-min,42px);height:var(--touch-target-min,42px);min-width:var(--touch-target-min,42px);min-height:var(--touch-target-min,42px);box-sizing:border-box;cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;font-size:1rem;transition:all .2s;display:inline-flex}.btn-inline-edit{border:1px solid var(--border-1);background:var(--surface-1);color:var(--text-2);margin-left:12px}.btn-inline-edit:hover:not(:disabled){color:var(--brand-500);background:#00a4e61f;border-color:#00a4e659;transform:translateY(-1px)}.btn-delete-icon{background:#14639424}.btn-delete-icon.is-loading{opacity:.55}.btn-delete-icon:hover:not(:disabled){background:#ef444442;transform:translateY(-1px)}.btn-inline-edit:disabled,.btn-delete-icon:disabled{opacity:.55;cursor:not-allowed;transform:none}.btn-edit:disabled,.btn-save:disabled,.btn-cancel:disabled{opacity:.5;pointer-events:none}.btn-save{color:#fff;background:#10b981}.btn-save:active{background:#059669;transform:scale(.95)}.btn-cancel{color:#fff;background:#ef4444}.btn-cancel:active{background:#dc2626;transform:scale(.95)}.btn-refresh{color:#edf4ff;cursor:pointer;white-space:nowrap;-webkit-tap-highlight-color:transparent;background:linear-gradient(#070f22eb 0%,#10498885 100%);border:1px solid #5981cb73;border-radius:12px;justify-content:center;align-items:center;gap:10px;width:auto;min-width:0;min-height:0;padding:9px 14px;font-size:.76rem;font-weight:700;line-height:1;transition:border-color .2s,color .2s,background-color .2s;display:flex;box-shadow:inset 0 1px #6f9aff29,0 8px 18px #0000004d}.btn-back-inline,.btn-refresh-compact{min-height:36px}.btn-refresh-compact{grid-area:refresh;justify-self:end;min-width:132px}.btn-refresh-icon{transform-origin:50%;flex-shrink:0;justify-content:center;align-items:center;width:18px;min-width:18px;height:18px;min-height:18px;display:inline-flex}.btn-refresh-icon svg{width:18px;height:18px;display:block}.btn-refresh-icon.is-spinning{animation:.9s linear infinite spin}.btn-refresh-label{text-align:center;min-width:88px;line-height:1;display:inline-block}.btn-refresh:hover:not(:disabled){color:#f3fbff;background:linear-gradient(#104988b8 0%,#0d234feb 100%);border-color:#8be0ffd1;transform:translateY(-1px);box-shadow:0 0 0 1px #50b4ff1f,0 14px 24px #00000052}.btn-refresh:active:not(:disabled){background:#00a4e61a}.btn-refresh:disabled{opacity:.55;cursor:not-allowed}@media (min-width:768px){.pon-clients-page{padding:32px 0}.pon-clients-container{padding:0 20px}.clients-logo-container{margin-bottom:24px}.clients-title-compact h1{font-size:1.4rem}.clients-header-search{width:100%}.clients-search-wrap{max-width:292px}.clients-table th{padding:14px 12px;font-size:.85rem}.clients-table td{padding:14px 12px;font-size:.95rem}.serial{font-size:.9rem}.status-badge{padding:6px 12px;font-size:.85rem}.btn-edit,.btn-save,.btn-cancel{padding:8px 16px;font-size:.85rem}.clients-table tbody tr:hover{background-color:var(--surface-2)}.btn-edit:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00a4e666}.btn-save:hover{background:#059669}.btn-cancel:hover{background:#dc2626}}@media (min-width:1024px){.pon-clients-page{padding:40px 0}.clients-title-compact h1{font-size:1.5rem}.clients-header{padding:14px}.clients-header-search{width:100%}.clients-search-wrap{max-width:292px}.clients-search-wrap .search-input.search-input-compact,.clients-metrics-row .metric-badge{min-height:52px}.clients-table th{font-size:.9rem}.clients-table td{font-size:.95rem}}@media (max-width:1080px){.clients-header-main{gap:10px}.clients-left-actions{flex-wrap:wrap}.clients-topbar-search{flex:320px;max-width:none}.clients-info-right{flex-wrap:wrap;justify-content:flex-end;width:100%;margin-left:0}.clients-info-right .clients-info-card{flex:260px;min-width:230px}.clients-search-wrap{max-width:none}}@media (max-width:768px){.clients-header-main{flex-direction:row;align-items:stretch;width:100%;display:flex}.clients-header{padding:12px}.clients-left-actions{gap:6px;width:100%}.clients-topbar-search{flex:100%;order:1;width:100%;max-width:none}.btn-back-inline{flex:none;min-width:98px}.btn-refresh-sq{order:2}.clients-subtitle-item{font-size:.78rem}.clients-topbar-badges{order:3;width:100%;margin-left:0}.clients-info-right{flex-wrap:wrap;justify-content:flex-start;width:100%;margin-left:0}.clients-metrics-row{gap:6px;width:100%}.clients-search-wrap{width:100%;max-width:none}.clients-search-wrap .search-input.search-input-compact{width:100%;min-height:40px;padding:9px 34px 9px 40px;font-size:.84rem}.clients-metrics-row .metric-badge{min-height:52px;padding:8px 10px 8px 48px}.metric-value{font-size:1.02rem}.metric-label{font-size:.56rem}.clients-table-container{box-shadow:none;background:0 0;border:none;border-radius:0;overflow:visible}.clients-table,.clients-table thead,.clients-table tbody,.clients-table th,.clients-table td,.clients-table tr{display:block;width:auto!important}.clients-table{min-width:unset}.clients-table thead{display:none}.clients-table tbody tr{background:var(--surface-1);border:1px solid var(--border-1);cursor:pointer;border-radius:10px;grid-template-columns:minmax(0,1fr);margin-bottom:10px;display:grid;overflow:hidden}.clients-table td{white-space:normal;border-bottom:1px solid var(--border-2);text-align:right;justify-content:space-between;align-items:center;gap:8px;padding:9px 14px;font-size:.88rem;display:flex;overflow:visible}.clients-table tbody tr td:last-child{border-bottom:none}.clients-table td:before{content:attr(data-label);text-transform:uppercase;letter-spacing:.4px;color:var(--text-2);white-space:nowrap;text-align:left;flex-shrink:0;margin-right:auto;padding-right:8px;font-size:.72rem;font-weight:700}.clients-table td:first-child{background:var(--surface-2);border-right:1px solid var(--border-2);border-bottom:2px solid var(--border-1);color:var(--text-1);text-align:center;justify-content:center;padding:6px 0;font-size:.82rem;font-weight:700}.clients-table td.clients-col-name{background:var(--surface-2);border-bottom:2px solid var(--border-1);text-align:left;justify-content:flex-start;padding:6px 38px 6px 10px;position:relative}.clients-table td.clients-col-name:before,.clients-table td:first-child:before{content:none}.clients-table tbody tr td:first-child{display:none!important}.clients-table td.clients-col-name:after{content:"▾";color:var(--text-3);font-size:.9rem;transition:transform .18s,color .18s;position:absolute;top:50%;right:14px;transform:translateY(-50%)}.clients-table tbody tr.mobile-expanded td.clients-col-name:after{color:var(--brand-500);transform:translateY(-50%)rotate(180deg)}.clients-table tbody tr td:not(.clients-col-name){grid-column:1/-1}.clients-table tbody tr:not(.mobile-expanded) td:not(.clients-col-name){display:none}.clients-table tbody tr:not(.mobile-expanded) td.clients-col-name{border-bottom:2px solid var(--border-1)}.client-name-inline{gap:8px;width:100%}.client-name-text,.client-name-button{white-space:normal;text-overflow:unset;text-align:left;line-height:1.35;overflow:visible}.serial{word-break:break-word;overflow-wrap:anywhere;font-size:.8rem}.clients-table td.clients-col-status,.clients-table td.clients-col-attenuation,.clients-table td.clients-col-actions{background:#00a4e60a}.clients-table td.clients-col-actions{justify-content:flex-end}.name-edit-wrap{border-radius:12px;width:100%;padding:10px;box-shadow:inset 0 0 0 1px #00a4e614}.edit-actions{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;width:100%;display:grid}.btn-save,.btn-cancel{justify-content:center;width:100%;min-height:40px}.name-format-tip code{word-break:break-word}.btn-refresh{min-height:var(--touch-target-min,42px)}}@media (max-width:540px){.clients-header{padding:12px}.clients-header-main{gap:10px}.btn-back-inline{flex:116px}.clients-left-actions{justify-content:flex-start;width:100%}.btn-refresh-sq{min-width:110px}.clients-topbar-search{flex:100%;order:1;max-width:none;margin-left:0}.clients-info-card{flex:100%;padding:0 12px}.clients-topbar-badges{order:3}.clients-metrics-row{justify-content:flex-start;width:100%;margin-left:0}.clients-metrics-row .metric-badge{flex:108px;min-height:52px;padding:8px 10px 8px 48px}.clients-info-title,.clients-info-subtitle{font-size:.8rem}.clients-search-wrap .search-input.search-input-compact,.clients-search-wrap{min-height:48px}}:root[data-theme=dark] .clients-header{background:linear-gradient(#070e1ef2 0%,#08142ced 100%),radial-gradient(circle at 0 0,#38bdf824,#0000 42%),radial-gradient(circle at 100% 0,#10b9811f,#0000 36%);border-color:#38bdf852;box-shadow:0 8px 24px #00000047,inset 0 1px #95bdff14}:root[data-theme=dark] .pon-clients-page{background-color:#040b1a;background-image:radial-gradient(circle at 18% 16%,#38bdf824 0%,#0000 48%),radial-gradient(circle at 82% 82%,#10b9811f 0%,#0000 52%),linear-gradient(#60a5fa0f 1px,#0000 1px),linear-gradient(90deg,#60a5fa0f 1px,#0000 1px),linear-gradient(140deg,#040b1a 0%,#0a1938 100%)}:root[data-theme=dark] .clients-info-card{background:linear-gradient(#071024d6 0%,#040916eb 100%);border-color:#5981cb52;box-shadow:inset 0 1px #6f9aff1f,0 10px 22px #00000029}:root[data-theme=dark] .clients-info-title{color:#edf4ff}:root[data-theme=dark] .clients-info-subtitle{color:#7ea2db}:root[data-theme=dark] .metric-value{color:#eef4ff}:root[data-theme=dark] .metric-label{color:#bfd3f8d9}:root[data-theme=dark] .clients-search-icon{background-color:#9bc5ff}:root[data-theme=dark] .clients-topbar-search .search-input.search-input-compact{color:#f8fbff;background:#070f22cc;border-color:#5981cb73}:root[data-theme=dark] .clients-topbar-search .search-input.search-input-compact::placeholder{color:#9bb4e6a6}:root[data-theme=dark] .clients-card-icon-pon{background:linear-gradient(135deg,#0ea5e96b 0%,#38bdf852 100%);box-shadow:0 2px 8px #0ea5e933}:root[data-theme=dark] .clients-card-icon-olt{background:linear-gradient(135deg,#8b5cf66b 0%,#a78bfa52 100%);box-shadow:0 2px 8px #8b5cf633}:root[data-theme=dark] .btn-refresh-sq{color:#c8e0ff;background:linear-gradient(#0a1430f2 0%,#103c788c 100%);border-color:#5981cb80}:root[data-theme=dark] .clients-topbar-badges .metric-badge.metric-total{background:linear-gradient(#0284c757 0%,#08142aed 100%);border-color:#38bdf86b}:root[data-theme=dark] .clients-topbar-badges .metric-badge.metric-geo-ok{background:linear-gradient(#05966957 0%,#08142aed 100%);border-color:#10b9816b}:root[data-theme=dark] .clients-topbar-badges .metric-badge.metric-geo-missing{background:linear-gradient(#dc262652 0%,#08142aed 100%);border-color:#f871716b}:root[data-theme=dark] .clients-error{color:#ffb3b3}:root[data-theme=dark] .clients-empty{color:#b7c9d8}:root[data-theme=light] .pon-clients-page{background-color:var(--app-bg);background-image:radial-gradient(circle at 20% 20%, #00a4e614 0%, transparent 52%), radial-gradient(circle at 80% 80%, #0077b60f 0%, transparent 54%), linear-gradient(#00a4e605 1px, transparent 1px), linear-gradient(90deg, #00a4e605 1px, transparent 1px), linear-gradient(135deg, var(--page-grad-start) 0%, var(--page-grad-end) 100%)}:root[data-theme=light] .clients-header{border-color:var(--light-panel-border);background:linear-gradient(180deg, #fffffff0 0%, #f2faffe6 100%), radial-gradient(circle at top left, #3b82f61a, transparent 40%), radial-gradient(circle at top right, #10b98114, transparent 34%), var(--surface-1);box-shadow:var(--light-inset-glow), var(--light-panel-shadow)}:root[data-theme=light] .clients-title-compact,:root[data-theme=light] .clients-info-card{border-color:var(--light-panel-border-strong);background:linear-gradient(#ecf7fff5 0%,#dcedffeb 100%);box-shadow:inset 0 1px #ffffffdb,0 10px 24px #144a8c1f}:root[data-theme=light] .clients-info-title{color:#102747}:root[data-theme=light] .clients-info-subtitle{color:#4b6f9f}:root[data-theme=light] .clients-title-compact h1{color:#102747}:root[data-theme=light] .clients-subtitle-item{color:#4b6f9f}:root[data-theme=light] .clients-subtitle-dot{color:#5f87bc}:root[data-theme=light] .clients-metrics-row .metric-badge.metric-total{background:linear-gradient(#0e749033 0%,#e0f2fef0 100%);border-color:#0e749057}:root[data-theme=light] .clients-metrics-row .metric-badge.metric-geo-ok{background:linear-gradient(#05966933 0%,#dcfce7f0 100%);border-color:#05966957}:root[data-theme=light] .clients-metrics-row .metric-badge.metric-geo-missing{background:linear-gradient(#dc26262e 0%,#fef2f2f2 100%);border-color:#dc262652}:root[data-theme=light] .clients-topbar-search .search-input.search-input-compact{border-color:var(--light-panel-border);color:#102748;background:#ffffffeb;box-shadow:inset 0 1px #ffffffdb,0 6px 14px #23529814}:root[data-theme=light] .clients-topbar-search .search-input.search-input-compact::placeholder{color:#3c64a080}:root[data-theme=light] .metric-value{color:#102747}:root[data-theme=light] .metric-label{color:#224574db}:root[data-theme=light] .clients-search-icon{background-color:#4b76ab}:root[data-theme=light] .clients-search-wrap .search-input.search-input-compact{border-color:var(--light-panel-border);color:#102748;background:#ffffffeb;box-shadow:inset 0 1px #ffffffdb,0 6px 14px #23529814}:root[data-theme=light] .clients-search-wrap .search-input.search-input-compact::placeholder{color:#4a70a4ad}:root[data-theme=light] .clients-search-wrap .search-input.search-input-compact:focus{box-shadow:0 0 0 3px var(--light-focus-ring), 0 0 18px #3882dc1f;border-color:#3882dcb8}:root[data-theme=light] .btn-back,:root[data-theme=light] .btn-refresh{border-color:var(--light-panel-border-strong);color:#153a72;background:linear-gradient(#e6f3fff0 0%,#cfe6ffe6 100%);box-shadow:inset 0 1px #ffffffd1,0 8px 18px #11498f1f}:root[data-theme=light] .btn-back:hover,:root[data-theme=light] .btn-refresh:hover{color:#0f356f;background:linear-gradient(#d8ecfffa 0%,#beddfff2 100%);border-color:#3882dca8}:root[data-theme=light] .btn-refresh-sq{border-color:var(--light-panel-border-strong);color:#153a72;background:linear-gradient(#e6f3fff0 0%,#cfe6ffe6 100%);box-shadow:inset 0 1px #ffffffd1,0 6px 14px #11498f1f}:root[data-theme=light] .btn-refresh-sq:hover:not(:disabled){color:#0f356f;background:linear-gradient(#d8ecfffa 0%,#beddfff2 100%);border-color:#3882dca8;transform:translateY(-1px)}:root[data-theme=light] .clients-card-icon-pon{background:linear-gradient(135deg,#0ea5e9 0%,#38bdf8 100%);box-shadow:0 2px 10px #0ea5e966}:root[data-theme=light] .clients-card-icon-olt{background:linear-gradient(135deg,#8b5cf6 0%,#a78bfa 100%);box-shadow:0 2px 10px #8b5cf666}:root[data-theme=light] .clients-empty{background:#00a4e614;border-color:#00a4e638}@keyframes applying-pulse{0%{opacity:1;background-color:#3b82f61a}50%{opacity:1;background-color:#3b82f633}to{opacity:1;background-color:#3b82f61a}}.clients-table tr.applying{animation:1.5s ease-in-out infinite applying-pulse}.clients-table tr.applying .applying-indicator{margin-right:6px;font-size:1.1em;animation:1s linear infinite spin;display:inline-block}:root[data-theme=dark] .clients-table tr.applying{background-color:#22c55e1f;animation:1.5s ease-in-out infinite applying-pulse}:root[data-theme=light] .clients-table tr.applying{background-color:#3b82f61f;animation:1.5s ease-in-out infinite applying-pulse}.success-modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;animation:.3s ease-out fade-in;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.success-modal{background:var(--surface-0);text-align:center;border:1px solid var(--border-1);border-radius:16px;width:90%;max-width:450px;padding:40px 36px;animation:.4s cubic-bezier(.34,1.56,.64,1) modal-pop;box-shadow:0 20px 60px #0000004d}.success-icon{color:#22c55e;background:#22c55e26;border-radius:50%;width:66px;height:66px;margin-bottom:12px;font-size:56px;line-height:66px;animation:.6s cubic-bezier(.34,1.56,.64,1) scale-bounce;display:inline-block}.success-title{color:var(--text-1);margin:16px 0 10px;font-size:1.5rem;font-weight:700}.success-message{color:var(--text-2);margin:0 0 6px;font-size:.95rem;line-height:1.6}.success-message strong{color:var(--text-1);word-break:break-word;font-weight:600}.success-subtitle{color:var(--text-3);margin:0 0 14px;font-size:.85rem;font-weight:500}.success-modal-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%);border:none;border-radius:8px;padding:12px 32px;font-size:.95rem;font-weight:600;transition:all .2s;box-shadow:0 4px 12px #3b82f64d}.success-modal-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #3b82f666}.success-modal-btn:active{transform:translateY(0)}.rename-modal-overlay{z-index:1150;background:#0f172a9e;justify-content:center;align-items:center;padding:20px;animation:.25s ease-out fade-in;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.rename-modal{background:var(--surface-0);border:1px solid var(--border-1);border-radius:16px;width:min(620px,100%);padding:22px;animation:.25s ease-out modal-pop;box-shadow:0 24px 60px #02061759}.rename-modal-title{color:var(--text-1);margin:0 0 14px;font-size:1.2rem}.rename-form-group{flex-direction:column;gap:6px;margin-bottom:10px;display:flex}.rename-form-group label{color:var(--text-2);font-size:.9rem;font-weight:600}.rename-modal-input{border:1px solid var(--border-1);background:var(--surface-1);width:100%;color:var(--text-1);border-radius:10px;padding:10px 12px;font-size:.95rem}.rename-modal-input:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 2px #3b82f638}.rename-format-hint{font-size:.78rem}.rename-format-hint.is-valid{color:#16a34a}.rename-format-hint.is-invalid{color:#dc2626}.rename-check-row{color:var(--text-2);align-items:center;gap:8px;margin:10px 0;font-size:.92rem;display:flex}.rename-modal-actions{justify-content:flex-end;gap:10px;margin-top:14px;display:flex}.geogrid-sync-card{text-align:left;border-radius:10px;width:100%;max-width:380px;margin:16px auto 20px;padding:12px 16px;animation:.3s ease-out fade-in}.geogrid-sync-loading{background:#eff6ff;border:1px solid #bfdbfe}.geogrid-sync-success{background:#f0fdf4;border:1px solid #bbf7d0}.geogrid-sync-error{background:#fef2f2;border:1px solid #fecaca}.geogrid-sync-warn{background:#fffbeb;border:1px solid #fde68a}.geogrid-sync-icon-row{align-items:center;gap:8px;display:flex}.geogrid-spinner{border:2px solid #3b82f6;border-top-color:#0000;border-radius:50%;flex-shrink:0;width:14px;height:14px;animation:.7s linear infinite spin}.geogrid-sync-check{color:#fff;background:#22c55e;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;font-size:11px;font-weight:700;display:inline-flex}.geogrid-check-wrap{flex-direction:column;align-items:center;gap:10px;padding:8px 0 4px;animation:.2s ease-out fade-in;display:flex}.geogrid-check-svg{stroke:#22c55e;stroke-width:2.5px;fill:none;width:56px;height:56px}.geogrid-check-circle{stroke-dasharray:166;stroke-dashoffset:166px;stroke-linecap:round;animation:.5s cubic-bezier(.65,0,.45,1) forwards geogrid-stroke}.geogrid-check-mark{stroke-dasharray:48;stroke-dashoffset:48px;stroke-linecap:round;stroke-linejoin:round;animation:.35s cubic-bezier(.65,0,.45,1) .45s forwards geogrid-stroke}@keyframes geogrid-stroke{to{stroke-dashoffset:0}}.geogrid-check-label{color:#15803d;font-size:13px;font-weight:700}.geogrid-check-sublabel{color:#64748b;margin:0;font-size:11px}.geogrid-sync-error-icon{color:#fff;background:#ef4444;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;font-size:12px;font-weight:700;display:inline-flex}.geogrid-sync-warn-icon{color:#fff;background:#f59e0b;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;font-size:13px;font-weight:700;display:inline-flex}.geogrid-sync-label{color:#1e293b;font-size:13px;font-weight:600}.geogrid-sync-sublabel{color:#64748b;text-align:center;margin:4px 0 0;font-size:12px}.geogrid-sync-icon-row{justify-content:center}.geogrid-sync-error-detail{color:#b91c1c;word-break:break-word;margin:4px 0 0 28px;font-size:12px;line-height:1.4}.geogrid-sync-flex{flex-direction:row;justify-content:center;align-items:center;gap:8px;display:flex}.geogrid-sync-flex-content{flex-direction:column;gap:2px;display:flex}.geogrid-sync-flex-content .geogrid-sync-error-detail{margin:0}.geogrid-sync-error-detail-standalone{color:#b91c1c;word-break:break-word;text-align:center;max-width:380px;margin:0 auto 16px;font-size:12px;line-height:1.4}:root[data-theme=dark] .geogrid-sync-error-detail-standalone{color:#fca5a5}.geogrid-sync-card.geogrid-sync-error .geogrid-sync-icon-row{justify-content:center}.geogrid-sync-card.geogrid-sync-error .geogrid-sync-error-detail{text-align:center;margin:6px 0 0}.geogrid-sync-warn .geogrid-sync-label{color:#92400e}.geogrid-sync-warn .geogrid-sync-error-detail{color:#a16207}:root[data-theme=dark] .geogrid-sync-loading{background:#1e293b;border-color:#1e3a5f}:root[data-theme=dark] .geogrid-sync-success{background:#0f261a;border-color:#166534}:root[data-theme=dark] .geogrid-sync-error{background:#2a1215;border-color:#7f1d1d}:root[data-theme=dark] .geogrid-sync-warn{background:#271e0a;border-color:#854d0e}:root[data-theme=dark] .geogrid-sync-label{color:#e2e8f0}:root[data-theme=dark] .geogrid-sync-sublabel{color:#94a3b8}:root[data-theme=dark] .geogrid-sync-error-detail{color:#fca5a5}:root[data-theme=dark] .geogrid-sync-warn .geogrid-sync-label{color:#fde68a}:root[data-theme=dark] .geogrid-sync-warn .geogrid-sync-error-detail{color:#fcd34d}.geogrid-notification{background-color:var(--alert-success-bg);border-left:4px solid var(--brand-500);border-radius:6px;align-items:center;width:-webkit-fit-content;width:-moz-fit-content;width:fit-content;margin:14px auto 20px;padding:6px 12px;display:flex}.geogrid-title{color:var(--brand-500);font-size:12px;font-weight:600;display:inline-block}.geogrid-badge{background-color:var(--chip-bg);color:var(--text-1);vertical-align:middle;border-radius:4px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.geogrid-status{color:var(--text-2);margin:6px 0 0;font-size:13px;line-height:1.4}.geogrid-error-title{color:var(--alert-warning-text);margin:0 0 4px;font-size:12px;font-weight:600}.geogrid-error-message{color:var(--alert-error-text);margin:0;font-size:12px;line-height:1.3}@media (max-width:640px){.success-modal{max-width:95%;max-height:90vh;padding:32px 24px;overflow-y:auto}.success-icon{width:60px;height:60px;margin-bottom:12px;font-size:48px;line-height:60px}.success-title{margin:16px 0 10px;font-size:1.25rem}.success-message{margin:0 0 6px;font-size:.9rem}.success-subtitle{margin:0 0 14px;font-size:.8rem}.success-modal-btn{padding:10px 24px;font-size:.9rem}.rename-modal{padding:16px}.rename-modal-title{margin-bottom:12px;font-size:1.05rem}.rename-modal-actions{grid-template-columns:repeat(2,minmax(0,1fr));display:grid}.rename-modal-actions .btn-cancel,.rename-modal-actions .btn-save{justify-content:center;width:100%}.geogrid-sync-card{max-width:100%;padding:10px 12px}.geogrid-sync-label{font-size:12px}.geogrid-sync-sublabel,.geogrid-sync-error-detail{margin-left:28px;font-size:11px}.geogrid-notification{justify-content:center;align-items:center;margin:10px auto 14px;padding:5px 6px;display:flex}.geogrid-title{font-size:12px!important}.geogrid-badge{font-size:10px!important}.geogrid-status,.geogrid-error-title,.geogrid-error-message{font-size:12px!important}}.delete-modal-overlay{z-index:1100;background:#0f172a9e;justify-content:center;align-items:center;padding:20px;animation:.25s ease-out fade-in;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.delete-modal{background:var(--surface-0);border:1px solid var(--border-1);border-radius:16px;width:min(680px,100%);padding:24px;animation:.25s ease-out modal-pop;box-shadow:0 24px 60px #02061759}.delete-modal-icon{background:#ef444424;border:1px solid #ef444459;border-radius:50%;place-items:center;width:52px;height:52px;margin-bottom:12px;font-size:1.5rem;display:grid}.delete-modal-title{color:var(--text-1);margin:0 0 8px;font-size:1.35rem}.delete-modal-message{color:var(--text-2);margin:0 0 16px;line-height:1.45}.delete-onu-summary{background:var(--surface-1);border:1px solid var(--border-1);border-radius:12px;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;padding:14px;display:grid}.delete-onu-row{flex-direction:column;gap:2px;min-width:0;display:flex}.delete-onu-row span{letter-spacing:.02em;text-transform:uppercase;color:var(--text-3);font-size:.78rem}.delete-onu-row strong{color:var(--text-1);overflow-wrap:anywhere;font-size:.95rem}.delete-modal-warning{color:#dc2626;margin:14px 0 0;font-size:.9rem;font-weight:700}.delete-modal-actions{justify-content:flex-end;gap:10px;margin-top:20px;display:flex}.delete-modal-cancel,.delete-modal-confirm{cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;min-width:132px;min-height:42px;padding:10px 14px;font-weight:600;transition:transform .15s,box-shadow .15s,opacity .2s;display:inline-flex}.delete-modal-cancel{color:var(--text-1);background:var(--surface-1);border:1px solid var(--border-1)}.delete-modal-confirm{color:#fff;background:linear-gradient(135deg,#ef4444 0%,#dc2626 100%);box-shadow:0 8px 20px #dc26264d}.delete-modal-cancel:hover:not(:disabled),.delete-modal-confirm:hover:not(:disabled){transform:translateY(-1px)}.delete-modal-cancel:disabled,.delete-modal-confirm:disabled{cursor:not-allowed;opacity:.7}@media (max-width:720px){.delete-modal{padding:18px}.delete-onu-summary{grid-template-columns:1fr}.delete-modal-actions{flex-direction:column-reverse}.delete-modal-cancel,.delete-modal-confirm{width:100%}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes modal-pop{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@keyframes scale-bounce{0%{transform:scale(0)}50%{transform:scale(1.1)}to{transform:scale(1)}}.reboot-modal-overlay{z-index:1100;background:#0f172a9e;justify-content:center;align-items:center;padding:20px;animation:.25s ease-out fade-in;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.reboot-modal{background:var(--surface-0);border:1px solid var(--border-1);border-radius:16px;width:min(680px,100%);padding:24px;animation:.25s ease-out modal-pop;box-shadow:0 24px 60px #02061759}.reboot-modal-icon{color:#ef4444;background:#ef444424;border:1px solid #ef444459;border-radius:50%;place-items:center;width:52px;height:52px;margin-bottom:12px;display:grid}.reboot-modal-title{color:var(--text-1);margin:0 0 8px;font-size:1.35rem}.reboot-modal-message{color:var(--text-2);margin:0 0 16px;line-height:1.45}.reboot-onu-summary{background:var(--surface-1);border:1px solid var(--border-1);border-radius:12px;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;padding:14px;display:grid}.reboot-onu-row{flex-direction:column;gap:2px;min-width:0;display:flex}.reboot-onu-row span{letter-spacing:.02em;text-transform:uppercase;color:var(--text-3);font-size:.78rem}.reboot-onu-row strong{color:var(--text-1);overflow-wrap:anywhere;font-size:.95rem}.reboot-modal-warning{color:#f59e0b;margin:14px 0 0;font-size:.9rem;font-weight:700}.reboot-modal-actions{justify-content:flex-end;gap:10px;margin-top:20px;display:flex}.reboot-modal-cancel,.reboot-modal-confirm{cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;min-width:132px;min-height:42px;padding:10px 14px;font-weight:600;transition:transform .15s,box-shadow .15s,opacity .2s;display:inline-flex}.reboot-modal-cancel{color:var(--text-1);background:var(--surface-1);border:1px solid var(--border-1)}.reboot-modal-confirm{color:#fff;background:linear-gradient(135deg,#ef4444 0%,#dc2626 100%);box-shadow:0 8px 20px #dc26264d}.reboot-modal-cancel:hover:not(:disabled),.reboot-modal-confirm:hover:not(:disabled){transform:translateY(-1px)}.reboot-modal-cancel:disabled,.reboot-modal-confirm:disabled{cursor:not-allowed;opacity:.7}@media (max-width:720px){.reboot-modal{padding:18px}.reboot-onu-summary{grid-template-columns:1fr}.reboot-modal-actions{flex-direction:column-reverse}.reboot-modal-cancel,.reboot-modal-confirm{width:100%}}.clients-col-config{text-align:center;white-space:nowrap}.config-actions-row{justify-content:center;align-items:center;gap:8px;display:inline-flex}.config-svg-icon{pointer-events:none;width:16px;height:16px;display:block}.btn-config-icon{border:1.5px solid var(--border-1);cursor:pointer;background:var(--surface-1);width:38px;min-width:38px;height:38px;min-height:38px;color:var(--text-3);-webkit-tap-highlight-color:transparent;border-radius:10px;justify-content:center;align-items:center;padding:0;font-size:0;transition:all .25s cubic-bezier(.4,0,.2,1);display:inline-flex;position:relative;box-shadow:0 1px 3px #0000000f}.btn-config-icon:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #0000001f}.btn-tr069{color:var(--brand-500,#00a4e6);background:#00a4e60f;border-color:#00a4e640}.btn-tr069:hover:not(:disabled){color:#08c;background:#00a4e626;border-color:#00a4e680;box-shadow:0 4px 14px #00a4e633}.btn-voip{color:#a855f7;background:#a855f70f;border-color:#a855f740}.btn-voip:hover:not(:disabled){color:#9333ea;background:#a855f726;border-color:#a855f780;box-shadow:0 4px 14px #a855f733}.btn-reboot{color:#ef4444;background:#ef44440f;border-color:#ef444440}.btn-reboot:hover:not(:disabled){color:#dc2626;background:#ef444426;border-color:#ef444480;box-shadow:0 4px 14px #ef444433}.btn-rbx-ip{color:#10b981;background:#10b9810f;border-color:#10b98140}.btn-rbx-ip:hover:not(:disabled){color:#059669;background:#10b98126;border-color:#10b98180;box-shadow:0 4px 14px #10b98133}.rbx-session-info{flex-wrap:wrap;align-items:center;gap:8px;margin-top:4px;font-size:.72rem;line-height:1.4;display:flex}.rbx-ip-link{color:#10b981;letter-spacing:.01em;align-items:center;gap:4px;font-weight:600;text-decoration:none;transition:color .15s;display:inline-flex}.rbx-ip-link:hover{color:#059669;text-decoration:underline}.rbx-ip-icon{flex-shrink:0;width:12px;height:12px}@media (max-width:900px){.clients-table td.clients-col-status{justify-content:space-between}.clients-table td.clients-col-status .status-stack{justify-items:end;width:172px}.clients-table td.clients-col-status .status-badge{max-width:100%}.clients-table td.clients-col-status .status-loading,.clients-table td.clients-col-status .status-badge.rbx-ip-badge{width:160px}}.btn-config-icon.is-loading{opacity:.6;pointer-events:none;animation:1.2s ease-in-out infinite pulse}.btn-config-icon:disabled{opacity:.35;cursor:not-allowed;box-shadow:none;transform:none}.config-spinner{border:2px solid var(--border-1);border-top-color:var(--brand-500);border-radius:50%;width:16px;height:16px;animation:.7s linear infinite spin;display:block}.voip-modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0000008c;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.voip-modal{background:var(--surface-1);border:1px solid var(--border-1);border-radius:16px;width:100%;max-width:440px;padding:28px 32px;animation:.25s slideUp;box-shadow:0 20px 60px #0000004d}.voip-modal-title{color:var(--text-1);text-align:center;margin:0 0 18px;font-size:1.15rem;font-weight:700}.voip-onu-summary{background:var(--surface-2,#0000000d);border-radius:10px;flex-direction:column;gap:6px;margin-bottom:18px;padding:12px 16px;display:flex}.voip-onu-row{color:var(--text-2);justify-content:space-between;align-items:center;font-size:.85rem;display:flex}.voip-onu-row strong{color:var(--text-1);font-weight:600}.voip-form-group{margin-bottom:14px}.voip-form-group label{color:var(--text-2);margin-bottom:6px;font-size:.82rem;font-weight:600;display:block}.voip-modal-input{border:1px solid var(--border-1);background:var(--input-bg,var(--surface-1));width:100%;color:var(--text-1);box-sizing:border-box;border-radius:10px;outline:none;padding:10px 14px;font-size:.9rem;transition:border-color .2s,box-shadow .2s}.voip-modal-input:focus{border-color:var(--brand-500);box-shadow:0 0 0 3px #00a4e626}.voip-modal-actions{justify-content:flex-end;gap:10px;margin-top:20px;display:flex}.action-feedback-toast{color:#fff;z-index:1100;border-radius:12px;align-items:center;gap:10px;max-width:420px;padding:12px 20px;font-size:.88rem;font-weight:500;animation:.3s slideUp,.3s fadeIn;display:flex;position:fixed;bottom:24px;right:24px;box-shadow:0 8px 30px #00000040}.action-feedback-toast.success{background:linear-gradient(135deg,#059669,#10b981)}.action-feedback-toast.error{background:linear-gradient(135deg,#dc2626,#ef4444)}.action-feedback-icon{flex-shrink:0;font-size:1.1rem;font-weight:700}.action-feedback-message{word-break:break-word;flex:1;min-width:0}.action-feedback-close{color:#ffffffbf;cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:2px 4px;font-size:1.2rem;line-height:1}.action-feedback-close:hover{color:#fff}.onu-consulta-page{background:radial-gradient(circle at 10% 20%, #00a4e612 0%, transparent 45%), radial-gradient(circle at 90% 80%, #0284c712 0%, transparent 50%), linear-gradient(135deg, var(--page-grad-start) 0%, var(--page-grad-end) 100%);min-height:100vh;padding:20px 0 32px}.onu-consulta-container{flex-direction:column;gap:12px;max-width:1600px;margin:0 auto;padding:0 18px;display:flex}.onu-consulta-header{background:linear-gradient(180deg, #08234ae6 0%, #051b3adb 100%), radial-gradient(circle at top left, #00a4e633, transparent 40%), radial-gradient(circle at top right, #0077b629, transparent 34%), var(--surface-1);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid #38bdf838;border-radius:16px;grid-template-columns:minmax(0,1fr) auto;align-items:stretch;gap:12px;padding:12px;display:grid;box-shadow:0 12px 28px #02061752,inset 0 1px #ffffff0a}.onu-consulta-title-block{flex-direction:column;justify-content:center;gap:4px;min-width:0;padding:2px 0;display:flex}.onu-consulta-title-block h1{letter-spacing:-.03em;color:#edf4ff;white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:1.35rem;font-weight:800;line-height:1;overflow:hidden}.onu-consulta-title-block p{color:#7ea2db;white-space:nowrap;text-overflow:ellipsis;margin:3px 0 0;font-size:.82rem;font-weight:700;overflow:hidden}.onu-consulta-refresh{color:#edf4ff;cursor:pointer;white-space:nowrap;background:linear-gradient(#070f22eb 0%,#10498885 100%);border:1px solid #5981cb73;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;gap:10px;min-width:132px;min-height:36px;padding:9px 14px;font-size:.76rem;font-weight:700;transition:border-color .2s,color .2s,background-color .2s,transform .18s,box-shadow .2s;display:inline-flex;box-shadow:inset 0 1px #6f9aff29,0 8px 18px #0000004d}.onu-consulta-refresh:hover:not(:disabled){color:#f3fbff;background:linear-gradient(#104988b8 0%,#0d234feb 100%);border-color:#8be0ffd1;transform:translateY(-1px);box-shadow:0 0 0 1px #50b4ff1f,0 14px 24px #00000052}.onu-consulta-refresh:active:not(:disabled){background:#00a4e61a}.onu-consulta-refresh:disabled{opacity:.6;cursor:not-allowed}.onu-refresh-icon{text-align:center;transform-origin:50%;width:18px;min-width:18px;height:18px;min-height:18px;line-height:1;display:inline-block}.onu-refresh-icon svg{width:18px;height:18px;display:block}.onu-refresh-label{text-align:center;min-width:88px;line-height:1;display:inline-block}.onu-refresh-icon.is-spinning{animation:.9s linear infinite spin}.onu-consulta-toolbar{background:linear-gradient(180deg, #0f172ac2 0%, #0f172aa8 100%), radial-gradient(circle at top left, #3b82f61f, transparent 40%), var(--surface-1);border:1px solid #38bdf838;border-radius:16px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;padding:12px;display:grid;box-shadow:0 12px 28px #0206173d,inset 0 1px #ffffff0a}.onu-consulta-search-wrap{flex:1;align-items:center;min-width:220px;max-width:none;display:flex;position:relative}.onu-search-icon{pointer-events:none;opacity:.82;background-color:#7ea2db;justify-content:center;align-items:center;width:16px;height:16px;display:inline-flex;position:absolute;left:12px;-webkit-mask-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 16 16' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='7' cy='7' r='4.75' fill='none' stroke='black' stroke-width='1.6'/%3E%3Cline x1='10.6' y1='10.6' x2='14.25' y2='14.25' stroke='black' stroke-width='1.6' stroke-linecap='round'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 16 16' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='7' cy='7' r='4.75' fill='none' stroke='black' stroke-width='1.6'/%3E%3Cline x1='10.6' y1='10.6' x2='14.25' y2='14.25' stroke='black' stroke-width='1.6' stroke-linecap='round'/%3E%3C/svg%3E");-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat}.onu-consulta-search{color:#f8fbff;background:#070f22cc;border:1px solid #5981cb73;border-radius:12px;width:100%;padding:10px 36px 10px 40px;font-size:.86rem;box-shadow:inset 0 1px #6f9aff1f,0 6px 16px #00000024}.onu-consulta-search:focus{border-color:#8be0ffd1;outline:none;box-shadow:0 0 0 3px #50b4ff2e,0 0 18px #50b4ff24}.onu-search-clear{cursor:pointer;color:var(--text-3);background:0 0;border:none;border-radius:4px;padding:2px 4px;font-size:.8rem;position:absolute;right:10px}.onu-search-clear:hover{color:var(--text-1);background:var(--surface-2)}.onu-consulta-stats{flex-wrap:wrap;flex-shrink:0;justify-content:flex-end;align-items:center;gap:6px;display:flex}.onu-stat-chip{white-space:nowrap;border:1px solid #0000;border-radius:10px;padding:7px 11px;font-size:.76rem;font-weight:700}.onu-stat-chip.total{background:var(--surface-1);color:var(--brand-500);border-color:var(--border-1)}.onu-stat-chip.online{color:var(--status-online);background:#10b9811f;border-color:#10b9814d}.onu-stat-chip.offline{color:var(--status-offline);background:#ef44441a;border-color:#ef444440}.onu-stat-chip.critical{color:var(--att-warning);background:#f59e0b24;border-color:#f59e0b47}.onu-stat-chip-link{cursor:pointer;transition:filter .15s,transform .15s}.onu-stat-chip-link:hover{filter:brightness(1.15);transform:translateY(-1px)}.onu-stat-chip-link.is-active{transform:translateY(-1px);box-shadow:inset 0 0 0 1px #0003,0 4px 12px #00000024}.onu-consulta-info,.onu-consulta-error{border-radius:10px;padding:12px 14px;font-size:.9rem;font-weight:600}.onu-consulta-info{background:var(--surface-1);color:var(--text-2);border:1px solid var(--border-1)}.onu-consulta-error{color:var(--status-offline);background:#ef44441f;border:1px solid #ef444459}.onu-consulta-table-wrap{background:var(--surface-1);border:1px solid var(--border-1);-webkit-overflow-scrolling:touch;border-radius:12px;overflow:auto;box-shadow:0 2px 12px #00000014}.onu-consulta-table{border-collapse:collapse;table-layout:fixed;width:100%;min-width:1320px}.onu-consulta-table thead tr{background:var(--surface-2)}.onu-consulta-table th{text-align:left;color:var(--text-2);text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--border-1);white-space:nowrap;padding:11px 10px;font-size:.72rem;font-weight:700}.onu-th-sort-btn{color:inherit;font:inherit;letter-spacing:inherit;text-transform:inherit;cursor:pointer;background:0 0;border:none;align-items:center;gap:5px;margin:0;padding:0;display:inline-flex}.onu-th-sort-btn:hover,.onu-th-sort-btn.is-active{color:var(--brand-500)}.onu-th-sort-arrow{font-size:.8rem;line-height:1}.onu-consulta-table tbody tr{border-bottom:1px solid var(--border-2);transition:background .15s}.onu-consulta-table tbody tr:hover{background:var(--surface-2)}.onu-consulta-table tbody tr:last-child{border-bottom:none}.onu-consulta-table td{color:var(--text-1);vertical-align:middle;white-space:normal;padding:9px 10px;font-size:.86rem;overflow:visible}.col-num{text-align:center;width:44px;color:var(--text-3);padding:9px 4px;font-size:.78rem}.col-name{width:300px}.col-serial,.col-olt{width:190px}.col-pon{width:92px}.col-id{width:64px}.col-geo{text-align:center;width:92px}.col-status{width:104px}.col-att{width:118px}.col-date{width:150px;color:var(--text-3);font-size:.8rem}.col-action{text-align:center;width:120px}.onu-go-pon-btn{color:var(--brand-500);cursor:pointer;white-space:nowrap;background:#00a4e61a;border:1px solid #00a4e659;border-radius:7px;padding:5px 9px;font-size:.76rem;font-weight:700;transition:all .18s}.onu-go-pon-btn:hover:not(:disabled){background:#00a4e62e;transform:translateY(-1px)}.onu-go-pon-btn:disabled{opacity:.5;cursor:not-allowed}.onu-cell-trunc{text-overflow:unset;white-space:normal;word-break:break-word;align-items:center;gap:8px;max-width:100%;display:flex;overflow:visible}.onu-client-name{color:var(--text-1);font-weight:600}.onu-consulta-page .onu-consulta-table tbody tr td.col-name,.onu-consulta-page .onu-consulta-table tbody tr td.col-name .onu-cell-trunc,.onu-consulta-page .onu-consulta-table tbody tr td.col-name .onu-client-name,.onu-consulta-page .onu-consulta-table tbody tr:hover td.col-name,.onu-consulta-page .onu-consulta-table tbody tr:hover td.col-name .onu-cell-trunc,.onu-consulta-page .onu-consulta-table tbody tr:hover td.col-name .onu-client-name{color:#0f172a!important;opacity:1!important}:root[data-theme=dark] .onu-consulta-page .onu-consulta-table tbody tr td.col-name,:root[data-theme=dark] .onu-consulta-page .onu-consulta-table tbody tr td.col-name .onu-cell-trunc,:root[data-theme=dark] .onu-consulta-page .onu-consulta-table tbody tr td.col-name .onu-client-name,:root[data-theme=dark] .onu-consulta-page .onu-consulta-table tbody tr:hover td.col-name,:root[data-theme=dark] .onu-consulta-page .onu-consulta-table tbody tr:hover td.col-name .onu-cell-trunc,:root[data-theme=dark] .onu-consulta-page .onu-consulta-table tbody tr:hover td.col-name .onu-client-name{color:var(--text-1)!important}:root[data-theme=light] .onu-consulta-page .onu-consulta-table td.col-name,:root[data-theme=light] .onu-consulta-page .onu-consulta-table td.col-name .onu-cell-trunc,:root[data-theme=light] .onu-consulta-page .onu-consulta-table td.col-name .onu-client-name{color:#0f172a!important}:root[data-theme=light] .onu-consulta-page{background:radial-gradient(circle at 10% 20%, #00a4e614 0%, transparent 45%), radial-gradient(circle at 90% 80%, #0284c714 0%, transparent 50%), linear-gradient(135deg, var(--page-grad-start) 0%, var(--page-grad-end) 100%)}:root[data-theme=light] .onu-consulta-header,:root[data-theme=light] .onu-consulta-toolbar{border:1px solid var(--light-panel-border);background:linear-gradient(180deg, #fffffff0 0%, #f2faffe6 100%), radial-gradient(circle at top left, #3b82f61a, transparent 42%), var(--surface-1);box-shadow:var(--light-inset-glow), var(--light-panel-shadow)}:root[data-theme=light] .onu-consulta-title-block h1{color:#0f1f3a}:root[data-theme=light] .onu-consulta-title-block p{color:#4b6f9f}:root[data-theme=light] .onu-consulta-refresh{border-color:var(--light-panel-border-strong);color:#153a72;background:linear-gradient(#e6f3fff0 0%,#cfe6ffe6 100%);box-shadow:inset 0 1px #ffffffd1,0 8px 18px #11498f1f}:root[data-theme=light] .onu-consulta-refresh:hover:not(:disabled){color:#0f356f;background:linear-gradient(#d8ecfffa 0%,#beddfff2 100%);border-color:#3882dca8;box-shadow:0 0 0 2px #3882dc1f,0 10px 20px #11498f26}:root[data-theme=light] .onu-search-icon{background-color:#4b76ab}:root[data-theme=light] .onu-consulta-search{border-color:var(--light-panel-border);color:#102748;background:#ffffffeb;box-shadow:inset 0 1px #ffffffdb,0 6px 14px #23529814}:root[data-theme=light] .onu-consulta-search::placeholder{color:#4a70a4ad}:root[data-theme=light] .onu-consulta-search:focus{box-shadow:0 0 0 3px var(--light-focus-ring), 0 0 18px #3882dc1f;border-color:#3882dcb8}:root[data-theme=light] .onu-consulta-table-wrap{background:var(--light-panel-bg-strong);border-color:var(--light-panel-border);box-shadow:var(--light-inset-glow), 0 10px 24px #1836661a}:root[data-theme=light] .onu-consulta-table thead tr{background:#e2effce0}:root[data-theme=light] .onu-consulta-table th{color:#476a97;border-bottom-color:#6691cd4d}:root[data-theme=light] .onu-consulta-table tbody tr:hover{background:#00a4e612}.onu-serial{max-width:100%;color:var(--text-2);background:var(--surface-2);letter-spacing:.3px;word-break:break-all;border-radius:5px;padding:2px 6px;font-family:Courier New,monospace;font-size:.8rem;display:inline-block}.onu-olt-wrap{overflow:visible}.onu-olt-name{color:var(--text-1);white-space:normal;word-break:break-word;font-size:.86rem;font-weight:600}.onu-olt-ip{color:var(--text-3);white-space:normal;word-break:break-all;font-family:Courier New,monospace;font-size:.76rem}.onu-pon-chip{color:var(--brand-500);white-space:nowrap;background:#00a4e61a;border:1px solid #00a4e638;border-radius:6px;padding:2px 7px;font-family:Courier New,monospace;font-size:.78rem;font-weight:700;display:inline-block}.onu-status{white-space:nowrap;border-radius:999px;align-items:center;gap:5px;padding:4px 9px;font-size:.76rem;font-weight:700;display:inline-flex}.onu-status-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.onu-geo-only-icon{background-color:currentColor;flex-shrink:0;width:16px;height:16px;display:inline-block;-webkit-mask-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 16 16' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M16 1L15 0L0 6V8L7 9L8 16H10L16 1Z'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 16 16' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M16 1L15 0L0 6V8L7 9L8 16H10L16 1Z'/%3E%3C/svg%3E");-webkit-mask-position:50%;mask-position:50%;-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat}.onu-geo-ok{color:#10b981}.onu-geo-missing{color:#ef4444}.col-geo{vertical-align:middle;text-align:center!important}.col-geo .onu-geo-only-icon{vertical-align:middle;margin:0;display:inline-flex}.onu-status.online{color:var(--status-online);background:#10b98124}.onu-status.online .onu-status-dot{background:#10b981;animation:2s infinite pulse-dot}.onu-status.offline{color:var(--status-offline);background:#ef44441f}.onu-status.offline .onu-status-dot{background:#ef4444}.onu-status.unknown{background:var(--chip-bg);color:var(--text-2)}.onu-status.unknown .onu-status-dot{background:var(--text-3)}.onu-att{white-space:nowrap;border-radius:999px;padding:3px 8px;font-family:Courier New,monospace;font-size:.8rem;font-weight:600}.onu-att.good{color:var(--att-good);background:#10b98124}.onu-att.warning{color:var(--att-warning);background:#f59e0b26}.onu-att.critical{color:var(--att-critical);background:#ef444421}.onu-att.unknown{background:var(--chip-bg);color:var(--text-2)}@media (max-width:820px){.onu-consulta-header{grid-template-columns:1fr}.onu-consulta-toolbar{flex-direction:column;grid-template-columns:1fr;align-items:stretch}.onu-consulta-stats{justify-content:flex-start}.onu-consulta-refresh{justify-self:stretch;width:100%}}@media (max-width:540px){.onu-consulta-container{padding:0 14px}.onu-consulta-header,.onu-consulta-toolbar{border-radius:14px;padding:10px}.onu-consulta-title-block h1{font-size:1.2rem}.onu-consulta-title-block p{font-size:.78rem}.onu-consulta-refresh{justify-content:center;width:100%;min-width:0;padding:9px 12px}.onu-refresh-label{min-width:86px;font-size:.74rem}.onu-stat-chip{font-size:.72rem}.onu-consulta-search{min-height:40px}}@media (max-width:768px){.onu-consulta-table-wrap{box-shadow:none;background:0 0;border:none;border-radius:0;overflow:visible}.onu-consulta-table,.onu-consulta-table thead,.onu-consulta-table tbody,.onu-consulta-table th,.onu-consulta-table td,.onu-consulta-table tr{display:block;width:auto!important}.onu-consulta-table{min-width:unset}.onu-consulta-table thead{display:none}.onu-consulta-table tbody tr{background:var(--surface-1);border:1px solid var(--border-1);cursor:pointer;border-radius:10px;grid-template-columns:60px minmax(0,1fr);margin-bottom:10px;display:grid;overflow:hidden}.onu-consulta-table td{white-space:normal;border-bottom:1px solid var(--border-2);text-align:right;justify-content:space-between;align-items:center;gap:8px;padding:9px 14px;font-size:.88rem;display:flex;overflow:visible}.onu-consulta-table tbody tr td:last-child{border-bottom:none}.onu-consulta-table td:before{content:attr(data-label);text-transform:uppercase;letter-spacing:.4px;color:var(--text-2);white-space:nowrap;text-align:left;flex-shrink:0;margin-right:auto;padding-right:8px;font-size:.72rem;font-weight:700}.onu-consulta-table td.col-num{background:var(--surface-2);border-right:1px solid var(--border-2);border-bottom:2px solid var(--border-1);color:var(--text-1);text-align:center;justify-content:center;padding:6px 0;font-size:.82rem;font-weight:700}.onu-consulta-table td.col-name{background:var(--surface-2);border-bottom:2px solid var(--border-1);text-align:left;justify-content:flex-start;padding:6px 38px 6px 6px;position:relative}.onu-consulta-table td.col-name:before,.onu-consulta-table td.col-num:before{content:none}.onu-consulta-table td.col-name:after{content:"▾";color:var(--text-3);font-size:.9rem;transition:transform .18s,color .18s;position:absolute;top:50%;right:14px;transform:translateY(-50%)}.onu-consulta-table tbody tr.mobile-expanded td.col-name:after{color:var(--brand-500);transform:translateY(-50%)rotate(180deg)}.onu-consulta-table tbody tr td:not(.col-num):not(.col-name){grid-column:1/-1}.onu-consulta-table tbody tr:not(.mobile-expanded) td:not(.col-num):not(.col-name){display:none}.onu-consulta-table tbody tr:not(.mobile-expanded) td.col-name{border-bottom:2px solid var(--border-1)}.onu-consulta-table td.col-pon{background:#00a4e60f}.onu-consulta-table td.col-pon:before{color:var(--brand-500)}.onu-consulta-table td.col-status.online{background:#10b98112}.onu-consulta-table td.col-status.online:before{color:var(--status-online)}.onu-consulta-table td.col-status.offline{background:#ef444414}.onu-consulta-table td.col-status.offline:before{color:var(--status-offline)}.onu-consulta-table td.col-status.unknown{background:#94a3b814}.onu-consulta-table td.col-status.unknown:before{color:var(--text-2)}.onu-consulta-table td.col-att.good{background:#10b98112}.onu-consulta-table td.col-att.good:before{color:var(--att-good)}.onu-consulta-table td.col-att.warning{background:#f59e0b14}.onu-consulta-table td.col-att.warning:before{color:var(--att-warning)}.onu-consulta-table td.col-att.critical{background:#ef444414}.onu-consulta-table td.col-att.critical:before{color:var(--att-critical)}.onu-consulta-table td.col-att.unknown{background:#94a3b814}.onu-consulta-table td.col-att.unknown:before{color:var(--text-2)}.onu-consulta-table td .onu-cell-trunc{white-space:normal;text-overflow:unset;text-align:right;flex:1;min-width:0;overflow:visible}.onu-consulta-table td.col-name .onu-cell-trunc{text-align:left}.onu-consulta-table td.col-num .onu-cell-trunc{text-align:center;flex:0 auto}.onu-olt-wrap{text-align:right;overflow:visible}.onu-olt-name,.onu-olt-ip{white-space:normal;text-overflow:unset;overflow:visible}.onu-pon-chip,.onu-status,.onu-att,.onu-go-pon-btn{margin-left:auto}}.onu-pagination{flex-wrap:wrap;justify-content:center;align-items:center;gap:14px;padding:12px 0 4px;display:flex}.onu-page-btn{border:1px solid var(--border-1);background:var(--surface-1);color:var(--brand-500);cursor:pointer;white-space:nowrap;border-radius:8px;padding:7px 16px;font-size:.85rem;font-weight:700;transition:background .15s,border-color .15s}.onu-page-btn:hover:not(:disabled){background:var(--surface-2);border-color:var(--brand-500)}.onu-page-btn:disabled{opacity:.4;cursor:not-allowed}.onu-page-info{color:var(--text-2);font-size:.85rem;font-weight:600}.onu-page-total{color:var(--text-3);font-weight:400}.provisioned-onu-table{table-layout:fixed;width:100%;min-width:0}.provisioned-onu-table th,.provisioned-onu-table td{text-overflow:ellipsis;white-space:nowrap;padding:7px 6px;font-size:.74rem;overflow:hidden}.provisioned-table-wrap{overflow:hidden}.provisioned-table-wrap .col-num{width:2.2%;padding-left:4px;padding-right:4px}.provisioned-table-wrap .col-name{width:19%}.provisioned-table-wrap .col-serial,.provisioned-table-wrap .col-olt{width:12%}.provisioned-table-wrap .col-pon{width:5%}.provisioned-table-wrap .col-id{width:4%}.provisioned-onu-table .col-pppoe-user,.provisioned-onu-table .col-pppoe-pass{width:7%}.provisioned-onu-table .col-phone-user{width:6%}.provisioned-onu-table .col-phone-pass{width:7%}.provisioned-onu-table .col-mode{width:5%}.provisioned-onu-table .col-by{width:8%}.provisioned-onu-table .col-date{width:8.8%}.provisioned-table-wrap .onu-olt-name,.provisioned-table-wrap .onu-olt-ip{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.provisionar-onu-page{background:radial-gradient(circle at 8% 10%, #00a4e614 0%, transparent 42%), radial-gradient(circle at 92% 90%, #0284c714 0%, transparent 48%), linear-gradient(135deg, var(--page-grad-start) 0%, var(--page-grad-end) 100%);min-height:100vh;padding:20px 0 32px}.provisionar-onu-container{flex-direction:column;gap:14px;max-width:1260px;margin:0 auto;padding:0 18px;display:flex}.provisionar-onu-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:14px;display:flex}.provisionar-onu-header h1{color:var(--text-1);margin:0;font-size:1.35rem;font-weight:700}.provisionar-onu-header p{color:var(--text-2);margin:4px 0 0;font-size:.92rem}.provisionar-onu-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.provisionar-onu-select{border:1px solid var(--border-1);background:var(--surface-1);min-width:210px;height:38px;color:var(--text-1);border-radius:9px;padding:0 10px;font-size:.88rem}.provisionar-onu-select:focus{border-color:var(--brand-500);outline:none;box-shadow:0 0 0 3px #00a4e629}.provisionar-onu-refresh-btn{border:1px solid var(--brand-500);background:var(--brand-500);color:#fff;cursor:pointer;border-radius:9px;height:38px;padding:0 14px;font-size:.88rem;font-weight:700}.provisionar-onu-refresh-btn:disabled,.provisionar-onu-clear-btn:disabled{opacity:.65;cursor:not-allowed}.provisionar-onu-clear-btn{height:38px;color:var(--alert-error-text);cursor:pointer;background:#ef444414;border:1px solid #ef444442;border-radius:9px;padding:0 12px;font-size:.83rem;font-weight:700}.provisionar-onu-card{background:var(--surface-1);border:1px solid var(--border-1);border-radius:12px;padding:16px;box-shadow:0 6px 18px #00000014}.provisionar-onu-status-card{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;display:grid}.provisionar-onu-status-chip{border:1px solid var(--border-1);background:var(--surface-0);border-radius:10px;flex-direction:column;gap:3px;padding:10px 12px;display:flex}.provisionar-onu-status-chip .label{color:var(--text-2);text-transform:uppercase;letter-spacing:.04em;font-size:.76rem;font-weight:700}.provisionar-onu-status-chip strong{color:var(--text-1);font-size:.95rem}.provisionar-onu-alert{border-radius:10px;padding:11px 12px;font-size:.88rem;font-weight:600}.provisionar-onu-alert.warning{color:var(--alert-warning-text);background:#f59e0b1f;border:1px solid #f59e0b61}.provisionar-onu-alert.error{color:var(--alert-error-text);background:#ef44441f;border:1px solid #ef444459}.provisionar-onu-alert.success{color:var(--alert-success-text);background:#22c55e1f;border:1px solid #22c55e59}.provisionar-onu-table-wrap{background:var(--surface-1);border:1px solid var(--border-1);border-radius:12px;overflow:auto;box-shadow:0 8px 20px #00000014}.provisionar-onu-table{border-collapse:collapse;width:100%;min-width:900px}.provisionar-onu-table thead tr{background:var(--surface-2)}.provisionar-onu-table th{text-align:left;letter-spacing:.04em;text-transform:uppercase;color:var(--text-2);border-bottom:1px solid var(--border-1);padding:10px 12px;font-size:.74rem;font-weight:800}.provisionar-onu-table td{border-bottom:1px solid var(--border-1);color:var(--text-1);vertical-align:top;padding:11px 12px;font-size:.88rem}.provisionar-onu-table tbody tr:hover{background:#00a4e60f}.provisionar-onu-table tbody tr.is-expanded td{background:#00a4e61f;border-bottom:none;animation:1.6s ease-in-out infinite provisionar-onu-row-pulse}.provisionar-onu-table tbody tr.is-expanded td:first-child{box-shadow:inset 3px 0 #00a4e6e6}.provisionar-onu-table tbody tr.provisionar-onu-inline-row:hover{background:0 0}.provisionar-onu-inline-row td{border-bottom:1px solid var(--border-1);background:#00a4e614;padding:0 10px 10px;animation:1.6s ease-in-out infinite provisionar-onu-colspan-pulse}.provisionar-onu-table tbody tr.provisionar-onu-inline-row .provisionar-onu-inline-panel{animation:1.6s ease-in-out infinite provisionar-onu-colspan-panel-pulse}.provisionar-onu-olt-cell{flex-direction:column;gap:2px;display:flex}.provisionar-onu-olt-cell span{color:var(--text-2);font-size:.8rem}.provisionar-onu-table .mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.provisionar-onu-cell-action{white-space:nowrap}.provisionar-onu-serial-cell{flex-direction:column;gap:3px;display:flex}.provisionar-onu-compat-cell{flex-direction:column;gap:4px;display:flex}.provisionar-onu-compat-chip{letter-spacing:.02em;border:1px solid #0000;border-radius:999px;justify-content:center;align-items:center;width:-webkit-fit-content;width:-moz-fit-content;width:fit-content;padding:2px 8px;font-size:.72rem;font-weight:700;display:inline-flex}.provisionar-onu-compat-chip.is-compatible{color:var(--alert-success-text);background:#22c55e1f;border-color:#22c55e59}.provisionar-onu-compat-chip.is-incompatible{color:var(--alert-warning-text);background:#fb923c24;border-color:#fb923c66}.provisionar-onu-compat-message{color:var(--text-2);font-size:.73rem;line-height:1.25}.provisionar-onu-card h2{color:var(--text-1);margin:0;font-size:1rem}.provisionar-onu-card p{color:var(--text-2);margin:8px 0 0;line-height:1.5}.provisionar-onu-inline-panel{background:var(--surface-1);border:1px solid var(--border-1);border-radius:10px;padding:0;overflow:hidden;box-shadow:0 6px 16px #00000017}.provisionar-onu-inline-header{border-bottom:1px solid var(--border-1);background:linear-gradient(135deg,#00a4e60d 0%,#0284c705 100%);justify-content:flex-start;align-items:center;gap:8px;padding:8px 14px;display:flex}.provisionar-onu-header-vlan{background:linear-gradient(#0284c714 0%,#0284c708 100%);border:1px solid #0284c733;border-radius:8px;width:100%;min-width:240px;max-width:380px;padding:6px 8px}.provisionar-onu-header-vlan-row{flex-direction:row;justify-content:flex-start;align-items:center;gap:8px;display:flex}.provisionar-onu-header-vlan-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-1);font-size:.64rem;font-weight:800}.provisionar-onu-header-vlan-input{text-align:left;flex:200px;width:auto;min-width:185px;height:28px;padding:0 28px 0 10px}.provisionar-onu-inline-content{padding:12px 14px 14px}.provisionar-onu-inline-form-grid{grid-template-columns:repeat(2,minmax(220px,1fr));gap:8px 10px;display:grid}.provisionar-onu-inline-help{color:var(--text-2);font-size:.72rem}.provisionar-onu-form-section{margin-bottom:12px}.provisionar-onu-form-section:last-child{margin-bottom:0}.provisionar-onu-form-section-title{color:var(--text-2);text-transform:uppercase;letter-spacing:.05em;margin-bottom:7px;font-size:.68rem;font-weight:800;display:block}.provisionar-onu-coord-fields{margin-top:6px}.provisionar-onu-coord-row{gap:8px;display:flex}.provisionar-onu-coord-group{flex:1;min-width:0}.provisionar-onu-coord-hint{color:var(--text-3);margin-top:4px;font-size:.65rem;display:block}.provisionar-onu-info-grid{grid-template-columns:1fr 1fr;gap:7px 8px;margin-bottom:4px;display:grid}.provisionar-onu-info-field{border:1px solid var(--border-1);background:var(--surface-0);border-radius:7px;flex-direction:column;gap:1px;padding:7px 8px;display:flex}.provisionar-onu-info-field label{color:var(--text-2);text-transform:uppercase;font-size:.66rem;font-weight:700}.provisionar-onu-info-field .value{color:var(--text-1);word-break:break-all;font-size:.82rem;font-weight:600}.provisionar-onu-info-field .value.mono{letter-spacing:.01em;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.8rem}.provisionar-onu-form-group{flex-direction:column;gap:5px;margin-bottom:6px;display:flex}.provisionar-onu-form-group:last-child{margin-bottom:0}.provisionar-onu-form-label{color:var(--text-1);font-size:.78rem;font-weight:600;display:block}.provisionar-onu-form-label.required:after{content:" *";color:#ef4444}.provisionar-onu-form-input{border:1px solid var(--border-1);background:var(--surface-0);height:34px;color:var(--text-1);border-radius:7px;padding:0 9px;font-size:.82rem;transition:all .2s}.provisionar-onu-form-input:focus{border-color:var(--brand-500);background:var(--surface-1);outline:none;box-shadow:0 0 0 3px #00a4e629}.provisionar-onu-form-input::placeholder{color:var(--text-3)}.provisionar-onu-form-input[readonly],.provisionar-onu-form-input--auto{color:var(--brand-400,#38bdf8);text-align:center;letter-spacing:.04em;cursor:default;background:#0284c71a;border-color:#0284c759;font-size:1.15rem;font-weight:700}.provisionar-onu-header-vlan-input.provisionar-onu-form-input--auto{font-size:9px}.provisionar-onu-inline-help--ok{color:var(--brand-500,#0ea5e9)}.provisionar-onu-inline-help--warn{color:var(--warning-600,#b45309)}.provisionar-onu-header-vlan .provisionar-onu-inline-help{width:100%;margin-top:4px}.provisionar-onu-header-vlan-status{align-items:center;gap:5px;font-size:.6rem;line-height:1.2;display:inline-flex}.provisionar-onu-header-vlan-status:before{content:"";opacity:.85;background:currentColor;border-radius:999px;width:5px;height:5px}.provisionar-onu-inline-actions{border-top:1px solid var(--border-1);justify-content:flex-end;gap:8px;margin-top:6px;padding-top:8px;display:flex}.provisionar-onu-inline-actions button{cursor:pointer;border-radius:7px;height:34px;padding:0 11px;font-size:.8rem;font-weight:700;transition:all .2s}.provisionar-onu-modal-cancel-btn{background:var(--surface-1);color:var(--text-1);border:1px solid var(--border-1)}.provisionar-onu-modal-cancel-btn:hover:not(:disabled){color:var(--alert-error-text);background:#ef44441f;border-color:#ef444480;outline:none}.provisionar-onu-modal-cancel-btn:focus-visible:not(:disabled){color:var(--alert-error-text);background:#ef44441f;border-color:#ef444480;outline:none}.provisionar-onu-modal-submit-btn{background:var(--brand-500);color:#fff}.provisionar-onu-modal-submit-btn:hover:not(:disabled){background:var(--brand-600);box-shadow:0 4px 12px #00a4e64d}.provisionar-onu-modal-submit-btn:disabled{opacity:.55;cursor:not-allowed}.provisionar-onu-action-btn{border:1px solid var(--brand-500);background:var(--brand-500);color:#fff;cursor:pointer;white-space:nowrap;border-radius:6px;height:32px;padding:0 12px;font-size:.8rem;font-weight:700;transition:all .2s}.provisionar-onu-action-btn:hover{background:var(--brand-600);box-shadow:0 2px 8px #00a4e64d}.provisionar-onu-action-btn:active{transform:scale(.98)}.provisionar-onu-action-btn:disabled{opacity:.55;cursor:not-allowed}.provisionar-onu-action-btn.is-selected{background:var(--brand-700);border-color:var(--brand-700);animation:1.4s ease-in-out infinite provisionar-onu-btn-pulse;box-shadow:0 0 0 2px #00a4e62e}@keyframes provisionar-onu-row-pulse{0%,to{background:#00a4e61a}50%{background:#00a4e633}}@keyframes provisionar-onu-colspan-pulse{0%,to{background:#00a4e614}50%{background:#00a4e629}}@keyframes provisionar-onu-colspan-panel-pulse{0%,to{box-shadow:0 6px 16px #00000017,0 0 0 1px #00a4e614}50%{box-shadow:0 8px 20px #0000001a,0 0 0 2px #00a4e638}}@keyframes provisionar-onu-btn-pulse{0%,to{box-shadow:0 0 0 2px #00a4e633,0 0 #00a4e673}50%{box-shadow:0 0 0 2px #00a4e640,0 0 0 6px #00a4e614}}@media (prefers-reduced-motion:reduce){.provisionar-onu-table tbody tr.is-expanded td,.provisionar-onu-table tbody tr.provisionar-onu-inline-row td,.provisionar-onu-table tbody tr.provisionar-onu-inline-row .provisionar-onu-inline-panel,.provisionar-onu-action-btn.is-selected{animation:none}}@media (max-width:900px){.provisionar-onu-table-wrap{padding:8px;overflow:visible}.provisionar-onu-table{border-collapse:separate;border-spacing:0 8px;min-width:0}.provisionar-onu-table thead{display:none}.provisionar-onu-table tbody tr{display:block}.provisionar-onu-table tbody tr:not(.provisionar-onu-inline-row){background:var(--surface-0);border:1px solid var(--border-1);border-radius:10px;overflow:hidden}.provisionar-onu-table tbody tr:not(.provisionar-onu-inline-row):hover{background:var(--surface-0)}.provisionar-onu-table tbody tr:not(.provisionar-onu-inline-row).is-expanded{border-color:#00a4e673;box-shadow:0 0 0 2px #00a4e629}.provisionar-onu-table tbody tr:not(.provisionar-onu-inline-row) td{border-bottom:1px solid var(--border-1);width:100%;box-shadow:none;background:0 0;justify-content:space-between;align-items:center;gap:10px;padding:9px 10px;font-size:.82rem;animation:none;display:flex}.provisionar-onu-table tbody tr:not(.provisionar-onu-inline-row) td:last-child{border-bottom:none}.provisionar-onu-table tbody tr:not(.provisionar-onu-inline-row) td:before{content:attr(data-label);color:var(--text-2);text-transform:uppercase;letter-spacing:.04em;flex-shrink:0;min-width:96px;font-size:.66rem;font-weight:800}.provisionar-onu-olt-cell{text-align:right;align-items:flex-end}.provisionar-onu-olt-cell strong{font-size:.9rem}.provisionar-onu-olt-cell span{font-size:.74rem}.provisionar-onu-cell-action{justify-content:flex-end}.provisionar-onu-action-btn{min-width:110px;height:30px;font-size:.78rem}.provisionar-onu-inline-row td{border-bottom:none;padding:0 0 8px;display:block}.provisionar-onu-inline-panel{border-radius:10px}}@media (max-width:760px){.provisionar-onu-page{padding:14px 0 24px}.provisionar-onu-container{gap:10px;padding:0 12px}.provisionar-onu-header h1{font-size:1.1rem}.provisionar-onu-header p{font-size:.84rem}.provisionar-onu-actions{gap:6px;width:100%}.provisionar-onu-select,.provisionar-onu-refresh-btn,.provisionar-onu-clear-btn{width:100%;min-width:0}.provisionar-onu-status-card{grid-template-columns:1fr}.provisionar-onu-table-wrap{padding:6px}.provisionar-onu-table tbody tr:not(.provisionar-onu-inline-row) td{padding:8px 9px}.provisionar-onu-table tbody tr:not(.provisionar-onu-inline-row) td:before{min-width:88px;font-size:.63rem}.provisionar-onu-inline-content{padding:10px}.provisionar-onu-inline-header{flex-direction:row;align-items:center;padding:10px}.provisionar-onu-header-vlan{min-width:0;max-width:100%}.provisionar-onu-header-vlan-row{width:100%}.provisionar-onu-header-vlan-input{flex:auto;min-width:0}.provisionar-onu-modal-cancel-btn:active:not(:disabled){color:var(--alert-error-text);background:#ef444424;border-color:#ef44448c}.provisionar-onu-info-grid,.provisionar-onu-inline-form-grid{grid-template-columns:1fr}.provisionar-onu-inline-actions{flex-direction:column}.provisionar-onu-inline-actions button{width:100%}}.usuarios-page{min-height:calc(100vh - 64px);padding:24px 16px}.usuarios-container{max-width:1100px;margin:0 auto}.usuarios-hero{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:20px;display:flex}.usuarios-hero-text .usuarios-eyebrow{letter-spacing:.12em;color:var(--brand-400,#00a4e6);text-transform:uppercase;margin-bottom:4px;font-size:.72rem;font-weight:700;display:block}.usuarios-hero-text h1{color:var(--text-1);margin:0 0 2px;font-size:1.6rem;font-weight:800}.usuarios-hero-text p{color:var(--text-2);margin:0;font-size:.88rem}.btn-novo-usuario{background:linear-gradient(135deg, var(--brand-500,#0090d0) 0%, var(--brand-600,#0077b6) 100%);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:8px;align-items:center;gap:8px;padding:10px 20px;font-size:.9rem;font-weight:600;transition:transform .15s,box-shadow .15s;display:flex}.btn-novo-usuario:hover{transform:translateY(-1px);box-shadow:0 6px 16px #0090d059}.roles-legenda{margin-bottom:16px}.roles-legenda-toggle{color:var(--text-3,#8b949e);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;align-items:center;gap:6px;padding:4px 0;font-size:.8rem;font-weight:500;list-style:none;display:inline-flex}.roles-legenda-toggle::-webkit-details-marker{display:none}.roles-legenda-toggle:hover{color:var(--text-2)}.roles-legenda-content{background:var(--card-bg,#161b22);border:1px solid var(--border-1,#30363d);border-radius:8px;flex-wrap:wrap;gap:8px 24px;margin-top:8px;padding:12px 16px;display:flex}.role-item{align-items:center;gap:8px;display:flex}.role-desc{color:var(--text-2);font-size:.85rem}.role-badge{white-space:nowrap;letter-spacing:.03em;border-radius:20px;padding:3px 10px;font-size:.78rem;font-weight:700;display:inline-block}.badge-admin{color:#f0a500;background:#ffb30026;border:1px solid #ffb3004d}.badge-operador{color:#00a4e6;background:#00a4e626;border:1px solid #00a4e64d}.badge-visualizador{color:#4caf50;background:#64c8641f;border:1px solid #64c8644d}.badge-inativo{color:#888;background:#9696961f;border:1px solid #96969640;border-radius:20px;padding:3px 10px;font-size:.78rem;font-weight:600;display:inline-block}.badge-ativo{color:#22c55e;background:#22c55e1f;border:1px solid #22c55e40;border-radius:20px;padding:3px 10px;font-size:.78rem;font-weight:600;display:inline-block}.usuario-form-card{background:var(--card-bg,#161b22);border:1px solid var(--border-1,#30363d);border-radius:12px;margin-bottom:24px;padding:24px}.usuario-form-card h2{color:var(--text-1);margin:0 0 20px;font-size:1.1rem;font-weight:700}.usuario-form{flex-direction:column;gap:16px;display:flex}.form-row{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;display:grid}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:var(--text-2);font-size:.85rem;font-weight:600}.form-group input,.form-group select{background:var(--input-bg,#0d1117);border:1px solid var(--border-1,#30363d);color:var(--text-1);border-radius:8px;outline:none;padding:10px 14px;font-size:.9rem;transition:border-color .15s}.form-group input:focus,.form-group select:focus{border-color:var(--brand-400,#00a4e6)}.form-group input:disabled{opacity:.5;cursor:not-allowed}.form-actions{align-items:center;gap:12px;display:flex}.btn-salvar{background:linear-gradient(135deg, var(--brand-500,#0090d0) 0%, var(--brand-600,#0077b6) 100%);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:10px 24px;font-size:.9rem;font-weight:600;transition:opacity .15s}.btn-salvar:disabled{opacity:.6;cursor:not-allowed}.btn-cancelar{color:var(--text-2);border:1px solid var(--border-1,#30363d);cursor:pointer;background:0 0;border-radius:8px;padding:10px 20px;font-size:.9rem;transition:border-color .15s,color .15s}.btn-cancelar:hover{border-color:var(--text-2);color:var(--text-1)}.usuarios-loading{text-align:center;color:var(--text-2);padding:40px}.usuarios-empty{text-align:center;color:var(--text-3,#8b949e);padding:32px 16px;font-size:.85rem}.usuarios-filters{flex-wrap:wrap;align-items:flex-end;gap:12px;margin-bottom:16px;display:flex}.filter-group{flex-direction:column;gap:4px;display:flex}.filter-group label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-3,#8b949e);font-size:.72rem;font-weight:600}.filter-group select{background:var(--card-bg,#161b22);border:1px solid var(--border-1,#30363d);color:var(--text-1);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;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='%238b949e' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;border-radius:6px;outline:none;padding:6px 28px 6px 10px;font-size:.82rem}.filter-group select:focus{border-color:var(--brand-400,#00a4e6)}.filter-clear{border:1px solid var(--border-1,#30363d);color:var(--text-3,#8b949e);cursor:pointer;background:0 0;border-radius:6px;padding:6px 12px;font-size:.78rem;transition:color .15s,border-color .15s}.filter-clear:hover{color:var(--text-1);border-color:var(--text-2)}.usuarios-table-wrap{background:var(--card-bg,#161b22);border:1px solid var(--border-1,#30363d);border-radius:10px;overflow:hidden}.usuarios-table-header{border-bottom:1px solid var(--border-1,#30363d);text-transform:uppercase;letter-spacing:.06em;color:var(--text-3,#8b949e);background:#ffffff08;grid-template-columns:1fr 130px 90px 160px;gap:10px;padding:10px 16px;font-size:.72rem;font-weight:700;display:grid}.usuarios-list{flex-direction:column;display:flex}.usuario-card{border-bottom:1px solid var(--border-1,#30363d);grid-template-columns:1fr 130px 90px 160px;align-items:center;gap:10px;padding:10px 16px;transition:background .12s;display:grid}.usuario-card:last-child{border-bottom:none}.usuario-card:hover{background:#ffffff05}.usuario-inativo{opacity:.55}.usuario-info{align-items:center;gap:8px;min-width:0;display:flex}.usuario-avatar{background:linear-gradient(135deg, var(--brand-500,#0090d0), var(--brand-600,#0077b6));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.9rem;font-weight:700;display:flex}.usuario-details{flex-direction:column;gap:2px;min-width:0;display:flex}.usuario-nome{color:var(--text-1);white-space:nowrap;text-overflow:ellipsis;font-size:.88rem;font-weight:600;overflow:hidden}.usuario-username{color:var(--text-3,#8b949e);white-space:nowrap;font-size:.75rem}.usuario-eu{color:var(--brand-400,#00a4e6);margin-left:6px;font-size:.72rem;font-style:italic}.usuario-meta{align-items:center;display:flex}.usuario-acoes{flex-shrink:0;align-items:center;gap:4px;display:flex}.btn-action{border:1px solid var(--border-1,#30363d);cursor:pointer;width:28px;height:28px;min-height:28px;color:var(--text-2);background:0 0;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:background .15s,border-color .15s;display:flex}.btn-action:hover{background:var(--hover-bg,#ffffff0f);border-color:var(--text-2)}.btn-edit:hover{color:var(--brand-400,#00a4e6);border-color:var(--brand-400,#00a4e6)}.usuarios-page .btn-action.btn-edit{width:28px;height:28px;min-height:28px;color:var(--text-2);border:1px solid var(--border-1,#30363d);background:0 0;padding:0}.btn-key:hover{color:#f0a500;border-color:#f0a500}.btn-toggle-off:hover{color:#888;border-color:#888}.btn-toggle-on:hover{color:#4caf50;border-color:#4caf50}.btn-delete:hover{color:#e05252;border-color:#e05252}.btn-save:hover{color:#4caf50;border-color:#4caf50}.btn-cancel-small:hover{color:#e05252;border-color:#e05252}.btn-action:disabled{opacity:.4;cursor:not-allowed}.change-password-inline{align-items:center;gap:6px;display:flex}.change-password-inline input{background:var(--input-bg,#0d1117);border:1px solid var(--brand-400,#00a4e6);color:var(--text-1);border-radius:6px;outline:none;width:160px;padding:6px 10px;font-size:.85rem}@media (max-width:720px){.usuarios-table-header{display:none}.usuario-card{grid-template-columns:1fr;gap:8px;padding:14px 16px}.usuario-meta,.col-status,.usuario-acoes{justify-self:start}.roles-legenda-content{flex-direction:column;gap:8px}}.co-filters{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.co-search-wrap{flex:260px;min-width:0;position:relative}.co-search-icon{width:16px;height:16px;color:var(--text-3);pointer-events:none;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.co-search{box-sizing:border-box;border:1px solid var(--border-1);background:var(--surface-0);width:100%;height:36px;color:var(--text-1);border-radius:9px;outline:none;padding:0 32px 0 34px;font-size:.875rem;transition:border-color .15s}.co-search::placeholder{color:var(--text-3)}.co-search:focus{border-color:var(--brand-500)}.co-search::-webkit-search-cancel-button{display:none}.co-search-clear{cursor:pointer;color:var(--text-3);background:0 0;border:none;border-radius:4px;padding:2px 4px;font-size:1rem;line-height:1;transition:color .15s;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.co-search-clear:hover{color:var(--text-1)}.co-olt-select{border:1px solid var(--border-1);background:var(--surface-0);height:36px;color:var(--text-1);cursor:pointer;border-radius:9px;outline:none;flex-shrink:0;padding:0 10px;font-size:.875rem;transition:border-color .15s}.co-olt-select:focus{border-color:var(--brand-500)}.co-filter-info{color:var(--text-3);white-space:nowrap;flex-shrink:0;font-size:.78rem}.co-page{padding:20px 24px;padding-bottom:max(140px, env(safe-area-inset-bottom));flex-direction:column;gap:14px;max-width:100%;margin:0 auto;display:flex}.co-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.co-header-left{flex-direction:column;gap:4px;display:flex}.co-title{color:var(--text-1);margin:0;font-size:1.5rem;font-weight:700}.co-subtitle{color:var(--text-3);font-size:.85rem}.co-header-right{flex-shrink:0;align-items:center;gap:10px;display:flex}.co-updated{color:var(--text-3);font-size:.78rem}.co-badge{letter-spacing:.02em;border-radius:999px;padding:4px 10px;font-size:.78rem;font-weight:600}.co-badge-warn{color:var(--status-offline);background:#e74c3c26}.co-badge-ok{color:var(--status-online);background:#27ae6026}.co-live-alert,.co-pon-warning{color:var(--alert-error-text);background:#e74c3c14;border:1px solid #e74c3c40;border-radius:8px;align-items:center;gap:8px;padding:8px 10px;font-size:.82rem;display:flex}.co-alert-action{color:var(--alert-error-text);cursor:pointer;white-space:nowrap;background:#e74c3c24;border:1px solid #e74c3c59;border-radius:999px;margin-left:auto;padding:3px 10px;font-size:.74rem;font-weight:700}.co-alert-action:hover{background:#e74c3c33;border-color:#e74c3c80}.co-live-alert{animation:.2s ease-out co-alert-enter}.co-live-alert-dot,.co-pon-warning-dot,.co-card-status-dot{background:#e74c3c;border-radius:50%;flex-shrink:0;width:8px;height:8px;animation:1s infinite co-red-blink;box-shadow:0 0 6px 1px #e74c3c59}@keyframes co-alert-enter{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@keyframes co-red-blink{0%,to{opacity:1}50%{opacity:.35}}.co-error{color:var(--status-offline);background:#e74c3c1a;border-radius:8px;padding:12px 16px;font-size:.875rem}.co-loading{text-align:center;color:var(--text-3);padding:48px;font-size:.9rem}.co-grid-wrap{border:1px solid var(--border-1);background:var(--surface-0);border-radius:10px;padding:8px;overflow:visible}.co-grid{isolation:isolate;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));align-items:start;gap:6px;display:grid}.co-card{z-index:1;box-sizing:border-box;border:1px solid var(--border-1);background:var(--surface-0);border-radius:9px;min-height:42px;padding:7px 9px;transition:border-color .15s,background .15s,transform .15s;position:relative;overflow:visible}.co-card:after{content:"";height:10px;position:absolute;top:100%;left:0;right:0}.co-card:hover{z-index:40;background:var(--surface-1);border-color:#e74c3c66;outline:none;transform:translateY(-1px)}.co-card-main{justify-content:space-between;align-items:center;gap:6px;display:flex}.co-card-name{min-width:0;color:var(--text-1);text-overflow:ellipsis;white-space:nowrap;font-size:.8rem;font-weight:600;overflow:hidden}.co-card-status{color:var(--status-offline);white-space:nowrap;align-items:center;gap:4px;font-size:.68rem;font-weight:700;display:inline-flex}.co-card-details{z-index:30;background:var(--surface-0);border:1px solid var(--border-1);color:var(--text-2);opacity:0;pointer-events:none;-webkit-user-select:text;-moz-user-select:text;user-select:text;border-radius:7px;padding:6px 8px;font-size:.72rem;transition:opacity .15s,transform .15s;position:absolute;top:calc(100% + 2px);left:0;right:0;transform:translateY(-4px);box-shadow:0 12px 28px #0000002e}.co-card:hover .co-card-details{opacity:1;pointer-events:auto;transform:translateY(0)}.co-card-details strong{color:var(--text-1)}.co-card-detail-row{justify-content:space-between;align-items:center;gap:6px;display:flex}.co-copy-serial-btn{border:1px solid var(--border-1);background:var(--surface-1);color:var(--text-2);cursor:pointer;white-space:nowrap;border-radius:6px;padding:1px 6px;font-size:.66rem;font-weight:700}.co-copy-serial-btn:hover{border-color:var(--brand-500);color:var(--brand-500)}@media (min-width:641px){.co-grid{grid-template-columns:repeat(auto-fill,220px);justify-content:space-between}.co-card{width:220px;min-width:220px;max-width:220px;height:42px;min-height:42px;max-height:42px;padding:5px 8px}.co-card-name{font-size:.76rem}.co-card-status{font-size:.65rem}}.co-empty{text-align:center;color:var(--text-3);padding:36px 16px}.co-empty-card{border:1px dashed var(--border-1);background:var(--surface-0);border-radius:10px}.co-empty-icon{color:var(--status-online);margin-bottom:8px;font-size:1.4rem;display:block}.co-pagination{flex-wrap:wrap;align-items:center;gap:4px;display:flex}.co-page-btn{border:1px solid var(--border-1);background:var(--surface-0);min-width:30px;height:30px;color:var(--text-1);cursor:pointer;border-radius:7px;padding:0 6px;font-size:.8rem;line-height:1;transition:background .15s,border-color .15s,color .15s}.co-page-btn:hover:not(:disabled){background:var(--surface-1);border-color:var(--brand-500);color:var(--brand-500)}.co-page-btn:disabled{opacity:.4;cursor:not-allowed}.co-page-btn-active{background:var(--brand-500);border-color:var(--brand-500);color:#fff;font-weight:700}.co-page-btn-active:hover:not(:disabled){background:var(--brand-600,var(--brand-500));color:#fff}.co-page-info{color:var(--text-3);margin-left:8px;font-size:.78rem}@media (max-width:640px){.co-page{padding:16px;padding-bottom:max(110px, env(safe-area-inset-bottom))}.co-title{font-size:1.2rem}.co-grid{grid-template-columns:1fr}}.audit-page{max-width:1200px;margin:0 auto;padding:24px}.audit-header{align-items:center;gap:16px;margin-bottom:20px;display:flex}.audit-title{color:var(--text-1);margin:0;font-size:1.5rem;font-weight:700}.audit-total{color:var(--text-3);background:var(--surface-2);border:1px solid var(--border-1);border-radius:20px;padding:2px 10px;font-size:.85rem}.audit-filters{flex-wrap:wrap;gap:12px;margin-bottom:20px;display:flex}.audit-select{background:var(--surface-2);border:1px solid var(--border-1);color:var(--text-1);cursor:pointer;border-radius:6px;padding:8px 12px;font-size:.875rem}.audit-search-form{flex:1;align-items:center;gap:8px;min-width:220px;display:flex}.audit-input{background:var(--surface-2);border:1px solid var(--border-1);color:var(--text-1);border-radius:6px;flex:1;padding:8px 12px;font-size:.875rem}.audit-input:focus{border-color:var(--cyan);outline:none}.audit-search-btn,.audit-clear-btn{background:var(--surface-3);border:1px solid var(--border-1);color:var(--text-2);cursor:pointer;white-space:nowrap;border-radius:6px;padding:8px 14px;font-size:.875rem;transition:background .15s}.audit-search-btn:hover,.audit-clear-btn:hover{background:var(--surface-4,var(--surface-3))}.audit-pagination-size-wrap{align-items:center;gap:8px;display:flex}.audit-pagination-size-label{color:var(--text-3);font-size:.8rem}.audit-pagination-size-select{background:var(--surface-2);border:1px solid var(--border-1);color:var(--text-1);cursor:pointer;border-radius:6px;padding:8px 10px;font-size:.875rem}.audit-danger-btn{color:#fca5a5;cursor:pointer;white-space:nowrap;background:#3a1a1a;border:1px solid #7f1d1d;border-radius:6px;margin-left:auto;padding:8px 14px;font-size:.875rem;transition:background .15s}.audit-danger-btn:hover:not(:disabled){background:#4a1d1d}.audit-danger-btn:disabled{opacity:.45;cursor:not-allowed}.audit-loading,.audit-empty,.audit-error{text-align:center;color:var(--text-3);padding:40px;font-size:.95rem}.audit-error{color:var(--red,#ef4444)}.audit-table-wrap{border:1px solid var(--border-1);border-radius:10px;overflow-x:auto}.audit-table{border-collapse:collapse;width:100%;font-size:.875rem}.audit-table th{background:var(--surface-2);color:var(--text-3);text-align:left;border-bottom:1px solid var(--border-1);white-space:nowrap;padding:10px 14px;font-weight:600}.audit-table td{color:var(--text-1);border-bottom:1px solid var(--border-1);vertical-align:middle;padding:9px 14px}.audit-table tr:last-child td{border-bottom:none}.audit-table tr:hover td{background:var(--surface-2)}.audit-cell-nowrap{white-space:nowrap}.audit-cell-target{text-overflow:ellipsis;white-space:nowrap;max-width:220px;overflow:hidden}.audit-badge{background:var(--surface-3);color:var(--text-2);border-radius:12px;padding:2px 10px;font-size:.78rem;font-weight:600;display:inline-block}.audit-badge-login{color:#4ade80;background:#1a3a2a}.audit-badge-login_fail{color:#f87171;background:#3a1a1a}.audit-badge-login_blocked{color:#f87171;background:#4a1a1a}.audit-badge-logout{background:var(--surface-3);color:var(--text-3)}.audit-badge-provision_onu{color:#38bdf8;background:#1a2f3a}.audit-badge-schedule_reboot{color:#a78bfa;background:#2a1a3a}.audit-badge-scheduled_reboot_executed{color:#4ade80;background:#1a3a2a}.audit-badge-export{color:#34d399;background:#1a2a2a}.audit-pagination{justify-content:center;align-items:center;gap:16px;margin-top:20px;display:flex}.audit-page-btn{background:var(--surface-2);border:1px solid var(--border-1);color:var(--text-2);cursor:pointer;border-radius:6px;padding:7px 16px;font-size:.875rem;transition:background .15s}.audit-page-btn:hover:not(:disabled){background:var(--surface-3)}.audit-page-btn:disabled{opacity:.4;cursor:not-allowed}.audit-page-info{color:var(--text-3);font-size:.875rem}.audit-confirm-overlay{z-index:1200;background:#070a14b8;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.audit-confirm-modal{background:var(--surface-1,#111827);border:1px solid var(--border-1,#2b3343);border-radius:12px;width:min(520px,100%);padding:18px;box-shadow:0 24px 60px #00000073}.audit-confirm-title{color:var(--text-1);margin:0 0 8px;font-size:1.05rem;font-weight:700}.audit-confirm-text{color:var(--text-2);margin:0;font-size:.92rem;line-height:1.45}.audit-confirm-actions{justify-content:flex-end;gap:8px;margin-top:14px;display:flex}.audit-confirm-cancel,.audit-confirm-submit{border:1px solid var(--border-1);cursor:pointer;border-radius:8px;padding:8px 14px;font-size:.875rem}.audit-confirm-cancel{background:var(--surface-2);color:var(--text-2)}.audit-confirm-cancel:hover:not(:disabled){background:var(--surface-3)}.audit-confirm-submit{color:#fecaca;background:#7f1d1d;border-color:#991b1b}.audit-confirm-submit:hover:not(:disabled){background:#991b1b}.audit-confirm-cancel:disabled,.audit-confirm-submit:disabled{opacity:.5;cursor:not-allowed}.reboots-page{max-width:1200px;margin:0 auto;padding:24px}.reboots-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:24px;display:flex}.reboots-title{color:var(--text-1);margin:0;font-size:1.5rem;font-weight:700}.reboots-header-actions{align-items:center;gap:10px;display:flex}.reboots-select{background:var(--surface-2);border:1px solid var(--border-1);color:var(--text-1);cursor:pointer;border-radius:6px;padding:8px 12px;font-size:.875rem}.reboots-btn-primary{background:var(--cyan,#06b6d4);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:8px 18px;font-size:.875rem;font-weight:600;transition:opacity .15s}.reboots-btn-primary:hover:not(:disabled){opacity:.85}.reboots-btn-primary:disabled{opacity:.5;cursor:not-allowed}.reboots-form{background:var(--surface-2);border:1px solid var(--border-1);border-radius:10px;margin-bottom:24px;padding:20px 24px}.reboots-form-title{color:var(--text-1);margin:0 0 16px;font-size:1rem;font-weight:600}.reboots-form-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;margin-bottom:14px;display:grid}.reboots-form-field{color:var(--text-2);flex-direction:column;gap:5px;font-size:.85rem;display:flex}.reboots-input{background:var(--surface-1,var(--surface-2));border:1px solid var(--border-1);color:var(--text-1);border-radius:6px;padding:8px 10px;font-size:.875rem}.reboots-input:focus{border-color:var(--cyan);outline:none}.reboots-form-error{color:var(--red,#ef4444);margin-bottom:10px;font-size:.85rem}.reboots-form-actions{justify-content:flex-end;display:flex}.reboots-loading,.reboots-empty,.reboots-error{text-align:center;color:var(--text-3);padding:40px;font-size:.95rem}.reboots-error{color:var(--red,#ef4444)}.reboots-table-wrap{border:1px solid var(--border-1);border-radius:10px;overflow-x:auto}.reboots-table{border-collapse:collapse;width:100%;font-size:.875rem}.reboots-table th{background:var(--surface-2);color:var(--text-3);text-align:left;border-bottom:1px solid var(--border-1);white-space:nowrap;padding:10px 14px;font-weight:600}.reboots-table td{color:var(--text-1);border-bottom:1px solid var(--border-1);vertical-align:middle;padding:9px 14px}.reboots-table tr:last-child td{border-bottom:none}.reboots-table tr:hover td{background:var(--surface-2)}.reboots-cell-nowrap{white-space:nowrap}.reboots-badge{background:var(--surface-3);color:var(--text-2);border-radius:12px;padding:2px 10px;font-size:.78rem;font-weight:600;display:inline-block}.reboots-badge-pending{color:#38bdf8;background:#1a2f3a}.reboots-badge-executing{color:#93c5fd;background:#1f2937}.reboots-badge-done{color:#4ade80;background:#1a3a2a}.reboots-badge-failed{color:#f87171;background:#3a1a1a}.reboots-badge-cancelled{background:var(--surface-3);color:var(--text-3)}.reboots-error-msg{cursor:help;color:var(--yellow,#f59e0b);margin-left:4px}.reboots-btn-cancel{border:1px solid var(--red,#ef4444);color:var(--red,#ef4444);cursor:pointer;background:0 0;border-radius:5px;padding:4px 12px;font-size:.8rem;transition:background .15s}.reboots-btn-cancel:hover{background:#ef44441a}.leaflet-pane,.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-tile-container,.leaflet-pane>svg,.leaflet-pane>canvas,.leaflet-zoom-box,.leaflet-image-layer,.leaflet-layer{position:absolute;top:0;left:0}.leaflet-container{overflow:hidden}.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow{-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none}.leaflet-tile::selection{background:0 0}.leaflet-safari .leaflet-tile{image-rendering:-webkit-optimize-contrast}.leaflet-safari .leaflet-tile-container{-webkit-transform-origin:0 0;width:1600px;height:1600px}.leaflet-marker-icon,.leaflet-marker-shadow{display:block}.leaflet-container .leaflet-overlay-pane svg{max-width:none!important;max-height:none!important}.leaflet-container .leaflet-marker-pane img,.leaflet-container .leaflet-shadow-pane img,.leaflet-container .leaflet-tile-pane img,.leaflet-container img.leaflet-image-layer,.leaflet-container .leaflet-tile{width:auto;padding:0;max-width:none!important;max-height:none!important}.leaflet-container img.leaflet-tile{mix-blend-mode:plus-lighter}.leaflet-container.leaflet-touch-zoom{-ms-touch-action:pan-x pan-y;touch-action:pan-x pan-y}.leaflet-container.leaflet-touch-drag{-ms-touch-action:pinch-zoom;touch-action:none;touch-action:pinch-zoom}.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom{-ms-touch-action:none;touch-action:none}.leaflet-container{-webkit-tap-highlight-color:transparent}.leaflet-container a{-webkit-tap-highlight-color:#33b5e566}.leaflet-tile{filter:inherit;visibility:hidden}.leaflet-tile-loaded{visibility:inherit}.leaflet-zoom-box{box-sizing:border-box;z-index:800;width:0;height:0}.leaflet-overlay-pane svg{-moz-user-select:none}.leaflet-pane{z-index:400}.leaflet-tile-pane{z-index:200}.leaflet-overlay-pane{z-index:400}.leaflet-shadow-pane{z-index:500}.leaflet-marker-pane{z-index:600}.leaflet-tooltip-pane{z-index:650}.leaflet-popup-pane{z-index:700}.leaflet-map-pane canvas{z-index:100}.leaflet-map-pane svg{z-index:200}.leaflet-vml-shape{width:1px;height:1px}.lvml{behavior:url(#default#VML);display:inline-block;position:absolute}.leaflet-control{z-index:800;pointer-events:visiblePainted;pointer-events:auto;position:relative}.leaflet-top,.leaflet-bottom{z-index:1000;pointer-events:none;position:absolute}.leaflet-top{top:0}.leaflet-right{right:0}.leaflet-bottom{bottom:0}.leaflet-left{left:0}.leaflet-control{float:left;clear:both}.leaflet-right .leaflet-control{float:right}.leaflet-top .leaflet-control{margin-top:10px}.leaflet-bottom .leaflet-control{margin-bottom:10px}.leaflet-left .leaflet-control{margin-left:10px}.leaflet-right .leaflet-control{margin-right:10px}.leaflet-fade-anim .leaflet-popup{opacity:0;transition:opacity .2s linear}.leaflet-fade-anim .leaflet-map-pane .leaflet-popup{opacity:1}.leaflet-zoom-animated{transform-origin:0 0}svg.leaflet-zoom-animated{will-change:transform}.leaflet-zoom-anim .leaflet-zoom-animated{-webkit-transition:-webkit-transform .25s cubic-bezier(0,0,.25,1);-moz-transition:-moz-transform .25s cubic-bezier(0,0,.25,1);transition:transform .25s cubic-bezier(0,0,.25,1)}.leaflet-zoom-anim .leaflet-tile,.leaflet-pan-anim .leaflet-tile{transition:none}.leaflet-zoom-anim .leaflet-zoom-hide{visibility:hidden}.leaflet-interactive{cursor:pointer}.leaflet-grab{cursor:-webkit-grab;cursor:-moz-grab;cursor:grab}.leaflet-crosshair,.leaflet-crosshair .leaflet-interactive{cursor:crosshair}.leaflet-popup-pane,.leaflet-control{cursor:auto}.leaflet-dragging .leaflet-grab,.leaflet-dragging .leaflet-grab .leaflet-interactive,.leaflet-dragging .leaflet-marker-draggable{cursor:move;cursor:-webkit-grabbing;cursor:-moz-grabbing;cursor:grabbing}.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-image-layer,.leaflet-pane>svg path,.leaflet-tile-container{pointer-events:none}.leaflet-marker-icon.leaflet-interactive,.leaflet-image-layer.leaflet-interactive,.leaflet-pane>svg path.leaflet-interactive,svg.leaflet-image-layer.leaflet-interactive path{pointer-events:visiblePainted;pointer-events:auto}.leaflet-container{outline-offset:1px;background:#ddd}.leaflet-container a{color:#0078a8}.leaflet-zoom-box{background:#ffffff80;border:2px dotted #38f}.leaflet-container{font-family:Helvetica Neue,Arial,Helvetica,sans-serif;font-size:.75rem;line-height:1.5}.leaflet-bar{border-radius:4px;box-shadow:0 1px 5px #000000a6}.leaflet-bar a{text-align:center;color:#000;background-color:#fff;border-bottom:1px solid #ccc;width:26px;height:26px;line-height:26px;text-decoration:none;display:block}.leaflet-bar a,.leaflet-control-layers-toggle{background-position:50%;background-repeat:no-repeat;display:block}.leaflet-bar a:hover,.leaflet-bar a:focus{background-color:#f4f4f4}.leaflet-bar a:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.leaflet-bar a:last-child{border-bottom:none;border-bottom-right-radius:4px;border-bottom-left-radius:4px}.leaflet-bar a.leaflet-disabled{cursor:default;color:#bbb;background-color:#f4f4f4}.leaflet-touch .leaflet-bar a{width:30px;height:30px;line-height:30px}.leaflet-touch .leaflet-bar a:first-child{border-top-left-radius:2px;border-top-right-radius:2px}.leaflet-touch .leaflet-bar a:last-child{border-bottom-right-radius:2px;border-bottom-left-radius:2px}.leaflet-control-zoom-in,.leaflet-control-zoom-out{text-indent:1px;font:700 18px Lucida Console,Monaco,monospace}.leaflet-touch .leaflet-control-zoom-in,.leaflet-touch .leaflet-control-zoom-out{font-size:22px}.leaflet-control-layers{background:#fff;border-radius:5px;box-shadow:0 1px 5px #0006}.leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABoAAAAaCAQAAAADQ4RFAAACf0lEQVR4AY1UM3gkARTePdvdoTxXKc+qTl3aU5U6b2Kbkz3Gtq3Zw6ziLGNPzrYx7946Tr6/ee/XeCQ4D3ykPtL5tHno4n0d/h3+xfuWHGLX81cn7r0iTNzjr7LrlxCqPtkbTQEHeqOrTy4Yyt3VCi/IOB0v7rVC7q45Q3Gr5K6jt+3Gl5nCoDD4MtO+j96Wu8atmhGqcNGHObuf8OM/x3AMx38+4Z2sPqzCxRFK2aF2e5Jol56XTLyggAMTL56XOMoS1W4pOyjUcGGQdZxU6qRh7B9Zp+PfpOFlqt0zyDZckPi1ttmIp03jX8gyJ8a/PG2yutpS/Vol7peZIbZcKBAEEheEIAgFbDkz5H6Zrkm2hVWGiXKiF4Ycw0RWKdtC16Q7qe3X4iOMxruonzegJzWaXFrU9utOSsLUmrc0YjeWYjCW4PDMADElpJSSQ0vQvA1Tm6/JlKnqFs1EGyZiFCqnRZTEJJJiKRYzVYzJck2Rm6P4iH+cmSY0YzimYa8l0EtTODFWhcMIMVqdsI2uiTvKmTisIDHJ3od5GILVhBCarCfVRmo4uTjkhrhzkiBV7SsaqS+TzrzM1qpGGUFt28pIySQHR6h7F6KSwGWm97ay+Z+ZqMcEjEWebE7wxCSQwpkhJqoZA5ivCdZDjJepuJ9IQjGGUmuXJdBFUygxVqVsxFsLMbDe8ZbDYVCGKxs+W080max1hFCarCfV+C1KATwcnvE9gRRuMP2prdbWGowm1KB1y+zwMMENkM755cJ2yPDtqhTI6ED1M/82yIDtC/4j4BijjeObflpO9I9MwXTCsSX8jWAFeHr05WoLTJ5G8IQVS/7vwR6ohirYM7f6HzYpogfS3R2OAAAAAElFTkSuQmCC);width:36px;height:36px}.leaflet-retina .leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA0CAQAAABvcdNgAAAEsklEQVR4AWL4TydIhpZK1kpWOlg0w3ZXP6D2soBtG42jeI6ZmQTHzAxiTbSJsYLjO9HhP+WOmcuhciVnmHVQcJnp7DFvScowZorad/+V/fVzMdMT2g9Cv9guXGv/7pYOrXh2U+RRR3dSd9JRx6bIFc/ekqHI29JC6pJ5ZEh1yWkhkbcFeSjxgx3L2m1cb1C7bceyxA+CNjT/Ifff+/kDk2u/w/33/IeCMOSaWZ4glosqT3DNnNZQ7Cs58/3Ce5HL78iZH/vKVIaYlqzfdLu8Vi7dnvUbEza5Idt36tquZFldl6N5Z/POLof0XLK61mZCmJSWjVF9tEjUluu74IUXvgttuVIHE7YxSkaYhJZam7yiM9Pv82JYfl9nptxZaxMJE4YSPty+vF0+Y2up9d3wwijfjZbabqm/3bZ9ecKHsiGmRflnn1MW4pjHf9oLufyn2z3y1D6n8g8TZhxyzipLNPnAUpsOiuWimg52psrTZYnOWYNDTMuWBWa0tJb4rgq1UvmutpaYEbZlwU3CLJm/ayYjHW5/h7xWLn9Hh1vepDkyf7dE7MtT5LR4e7yYpHrkhOUpEfssBLq2pPhAqoSWKUkk7EDqkmK6RrCEzqDjhNDWNE+XSMvkJRDWlZTmCW0l0PHQGRZY5t1L83kT0Y3l2SItk5JAWHl2dCOBm+fPu3fo5/3v61RMCO9Jx2EEYYhb0rmNQMX/vm7gqOEJLcXTGw3CAuRNeyaPWwjR8PRqKQ1PDA/dpv+on9Shox52WFnx0KY8onHayrJzm87i5h9xGw/tfkev0jGsQizqezUKjk12hBMKJ4kbCqGPVNXudyyrShovGw5CgxsRICxF6aRmSjlBnHRzg7Gx8fKqEubI2rahQYdR1YgDIRQO7JvQyD52hoIQx0mxa0ODtW2Iozn1le2iIRdzwWewedyZzewidueOGqlsn1MvcnQpuVwLGG3/IR1hIKxCjelIDZ8ldqWz25jWAsnldEnK0Zxro19TGVb2ffIZEsIO89EIEDvKMPrzmBOQcKQ+rroye6NgRRxqR4U8EAkz0CL6uSGOm6KQCdWjvjRiSP1BPalCRS5iQYiEIvxuBMJEWgzSoHADcVMuN7IuqqTeyUPq22qFimFtxDyBBJEwNyt6TM88blFHao/6tWWhuuOM4SAK4EI4QmFHA+SEyWlp4EQoJ13cYGzMu7yszEIBOm2rVmHUNqwAIQabISNMRstmdhNWcFLsSm+0tjJH1MdRxO5Nx0WDMhCtgD6OKgZeljJqJKc9po8juskR9XN0Y1lZ3mWjLR9JCO1jRDMd0fpYC2VnvjBSEFg7wBENc0R9HFlb0xvF1+TBEpF68d+DHR6IOWVv2BECtxo46hOFUBd/APU57WIoEwJhIi2CdpyZX0m93BZicktMj1AS9dClteUFAUNUIEygRZCtik5zSxI9MubTBH1GOiHsiLJ3OCoSZkILa9PxiN0EbvhsAo8tdAf9Seepd36lGWHmtNANTv5Jd0z4QYyeo/UEJqxKRpg5LZx6btLPsOaEmdMyxYdlc8LMaJnikDlhclqmPiQnTEpLUIZEwkRagjYkEibQErwhkTAKCLQEbUgkzJQWc/0PstHHcfEdQ+UAAAAASUVORK5CYII=);background-size:26px 26px}.leaflet-touch .leaflet-control-layers-toggle{width:44px;height:44px}.leaflet-control-layers .leaflet-control-layers-list,.leaflet-control-layers-expanded .leaflet-control-layers-toggle{display:none}.leaflet-control-layers-expanded .leaflet-control-layers-list{display:block;position:relative}.leaflet-control-layers-expanded{color:#333;background:#fff;padding:6px 10px 6px 6px}.leaflet-control-layers-scrollbar{padding-right:5px;overflow-x:hidden;overflow-y:scroll}.leaflet-control-layers-selector{margin-top:2px;position:relative;top:1px}.leaflet-control-layers label{font-size:1.08333em;display:block}.leaflet-control-layers-separator{border-top:1px solid #ddd;height:0;margin:5px -10px 5px -6px}.leaflet-default-icon-path{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAApCAYAAADAk4LOAAAFgUlEQVR4Aa1XA5BjWRTN2oW17d3YaZtr2962HUzbDNpjszW24mRt28p47v7zq/bXZtrp/lWnXr337j3nPCe85NcypgSFdugCpW5YoDAMRaIMqRi6aKq5E3YqDQO3qAwjVWrD8Ncq/RBpykd8oZUb/kaJutow8r1aP9II0WmLKLIsJyv1w/kqw9Ch2MYdB++12Onxee/QMwvf4/Dk/Lfp/i4nxTXtOoQ4pW5Aj7wpici1A9erdAN2OH64x8OSP9j3Ft3b7aWkTg/Fm91siTra0f9on5sQr9INejH6CUUUpavjFNq1B+Oadhxmnfa8RfEmN8VNAsQhPqF55xHkMzz3jSmChWU6f7/XZKNH+9+hBLOHYozuKQPxyMPUKkrX/K0uWnfFaJGS1QPRtZsOPtr3NsW0uyh6NNCOkU3Yz+bXbT3I8G3xE5EXLXtCXbbqwCO9zPQYPRTZ5vIDXD7U+w7rFDEoUUf7ibHIR4y6bLVPXrz8JVZEql13trxwue/uDivd3fkWRbS6/IA2bID4uk0UpF1N8qLlbBlXs4Ee7HLTfV1j54APvODnSfOWBqtKVvjgLKzF5YdEk5ewRkGlK0i33Eofffc7HT56jD7/6U+qH3Cx7SBLNntH5YIPvODnyfIXZYRVDPqgHtLs5ABHD3YzLuespb7t79FY34DjMwrVrcTuwlT55YMPvOBnRrJ4VXTdNnYug5ucHLBjEpt30701A3Ts+HEa73u6dT3FNWwflY86eMHPk+Yu+i6pzUpRrW7SNDg5JHR4KapmM5Wv2E8Tfcb1HoqqHMHU+uWDD7zg54mz5/2BSnizi9T1Dg4QQXLToGNCkb6tb1NU+QAlGr1++eADrzhn/u8Q2YZhQVlZ5+CAOtqfbhmaUCS1ezNFVm2imDbPmPng5wmz+gwh+oHDce0eUtQ6OGDIyR0uUhUsoO3vfDmmgOezH0mZN59x7MBi++WDL1g/eEiU3avlidO671bkLfwbw5XV2P8Pzo0ydy4t2/0eu33xYSOMOD8hTf4CrBtGMSoXfPLchX+J0ruSePw3LZeK0juPJbYzrhkH0io7B3k164hiGvawhOKMLkrQLyVpZg8rHFW7E2uHOL888IBPlNZ1FPzstSJM694fWr6RwpvcJK60+0HCILTBzZLFNdtAzJaohze60T8qBzyh5ZuOg5e7uwQppofEmf2++DYvmySqGBuKaicF1blQjhuHdvCIMvp8whTTfZzI7RldpwtSzL+F1+wkdZ2TBOW2gIF88PBTzD/gpeREAMEbxnJcaJHNHrpzji0gQCS6hdkEeYt9DF/2qPcEC8RM28Hwmr3sdNyht00byAut2k3gufWNtgtOEOFGUwcXWNDbdNbpgBGxEvKkOQsxivJx33iow0Vw5S6SVTrpVq11ysA2Rp7gTfPfktc6zhtXBBC+adRLshf6sG2RfHPZ5EAc4sVZ83yCN00Fk/4kggu40ZTvIEm5g24qtU4KjBrx/BTTH8ifVASAG7gKrnWxJDcU7x8X6Ecczhm3o6YicvsLXWfh3Ch1W0k8x0nXF+0fFxgt4phz8QvypiwCCFKMqXCnqXExjq10beH+UUA7+nG6mdG/Pu0f3LgFcGrl2s0kNNjpmoJ9o4B29CMO8dMT4Q5ox8uitF6fqsrJOr8qnwNbRzv6hSnG5wP+64C7h9lp30hKNtKdWjtdkbuPA19nJ7Tz3zR/ibgARbhb4AlhavcBebmTHcFl2fvYEnW0ox9xMxKBS8btJ+KiEbq9zA4RthQXDhPa0T9TEe69gWupwc6uBUphquXgf+/FrIjweHQS4/pduMe5ERUMHUd9xv8ZR98CxkS4F2n3EUrUZ10EYNw7BWm9x1GiPssi3GgiGRDKWRYZfXlON+dfNbM+GgIwYdwAAAAASUVORK5CYII=)}.leaflet-container .leaflet-control-attribution{background:#fffc;margin:0}.leaflet-control-attribution,.leaflet-control-scale-line{color:#333;padding:0 5px;line-height:1.4}.leaflet-control-attribution a{text-decoration:none}.leaflet-control-attribution a:hover,.leaflet-control-attribution a:focus{text-decoration:underline}.leaflet-attribution-flag{width:1em;height:.6669em;vertical-align:baseline!important;display:inline!important}.leaflet-left .leaflet-control-scale{margin-left:5px}.leaflet-bottom .leaflet-control-scale{margin-bottom:5px}.leaflet-control-scale-line{white-space:nowrap;box-sizing:border-box;text-shadow:1px 1px #fff;background:#fffc;border:2px solid #777;border-top:none;padding:2px 5px 1px;line-height:1.1}.leaflet-control-scale-line:not(:first-child){border-top:2px solid #777;border-bottom:none;margin-top:-2px}.leaflet-control-scale-line:not(:first-child):not(:last-child){border-bottom:2px solid #777}.leaflet-touch .leaflet-control-attribution,.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{box-shadow:none}.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{background-clip:padding-box;border:2px solid #0003}.leaflet-popup{text-align:center;margin-bottom:20px;position:absolute}.leaflet-popup-content-wrapper{text-align:left;border-radius:12px;padding:1px}.leaflet-popup-content{min-height:1px;margin:13px 24px 13px 20px;font-size:1.08333em;line-height:1.3}.leaflet-popup-content p{margin:1.3em 0}.leaflet-popup-tip-container{pointer-events:none;width:40px;height:20px;margin-top:-1px;margin-left:-20px;position:absolute;left:50%;overflow:hidden}.leaflet-popup-tip{pointer-events:auto;width:17px;height:17px;margin:-10px auto 0;padding:1px;transform:rotate(45deg)}.leaflet-popup-content-wrapper,.leaflet-popup-tip{color:#333;background:#fff;box-shadow:0 3px 14px #0006}.leaflet-container a.leaflet-popup-close-button{text-align:center;color:#757575;background:0 0;border:none;width:24px;height:24px;font:16px/24px Tahoma,Verdana,sans-serif;text-decoration:none;position:absolute;top:0;right:0}.leaflet-container a.leaflet-popup-close-button:hover,.leaflet-container a.leaflet-popup-close-button:focus{color:#585858}.leaflet-popup-scrolled{overflow:auto}.leaflet-oldie .leaflet-popup-content-wrapper{-ms-zoom:1}.leaflet-oldie .leaflet-popup-tip{-ms-filter:"progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";width:24px;filter:progid:DXImageTransform.Microsoft.Matrix(M11=.707107, M12=.707107, M21=-.707107, M22=.707107);margin:0 auto}.leaflet-oldie .leaflet-control-zoom,.leaflet-oldie .leaflet-control-layers,.leaflet-oldie .leaflet-popup-content-wrapper,.leaflet-oldie .leaflet-popup-tip{border:1px solid #999}.leaflet-div-icon{background:#fff;border:1px solid #666}.leaflet-tooltip{color:#222;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:none;background-color:#fff;border:1px solid #fff;border-radius:3px;padding:6px;position:absolute;box-shadow:0 1px 3px #0006}.leaflet-tooltip.leaflet-interactive{cursor:pointer;pointer-events:auto}.leaflet-tooltip-top:before,.leaflet-tooltip-bottom:before,.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{pointer-events:none;content:"";background:0 0;border:6px solid #0000;position:absolute}.leaflet-tooltip-bottom{margin-top:6px}.leaflet-tooltip-top{margin-top:-6px}.leaflet-tooltip-bottom:before,.leaflet-tooltip-top:before{margin-left:-6px;left:50%}.leaflet-tooltip-top:before{border-top-color:#fff;margin-bottom:-12px;bottom:0}.leaflet-tooltip-bottom:before{border-bottom-color:#fff;margin-top:-12px;margin-left:-6px;top:0}.leaflet-tooltip-left{margin-left:-6px}.leaflet-tooltip-right{margin-left:6px}.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{margin-top:-6px;top:50%}.leaflet-tooltip-left:before{border-left-color:#fff;margin-right:-12px;right:0}.leaflet-tooltip-right:before{border-right-color:#fff;margin-left:-12px;left:0}@media print{.leaflet-control{-webkit-print-color-adjust:exact;-moz-print-color-adjust:exact;print-color-adjust:exact}}.map-view{height:100vh;height:100dvh;min-height:100vh;background:radial-gradient(circle at top left, #00a4e614, transparent 28%), linear-gradient(180deg, var(--page-grad-start), var(--page-grad-end));width:100%;min-height:100svh;color:var(--app-text);flex-direction:column;gap:12px;padding:12px;display:flex;overflow:hidden}.map-toolbar{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:linear-gradient(#ffffffeb,#ffffffd1);border:1px solid #11203314;border-radius:20px;flex-direction:column;gap:14px;padding:max(12px,min(1.8vw,18px));display:flex;box-shadow:0 14px 35px #0a111d14}.toolbar-row{align-items:center;gap:14px;min-width:0;display:flex}.toolbar-row-main{grid-template-columns:minmax(240px,1.05fr) minmax(420px,1.95fr);align-items:stretch;gap:12px;display:grid}.toolbar-brand{background:linear-gradient(#ffffffe6,#f6faffdb);border:1px solid #11203314;border-radius:14px;align-content:center;gap:4px;min-width:0;padding:10px 12px;display:grid}.toolbar-brand h1{letter-spacing:-.02em;color:var(--app-text);margin:0;font-size:18px;font-weight:700}.toolbar-subtitle{color:var(--text-2);margin:0;font-size:12px}.toolbar-stats{grid-template-columns:repeat(5,minmax(112px,1fr));gap:8px;min-width:0;display:grid}.stat-item{background:linear-gradient(#ffffffeb,#f3f7fce0);border:1px solid #11203314;border-radius:12px;align-content:center;gap:3px;min-height:66px;padding:8px 10px;font-size:12px;display:grid;box-shadow:0 8px 20px #0a111d0d}.stat-item.online{border-left:4px solid var(--status-online)}.stat-item.offline{border-left:4px solid var(--status-offline)}.stat-label{text-transform:uppercase;letter-spacing:.03em;color:var(--text-2);font-size:10px;font-weight:700}.stat-value{color:var(--text-1);font-size:20px;font-weight:700;line-height:1}.toolbar-controls{background:linear-gradient(#ffffffe0,#f5f9ffd6);border:1px solid #11203314;border-radius:14px;flex-wrap:wrap;justify-content:flex-start;align-items:stretch;gap:10px;min-width:0;padding:10px 12px;display:flex}.filter-group{white-space:nowrap;background:#ffffffb8;border:1px solid #1120331a;border-radius:12px;flex:none;grid-template-columns:auto 92px;align-items:center;column-gap:8px;min-width:156px;min-height:36px;padding:0 11px;display:inline-grid;box-shadow:0 5px 10px #0a111d0d}.filter-group label{color:var(--text-2);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;text-overflow:ellipsis;font-size:11px;font-weight:600;overflow:hidden}.filter-group select{width:92px;height:28px;color:var(--text-1);cursor:pointer;background:#0913220d;border:none;border-radius:999px;justify-self:end;padding:0 10px;font-size:12px}.toggle-group{background:#ffffff80;border:1px solid #11203314;border-radius:12px;flex:0 auto;align-items:center;gap:6px;min-height:36px;padding:0 11px;display:inline-flex}.toggle-group input[type=checkbox]{cursor:pointer;width:14px;height:14px;margin:0}.toggle-group label{cursor:pointer;color:var(--text-1);align-items:center;gap:6px;min-height:28px;font-size:11px;line-height:1;display:flex}.map-search-group{background:#ffffffb8;border:1px solid #1120331a;border-radius:12px;align-items:center;min-height:36px;padding:0 10px;display:inline-flex;position:relative;box-shadow:0 5px 10px #0a111d0d}.map-search-input{width:180px;height:30px;color:var(--text-1);background:0 0;border:none;padding:0 22px 0 2px;font-size:12px}.map-search-input:focus{outline:none}.map-search-input::placeholder{color:var(--text-3)}.map-search-clear{color:var(--text-3);cursor:pointer;background:0 0;border:none;padding:0;font-size:14px;line-height:1;position:absolute;right:8px}.map-search-clear:hover{color:var(--text-1)}.btn-reset{background:linear-gradient(135deg, var(--brand-500), var(--brand-600));color:#fff;cursor:pointer;border:none;border-radius:12px;height:36px;padding:0 14px;font-size:11px;font-weight:600;transition:transform .18s,box-shadow .18s;box-shadow:0 10px 20px #0077b638}.btn-reset:hover{transform:translateY(-1px);box-shadow:0 14px 24px #0077b647}.map-container{background:var(--surface-0);isolation:isolate;border:1px solid #11203314;border-radius:22px;flex:1;min-height:0;position:relative;overflow:hidden;box-shadow:0 18px 50px #0a111d1f}.leaflet-host{background:radial-gradient(circle at 0 0,#00a4e61f,#0000 34%),linear-gradient(#080d1708,#080d1714);width:100%;height:100%;min-height:300px}.map-overlay{z-index:500;position:absolute;top:0;bottom:0;left:0;right:0}.map-controls-overlay{z-index:620;pointer-events:none;top:16px;bottom:auto;left:auto;right:16px}.map-fullscreen-btn{pointer-events:auto;width:42px;height:42px;color:var(--text-1);cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffeb;border:1px solid #1120331f;border-radius:14px;justify-content:center;align-items:center;transition:transform .18s,box-shadow .18s,background .18s;display:inline-flex;position:absolute;top:0;right:0;box-shadow:0 12px 24px #0a111d24}.map-fullscreen-btn:hover{background:#fff;transform:translateY(-1px);box-shadow:0 16px 30px #0a111d2e}.map-fullscreen-btn span{font-size:18px;line-height:1}.map-refreshing{top:16px;right:16px;z-index:550;color:#fff;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);pointer-events:none;background:#0c121cd1;border-radius:999px;align-items:center;padding:10px 14px;font-size:13px;font-weight:600;display:inline-flex;position:absolute;top:auto;bottom:auto;left:auto;right:16px;box-shadow:0 8px 20px #0003}.leaflet-host.map-style-clean.leaflet-container,.leaflet-host.map-style-detailed.leaflet-container{background:#e0e0e0!important}.leaflet-host.map-style-dark.leaflet-container{background:#0b1420!important}.leaflet-container .leaflet-control-zoom{border:none;box-shadow:0 12px 24px #00000029}.leaflet-container .leaflet-control-zoom a{color:#112033;background:#fffffff0;border:none;width:34px;height:34px;line-height:34px}.leaflet-container .leaflet-control-attribution{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffffe0}.leaflet-container .leaflet-tile{outline:1px solid #0000}.custom-marker{filter:drop-shadow(0 2px 4px #0000004d)}.marker-icon{justify-content:center;align-items:center;display:flex}.marker-cluster{background:0 0!important}.cluster-icon{justify-content:center;align-items:center;display:flex!important}.client-popup{color:#0f172a;min-width:240px;max-width:300px;font-size:12px}.map-client-popup .leaflet-popup-content{margin:10px 12px}.map-client-popup .leaflet-popup-content-wrapper{background:#fff;border:1px solid #0f172a24;border-radius:16px;box-shadow:0 16px 40px #0a111d3d}.map-client-popup .leaflet-popup-tip{background:#fff}.leaflet-popup .client-popup{transform-origin:50% 100%;animation:.22s cubic-bezier(.2,.85,.3,1) popupReveal}@keyframes popupReveal{0%{opacity:0;transform:translateY(6px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.leaflet-popup-content{margin:12px 14px}.popup-head{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:6px 10px;margin-bottom:8px;display:grid}.popup-title-wrap{gap:2px;min-width:0;display:grid}.popup-title-wrap h3{color:#0b1220;white-space:normal;overflow-wrap:anywhere;margin:0;font-size:12px;font-weight:700;line-height:1.2}.popup-subtitle{color:#334155;margin:0;font-size:10px;line-height:1.2}.popup-status-pill{white-space:nowrap;border:1px solid #0000;border-radius:999px;justify-content:center;align-items:center;min-height:22px;padding:0 9px;font-size:10px;font-weight:700;display:inline-flex}.popup-status-pill.status-online{color:#047857;background:#10b9811f;border-color:#10b98159}.popup-status-pill.status-offline{color:#b91c1c;background:#ef44441f;border-color:#ef444459}.popup-grid{background:linear-gradient(#f8fbff,#f1f6fc);border:1px solid #0f172a1a;border-radius:12px;gap:2px;margin-bottom:8px;padding:6px 8px;display:grid}.popup-row{grid-template-columns:110px minmax(0,1fr);align-items:center;gap:8px;min-width:0;display:grid}.popup-label{color:#475569;text-transform:uppercase;letter-spacing:.02em;white-space:nowrap;grid-template-columns:14px auto;align-items:center;gap:4px;font-size:10px;font-weight:700;display:grid}.popup-label-icon{opacity:.85;justify-content:center;width:14px;min-width:14px;font-size:11px;display:inline-flex}.popup-value{color:#0f172a;overflow-wrap:anywhere;font-size:11px;font-weight:600;line-height:1.25;display:block}.popup-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:11px}.popup-attenuation{color:#0f766e;font-weight:700}.popup-coordinates{letter-spacing:.01em;word-spacing:1px;color:#0b1220;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:10px}.popup-actions{padding-top:2px;display:flex}.action-link{text-align:center;background:linear-gradient(135deg, var(--brand-500), var(--brand-600));-webkit-text-fill-color:#fff;letter-spacing:.01em;border-radius:10px;justify-content:center;align-items:center;width:100%;min-height:34px;padding:0 10px;font-size:11px;font-weight:700;text-decoration:none;transition:transform .16s,box-shadow .16s;display:inline-flex;box-shadow:0 8px 18px #0077b63d;color:#fff!important}.action-link:visited,.action-link:hover,.action-link:active,.action-link:focus{-webkit-text-fill-color:#fff;color:#fff!important}.action-link:hover{transform:translateY(-1px);box-shadow:0 12px 22px #0077b64d}.map-legend{background:linear-gradient(#ffffffd6,#f8fafdeb);border:1px solid #11203314;border-radius:18px;flex-wrap:wrap;align-items:center;gap:16px;padding:12px 16px;font-size:12px;display:flex;box-shadow:0 10px 24px #0a111d0f}.map-legend-floating{z-index:610;pointer-events:auto;overflow-wrap:anywhere;max-width:calc(100% - 32px);top:auto;bottom:16px;left:16px;right:auto}.legend-title{color:var(--text-2);margin-right:4px;font-size:13px;font-weight:600}.legend-item{align-items:center;gap:8px;display:flex}.legend-color{border:1px solid #1120331f;border-radius:50%;width:16px;height:16px;box-shadow:0 0 0 2px #fffc}.legend-gradient{background:linear-gradient(90deg,#0a0,#fa0,#d00);border-radius:999px;width:120px;height:12px}.legend-section{border-left:1px solid var(--border-1);align-items:center;gap:10px;padding-left:14px;display:flex}:root[data-theme=dark] .map-view{background:radial-gradient(circle at 0 0,#66c9f01f,#0000 28%),linear-gradient(#0d1117,#111a27)}:root[data-theme=dark] .map-toolbar,:root[data-theme=dark] .map-legend{background:linear-gradient(#0f1824eb,#132031e0);border-color:#7d9ebe29;box-shadow:0 18px 42px #00000047}:root[data-theme=dark] .toolbar-brand{background:linear-gradient(#111c2bf5,#0e1825eb);border-color:#7d9ebe33;box-shadow:0 10px 22px #00000038}:root[data-theme=dark] .toolbar-controls{background:linear-gradient(#0f1927f2,#0c1521e6);border-color:#7d9ebe33;box-shadow:0 10px 26px #00000038}:root[data-theme=dark] .map-fullscreen-btn{color:var(--text-1);background:#132031eb;border-color:#7d9ebe2e}:root[data-theme=dark] .map-fullscreen-btn:hover{background:#182639fa}:root[data-theme=dark] .stat-item,:root[data-theme=dark] .filter-group select{color:var(--text-1);background:#0d1117db;border-color:#7d9ebe29}:root[data-theme=dark] .stat-item{background:linear-gradient(#111c2beb,#0d1622e6);border-color:#7d9ebe33;box-shadow:0 10px 22px #0000003d}:root[data-theme=dark] .stat-item.online{border-left-color:#22c55e}:root[data-theme=dark] .stat-item.offline{border-left-color:#ef4444}:root[data-theme=dark] .stat-value{color:#f8fafc}:root[data-theme=dark] .filter-group,:root[data-theme=dark] .toggle-group{background:#0d1117b8;border-color:#7d9ebe29}:root[data-theme=dark] .filter-group{background:#111c2bdb;border-color:#7d9ebe33;box-shadow:0 8px 18px #00000038}:root[data-theme=dark] .toggle-group{background:#101b28db;border-color:#7d9ebe33}:root[data-theme=dark] .map-search-group{background:#111c2bdb;border-color:#7d9ebe33;box-shadow:0 8px 18px #00000038}:root[data-theme=dark] .map-search-input{color:var(--text-1)}:root[data-theme=dark] .map-search-input::placeholder,:root[data-theme=dark] .map-search-clear{color:var(--text-2)}:root[data-theme=dark] .map-search-clear:hover{color:#f8fafc}:root[data-theme=dark] .legend-title,:root[data-theme=dark] .toolbar-section h1,:root[data-theme=dark] .stat-label,:root[data-theme=dark] .filter-group label,:root[data-theme=dark] .toggle-group label{color:var(--text-2)}:root[data-theme=dark] .toolbar-brand h1{color:#f8fafc}:root[data-theme=dark] .toolbar-subtitle{color:#b8c7da}:root[data-theme=dark] .map-container{border-color:#7d9ebe24;box-shadow:0 20px 55px #00000057}:root[data-theme=dark] .leaflet-host.map-style-clean,:root[data-theme=dark] .leaflet-host.map-style-detailed{background:#e0e0e0}:root[data-theme=dark] .leaflet-host.map-style-dark{background:#0b1420}:root[data-theme=dark] .legend-color{box-shadow:0 0 0 2px #132031bf}@media (max-width:960px){.map-view{height:calc(100dvh - 54px);min-height:0;padding:10px}.map-container{min-height:420px}.map-legend{gap:12px;padding:10px 14px}.toolbar-row-main{grid-template-columns:1fr}.toolbar-stats{grid-template-columns:repeat(3,minmax(112px,1fr))}.map-legend-floating{max-width:none;bottom:10px;left:10px;right:10px}.map-controls-overlay{top:10px;right:10px}.legend-section{border-left:0;padding-left:0}}.map-loading,.map-error,.map-empty-state{height:100%;color:var(--app-text-secondary);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#ffffffb8;justify-content:center;align-items:center;font-size:14px;display:flex}.map-error{flex-direction:column;gap:10px}.map-error h2{color:var(--app-text);margin:0}.map-error p{color:#d00;margin:0}.map-empty-state{flex-direction:column;gap:20px;padding:40px}.map-empty-state h2{color:var(--app-text);margin:0;font-size:18px}.diagnostics-info{background:var(--card-bg);text-align:left;border-left:4px solid var(--primary-color,#007bff);border-radius:8px;max-width:600px;padding:20px}.diagnostics-info p{color:var(--app-text);margin:8px 0;font-size:14px}.diagnostics-info strong{color:var(--app-text)}.diagnostics-info ul{color:var(--app-text-secondary);margin:12px 0;padding-left:20px}.diagnostics-info li{margin:6px 0;font-size:13px}.diagnostics-info hr{border:none;border-top:1px solid var(--border-1);margin:12px 0}.help-text{font-weight:600;color:var(--app-text)!important;margin-top:12px!important}@media (max-width:768px){.map-view{gap:10px;padding:10px}.map-toolbar{gap:12px;padding:14px}.toolbar-row{flex-direction:column;align-items:stretch;width:100%}.toolbar-row-main{gap:10px}.toolbar-brand{justify-content:flex-start}.toolbar-stats{flex-wrap:wrap;grid-template-columns:repeat(2,minmax(112px,1fr));justify-content:flex-start;width:100%;min-width:0}.toolbar-controls{justify-content:flex-start;width:100%;padding:10px}.map-legend{gap:10px;padding:10px 12px;font-size:11px}.client-popup{min-width:230px;max-width:280px;font-size:11px}.popup-row{grid-template-columns:92px minmax(0,1fr);gap:6px}}@media (max-width:1180px){.toolbar-row-main{flex-direction:column;align-items:flex-start}.toolbar-stats{justify-content:flex-start;width:100%}.toolbar-controls,.map-search-group,.map-search-input{width:100%}}@media (max-width:480px){.toolbar-brand h1{font-size:16px}.toolbar-stats{grid-template-columns:1fr;gap:8px}.stat-item{padding:6px 10px;font-size:12px}.toolbar-controls{gap:6px}.filter-group,.toggle-group{flex-wrap:wrap;width:100%;min-height:auto;padding:8px 10px}.filter-group{flex-wrap:nowrap;grid-template-columns:auto 110px}.toggle-group label,.btn-reset{width:100%}.btn-reset{height:34px;min-height:34px;font-size:12px}}.sysver-page{max-width:720px;margin:0 auto;padding:24px 16px}.sysver-loading{text-align:center;color:var(--text-3);padding:48px 0}.sysver-header{margin-bottom:20px}.sysver-title{color:var(--text-1);margin:0;font-size:1.25rem;font-weight:600}.sysver-current-card{background:var(--surface-2);border:1px solid var(--border-1);border-radius:10px;margin-bottom:28px;padding:20px}.sysver-current-info{flex-wrap:wrap;align-items:center;gap:16px;display:flex}.sysver-version-badge{flex-direction:column;gap:2px;display:flex}.sysver-version-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-3);font-size:.72rem}.sysver-version-number{color:var(--text-1);font-variant-numeric:tabular-nums;font-size:1.5rem;font-weight:700}.sysver-update-available{color:#f59e0b;align-items:center;gap:6px;font-size:.85rem;display:flex}.sysver-update-dot{background:#f59e0b;border-radius:50%;width:8px;height:8px;animation:2s infinite sysver-pulse}@keyframes sysver-pulse{0%,to{opacity:1}50%{opacity:.4}}.sysver-up-to-date{color:#22c55e;align-items:center;gap:6px;font-size:.85rem;display:flex}.sysver-update-actions{margin-top:16px}.sysver-btn-update{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:6px;align-items:center;gap:6px;padding:8px 16px;font-size:.85rem;font-weight:500;transition:background .15s;display:inline-flex}.sysver-btn-update:hover{background:#1d4ed8}.sysver-confirm{background:#f59e0b14;border:1px solid #f59e0b40;border-radius:8px;padding:14px;font-size:.85rem}.sysver-confirm p{color:var(--text-1);margin:0 0 6px}.sysver-confirm-detail{color:var(--text-3);font-size:.78rem}.sysver-confirm-buttons{gap:8px;margin-top:12px;display:flex}.sysver-btn-confirm{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:5px;padding:6px 16px;font-size:.82rem;font-weight:500}.sysver-btn-confirm:hover{background:#1d4ed8}.sysver-btn-cancel{color:var(--text-2);background:var(--surface-3);border:1px solid var(--border-1);cursor:pointer;border-radius:5px;padding:6px 16px;font-size:.82rem}.sysver-btn-cancel:hover{background:var(--surface-4,var(--surface-3))}.sysver-updating{color:var(--text-2);align-items:center;gap:10px;padding:8px 0;font-size:.85rem;display:flex}.sysver-spinner{border:2px solid var(--border-1);border-top-color:#2563eb;border-radius:50%;width:18px;height:18px;animation:.7s linear infinite sysver-spin}@keyframes sysver-spin{to{transform:rotate(360deg)}}.sysver-result{border-radius:6px;align-items:center;gap:8px;margin-top:14px;padding:10px 14px;font-size:.82rem;display:flex}.sysver-result-success{color:#22c55e;background:#22c55e1a;border:1px solid #22c55e4d}.sysver-result-error{color:#ef4444;background:#ef44441a;border:1px solid #ef44444d}.sysver-releases{margin-top:8px}.sysver-releases-title{color:var(--text-1);margin:0 0 14px;font-size:1rem;font-weight:600}.sysver-no-releases{color:var(--text-3);font-size:.85rem}.sysver-releases-list{flex-direction:column;gap:1px;display:flex}.sysver-release-item{background:var(--surface-2);border:1px solid var(--border-1);border-radius:8px;margin-bottom:8px;padding:14px 16px;transition:border-color .15s}.sysver-release-item.is-current{border-color:#2563eb66}.sysver-release-header{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.sysver-release-tag{color:var(--text-1);font-variant-numeric:tabular-nums;font-size:.9rem;font-weight:600}.sysver-release-current-badge{text-transform:uppercase;letter-spacing:.04em;color:#60a5fa;background:#2563eb26;border-radius:4px;padding:1px 7px;font-size:.68rem;font-weight:600}.sysver-release-pre-badge{text-transform:uppercase;letter-spacing:.04em;color:#f59e0b;background:#f59e0b26;border-radius:4px;padding:1px 7px;font-size:.68rem;font-weight:600}.sysver-release-date{color:var(--text-3);margin-left:auto;font-size:.78rem}.sysver-release-name{color:var(--text-2);margin-top:6px;font-size:.85rem}.sysver-release-body{color:var(--text-3);white-space:pre-wrap;word-break:break-word;margin-top:8px;font-size:.82rem;line-height:1.5}.connection-indicator{background:var(--surface-1);box-shadow:var(--shadow-soft);border:1px solid var(--border-1);z-index:1000;border-radius:20px;align-items:center;gap:8px;padding:8px 16px;font-size:.85rem;font-weight:600;transition:all .3s;display:flex;position:fixed;bottom:20px;left:20px}.connection-indicator.in-sidebar{z-index:2;border-radius:12px;justify-content:center;width:100%;margin-top:8px;position:-webkit-sticky;position:sticky;bottom:0;left:auto;transform:none}.indicator-dot{border-radius:50%;width:10px;height:10px;transition:all .3s}.connection-indicator.connected{border:2px solid #00a4e6}.connection-indicator.connected .indicator-dot{background:#00a4e6;animation:2s infinite pulse-blue}.connection-indicator.connected span{color:#00a4e6}.connection-indicator.disconnected{border:2px solid #e74c3c}.connection-indicator.disconnected .indicator-dot{background:#e74c3c;animation:2s infinite pulse-red}.connection-indicator.disconnected span{color:#e74c3c}.connection-indicator.loading{border:2px solid var(--text-3)}.connection-indicator.loading .indicator-dot{background:var(--text-3);animation:1s infinite pulse-gray}.connection-indicator.loading span{color:var(--text-3)}@keyframes pulse-blue{0%,to{box-shadow:0 0 #00a4e6b3}50%{box-shadow:0 0 0 6px #00a4e600}}@keyframes pulse-red{0%,to{box-shadow:0 0 #e74c3cb3}50%{box-shadow:0 0 0 6px #e74c3c00}}@keyframes pulse-gray{0%,to{opacity:1}50%{opacity:.5}}@media (max-width:600px){.connection-indicator{bottom:80px;left:50%;transform:translate(-50%)}.connection-indicator.in-sidebar{bottom:0;left:auto;transform:none}}@media (max-width:767px){.connection-indicator.connected{display:none}.connection-indicator.in-sidebar.connected{display:flex}}.sidebar-group{margin-bottom:.2rem}.sidebar-link.sidebar-link-static{align-items:center;min-height:40px;display:flex}.sidebar-group+.sidebar-group{margin-top:.1rem}.sidebar-toolbar-actions{align-items:center;gap:8px;min-width:0;display:flex}.sidebar-logo-button{cursor:pointer;background:0 0;border:0;justify-content:center;align-items:center;padding:0;display:inline-flex}.sidebar-logo{object-fit:contain;filter:brightness(0)saturate()invert(32%)sepia(89%)saturate(1588%)hue-rotate(175deg)brightness(91%)contrast(101%);width:auto;height:50px}.sidebar-provision-icon.is-pending{color:#ff9800;animation:1.2s ease-in-out infinite sidebar-app-icon-pulse-orange}.pending-onus-indicator{background:orange;border-radius:50%;width:10px;height:10px;margin-left:2px;animation:1s infinite pending-onus-blink;display:inline-block;box-shadow:0 0 4px 2px #ff8c004d}.offline-clients-indicator{background:#e74c3c;border-radius:50%;width:10px;height:10px;margin-left:2px;animation:1s infinite pending-onus-blink;display:inline-block;box-shadow:0 0 4px 2px #e74c3c59}@keyframes pending-onus-blink{0%,to{opacity:1}50%{opacity:.3}}@keyframes sidebar-app-icon-pulse-orange{0%,to{filter:drop-shadow(0 0 #ff980000);opacity:1;transform:scale(1)}50%{filter:drop-shadow(0 0 8px #ff9800f2);opacity:.88;transform:scale(1.14)}}.app-sidebar{border-right:1px solid var(--border-1);background:linear-gradient(180deg, #0f18240f 140px), var(--surface-0);min-height:100vh;width:var(--sidebar-width,290px);z-index:210;flex-direction:column;align-self:start;height:100vh;transition:width .22s,transform .22s;display:flex;position:-webkit-sticky;position:sticky;top:0;overflow:hidden}.sidebar-scrollable{z-index:1;scrollbar-gutter:stable;flex-direction:column;flex:auto;justify-content:flex-start;align-items:stretch;gap:12px;min-height:0;padding:0 12px 14px;display:flex;position:relative;overflow-x:hidden;overflow-y:auto}.sidebar-scrollable>*{width:100%}.sidebar-fixed-bottom{border-top:1px solid var(--border-1);background:linear-gradient(180deg, #0f182405 0%, var(--surface-0) 40%);flex:none;padding:8px 12px 12px}.sidebar-toolbar{justify-content:space-between;align-items:center;gap:8px;padding:6px 0 4px;display:flex}.sidebar-toolbar-title{flex-direction:column;min-width:0;display:flex}.sidebar-toolbar-title strong{color:var(--text-1);font-size:.9rem;line-height:1.2}.sidebar-toolbar-eyebrow{letter-spacing:.12em;text-transform:uppercase;color:var(--brand-500);font-size:.66rem;font-weight:800}.sidebar-collapse-button{border:1px solid var(--border-1);background:var(--surface-1);width:30px;height:30px;color:var(--text-2);cursor:pointer;border-radius:9px;justify-content:center;align-items:center;transition:background .18s,color .18s,border-color .18s,transform .18s;display:inline-flex}.sidebar-collapse-button:hover{background:var(--chip-bg);color:var(--text-1);border-color:var(--brand-500)}.sidebar-collapse-icon{transition:transform .2s}.sidebar-nav-main,.sidebar-nav-admin,.sidebar-nav-common{flex-direction:column;gap:6px;display:flex}.sidebar-nav-common{margin-top:6px}.sidebar-nav-admin{border-top:0;padding-top:0}.sidebar-connection-wrap{background:0 0;margin-top:8px;padding-top:8px;position:static}.sidebar-section-title{letter-spacing:.12em;text-transform:uppercase;color:var(--text-3);padding:0 8px;font-size:.7rem;font-weight:800}.sidebar-menu,.sidebar-submenu{margin:0;padding:0;list-style:none}.sidebar-menu{flex-direction:column;gap:4px;display:flex}.sidebar-group{flex-direction:column;gap:6px;display:flex}.sidebar-link,.sidebar-sublink{box-sizing:border-box;width:100%;color:var(--text-2);border-radius:12px;align-items:center;gap:12px;text-decoration:none;transition:background .18s,color .18s,transform .18s;display:flex}.sidebar-link{min-height:40px;padding:0 10px;font-weight:700}.sidebar-link-static{cursor:pointer;text-align:left;background:0 0;border:0}.sidebar-expand-icon{opacity:.65;margin-left:auto;transition:transform .2s,opacity .2s;transform:rotate(0)}.sidebar-expand-icon.is-open{opacity:1;transform:rotate(180deg)}.sidebar-label{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.sidebar-sublink{border:1px solid #0000;width:calc(100% - 14px);min-height:32px;margin-left:14px;padding:0 10px 0 16px;font-size:.88rem;font-weight:600;position:relative}.sidebar-sublink-button{cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:10px;display:flex;padding-left:16px!important}.sidebar-link-logout:hover{color:#e74c3c!important;background:#e74c3c1f!important}.sidebar-submenu{max-height:0;padding-top:2px;transition:max-height .22s;overflow:hidden}.sidebar-submenu.is-open{max-height:300px}.sidebar-sublink:before{content:"";opacity:.45;background:currentColor;border-radius:50%;width:4px;height:4px;position:absolute;top:50%;left:8px;transform:translateY(-50%)}.sidebar-link:hover,.sidebar-sublink:hover,.sidebar-group.is-open>.sidebar-link{background:var(--chip-bg);color:var(--text-1)}.sidebar-link.is-selected,.sidebar-sublink.is-selected{color:var(--text-1);background:linear-gradient(135deg,#00a4e62e,#0077b61f);box-shadow:inset 0 0 0 1px #00a4e62e}.sidebar-link.is-selected{transform:translate(2px)}.app-sidebar.is-collapsed .sidebar-scrollable{scrollbar-gutter:auto;padding:6px 10px 14px}.app-sidebar.is-collapsed .sidebar-fixed-bottom{padding-left:10px;padding-right:10px}.app-sidebar.is-collapsed .sidebar-toolbar{justify-content:center}.app-sidebar.is-collapsed .sidebar-toolbar-title,.app-sidebar.is-collapsed .sidebar-section-title,.app-sidebar.is-collapsed .sidebar-label,.app-sidebar.is-collapsed .sidebar-toolbar-actions,.app-sidebar.is-collapsed .sidebar-expand-icon,.app-sidebar.is-collapsed .sidebar-submenu{display:none}.app-sidebar.is-collapsed .sidebar-group{gap:0}.app-sidebar.is-collapsed .sidebar-connection-wrap .connection-indicator.in-sidebar{justify-content:center;padding-left:0;padding-right:0}.app-sidebar.is-collapsed .sidebar-connection-wrap .connection-indicator.in-sidebar span{display:none}.app-sidebar.is-collapsed .sidebar-nav-admin{flex-direction:column;align-items:center;padding-top:0;display:flex}.app-sidebar.is-collapsed .sidebar-nav-common{flex-direction:column;align-items:center;display:flex}.app-sidebar.is-collapsed .sidebar-link{justify-content:center;gap:0;width:53px;height:40px;min-height:40px;margin:0 auto;padding:0}.app-sidebar.is-collapsed .sidebar-link .app-icon+.app-icon{display:none}.app-sidebar.is-collapsed .sidebar-link>span:not(.app-icon){display:none!important}.app-sidebar.is-collapsed .sidebar-menu{align-items:center}.app-sidebar.is-collapsed .sidebar-collapse-button{border-radius:12px;width:53px;height:40px}.app-sidebar.is-collapsed .sidebar-link.is-selected{transform:none}.app-sidebar.is-collapsed .sidebar-collapse-icon{transform:rotate(180deg)}@media (max-width:960px){.app-sidebar{height:100vh;min-height:0;height:100dvh;min-height:100vh;min-height:100dvh;max-height:100vh;border-right:1px solid var(--border-1);z-index:210;border-bottom:0;width:min(90vw,340px);max-height:100dvh;margin-top:0;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%);box-shadow:0 24px 60px #00000052}.sidebar-scrollable{min-height:0;padding:calc(2px + env(safe-area-inset-top,0px)) 12px 12px;flex:auto}.sidebar-logo{height:60px}.sidebar-fixed-bottom{margin-top:auto;padding:8px 12px 12px}.app-sidebar.is-collapsed .sidebar-fixed-bottom{padding-left:12px;padding-right:12px}.sidebar-nav-admin{margin-top:0}.sidebar-connection-wrap{background:0 0}.app-sidebar.is-mobile-open{transform:translate(0)}.app-sidebar.is-collapsed{width:min(90vw,340px)}.app-sidebar.is-collapsed .sidebar-toolbar,.app-sidebar.is-collapsed .sidebar-nav-main,.app-sidebar.is-collapsed .sidebar-nav-admin,.app-sidebar.is-collapsed .sidebar-nav-common{align-items:stretch}.app-sidebar.is-collapsed .sidebar-toolbar-title,.app-sidebar.is-collapsed .sidebar-section-title,.app-sidebar.is-collapsed .sidebar-label{display:initial}.app-sidebar.is-collapsed .sidebar-toolbar-title{display:flex}.app-sidebar.is-collapsed .sidebar-toolbar-actions{width:auto;display:flex}.app-sidebar.is-collapsed .sidebar-submenu{display:block}.app-sidebar.is-collapsed .sidebar-link{justify-content:flex-start;gap:12px;width:100%;height:auto;margin:0;padding:0 12px}.app-sidebar.is-collapsed .sidebar-link>span:not(.app-icon){display:initial!important}.app-sidebar.is-collapsed .sidebar-collapse-button{border-radius:9px;width:30px;height:30px}.app-sidebar.is-collapsed .sidebar-collapse-icon{transform:none}}@media (max-width:420px){.app-sidebar,.app-sidebar.is-collapsed{width:92vw;max-width:320px}.sidebar-scrollable{padding-left:10px;padding-right:10px}.sidebar-fixed-bottom{padding:8px 10px calc(10px + env(safe-area-inset-bottom,0px))}}:root[data-theme=dark] .sidebar-logo{filter:brightness(0)saturate()invert(88%)sepia(11%)saturate(716%)hue-rotate(165deg)brightness(104%)contrast(93%)}.update-banner{color:var(--text-1);background:linear-gradient(135deg,#38bdf81f,#0ea5e914);border:1px solid #38bdf84d;border-radius:8px;align-items:center;gap:10px;margin:0 16px 12px;padding:10px 16px;font-size:.85rem;display:flex}.update-banner-icon{color:#38bdf8;flex-shrink:0}.update-banner-text{flex:1;line-height:1.4}.update-banner-text strong{color:#38bdf8}.update-banner-action{color:#38bdf8;cursor:pointer;white-space:nowrap;background:#38bdf81f;border:1px solid #38bdf84d;border-radius:5px;flex-shrink:0;padding:4px 12px;font-size:.78rem;font-weight:500;transition:background .15s}.update-banner-action:hover{background:#38bdf833}.update-banner-dismiss{color:var(--text-3);cursor:pointer;background:0 0;border:none;border-radius:4px;flex-shrink:0;padding:4px;line-height:1}.update-banner-dismiss:hover{color:var(--text-1);background:#ffffff0f}.mobile-topbar{display:none}.btn-mobile-toggle{border:1px solid var(--border-1);background:var(--surface-1);width:38px;height:38px;color:var(--text-2);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;transition:background .18s,color .18s;display:inline-flex}.btn-mobile-toggle:hover{background:var(--chip-bg);color:var(--text-1)}.auth-layout{--shell-header-height:0px;--sidebar-width:290px;--sidebar-collapsed-width:88px;background:var(--app-bg);min-height:100vh}.auth-layout.sidebar-collapsed{--sidebar-width:var(--sidebar-collapsed-width)}.auth-layout-body{grid-template-columns:var(--sidebar-width) minmax(0, 1fr);align-items:start;transition:grid-template-columns .22s;display:grid}.auth-layout-content{min-width:0;min-height:100vh;min-height:100dvh}.auth-layout-backdrop{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:205;background:#060b1294;border:0;position:fixed;top:0;bottom:0;left:0;right:0}@media (max-width:960px){.auth-layout-body{grid-template-columns:1fr}.mobile-topbar{padding:calc(8px + env(safe-area-inset-top,0px)) var(--page-pad-x,14px) 8px;background:var(--surface-0);border-bottom:1px solid var(--border-1);z-index:100;align-items:center;min-height:54px;display:flex;position:-webkit-sticky;position:sticky;top:0}.auth-layout-content{min-height:calc(100dvh - 54px)}}@media (min-width:768px){.auth-layout{--shell-header-height:82px}}.geogrid-global-alert{color:var(--alert-warning-text,#92400e);z-index:200;background:#f59e0b21;border:1px solid #f59e0b73;border-radius:10px;justify-content:space-between;align-items:center;gap:10px;margin:12px 18px 0;padding:12px 18px;font-size:.92rem;font-weight:600;animation:.3s geogrid-alert-in;display:flex}.geogrid-global-alert-close{cursor:pointer;color:inherit;opacity:.7;background:0 0;border:none;padding:0 4px;font-size:1.1rem;font-weight:700;line-height:1;transition:opacity .15s}.geogrid-global-alert-close:hover{opacity:1}@keyframes geogrid-alert-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}*{box-sizing:border-box;margin:0;padding:0}:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--brand-500:#00a4e6;--brand-600:#0077b6;--brand-400:#33b5eb;--danger-500:#ef4444;--success-500:#10b981;--app-bg:#f5f8fc;--page-grad-start:#f0f4f8;--page-grad-end:#d9e8f5;--surface-0:#fff;--surface-1:#fff;--surface-2:#f8f9fa;--light-panel-bg:#ffffffe6;--light-panel-bg-strong:#fffffff5;--light-panel-border:#6088c44d;--light-panel-border-strong:#5680c275;--light-panel-shadow:0 12px 28px #1836661f;--light-inset-glow:inset 0 1px 0 #ffffffc7;--light-accent-soft:#00a4e61f;--light-accent-mid:#00a4e633;--light-focus-ring:#0084dc33;--text-1:#1a2a3a;--text-2:#5a7184;--text-3:#8a9aaa;--border-1:#e0e8f0;--border-2:#e8edf2;--card-bg:#fff;--input-bg:#f5f8fc;--hover-bg:#0000000a;--chip-bg:#f0f4f8;--chip-bg-hover:#e0e8f0;--status-online:#0f7a35;--status-offline:#dc2626;--status-unknown:#6b7280;--status-online-bg:#ecfdf5;--status-offline-bg:#fef2f2;--status-unknown-bg:#f3f4f6;--alert-success-bg:#ecfdf5;--alert-success-text:#166534;--alert-success-border:#bbf7d0;--alert-warning-bg:#fffbeb;--alert-warning-text:#92400e;--alert-warning-border:#fde68a;--alert-error-bg:#fef2f2;--alert-error-text:#991b1b;--alert-error-border:#fecaca;--att-good:#0f7a35;--att-warning:#b45309;--att-critical:#dc2626;--header-bg:#fff;--header-border:#e0e0e0;--header-shadow:0 2px 8px #0000000d;--shadow-soft:0 4px 20px #0000001a;--shadow-strong:0 20px 60px #0000004d;--page-pad-x:clamp(12px, 3.2vw, 24px);--page-pad-y:clamp(12px, 2.2vw, 24px);--touch-target-min:42px;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Noto Sans,Ubuntu,Cantarell,Helvetica Neue,Avenir,Helvetica,Arial,sans-serif;font-weight:400;line-height:1.5}:root[data-theme=dark]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--brand-400:#66c9f0;--app-bg:#0d1117;--page-grad-start:#0d1117;--page-grad-end:#111a27;--surface-0:#0f1824;--surface-1:#132031;--surface-2:#1a2738;--light-panel-bg:#132031db;--light-panel-bg-strong:#132031f0;--light-panel-border:#40669b73;--light-panel-border-strong:#4b76b499;--light-panel-shadow:0 16px 32px #00000057;--light-inset-glow:inset 0 1px 0 #82aae229;--light-accent-soft:#00a4e638;--light-accent-mid:#00a4e652;--light-focus-ring:#50b4ff33;--text-1:#e6f0f8;--text-2:#9db3c5;--text-3:#748ca0;--border-1:#2a3b4d;--border-2:#233244;--card-bg:#132031;--input-bg:#0d1117;--hover-bg:#ffffff0f;--chip-bg:#1a2738;--chip-bg-hover:#223246;--status-online:#34d399;--status-offline:#f87171;--status-unknown:#9ca3af;--status-online-bg:#10b9811f;--status-offline-bg:#ef44441f;--status-unknown-bg:#9ca3af1a;--alert-success-bg:#10b9811f;--alert-success-text:#6ee7b7;--alert-success-border:#10b98140;--alert-warning-bg:#f59e0b1f;--alert-warning-text:#fbbf24;--alert-warning-border:#f59e0b40;--alert-error-bg:#ef44441f;--alert-error-text:#fca5a5;--alert-error-border:#ef444440;--att-good:#34d399;--att-warning:#fbbf24;--att-critical:#f87171;--header-bg:#0f1824;--header-border:#213244;--header-shadow:0 10px 30px #00000059;--shadow-soft:0 10px 30px #00000059;--shadow-strong:0 24px 70px #00000080}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}html,body{width:100%;height:100%;margin:0;padding:0;overflow-x:hidden}html{scrollbar-gutter:stable;font-size:max(14px,min(1.55vw,16px))}#root{width:100%;min-height:100vh}button,a,input,select,textarea{-webkit-tap-highlight-color:#00a4e61a}html{scroll-behavior:smooth}body{-webkit-overflow-scrolling:touch;background:var(--app-bg);color:var(--text-1)}.olts-container,.pon-selector-container,.pon-clients-container,.provisionar-onu-container,.onu-consulta-container,.olt-config-container,.usuarios-container,.co-page{padding-left:var(--page-pad-x)!important;padding-right:var(--page-pad-x)!important}.olts-page,.pon-selector-page,.pon-clients-page,.provisionar-onu-page,.onu-consulta-page,.olt-config-page,.usuarios-page,.co-page{padding-top:var(--page-pad-y)!important}@media (max-width:420px){:root{--page-pad-x:10px;--page-pad-y:10px;--touch-target-min:40px}html{font-size:14px}}@media (min-width:421px) and (max-width:767px){:root{--page-pad-x:14px}}.app-icon{vertical-align:middle;flex-shrink:0;display:inline-block}
