:root{color:#eef3ff;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;--bg:#050914;--bg-2:#070d19;--sidebar:#070c17;--panel:#111827;--panel-2:#151f31;--panel-3:#0d1422;--line:#7787aa29;--line-strong:#7787aa42;--text:#eef3ff;--muted:#8794ad;--muted-2:#b4bed0;--purple:#6d3df3;--purple-2:#8b5cf6;--purple-soft:#6d3df32e;--blue:#2377ff;--blue-soft:#2377ff2e;--green:#31d979;--green-soft:#31d97924;--red:#ff456b;--red-soft:#ff456b24;--amber:#f59f22;--shadow:0 18px 45px #00000061;--glow:0 0 34px #6d3df32e;background:#050914;font-family:Inter,Segoe UI,system-ui,-apple-system,BlinkMacSystemFont,sans-serif}*{box-sizing:border-box}body{background:var(--bg);min-width:320px;min-height:100vh;margin:0}button,input,select{font:inherit}button{cursor:pointer}.app-shell{background:radial-gradient(circle at 75% 0%, #6d3df321, transparent 34%), radial-gradient(circle at 35% 10%, #2377ff14, transparent 32%), var(--bg);grid-template-columns:260px minmax(0,1fr);min-height:100vh;display:grid}.sidebar{background:var(--sidebar);border-right:1px solid var(--line);flex-direction:column;gap:28px;height:100vh;padding:22px 18px;display:flex;position:sticky;top:0}.brand{min-height:66px;color:var(--purple-2);justify-content:flex-start;align-items:center;gap:0;display:flex}.brand-mark{width:188px;max-width:100%;height:auto;display:block}.brand-logo{background:linear-gradient(135deg,#6d3df3fa,#2377ffb8);border:1px solid #8b5cf694;border-radius:11px;place-items:center;width:36px;height:36px;display:grid;position:relative;box-shadow:0 14px 30px #6d3df347}.brand-logo span{color:var(--text);font-size:18px;font-weight:900;line-height:1}.brand-logo i,.brand-logo b{background:#c4b5fd;border-radius:999px;width:6px;height:6px;position:absolute;box-shadow:0 0 0 3px #8b5cf62e}.brand-logo i{top:7px;right:-3px}.brand-logo b{bottom:7px;left:-3px}.brand strong{color:var(--text);letter-spacing:0;font-size:17px;line-height:1.1}.brand small{color:var(--muted);margin-top:5px;font-size:11px;display:block}.sidebar nav{gap:7px;display:grid}.sidebar nav button{color:#d8dfef;text-align:left;background:0 0;border:0;border-radius:8px;align-items:center;gap:12px;height:46px;padding:0 14px;font-size:14px;font-weight:750;display:flex}.sidebar nav button.active,.sidebar nav button:hover{color:#fff;box-shadow:inset 3px 0 0 var(--purple-2), 0 10px 24px #00000029;background:linear-gradient(90deg,#6d3df35c,#6d3df329)}.account-card{border:1px solid var(--line);background:linear-gradient(#151f31f5,#0d1422fa);border-radius:10px;gap:11px;margin-top:auto;padding:16px;display:grid}.account-card span,.account-card strong{text-overflow:ellipsis;overflow:hidden}.account-card span{color:var(--text);font-size:12px;font-weight:850}.account-card strong{color:var(--green);align-items:center;gap:7px;font-size:12px;display:inline-flex}.account-card strong i,.account-card li em{background:var(--green);border-radius:999px;flex:none;width:8px;height:8px;box-shadow:0 0 12px #31d97999}.account-card ul{gap:10px;margin:2px 0 0;padding:0;list-style:none;display:grid}.account-card li{color:var(--muted-2);align-items:center;gap:8px;font-size:11px;display:flex}.workspace{gap:20px;min-width:0;padding:22px 28px 32px;display:grid}.topbar{justify-content:space-between;align-items:center;gap:16px;min-height:54px;display:flex}.connection-strip,.top-actions{align-items:center;gap:10px;min-width:0;display:flex}.connection-strip{color:var(--muted);flex-wrap:wrap;font-size:12px}.cloud-pill{border:1px solid var(--line);height:34px;color:var(--text);background:#111827d1;border-radius:9px;align-items:center;gap:8px;padding:0 12px;display:inline-flex}.reachable{color:var(--green);background:var(--green-soft);border-radius:999px;padding:5px 10px;font-weight:850}.controller-url{text-overflow:ellipsis;white-space:nowrap;max-width:360px;overflow:hidden}.sync-button{border:1px solid var(--line);background:var(--panel-2);height:42px;color:var(--text);border-radius:9px;align-items:center;gap:8px;padding:0 14px;font-weight:700;display:inline-flex}.voice-control{align-items:center;gap:9px;min-width:0;display:flex}.voice-button{color:#fff;background:linear-gradient(135deg,#6d3df3eb,#4c1d95e0);border:1px solid #8b5cf67a;border-radius:9px;align-items:center;gap:8px;height:42px;padding:0 14px;font-weight:800;display:inline-flex;box-shadow:0 12px 26px #6d3df33d}.voice-button.active{background:var(--red-soft);color:var(--red);border-color:#ff4f7280}.voice-status{max-width:220px;color:var(--muted);gap:2px;font-size:11px;line-height:1.2;display:grid}.voice-status span,.voice-status small{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.voice-status small{color:#b8c8ce}.view-pill{color:#d8ccff;background:var(--purple-soft);border:1px solid #8b5cf670;border-radius:9px;align-items:center;height:34px;padding:0 13px;font-weight:800;display:inline-flex}.time-chip{text-align:right;gap:2px;min-width:86px;display:grid}.time-chip strong{color:var(--text);font-size:13px}.time-chip span{color:var(--muted);font-size:11px}.dashboard{gap:18px;display:grid}.page-title{justify-content:space-between;align-items:end;gap:18px;display:flex}.page-title h1{color:var(--text);letter-spacing:0;margin:0;font-size:31px;font-weight:900;line-height:1.1}.site-detail-title{align-items:center}.back-link{color:var(--blue-2);background:0 0;border:0;padding:0 0 8px;font-size:12px;font-weight:850}.back-link:hover{color:#fff}.page-title p,.section-head p{color:var(--muted);margin:6px 0 0;font-size:13px}.online-badge{height:32px;color:var(--green);background:var(--green-soft);border:1px solid #31d97942;border-radius:999px;align-items:center;padding:0 13px;font-size:12px;font-weight:900;display:inline-flex}.stats-grid{grid-template-columns:repeat(6,minmax(146px,1fr));gap:14px;display:grid}.stat-card,.panel{background:var(--panel);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:10px}.stat-card{background:var(--panel);align-content:start;gap:5px;min-height:136px;padding:16px 16px 14px;display:grid;position:relative;overflow:hidden}.stat-icon{color:#fff;background:#6d3df338;border-radius:999px;place-items:center;width:38px;height:38px;margin-left:auto;display:grid}.metric-sites .stat-icon{color:#bda9ff;background:#6d3df342}.metric-gateways .stat-icon{color:#74a9ff;background:#2377ff33}.metric-switches .stat-icon{color:#ffc66d;background:#f59f222e}.metric-aps .stat-icon{color:#73f2a8;background:#31d9792b}.metric-clients .stat-icon{color:#74a9ff;background:#2377ff33}.metric-alerts .stat-icon{color:#ff7c98;background:#ff456b2b}.stat-card svg{color:currentColor}.stat-card span,.stat-card small{color:var(--muted-2);z-index:1;font-size:12px;position:relative}.stat-card strong{color:var(--text);z-index:1;margin-top:2px;font-size:32px;line-height:1;position:relative}.danger{color:var(--red)!important}.panel{background:linear-gradient(#111827f5,#0d1422fa);min-width:0;padding:18px}.section-head{justify-content:space-between;align-items:start;gap:12px;margin-bottom:14px;display:flex}.section-head h2{color:var(--text);letter-spacing:0;margin:0;font-size:16px;font-weight:900}.table-wrap{overflow-x:auto}.table-wrap.compact{margin:0 -4px}.table-note,.table-message{color:var(--muted);margin:0 0 14px;font-size:12px}.table-message{color:var(--muted-2);margin:12px 0 0}table{border-collapse:collapse;width:100%;min-width:620px}.panel.table-wrap table{min-width:760px}th,td{border-bottom:1px solid var(--line);text-align:left;color:#cbd5e7;padding:13px 10px;font-size:12px}th{color:var(--muted);text-transform:uppercase;font-size:10px;font-weight:800}.empty-cell,.empty-state{color:var(--muted);padding:20px}.status-dot{white-space:nowrap;align-items:center;gap:6px;display:inline-flex}.status-dot i{background:currentColor;border-radius:999px;width:8px;height:8px}.status-dot.green{color:var(--green)}.status-dot.red{color:var(--red)}.status-dot.amber{color:var(--amber)}.load-bar{background:#7787aa29;border-radius:999px;width:86px;height:7px;display:block;overflow:hidden}.load-bar i{border-radius:inherit;background:linear-gradient(90deg, var(--blue), var(--purple-2));height:100%;display:block}.move-device-control{align-items:center;gap:8px;min-width:280px;display:flex}.move-device-control select{border:1px solid var(--line);min-width:170px;height:34px;color:var(--text);background:#151f31eb;border-radius:8px;outline:0;padding:0 10px}.move-device-control button{background:var(--purple-soft);color:#d8ccff;border:1px solid #8b5cf685;border-radius:8px;height:34px;padding:0 12px;font-weight:850}.move-device-control button:hover{color:#fff;background:#6d3df34d}.site-list{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.single-site-list{grid-template-columns:1fr}.site-list button{border:1px solid var(--line);width:100%;color:var(--text);text-align:left;background:#151f31db;border-radius:10px;grid-template-columns:minmax(0,1fr) auto;gap:10px;padding:14px;transition:border-color .18s,transform .18s,background .18s;display:grid}.site-list button:hover{background:#192337f5;border-color:#8b5cf675;transform:translateY(-1px)}.single-site-list button{cursor:default}.single-site-list button:hover{transform:none}.site-list strong,.site-list span{text-overflow:ellipsis;white-space:nowrap;display:block;overflow:hidden}.site-list span{color:var(--muted);margin-top:4px;font-size:12px}.site-list small{color:var(--muted-2);margin-top:7px;font-size:12px;line-height:1.35;display:block}.site-list em{color:var(--green);font-style:normal;font-weight:800}.empty-site-list{min-height:92px;color:var(--muted);background:#151f316b;border:1px dashed #94a3b83d;border-radius:10px;grid-column:1/-1;align-content:center;gap:5px;padding:18px;display:grid}.empty-site-list strong{color:var(--text);font-size:14px}.empty-site-list span{font-size:12px}.activity-panel{gap:15px;display:grid}.activity-head{justify-content:space-between;align-items:center;gap:18px;display:flex}.activity-head h2{color:var(--text);margin:0;font-size:17px;font-weight:900}.activity-date{border:1px solid var(--line);height:36px;color:var(--text);background:#151f31e6;border-radius:9px;align-items:center;gap:8px;padding:0 10px;display:inline-flex}.activity-date span{color:var(--muted);font-size:12px}.activity-date input{color:var(--text);--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;background:0 0;border:0;outline:0}.activity-legend{color:var(--text);flex-wrap:wrap;align-items:center;gap:22px;font-size:12px;display:flex}.activity-legend span{align-items:center;gap:5px;display:inline-flex}.activity-legend i{width:8px;height:8px;display:inline-block}.legend-upload{background:var(--purple-2)}.legend-download{background:var(--blue)}.legend-wired{background:#2b5f9f}.legend-wireless{background:var(--green)}.mixed-chart{grid-template-columns:70px minmax(0,1fr) 42px;gap:12px;height:300px;display:grid}.traffic-axis,.client-axis{color:var(--muted);flex-direction:column;justify-content:space-between;font-size:12px;display:flex}.traffic-axis{text-align:right}.chart-stage{border-radius:8px;min-width:0;position:relative;overflow:hidden}.grid-lines{flex-direction:column;justify-content:space-between;display:flex;position:absolute;inset:0}.grid-lines span{border-top:1px solid #7787aa1f}.chart-stage svg{width:100%;height:100%;position:absolute;inset:0;overflow:visible}.chart-stage path{stroke-width:2.2px;vector-effect:non-scaling-stroke}.line-upload{fill:none;stroke:var(--purple-2);filter:drop-shadow(0 0 8px #8b5cf66b)}.line-download{fill:none;stroke:var(--blue);filter:drop-shadow(0 0 8px #2377ff6b)}.area-upload{fill:url(#uploadArea);stroke:none}.area-download{fill:url(#downloadArea);stroke:none}.client-bars{opacity:.58;align-items:end;gap:5px;padding:0 12px 1px;display:flex;position:absolute;inset:0}.client-bar-hit{background:0 0;border:0;outline:0;flex:1;align-items:end;min-width:4px;max-width:18px;height:100%;padding:0;display:flex}.client-bar-hit>span{background:#ffffff0a;border-radius:4px 4px 0 0;flex-direction:column-reverse;width:100%;display:flex;overflow:hidden}.client-bar-hit:hover>span,.client-bar-hit:focus>span{box-shadow:0 0 0 2px #8b5cf68c}.client-bars i{width:100%;display:block}.wired-segment{background:#2b5f9f}.wireless-segment{background:linear-gradient(180deg, var(--green), #31d97994)}.chart-empty{text-align:center;color:var(--muted);pointer-events:none;place-content:center;display:grid;position:absolute;inset:0}.activity-tooltip{z-index:5;border:1px solid var(--line-strong);color:#f5f5f5;pointer-events:none;background:#0c121ffa;border-radius:10px;width:min(330px,100% - 24px);padding:16px;position:absolute;top:18px;left:50%;transform:translate(-50%);box-shadow:0 18px 44px #0000008a}.activity-tooltip strong{margin-bottom:14px;font-size:14px;display:block}.tooltip-divider{background:var(--line-strong);height:1px;margin-bottom:14px}.tooltip-row{grid-template-columns:95px 1fr 1fr;align-items:center;gap:10px;margin-top:14px;display:grid}.tooltip-row span{color:#f0f0f0;font-weight:650}.tooltip-row em{color:#e7e7e7;align-items:center;gap:6px;font-style:normal;display:inline-flex}.tooltip-row i{width:8px;height:8px;display:inline-block}.tooltip-row .up{color:var(--blue)}.tooltip-row .down{color:var(--purple-2)}.tooltip-row.total{grid-template-columns:95px 1fr}.chart-empty strong{color:var(--text);margin-bottom:5px}.chart-labels{color:var(--muted);grid-template-columns:repeat(24,minmax(0,1fr));min-height:30px;padding-left:74px;padding-right:48px;font-size:10px;display:grid}.chart-labels span{text-overflow:clip;white-space:nowrap;text-align:center;overflow:visible;transform:none}.activity-total{color:var(--muted);font-size:12px}.alerts-panel{display:grid}.alerts-list{gap:10px;display:grid}.alerts-list article{border:1px solid var(--line);background:#151f31d1;border-radius:9px;grid-template-columns:auto minmax(0,1fr);gap:10px;padding:10px;display:grid}.alerts-list svg{color:var(--red)}.alerts-list strong,.alerts-list span{display:block}.alerts-list strong{color:var(--text);font-size:13px}.alerts-list span{color:var(--muted);margin-top:4px;font-size:12px}.sites-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;display:grid}.sites-page{gap:16px;display:grid}.add-site-panel{gap:12px;display:grid}.add-site-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.add-site-grid label{gap:7px;display:grid}.add-site-grid label span{color:var(--muted);font-size:12px;font-weight:800}.add-site-grid input{border:1px solid var(--line);height:40px;color:var(--text);background:#151f31eb;border-radius:9px;outline:0;padding:0 11px}.add-site-actions{justify-content:flex-end;display:flex}.history-page{gap:16px;display:grid}.primary-action{background:linear-gradient(135deg, var(--purple), #4f2ac9);color:#fff;border:1px solid #8b5cf685;border-radius:9px;justify-content:center;align-items:center;gap:8px;height:40px;font-weight:900;display:inline-flex}.primary-action:disabled{opacity:.72}.form-message{color:var(--muted);margin:0;font-size:12px}.site-card{border:1px solid var(--line);color:var(--text);text-align:left;background:#151f31e0;border-radius:10px;display:grid;overflow:hidden}.site-card-main{color:var(--text);text-align:left;background:0 0;border:0;gap:8px;padding:16px;display:grid}.site-card span,.site-card em{color:var(--muted);font-style:normal}.delete-site-action{border:0;border-top:1px solid var(--line);min-height:38px;color:var(--red);background:#ff4f7214;justify-content:center;align-items:center;gap:8px;padding:0 12px;font-size:12px;font-weight:800;display:inline-flex}.delete-site-action:disabled{cursor:not-allowed;opacity:.42;color:var(--muted);background:#ffffff05}.history-list{gap:10px;display:grid}.history-card{border:1px solid var(--line);background:#151f31e0;border-radius:10px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;padding:13px;display:grid}.history-card strong,.history-card span,.history-card em{display:block}.history-card strong{color:var(--text)}.history-card span,.history-card em{color:var(--muted);margin-top:5px;font-size:12px;font-style:normal}.history-card button{border:1px solid var(--line);background:var(--panel-2);color:#c7b9ff;border-radius:9px;height:34px;padding:0 12px;font-weight:800}.settings-grid{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:16px;display:grid}.settings-rows{gap:10px;display:grid}.setting-row{border:1px solid var(--line);background:#151f31e0;border-radius:9px;gap:5px;padding:12px;display:grid}.setting-row span{color:var(--muted);font-size:12px}.setting-row strong{color:var(--text);overflow-wrap:anywhere}.debug-console summary{cursor:pointer;color:var(--text);font-weight:800}.console-actions{gap:8px;margin:14px 0;display:flex}.console-actions button{border:1px solid var(--line);background:var(--panel-2);height:36px;color:var(--text);border-radius:9px;align-items:center;gap:8px;padding:0 12px;display:inline-flex}.terminal{color:#b8c7ff;background:#070d19;border-radius:9px;grid-template-columns:auto minmax(0,1fr);gap:10px;padding:14px;display:grid}pre{white-space:pre-wrap;margin:0;font:12px/1.6 Consolas,SFMono-Regular,monospace}.spin{animation:.9s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@media (width<=980px){.app-shell{grid-template-columns:1fr;overflow-x:hidden}.sidebar{flex-direction:row;align-items:center;width:100%;height:auto;position:static;overflow-x:auto}.sidebar nav{flex:1 0 auto;min-width:0;display:flex}.account-card{display:none}.workspace{padding:14px;overflow-x:hidden}.topbar,.settings-grid,.add-site-grid{grid-template-columns:1fr;display:grid}.topbar{overflow:hidden}.add-site-actions{justify-content:stretch}.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.site-list,.sites-grid{grid-template-columns:1fr}}@media (width<=560px){.sidebar{padding:12px}.brand strong,.brand div{display:none}.brand{min-width:48px;min-height:44px}.brand-mark{width:112px}.sidebar nav button span{display:none}.sidebar nav button{justify-content:center;width:44px;padding:0}.time-chip{text-align:left}.stats-grid{grid-template-columns:1fr}.top-actions,.connection-strip{align-items:stretch}.top-actions,.voice-control{display:grid}.voice-status{max-width:none}}

/* FIRAS dashboard polish overrides. Kept CSS-only because this deployment is a compiled bundle. */
body{background:linear-gradient(180deg,#050914 0%,#080d18 52%,#050914 100%)}
.workspace{max-width:1680px;width:100%;margin:0 auto}
.topbar{position:sticky;top:0;z-index:20;margin:-22px -28px 0;padding:18px 28px 14px;background:linear-gradient(180deg,#050914f2 0%,#050914d9 74%,#05091400 100%);backdrop-filter:blur(14px)}
.page-title{padding-top:4px}
.page-title h1{font-size:clamp(25px,3vw,36px)}
.cloud-pill,.sync-button,.voice-button,.view-pill,.activity-date,.history-card button,.console-actions button,.primary-action{transition:transform .16s ease,border-color .16s ease,background .16s ease,box-shadow .16s ease}
.sync-button:hover,.voice-button:hover,.history-card button:hover,.console-actions button:hover,.primary-action:hover{transform:translateY(-1px);border-color:#8b5cf68a;box-shadow:0 12px 28px #00000035}
.stats-grid{grid-template-columns:repeat(auto-fit,minmax(154px,1fr))}
.stat-card{isolation:isolate;transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease}
.stat-card:before{content:"";position:absolute;inset:0 0 auto;height:3px;background:linear-gradient(90deg,currentColor,transparent);opacity:.62}
.stat-card:hover{transform:translateY(-2px);border-color:var(--line-strong);box-shadow:0 22px 52px #00000073}
.metric-sites{color:var(--purple-2)}.metric-gateways,.metric-clients{color:var(--blue)}.metric-switches{color:var(--amber)}.metric-aps{color:var(--green)}.metric-alerts{color:var(--red)}
.stat-card span,.stat-card small{color:#c3ccdc}.stat-card strong{font-variant-numeric:tabular-nums}
.panel{border-color:#8191b333;box-shadow:0 18px 42px #00000052}
.section-head{padding-bottom:12px;border-bottom:1px solid var(--line);margin-bottom:12px}
.section-head h2{font-size:17px}.section-head p{color:#a4afc2}
tbody tr{transition:background .14s ease}
tbody tr:hover{background:#ffffff05}
th,td{vertical-align:middle}
.status-dot{font-weight:800}.status-dot i{box-shadow:0 0 0 4px color-mix(in srgb,currentColor 18%,transparent)}
.site-list button,.site-card,.history-card,.alerts-list article,.setting-row{border-color:#8191b330}
.site-list button:hover,.site-card:hover,.history-card:hover{border-color:#8b5cf67a;background:#192337f0}
.activity-panel{gap:16px}
.chart-stage{background:linear-gradient(180deg,#ffffff05,#ffffff01);border:1px solid #7787aa1f}
.client-bar-hit>span{background:#ffffff12}
.empty-state,.empty-cell,.empty-site-list{color:#a4afc2}
@media (width<=980px){.workspace{max-width:none}.topbar{position:static;margin:-14px -14px 0;padding:14px}.sidebar{position:sticky;top:0;z-index:30;background:#070c17f2;backdrop-filter:blur(14px)}.page-title{align-items:start}.controller-url{max-width:100%}}
@media (width<=560px){.page-title{display:grid}.online-badge{justify-self:start}.stat-card{min-height:118px}.mixed-chart{grid-template-columns:48px minmax(0,1fr) 30px}.chart-labels{padding-left:52px;padding-right:34px}.activity-head{display:grid}.activity-date{justify-self:start}.history-card{grid-template-columns:1fr}.history-card button{justify-content:center}}
