*,*:before,*:after{box-sizing:border-box}:root{color:#f4f7ff;background:#05070d;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--neon: #ffee00;--neon-soft: rgba(255, 238, 0, .14);--accent: #4dffa1;--accent-soft: rgba(77, 255, 161, .1);--ink: #080b12;--panel: rgba(16, 22, 34, .9);--panel-strong: rgba(10, 14, 24, .96);--panel-soft: rgba(255, 255, 255, .04);--border: rgba(255, 238, 0, .22);--border-soft: rgba(255, 238, 0, .1);--muted: #8b97b5;--muted-strong: #c5cee4;--danger: #ff4d67;--warning: #ffcf33;--success: #4dffa1}body{min-width:320px;min-height:100vh;margin:0}#root{isolation:isolate}button,input,select{font:inherit}button{cursor:pointer}.admin-shell{display:grid;grid-template-columns:292px minmax(0,1fr);min-height:100vh;background:radial-gradient(ellipse 80% 50% at 10% -10%,rgba(255,238,0,.08),transparent 55%),radial-gradient(ellipse 60% 40% at 100% 0%,rgba(77,255,161,.05),transparent 50%),linear-gradient(rgba(255,238,0,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,238,0,.02) 1px,transparent 1px),#05070d;background-size:auto,auto,36px 36px,36px 36px,auto}.login-shell{display:grid;place-items:center;min-height:100vh;padding:20px;background:linear-gradient(rgba(228,255,33,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(97,255,208,.03) 1px,transparent 1px),linear-gradient(145deg,rgba(228,255,33,.13),transparent 38%),#050603;background-size:34px 34px,34px 34px,auto,auto}.login-panel{width:min(460px,100%);padding:26px;border:1px solid var(--border);border-radius:8px;background:linear-gradient(180deg,rgba(255,255,255,.045),transparent 34%),#0a0c07f0;box-shadow:0 34px 100px #0009,0 0 60px #dfff001a}.brand-compact{margin-bottom:22px}.login-panel h1{margin:0;color:#fff;font-size:34px;line-height:1.05}.login-copy{margin:10px 0 20px;color:var(--muted)}.login-button{width:100%;margin-top:18px}.sidebar{position:sticky;top:0;display:flex;flex-direction:column;height:100vh;padding:24px 16px;border-right:1px solid var(--border-soft);background:linear-gradient(180deg,rgba(228,255,33,.06),transparent 28%),#050604d1;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);box-shadow:16px 0 60px #00000061}.brand{display:flex;align-items:center;gap:12px;min-height:58px;margin-bottom:24px;padding:0 6px}.brand-logo,.stat-icon{display:grid;place-items:center;width:42px;height:42px;border:1px solid rgba(228,255,33,.7);border-radius:8px;color:var(--ink);background:linear-gradient(145deg,#f7ff77,var(--neon));box-shadow:0 0 24px #e4ff215c,inset 0 1px #fff9}.brand-logo{overflow:visible;width:34px;height:40px;padding:0;border-color:transparent;color:inherit;background:transparent;box-shadow:none}.brand-logo img{display:block;width:32px;height:38px;object-fit:contain}.brand strong,.panel h2,.topbar h1{margin:0;letter-spacing:0}.brand strong{color:#fff;font-size:20px;line-height:1}.brand p,.panel p,.topbar p,.stat-card p,.stat-card span,.compact-row p,.request-row p,.table-row p{margin:0;color:var(--muted)}.sidebar nav{display:grid;gap:7px}.nav-item,.logout-button,.primary-button,.secondary-button,.icon-button{display:inline-flex;align-items:center;justify-content:center;gap:9px;min-height:42px;border-radius:8px;transition:background-color .16s ease,border-color .16s ease,box-shadow .16s ease,color .16s ease,transform .16s ease}.nav-item{justify-content:flex-start;width:100%;padding:0 14px;color:#cbd2bd;border:1px solid transparent;background:transparent}.nav-item:hover,.nav-item.active{color:#f9ffd5;border-color:#e4ff2152;background:linear-gradient(90deg,#e4ff2121,#61ffd009)}.nav-item.active{box-shadow:inset 3px 0 0 var(--neon),0 0 22px #e4ff211a}.logout-button{justify-content:flex-start;margin-top:auto;padding:0 14px;color:#ffc6cf;border:1px solid rgba(255,79,109,.22);background:#ff4f6d14}.workspace{min-width:0;padding:26px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:18px;min-height:78px;margin-bottom:20px;padding:12px 14px 12px 0;border-bottom:1px solid var(--border-soft)}.topbar p{display:inline-flex;align-items:center;gap:6px;margin-bottom:4px}.eyebrow{color:#d9e3ad;font-size:13px;font-weight:800}.topbar h1{color:#fff;font-size:clamp(29px,4vw,44px);line-height:1.05;text-shadow:0 0 26px rgba(228,255,33,.14)}.topbar-actions,.row-actions,.toolbar{display:flex;align-items:center;gap:10px}.topbar-actions{justify-content:flex-end}.quick-metrics{display:flex;align-items:center;gap:8px}.top-metric{display:inline-flex;align-items:center;gap:7px;min-height:38px;padding:0 10px;border:1px solid var(--border-soft);border-radius:8px;color:#dbe3c2;background:#ffffff0a}.top-metric strong{color:#fff}.operator{display:grid;place-items:center;width:42px;height:42px;border:1px solid rgba(228,255,33,.42);border-radius:50%;color:var(--ink);font-weight:900;background:linear-gradient(145deg,#f7ff80,var(--neon));box-shadow:0 0 22px #e4ff2147}.icon-button{width:42px;color:#f2ffc3;border:1px solid var(--border-soft);background:#11140cd1}.primary-button{padding:0 14px;color:var(--ink);border:1px solid rgba(228,255,33,.78);font-weight:800;background:linear-gradient(145deg,#f8ff7a,var(--neon));box-shadow:0 0 24px #e4ff2133}.secondary-button{padding:0 13px;color:#f4ffc1;border:1px solid var(--border-soft);font-weight:800;background:linear-gradient(180deg,rgba(255,255,255,.045),transparent),#11140cd1}.primary-button:hover,.secondary-button:hover,.icon-button:hover{transform:translateY(-1px);border-color:#e4ff216b;box-shadow:0 0 28px #e4ff212e}.error-banner{margin-bottom:16px;padding:13px 14px;border:1px solid rgba(255,207,51,.35);border-radius:8px;color:#fff1a8;background:#ffcf3317}.success-banner{margin-bottom:16px;padding:13px 14px;border:1px solid rgba(85,255,152,.35);border-radius:8px;color:#caffdc;background:#55ff9814}.view-stack{display:grid;gap:18px}.dashboard-v2{gap:18px}.dash-period-bar{display:grid;gap:14px;padding:16px 18px;border-radius:16px;border:1px solid rgba(228,255,33,.1);background:linear-gradient(135deg,#e4ff210f,#61ffd008),#070905e0;box-shadow:inset 0 1px #ffffff0a}.dash-period-main{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.dash-period-title{display:flex;align-items:center;gap:12px;color:var(--neon)}.dash-period-title strong{display:block;color:#fff;font-size:15px;font-weight:900}.dash-period-title p{margin-top:2px;color:#9eb08a;font-size:12px;font-weight:600}.dash-period-presets{display:flex;flex-wrap:wrap;gap:8px}.dash-period-pill{min-height:36px;padding:0 14px;border-radius:999px;border:1px solid rgba(255,255,255,.08);background:#ffffff08;color:#d8e7b8;font-size:12px;font-weight:800;cursor:pointer;transition:border-color .15s ease,background .15s ease,color .15s ease}.dash-period-pill:hover:not(:disabled){border-color:#e4ff2138;color:#fff}.dash-period-pill.active{border-color:#e4ff2159;background:#e4ff211f;color:var(--neon);box-shadow:0 0 18px #7cff6b1f}.dash-period-pill:disabled{opacity:.55;cursor:wait}.dash-period-custom{display:flex;align-items:end;gap:12px;flex-wrap:wrap}.dash-period-field{display:grid;gap:6px;min-width:150px}.dash-period-field.compact{min-width:132px}.dash-period-field span{color:#9eb08a;font-size:10px;font-weight:800;letter-spacing:.35px;text-transform:uppercase}.dash-period-field input[type=date]{min-height:38px;padding:0 12px;border-radius:10px;border:1px solid rgba(255,255,255,.08);background:#00000047;color:#fff;font-size:13px;font-weight:700;color-scheme:dark}.dash-period-field input[type=date]:focus{outline:none;border-color:#e4ff2159;box-shadow:0 0 0 3px #e4ff2114}.dash-period-range{display:flex;align-items:end;gap:8px;flex-wrap:wrap}.dash-period-sep{color:#7f916d;font-size:14px;font-weight:800;padding-bottom:10px}.dash-period-apply{min-height:38px;padding:0 16px;border-radius:10px;border:1px solid rgba(228,255,33,.28);background:linear-gradient(135deg,#e4ff212e,#61ffd014);color:var(--neon);font-size:12px;font-weight:900;cursor:pointer}.dash-period-apply:disabled{opacity:.45;cursor:not-allowed}.panel-loading{opacity:.72;pointer-events:none}.trend-bars-hourly{grid-template-columns:repeat(24,minmax(0,1fr));gap:2px}.trend-bars-hourly .trend-bar-track{height:56px}.trend-bars-hourly .trend-bar-col small{font-size:7px}.dash-kpi-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.dash-kpi-grid .stat-card{min-height:112px}.dash-main-grid{align-items:start}.dash-main-column,.dash-side-column{display:grid;gap:18px;align-content:start}.dash-side-metrics{grid-template-columns:repeat(2,minmax(0,1fr))}.dash-network-layout{display:grid;grid-template-columns:minmax(120px,.45fr) minmax(0,1fr);gap:16px;align-items:center}.dash-network-total{display:grid;gap:4px;padding:14px;border:1px solid rgba(228,255,33,.12);border-radius:12px;background:linear-gradient(135deg,#e4ff211a,#61ffd00a),#070905d1}.dash-network-total span{color:var(--muted);font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.4px}.dash-network-total strong{color:#fff;font-size:38px;font-weight:900;line-height:1}.dash-network-total p{margin-top:4px;color:#b8c98d;font-size:12px;font-weight:700}.dash-ocpp-pills{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}.dash-ocpp-pill{display:inline-flex;align-items:center;min-height:30px;padding:0 10px;border-radius:999px;border:1px solid rgba(255,255,255,.08);background:#ffffff08;color:#d8e7b8;font-size:11px;font-weight:800}.dash-ocpp-pill.tone-success{border-color:#55ff9838;color:var(--success)}.dash-ocpp-pill.tone-warning{border-color:#ffcf3338;color:var(--warning)}.analytics-trends-row{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.rank-list-compact{gap:5px}.rank-list-compact .rank-row{padding:6px 8px;border-radius:10px}.rank-list-compact .rank-index{width:24px;height:24px;font-size:10px}.rank-list-compact .rank-copy strong{font-size:13px}.rank-list-compact .rank-copy p{font-size:11px}.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.stats-grid-wide{grid-template-columns:repeat(3,minmax(0,1fr))}.analytics-grid{align-items:stretch}.analytics-trends{display:grid;gap:18px}.detail-metrics-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.detail-metrics-grid.compact{grid-template-columns:repeat(3,minmax(0,1fr))}.detail-metric{display:grid;gap:2px;padding:8px 10px;border-radius:10px;border:1px solid rgba(255,255,255,.06);background:#ffffff05}.detail-metric span{color:#9eb08a;font-size:10px;font-weight:800;letter-spacing:.35px;text-transform:uppercase}.detail-metric strong{color:var(--ink);font-size:15px;font-weight:900;font-variant-numeric:tabular-nums}.detail-metric small{color:#7f916d;font-size:10px;font-weight:700}.trend-chart{display:grid;gap:10px}.trend-chart-head{display:flex;align-items:center;justify-content:space-between;gap:12px;color:#b8c98d;font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.5px}.trend-chart-head strong{color:var(--neon);font-size:13px}.trend-bars{display:grid;grid-template-columns:repeat(14,minmax(0,1fr));gap:4px;align-items:end;min-height:88px;padding:6px 2px 0}.trend-bar-col{display:grid;gap:6px;justify-items:center;min-width:0}.trend-bar-track{display:flex;align-items:flex-end;width:100%;height:64px;border-radius:6px 6px 3px 3px;background:#ffffff0a;border:1px solid rgba(255,255,255,.05);overflow:hidden}.trend-bar-fill{display:block;width:100%;border-radius:8px 8px 2px 2px;background:linear-gradient(180deg,#fff176 0%,var(--neon) 100%);box-shadow:0 0 16px #7cff6b2e}.trend-bar-col small{color:#7f916d;font-size:9px;font-weight:800;text-align:center;line-height:1.1}.rank-list{display:grid;gap:8px}.rank-row{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.06);background:#ffffff05}.rank-index{display:grid;place-items:center;width:30px;height:30px;border-radius:10px;color:var(--ink);font-size:12px;font-weight:900;background:linear-gradient(145deg,#fff176,var(--neon))}.rank-copy{flex:1;min-width:0}.rank-copy strong{display:block;color:var(--ink);font-size:14px}.rank-copy p{margin-top:3px;color:#9eb08a;font-size:12px;font-weight:700}.empty-state-compact{padding:18px 12px}.empty-state-compact strong{font-size:14px}.empty-state-compact p{font-size:12px}.station-network-panel{overflow:hidden}.station-network-body{display:grid;gap:18px}.station-network-body-compact{grid-template-columns:minmax(220px,.9fr) minmax(0,1.1fr);gap:14px;align-items:stretch}.station-network-hero{display:grid;grid-template-columns:auto minmax(0,1fr);gap:18px;align-items:center;padding:16px;border-radius:14px;border:1px solid rgba(255,238,0,.12);background:linear-gradient(135deg,#ffee0014,#55ff980a),#070905b8}.station-ring-wrap{display:grid;place-items:center}.station-ring{width:132px;height:132px;border-radius:50%;padding:10px;box-shadow:0 0 28px #7cff6b1f}.station-ring-sm{width:84px;height:84px;padding:6px}.station-ring-sm .station-ring-core strong{font-size:22px}.station-ring-sm .station-ring-core span{font-size:9px}.station-ring-core{display:grid;place-content:center;justify-items:center;width:100%;height:100%;border-radius:50%;background:#070905f0;border:1px solid rgba(255,255,255,.06)}.station-ring-core strong{color:#fff;font-size:34px;font-weight:900;line-height:1}.station-ring-core span{margin-top:4px;color:#9eb08a;font-size:11px;font-weight:800;letter-spacing:.8px;text-transform:uppercase}.station-network-copy h3{color:#fff;font-size:clamp(22px,3vw,30px);font-weight:900;line-height:1.1}.station-network-eyebrow{color:#9eb08a;font-size:11px;font-weight:800;letter-spacing:.8px;text-transform:uppercase}.station-network-sub{margin-top:8px;color:#b8c98d;font-size:13px;font-weight:700}.station-network-columns{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.station-network-columns-inline{grid-template-columns:1fr;gap:12px}.station-status-grid-inline{grid-template-columns:repeat(3,minmax(0,1fr))}.station-network-body-compact .station-network-hero{padding:10px;gap:10px}.station-network-body-compact .station-network-copy h3{font-size:18px}.station-network-body-compact .station-network-sub{margin-top:4px;font-size:11px}.station-network-group h4{margin-bottom:6px;color:#b8c98d;font-size:10px;font-weight:800;letter-spacing:.5px;text-transform:uppercase}.station-status-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.station-status-tile{display:grid;gap:2px;padding:8px;border-radius:10px;border:1px solid rgba(255,255,255,.06);background:#ffffff05}.station-status-tile span{color:#9eb08a;font-size:9px;font-weight:800}.station-status-tile strong{color:#fff;font-size:17px;font-weight:900}.station-status-tile small{color:#7f916d;font-size:9px;font-weight:700}.station-status-tile.tone-success{border-color:#55ff982e;background:#55ff980d}.station-status-tile.tone-warning{border-color:#ffcf332e;background:#ffcf330d}.station-status-tile.tone-danger{border-color:#ff4f6d2e;background:#ff4f6d0d}.stations-page{gap:0}.stations-panel-header{align-items:flex-start}.stations-inline-stats{display:flex;flex-wrap:wrap;gap:6px 12px;margin-top:8px;color:#9eb08a;font-size:11px;font-weight:700}.stations-inline-stats strong{color:#fff;font-size:12px;font-weight:900}.stations-inline-stats .tone-success strong{color:var(--success)}.stations-inline-stats .tone-warning strong{color:var(--warning)}.stations-inline-stats .tone-danger strong{color:#ff8ea0}.stations-inline-stats .tone-live strong{color:var(--neon)}.stations-control-bar{display:grid;grid-template-columns:minmax(220px,280px) minmax(0,1fr) auto;gap:12px;align-items:center;margin-bottom:14px}.stations-control-bar .toolbar{margin-bottom:0}.stations-result-count{color:#9eb08a;font-size:12px;font-weight:800;white-space:nowrap}.stations-summary-bar{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:10px}.stations-summary-tile{display:grid;gap:4px;padding:12px 14px;border-radius:14px;border:1px solid rgba(255,255,255,.06);background:#ffffff05}.stations-summary-tile span{color:#9eb08a;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.4px}.stations-summary-tile strong{color:#fff;font-size:24px;font-weight:900}.stations-summary-tile.tone-success strong{color:var(--success)}.stations-summary-tile.tone-warning strong{color:var(--warning)}.stations-summary-tile.tone-danger strong{color:#ff8ea0}.stations-summary-tile.tone-live strong{color:var(--neon)}.stations-panel{overflow:hidden;padding:12px 14px}.stations-panel .panel-header h2{font-size:17px}.stations-panel .panel-header p{font-size:11px}.stations-filter-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:0}.filter-chip{min-height:30px;padding:0 10px;border:1px solid var(--border-soft);border-radius:999px;color:#d8e7b8;font-size:11px;font-weight:800;background:#070905b8}.filter-chip.active-filter{border-color:#e4ff218c;color:var(--ink);background:linear-gradient(145deg,#f8ff7a,var(--neon))}.stations-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(420px,1fr));gap:10px}.station-card-modern{display:grid;gap:8px;padding:10px;border-radius:12px;border:1px solid rgba(255,255,255,.07);background:linear-gradient(180deg,#ffffff08,#ffffff03),#070905d1;transition:border-color .18s ease,transform .18s ease}.station-card-modern:hover{border-color:#ffee002e;transform:translateY(-1px)}.station-card-modern.tone-success{box-shadow:inset 3px 0 0 var(--success)}.station-card-modern.tone-warning{box-shadow:inset 3px 0 0 var(--warning)}.station-card-modern.tone-danger{box-shadow:inset 3px 0 0 var(--danger)}.station-card-top{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:10px;align-items:start}.station-card-modern .station-card-actions-main{flex:1;min-width:0}.station-card-modern .station-card-actions-main .secondary-button.mini-button{flex:1;justify-content:center;min-width:88px}.station-card-icon{display:grid;place-items:center;width:32px;height:32px;border-radius:10px;color:var(--ink);background:linear-gradient(145deg,#f8ff7a,var(--neon))}.station-card-main strong{color:#fff;font-size:14px}.station-card-location,.station-card-identity{display:inline-flex;align-items:center;gap:4px;margin-top:2px;color:#9eb08a;font-size:11px;font-weight:700}.station-card-badges{display:grid;justify-items:end;gap:4px}.station-card-badges .badge{min-height:24px;padding:0 8px;font-size:11px}.station-card-chips{display:flex;flex-wrap:wrap;gap:6px}.station-chip{display:inline-flex;align-items:center;min-height:22px;padding:0 8px;border-radius:999px;border:1px solid rgba(255,255,255,.07);background:#ffffff08;color:#d8e7b8;font-size:10px;font-weight:800}.station-chip-live{border-color:#ffee0047;color:var(--neon);background:#ffee0014}.station-card-metrics{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.station-metric{display:grid;gap:3px;padding:10px;border-radius:10px;background:#ffffff08;border:1px solid rgba(255,255,255,.05)}.station-metric span{color:#7f916d;font-size:10px;font-weight:800;text-transform:uppercase}.station-metric strong{color:#fff;font-size:14px;font-weight:900}.station-metric .metric-live{color:var(--neon)}.station-card-modern .connector-live-row{grid-column:auto}.station-card-actions{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:6px;padding-top:6px;border-top:1px solid rgba(255,255,255,.05)}.station-card-actions-main,.station-card-actions-icons{display:flex;flex-wrap:wrap;align-items:center;gap:6px}.secondary-button.danger-text{color:#ff8ea0;border-color:#ff4f6d47}.live-kwh{color:var(--neon);font-weight:800;font-variant-numeric:tabular-nums}.nav-item{position:relative}.nav-badge{display:inline-grid;place-items:center;min-width:20px;height:20px;padding:0 6px;margin-left:auto;border-radius:999px;color:var(--ink);font-size:11px;font-weight:900;background:linear-gradient(145deg,#fff176,var(--neon))}.alert-button{position:relative}.alert-button .nav-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;margin-left:0;font-size:10px}.ocpp-info-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-bottom:16px}.ocpp-url{font-size:12px;word-break:break-all}.station-name-link{padding:0;color:inherit;border:0;background:transparent;text-align:left}.station-name-link:hover strong{color:var(--neon)}.station-detail-modal .panel-header{align-items:flex-start}.station-detail-subtitle{margin-top:4px}.station-detail-meta{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-top:10px;color:#b8c98d;font-size:13px}.station-detail-extras{display:grid;gap:12px;margin-top:4px}.detail-section-tight{margin-bottom:14px}.detail-section-tight h3{margin-bottom:8px;font-size:15px}.connector-grid-compact{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}.connector-card-compact{padding:12px}.connector-metrics-compact{grid-template-columns:1fr 1fr;gap:6px;margin-top:8px}.connector-card-foot{margin:8px 0 0;font-size:11px}.meta-grid-compact{margin-top:10px;font-size:12px}.meta-with-action{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.detail-collapsible{border:1px solid var(--border-soft);border-radius:10px;padding:8px 12px;background:#0709058c}.detail-collapsible summary{cursor:pointer;color:#b8c98d;font-size:13px;font-weight:700}.detail-collapsible .diagnostics-table{margin-top:10px}.session-detail-table .session-detail-row{grid-template-columns:minmax(140px,1fr) auto}.station-detail-actions{flex-wrap:wrap;justify-content:flex-end}.meta-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px 14px;color:var(--muted);font-size:13px}.meta-grid strong{color:#f4ffd0}.meta-wide{grid-column:1 / -1;word-break:break-all}.connector-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.connector-card{padding:14px;border:1px solid var(--border-soft);border-radius:12px;background:linear-gradient(135deg,rgba(255,238,0,.05),transparent 55%),#070905d1}.connector-card-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}.connector-card-head strong{color:#f4ffd0}.connector-metrics{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px 10px;color:#dbe3c2;font-size:14px;font-weight:700}.audit-metadata-grid{display:grid;gap:8px}.audit-metadata-row{display:grid;grid-template-columns:minmax(120px,.45fr) minmax(0,1fr);gap:12px;padding:10px 12px;border:1px solid var(--border-soft);border-radius:10px;background:#070905c7}.audit-metadata-row span{color:var(--muted);font-size:12px;font-weight:700;text-transform:lowercase}.audit-metadata-row strong{color:#f4ffd0;font-size:13px;word-break:break-word}.stat-card,.panel{position:relative;overflow:hidden;border:1px solid var(--border-soft);border-radius:14px;background:linear-gradient(180deg,rgba(255,255,255,.045),transparent 42%),var(--panel);box-shadow:0 24px 80px #0000005c,inset 0 1px #ffffff0a}.stat-card:before,.panel:before{position:absolute;inset:0 0 auto;height:1px;content:"";background:linear-gradient(90deg,transparent,rgba(228,255,33,.42),transparent);opacity:.64}.stat-card{display:flex;align-items:center;gap:14px;min-height:124px;padding:18px}.stat-card strong{display:block;margin:3px 0;color:#fff;font-size:27px;line-height:1.1}.content-grid,.split-grid{display:grid;grid-template-columns:minmax(0,1.65fr) minmax(310px,.85fr);gap:18px}.panel{padding:20px}.panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px}.panel-header-actions{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:10px}.view-toggle{display:flex;flex-wrap:wrap;gap:8px}.stations-map-wrap{display:grid;gap:12px}.connector-live-row{display:flex;flex-wrap:wrap;gap:8px;grid-column:1 / -1}.connector-live-pill{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border:1px solid var(--border-soft);border-radius:999px;background:#070905c7;font-size:12px}.connector-live-pill.active{border-color:#ffee0073;box-shadow:0 0 0 1px #ffee001f}.connector-live-pill strong{color:#f4ffd0}.connector-live-metric{color:#fe0;font-weight:700}.table-row:has(.connector-live-row){grid-template-columns:minmax(180px,1.1fr) auto minmax(220px,1fr) auto auto}.map-hint-banner{padding:10px 12px;border:1px solid rgba(255,238,0,.22);border-radius:10px;background:#ffee0014;color:#f4ffd0;font-size:13px}.stations-map{position:relative;min-height:460px;border:1px solid rgba(255,238,0,.12);border-radius:18px;overflow:hidden;background:#dfe8ec;box-shadow:inset 0 0 0 1px #ffffff0a}.stations-map-canvas{position:relative;width:100%;height:460px;overflow:hidden}.map-tile{position:absolute;width:256px;height:256px;object-fit:cover;-webkit-user-select:none;user-select:none;pointer-events:none}.map-marker{position:absolute;width:20px;height:20px;margin-left:-10px;margin-top:-10px;padding:0;border:3px solid #07090f;border-radius:50%;box-shadow:0 5px 14px #00000052;cursor:pointer;z-index:4;transition:transform .15s ease,box-shadow .15s ease}.map-marker:hover,.map-marker:focus-visible{transform:scale(1.15);box-shadow:0 0 0 5px #ffee003d,0 8px 18px #00000057;outline:none}.map-marker-core{display:block;width:100%;height:100%;border-radius:50%}.map-controls{position:absolute;top:12px;right:12px;display:flex;gap:8px;z-index:6}.map-legend{position:absolute;left:12px;bottom:36px;display:flex;flex-wrap:wrap;gap:10px;padding:8px 10px;border-radius:10px;background:#070905c7;color:#d8e8b0;font-size:12px;z-index:6}.map-legend span{display:inline-flex;align-items:center;gap:6px}.legend-dot{display:inline-block;width:10px;height:10px;border-radius:50%;border:2px solid #07090f}.legend-dot.available{background:#7ddf8a}.legend-dot.charging{background:#fe0}.legend-dot.offline{background:#ff7b7b}.map-attribution{position:absolute;left:8px;bottom:8px;z-index:6;color:#07090fb8;font-size:10px;background:#ffffffb8;border-radius:7px;padding:3px 6px}.panel h2{color:#fff;font-size:19px;line-height:1.2}.network-panel{display:grid;grid-template-columns:minmax(160px,.5fr) minmax(0,1fr);gap:18px;min-height:240px}.network-total{display:grid;align-content:center;gap:6px;padding:18px;border:1px solid rgba(228,255,33,.12);border-radius:8px;background:linear-gradient(135deg,#e4ff211c,#61ffd009),#070905d1}.network-total span{color:var(--muted);font-weight:800}.network-total strong{color:#fff;font-size:clamp(38px,7vw,76px);line-height:.95}.meter-stack{display:grid;align-content:center;gap:16px}.meter-row{display:grid;gap:9px}.meter-row>div{display:flex;align-items:center;justify-content:space-between;gap:12px}.meter-row strong{color:#fff}.meter-track{display:block;height:12px;overflow:hidden;border:1px solid var(--border-soft);border-radius:999px;background:#ffffff0b}.meter-track>span{display:block;height:100%;min-width:0;border-radius:inherit}.meter-success>span{background:linear-gradient(90deg,var(--success),var(--accent))}.meter-warning>span{background:linear-gradient(90deg,var(--warning),var(--neon))}.meter-danger>span{background:linear-gradient(90deg,var(--danger),#ff9aaa)}.signal-grid{display:grid;grid-template-columns:repeat(6,1fr);align-items:end;gap:12px;height:240px;padding:16px;border:1px solid rgba(223,255,0,.12);border-radius:8px;background:linear-gradient(rgba(223,255,0,.06) 1px,transparent 1px),#080a05;background-size:100% 40px}.signal-grid span{display:block;min-height:40%;border-radius:8px 8px 3px 3px;background:linear-gradient(180deg,#f3ff4f,var(--neon));box-shadow:0 0 22px #dfff0042}.signal-grid span:nth-child(2){min-height:62%}.signal-grid span:nth-child(3){min-height:48%}.signal-grid span:nth-child(4){min-height:78%}.signal-grid span:nth-child(5){min-height:58%}.signal-grid span:nth-child(6){min-height:88%}.status-list{display:grid;gap:12px}.status-list>div{display:flex;align-items:center;justify-content:space-between;min-height:54px;padding:0 14px;border:1px solid var(--border-soft);border-radius:8px;background:var(--panel-strong)}.toolbar{justify-content:space-between;margin-bottom:16px;padding:10px;border:1px solid var(--border-soft);border-radius:8px;background:#ffffff08}.search-box{display:flex;align-items:center;gap:8px;width:min(100%,380px);min-height:42px;padding:0 12px;color:#dceca1;border:1px solid var(--border-soft);border-radius:8px;background:#070905e6}.search-box input,.settings-grid input,.settings-grid select{width:100%;border:0;outline:0;color:#f8ffd0;background:transparent}.search-box input::placeholder,.settings-grid input::placeholder{color:#70765f}.table{display:grid;gap:9px}.table-row,.compact-row,.request-row{display:grid;align-items:center;gap:14px;min-height:72px;padding:12px 14px;border:1px solid var(--border-soft);border-radius:8px;background:linear-gradient(90deg,rgba(228,255,33,.035),transparent 42%),#070905c7;transition:border-color .16s ease,background-color .16s ease,transform .16s ease}.table-row:hover,.compact-row:hover,.request-row:hover{border-color:#e4ff2147;background-color:#0f120bdb;transform:translateY(-1px)}.table-row{grid-template-columns:minmax(220px,1.2fr) 140px minmax(120px,.7fr) 110px minmax(190px,auto)}.table-row.four{grid-template-columns:minmax(220px,1.3fr) minmax(120px,.9fr) 120px minmax(120px,.7fr)}.station-cell,.compact-row{display:flex;align-items:center;gap:12px}.station-cell p{display:inline-flex;align-items:center;gap:5px;margin-top:3px}.station-badges{display:grid;justify-items:start;gap:6px}.station-dot{width:12px;height:44px;border-radius:999px;background:linear-gradient(180deg,var(--accent),var(--neon));box-shadow:0 0 18px #e4ff2157}.badge{display:inline-flex;align-items:center;justify-content:center;width:fit-content;min-height:28px;padding:0 10px;border:1px solid rgba(228,255,33,.16);border-radius:999px;color:#ecf6b9;font-size:13px;font-weight:800;background:#e4ff2114}.badge-success{color:var(--success);border-color:#55ff9847;background:#55ff9814}.badge-warning{color:var(--warning);border-color:#ffcf334d;background:#ffcf3314}.badge-danger{color:#ff8ea0;border-color:#ff4f6d4d;background:#ff4f6d17}.avatar{display:grid;place-items:center;width:42px;height:42px;flex:0 0 auto;border:1px solid rgba(228,255,33,.34);border-radius:50%;color:var(--ink);font-weight:900;background:linear-gradient(145deg,#f8ff7a,var(--neon))}.compact-row{display:grid;grid-template-columns:42px minmax(0,1fr) auto;margin-bottom:8px}.compact-row.user-row{grid-template-columns:42px minmax(180px,1.1fr) repeat(3,auto)}.compact-row.personal-row,.compact-row.client-row{grid-template-columns:42px minmax(160px,1fr) repeat(4,auto) auto}.debt-value{color:#ffcf33}.modal-panel-wide{width:min(920px,100%)}.billing-summary-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-bottom:18px}.billing-stat{display:grid;gap:6px;padding:12px;border:1px solid var(--border-soft);border-radius:8px;background:#070905c7}.billing-stat span{color:#b8c98d;font-size:12px;font-weight:700}.billing-stat strong{color:#f4ffd0;font-size:18px}.detail-section{margin-bottom:18px}.detail-section h3{margin:0 0 10px;color:#f4ffd0;font-size:16px}.detail-empty{margin:0;color:#b8c98d;font-size:13px}.detail-table{display:grid;gap:8px}.detail-row{display:grid;grid-template-columns:minmax(180px,1.2fr) auto auto minmax(160px,auto);align-items:center;gap:12px;padding:10px 12px;border:1px solid var(--border-soft);border-radius:8px;background:#070905c7}.detail-row p{margin:4px 0 0;color:#b8c98d;font-size:12px}.diagnostics-ftp-hint{margin:0 0 10px}.diagnostics-row{grid-template-columns:minmax(140px,.8fr) auto minmax(0,1.4fr)}.diagnostics-result{display:flex;flex-wrap:wrap;align-items:center;gap:8px;min-width:0}.diagnostics-result span{overflow-wrap:anywhere;font-size:13px}.request-row{grid-template-columns:minmax(0,1fr) auto auto;margin-bottom:10px}.status-filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.status-filters .active-filter{border-color:#e4ff218c;color:var(--ink);background:linear-gradient(145deg,#f8ff7a,var(--neon))}.request-meta{margin-top:4px;color:#b8c79a;font-size:12px;font-weight:600}.compact-actions{justify-content:flex-end}.end-actions{justify-content:space-between}.invoice-actions{justify-content:flex-end}.mini-button{min-height:34px;padding:0 10px}.danger-icon{color:#ffc6cf;border-color:#ff4f6d4d;background:#ff4f6d14}.settings-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.settings-grid.compact{grid-template-columns:1fr}.full-field{grid-column:1 / -1}.settings-grid label{display:grid;gap:7px;color:#cfd6b5;font-size:13px;font-weight:800}.settings-grid input,.settings-grid select{min-height:44px;padding:0 12px;border:1px solid var(--border-soft);border-radius:8px;background:#070905e6}.settings-grid input:focus,.settings-grid select:focus,.search-box:focus-within{border-color:#e4ff216b;box-shadow:0 0 0 3px #e4ff2114}.settings-save{margin-top:16px}.empty-state{display:grid;place-items:center;min-height:260px;padding:28px;text-align:center;border:1px dashed rgba(223,255,0,.26);border-radius:8px;color:#eaff8c;background:linear-gradient(135deg,#e4ff210d,#61ffd006),#e4ff2105}.empty-state strong{margin-top:10px;color:#fff}.empty-state p{max-width:460px;margin-top:6px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20;display:grid;place-items:center;padding:20px;background:#000000ad;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.modal-panel{width:min(720px,100%);max-height:calc(100vh - 40px);overflow:auto;padding:20px;border:1px solid rgba(223,255,0,.28);border-radius:8px;background:linear-gradient(180deg,rgba(255,255,255,.04),transparent 34%),#0a0c07fa;box-shadow:0 34px 100px #000000ad,0 0 48px #dfff0014}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:18px}.field-hint{margin:-4px 0 0;color:#b8c98d;font-size:12px;line-height:1.45}.primary-button:disabled{cursor:wait;opacity:.68}.pulse-ring{width:32px;height:32px;border:2px solid rgba(223,255,0,.22);border-top-color:var(--neon);border-radius:50%;animation:spin .84s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 1120px){.admin-shell{grid-template-columns:88px minmax(0,1fr)}.brand div,.nav-item span,.logout-button{display:none}.sidebar{align-items:center}.nav-item{justify-content:center;width:52px;padding:0}.stats-grid,.stats-grid-wide,.content-grid,.split-grid,.network-panel,.ocpp-info-grid,.detail-metrics-grid,.detail-metrics-grid.compact,.station-network-columns,.station-status-grid,.stations-summary-bar,.station-card-metrics,.dash-kpi-grid,.dash-side-metrics,.analytics-trends-row{grid-template-columns:repeat(2,minmax(0,1fr))}.dash-network-layout,.station-network-body-compact,.stations-control-bar{grid-template-columns:1fr}.station-network-hero{grid-template-columns:1fr;justify-items:center;text-align:center}.trend-bars{grid-template-columns:repeat(7,minmax(0,1fr))}.table-row,.table-row.four{grid-template-columns:1fr}}@media (max-width: 920px){.topbar{align-items:stretch;flex-direction:column}.topbar-actions{justify-content:space-between}.quick-metrics{flex-wrap:wrap}}@media (max-width: 720px){.admin-shell{grid-template-columns:1fr}.sidebar{position:static;height:auto;align-items:stretch;padding:14px}.sidebar nav{grid-template-columns:repeat(4,minmax(0,1fr))}.brand div,.nav-item span{display:block}.nav-item{justify-content:center;width:auto;min-height:58px;flex-direction:column;gap:5px;padding:6px;font-size:12px}.workspace{padding:18px 14px 28px}.topbar,.panel-header,.toolbar{align-items:stretch;flex-direction:column}.stats-grid,.stats-grid-wide,.content-grid,.split-grid,.settings-grid,.network-panel,.ocpp-info-grid,.detail-metrics-grid,.detail-metrics-grid.compact,.station-network-columns,.station-status-grid,.stations-summary-bar,.station-card-metrics,.stations-card-grid,.dash-kpi-grid,.dash-side-metrics,.analytics-trends-row,.station-status-grid-inline,.dash-period-main,.dash-period-custom,.dash-period-range{grid-template-columns:1fr}.dash-period-main,.dash-period-custom,.dash-period-range{display:grid;align-items:stretch}.dash-period-sep{display:none}.station-network-body-compact,.station-network-hero,.station-card-top,.stations-control-bar{grid-template-columns:1fr}.station-card-actions{flex-direction:column;align-items:stretch}.station-card-actions-icons{justify-content:flex-end}.station-card-badges{justify-items:start}.trend-bars{grid-template-columns:repeat(7,minmax(0,1fr))}.quick-metrics{display:grid;grid-template-columns:1fr}.top-metric{justify-content:space-between}.request-row{grid-template-columns:1fr}.row-actions{justify-content:stretch}.row-actions>button{flex:1}}
