.emulation-panel-collapsed{position:absolute;right:0;top:50%;transform:translateY(-50%);width:32px;background:var(--bg-card);border:1px solid var(--border-subtle);border-right:none;border-top-left-radius:12px;border-bottom-left-radius:12px;padding:16px 4px;display:flex;flex-direction:column;align-items:center;gap:16px;cursor:pointer;box-shadow:-4px 0 16px #0006;z-index:1000;color:var(--text-primary);font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:2px;line-height:1.2;transition:background .2s,transform .2s}.emulation-panel-collapsed:hover{background:var(--bg-element);transform:translateY(-50%) translate(-4px)}.emulation-panel-collapsed span{text-align:center}.expand-icon{font-size:10px;opacity:.6}.emulation-panel-expanded{position:absolute;right:20px;top:20px;width:300px;background:#0a0e1ad9;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--border-subtle);border-radius:16px;box-shadow:-4px 4px 24px #00000080;z-index:1000;display:flex;flex-direction:column;overflow:hidden;animation:slideIn .3s cubic-bezier(.16,1,.3,1)}@keyframes slideIn{0%{transform:translate(120%);opacity:0}to{transform:translate(0);opacity:1}}.emulation-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border-subtle);background:#ffffff05}.emulation-header h3{margin:0;font-size:16px;font-weight:600;color:var(--text-primary)}.emulation-header .close-btn{padding:4px;height:24px;width:24px;display:flex;align-items:center;justify-content:center;border-radius:50%}.emulation-body{padding:20px;display:flex;flex-direction:column;gap:16px}.battery-display{width:100%;height:8px;background:var(--bg-page);border-radius:4px;overflow:hidden;margin-bottom:8px;border:1px solid var(--border-subtle)}.battery-bar{height:100%;transition:width .3s ease,background .3s ease}.emulation-actions{margin-top:8px;padding-top:16px;border-top:1px solid var(--border-subtle)}.trip-planner-collapsed{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-sm) var(--space-md);display:flex;align-items:center;gap:var(--space-sm);cursor:pointer;margin-bottom:var(--space-md);transition:all var(--transition-fast)}.trip-planner-collapsed:hover{border-color:var(--accent-blue);background:var(--bg-card-hover)}.trip-planner-collapsed .planner-icon{font-size:1.2rem}.trip-planner-collapsed .expand-icon{margin-left:auto;font-size:.8rem;color:var(--text-muted)}.trip-planner-expanded{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);margin-bottom:var(--space-md);animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.planner-header{padding:var(--space-sm) var(--space-md);background:var(--bg-glass);border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:space-between;cursor:pointer}.planner-header h3{font-size:var(--font-sm);text-transform:uppercase;letter-spacing:.05em;margin:0}.planner-body{padding:var(--space-md)}.poi-section{margin:var(--space-md) 0}.poi-section>label{display:block;font-size:var(--font-xs);color:var(--text-muted);text-transform:uppercase;margin-bottom:var(--space-sm)}.poi-distance-label{display:flex;justify-content:space-between;font-size:var(--font-xs);color:var(--text-muted);margin-bottom:4px}.poi-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-sm)}.poi-chip{display:flex;align-items:center;gap:6px;background:var(--bg-glass);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-xs) var(--space-sm);font-size:var(--font-xs);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);text-align:left}.poi-chip:hover{border-color:var(--accent-blue);color:var(--text-primary)}.poi-chip.active{background:var(--accent-blue-glow);border-color:var(--accent-blue);color:var(--accent-blue)}.btn-plan{width:100%;margin-top:var(--space-sm)}.route-instructions-overlay{position:absolute;bottom:24px;right:24px;width:350px;max-height:50vh;background:#0a0e1ad9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border-subtle);border-radius:16px;box-shadow:0 12px 32px #00000080;z-index:1100;display:flex;flex-direction:column;overflow:hidden;color:var(--text-primary);animation:slideInUp .3s ease-out}@keyframes slideInUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.route-header{padding:16px;border-bottom:1px solid var(--border-subtle);display:flex;justify-content:space-between;align-items:center;background:#ffffff08}.route-header h3{margin:0;font-size:16px;font-weight:600;color:var(--accent-blue, #60a5fa)}.route-summary{padding:12px 16px;background:#ffffff0d;display:flex;justify-content:space-around;font-size:14px;border-bottom:1px solid var(--border-subtle)}.summary-item{display:flex;flex-direction:column;align-items:center}.summary-label{font-size:10px;text-transform:uppercase;opacity:.6;letter-spacing:.5px}.summary-value{font-weight:600}.instructions-list{flex:1;overflow-y:auto;padding:8px 0}.instruction-step{padding:12px 16px;border-bottom:1px solid rgba(255,255,255,.05);display:flex;gap:12px;transition:background .2s;font-size:13px;line-height:1.4}.instruction-step{cursor:pointer}.instruction-step:hover{background:#60a5fa14}.instruction-step.active{background:#ef444426;border-left:3px solid #ef4444;padding-left:13px}.instruction-step:last-child{border-bottom:none}.step-icon{font-size:16px;min-width:24px;text-align:center}.step-details{flex:1}.step-distance{font-size:11px;opacity:.5;margin-top:4px}.btn-close-route{background:none;border:none;color:var(--text-muted);font-size:20px;cursor:pointer;line-height:1;padding:4px;border-radius:4px}.btn-close-route:hover{color:var(--text-primary);background:#ffffff1a}.routing-error{padding:20px;text-align:center;color:var(--accent-red, #ef4444)}:root{color-scheme:dark;--bg-primary: #0a0e1a;--bg-secondary: #111827;--bg-card: rgba(17, 24, 39, .8);--bg-card-hover: rgba(30, 41, 59, .9);--bg-glass: rgba(255, 255, 255, .05);--bg-glass-hover: rgba(255, 255, 255, .1);--bg-input: rgba(255, 255, 255, .07);--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #64748b;--text-inverse: #0a0e1a;--accent-blue: #3b82f6;--accent-blue-glow: rgba(59, 130, 246, .3);--accent-green: #10b981;--accent-green-glow: rgba(16, 185, 129, .3);--accent-amber: #f59e0b;--accent-amber-glow: rgba(245, 158, 11, .3);--accent-red: #ef4444;--accent-red-glow: rgba(239, 68, 68, .3);--accent-purple: #8b5cf6;--accent-cyan: #06b6d4;--gradient-primary: linear-gradient(135deg, #3b82f6, #8b5cf6);--gradient-success: linear-gradient(135deg, #10b981, #06b6d4);--gradient-warm: linear-gradient(135deg, #f59e0b, #ef4444);--gradient-hero: linear-gradient(135deg, rgba(59, 130, 246, .15), rgba(139, 92, 246, .1));--border-subtle: rgba(255, 255, 255, .08);--border-medium: rgba(255, 255, 255, .15);--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--shadow-glow-blue: 0 0 20px rgba(59, 130, 246, .3);--shadow-glow-green: 0 0 20px rgba(16, 185, 129, .3);--font-family: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-xs: .75rem;--font-sm: .875rem;--font-md: 1rem;--font-lg: 1.125rem;--font-xl: 1.25rem;--font-2xl: 1.5rem;--font-3xl: 2rem;--font-4xl: 2.5rem;--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;line-height:1.6}#root{min-height:100vh;display:flex;flex-direction:column}a{color:var(--accent-blue);text-decoration:none}a:hover{text-decoration:underline}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.app-layout{display:flex;flex-direction:column;min-height:100vh}.page-container{flex:1;padding:var(--space-lg);max-width:1400px;margin:0 auto;width:100%}.page-header{margin-bottom:var(--space-xl)}.page-header h1{font-size:var(--font-3xl);font-weight:800;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em}.page-header p{color:var(--text-secondary);margin-top:var(--space-xs);font-size:var(--font-lg)}.navbar{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);background:#111827f2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border-subtle);position:sticky;top:0;z-index:1000}.navbar-brand{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--font-xl);font-weight:700;color:var(--text-primary);text-decoration:none}.navbar-brand:hover{text-decoration:none}.navbar-brand .brand-icon{font-size:var(--font-2xl)}.navbar-brand .brand-text{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.navbar-links{display:flex;align-items:center;gap:var(--space-xs);list-style:none}.navbar-links a,.navbar-links button{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--font-sm);font-weight:500;text-decoration:none;transition:all var(--transition-fast);border:none;background:none;cursor:pointer;font-family:inherit}.navbar-links a:hover,.navbar-links button:hover{color:var(--text-primary);background:var(--bg-glass-hover);text-decoration:none}.navbar-links a.active{color:var(--accent-blue);background:var(--accent-blue-glow)}.navbar-user{display:flex;align-items:center;gap:var(--space-md)}.navbar-user .user-badge{padding:var(--space-xs) var(--space-md);border-radius:var(--radius-full);font-size:var(--font-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.user-badge.driver{background:var(--accent-blue-glow);color:var(--accent-blue)}.user-badge.operator{background:var(--accent-purple);color:#fff}.user-badge.admin{background:var(--gradient-warm);color:#fff}.card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-lg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all var(--transition-base)}.card:hover{border-color:var(--border-medium);box-shadow:var(--shadow-md)}.card-clickable{cursor:pointer}.card-clickable:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.stat-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-lg);display:flex;align-items:flex-start;gap:var(--space-md)}.stat-card .stat-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:var(--font-xl);flex-shrink:0}.stat-card .stat-icon.blue{background:var(--accent-blue-glow)}.stat-card .stat-icon.green{background:var(--accent-green-glow)}.stat-card .stat-icon.amber{background:var(--accent-amber-glow)}.stat-card .stat-icon.red{background:var(--accent-red-glow)}.stat-card .stat-info{flex:1}.stat-card .stat-label{font-size:var(--font-sm);color:var(--text-secondary);font-weight:500}.stat-card .stat-value{font-size:var(--font-2xl);font-weight:700;margin-top:var(--space-xs)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--space-md);margin-bottom:var(--space-xl)}.form-group{margin-bottom:var(--space-md)}.form-group label{display:block;font-size:var(--font-sm);font-weight:500;color:var(--text-secondary);margin-bottom:var(--space-xs)}.form-input,.form-select,.form-textarea{width:100%;padding:var(--space-sm) var(--space-md);background:var(--bg-input);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-primary);font-family:inherit;font-size:var(--font-md);transition:all var(--transition-fast);outline:none}.form-select option{background-color:var(--bg-secondary);color:var(--text-primary)}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent-blue);box-shadow:0 0 0 3px var(--accent-blue-glow)}.form-textarea{resize:vertical;min-height:80px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-md);font-family:inherit;font-size:var(--font-sm);font-weight:600;cursor:pointer;border:none;transition:all var(--transition-fast);text-decoration:none;white-space:nowrap}.btn:hover{text-decoration:none}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:hover{box-shadow:var(--shadow-glow-blue);transform:translateY(-1px)}.btn-success{background:var(--gradient-success);color:#fff}.btn-success:hover{box-shadow:var(--shadow-glow-green);transform:translateY(-1px)}.btn-danger{background:var(--accent-red);color:#fff}.btn-danger:hover{background:#dc2626}.btn-ghost{background:var(--bg-glass);color:var(--text-secondary);border:1px solid var(--border-subtle)}.btn-ghost:hover{background:var(--bg-glass-hover);color:var(--text-primary)}.btn-sm{padding:var(--space-xs) var(--space-md);font-size:var(--font-xs)}.btn-lg{padding:var(--space-md) var(--space-xl);font-size:var(--font-md)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 10px;border-radius:var(--radius-full);font-size:var(--font-xs);font-weight:600;text-transform:uppercase;letter-spacing:.03em}.badge-available{background:var(--accent-green-glow);color:var(--accent-green)}.badge-occupied{background:var(--accent-amber-glow);color:var(--accent-amber)}.badge-faulted{background:var(--accent-red-glow);color:var(--accent-red)}.badge-reserved{background:#8b5cf633;color:var(--accent-purple)}.badge-offline{background:#64748b33;color:var(--text-muted)}.badge-maintenance{background:var(--accent-amber-glow);color:var(--accent-amber)}.badge-ccs{background:#3b82f626;color:var(--accent-blue)}.badge-type2{background:#10b98126;color:var(--accent-green)}.badge-chademo{background:#f59e0b26;color:var(--accent-amber)}.table-container{overflow-x:auto;border:1px solid var(--border-subtle);border-radius:var(--radius-lg);background:var(--bg-card)}table{width:100%;border-collapse:collapse}th,td{padding:var(--space-sm) var(--space-md);text-align:left;border-bottom:1px solid var(--border-subtle)}th{font-size:var(--font-xs);font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;background:#0003}tr:hover{background:var(--bg-glass)}tr:last-child td{border-bottom:none}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-primary);padding:var(--space-lg)}.login-card{width:100%;max-width:420px;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-2xl);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:var(--shadow-lg)}.login-card .login-header{text-align:center;margin-bottom:var(--space-xl)}.login-card .login-header .logo-icon{font-size:3rem;margin-bottom:var(--space-sm)}.login-card .login-header h1{font-size:var(--font-2xl);font-weight:700;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-card .login-header p{color:var(--text-secondary);font-size:var(--font-sm);margin-top:var(--space-xs)}.login-error{padding:var(--space-sm) var(--space-md);background:var(--accent-red-glow);color:var(--accent-red);border-radius:var(--radius-md);font-size:var(--font-sm);margin-bottom:var(--space-md);text-align:center}.login-btn{width:100%;padding:var(--space-md);font-size:var(--font-md);margin-top:var(--space-md)}.login-divider{display:flex;align-items:center;gap:var(--space-md);margin:var(--space-lg) 0;color:var(--text-muted);font-size:var(--font-xs)}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--border-subtle)}.demo-accounts{display:flex;flex-direction:column;gap:var(--space-sm)}.demo-account-btn{width:100%;justify-content:flex-start;padding:var(--space-sm) var(--space-md)}.discovery-layout{height:calc(100vh - 72px);overflow:hidden;position:relative}.discovery-sidebar{display:flex;flex-direction:column;overflow-y:auto;position:absolute;left:20px;top:20px;width:380px;height:calc(100% - 40px);background:#0a0e1ad9;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--border-subtle);border-radius:16px;box-shadow:4px 4px 24px #00000080;z-index:1000;padding:20px;animation:slideInLeft .3s cubic-bezier(.16,1,.3,1)}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.filter-panel{padding:var(--space-md);background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);margin-bottom:var(--space-md)}.filter-panel h3{font-size:var(--font-sm);font-weight:600;color:var(--text-secondary);margin-bottom:var(--space-sm);text-transform:uppercase;letter-spacing:.05em}.filter-row{display:flex;gap:var(--space-sm);flex-wrap:wrap;margin-bottom:var(--space-sm)}.filter-chip{padding:4px 12px;border-radius:var(--radius-full);font-size:var(--font-xs);font-weight:500;border:1px solid var(--border-subtle);background:var(--bg-glass);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.filter-chip:hover{border-color:var(--accent-blue);color:var(--accent-blue)}.filter-chip.active{background:var(--accent-blue-glow);border-color:var(--accent-blue);color:var(--accent-blue)}.station-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:var(--space-sm);padding-right:var(--space-xs)}.station-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-md);cursor:pointer;transition:all var(--transition-base)}.station-card:hover{border-color:var(--accent-blue);box-shadow:0 0 15px var(--accent-blue-glow);transform:translate(4px)}.station-card .station-name{font-weight:600;font-size:var(--font-md);margin-bottom:2px}.station-card .station-address{font-size:var(--font-sm);color:#b8c8d8;margin-bottom:var(--space-sm)}.station-card .station-meta{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap}.station-card .station-operator{font-size:var(--font-xs);color:var(--text-muted)}.station-card .connector-counts{display:flex;align-items:center;gap:4px;font-size:var(--font-xs)}.connector-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.connector-dot.green{background:var(--accent-green)}.connector-dot.amber{background:var(--accent-amber)}.connector-dot.red{background:var(--accent-red)}.map-container{border-radius:var(--radius-lg);height:100%;border:1px solid var(--border-subtle);clip-path:inset(0 round var(--radius-lg))}.map-container .leaflet-container{height:100%;width:100%;background:var(--bg-secondary);transform:translateZ(0);will-change:transform}.map-container .leaflet-tile-pane{will-change:transform}.leaflet-popup-content-wrapper{background:var(--bg-card)!important;color:var(--text-primary)!important;border:1px solid var(--border-subtle)!important;border-radius:var(--radius-md)!important;box-shadow:var(--shadow-lg)!important}.leaflet-popup-tip{background:var(--bg-card)!important}.leaflet-popup-content{margin:12px!important;font-family:var(--font-family)!important}.station-detail{max-width:900px;margin:0 auto}.station-detail .detail-header{margin-bottom:var(--space-xl)}.station-detail .detail-header h1{font-size:var(--font-3xl);font-weight:800;margin-bottom:var(--space-xs)}.station-detail .detail-info{display:flex;gap:var(--space-lg);flex-wrap:wrap;color:var(--text-secondary);font-size:var(--font-sm)}.station-detail .detail-info span{display:flex;align-items:center;gap:var(--space-xs)}.evse-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-md);margin-bottom:var(--space-xl)}.evse-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-md)}.evse-card .evse-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md)}.evse-card .evse-code{font-weight:600;font-size:var(--font-sm)}.connector-item{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm);flex-wrap:wrap;padding:var(--space-sm);background:var(--bg-glass);border-radius:var(--radius-md);margin-bottom:var(--space-sm)}.connector-item:last-child{margin-bottom:0}.connector-info{display:flex;align-items:center;gap:var(--space-sm)}.connector-power{font-size:var(--font-sm);font-weight:600}.tariff-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-md)}.tariff-card h3{font-size:var(--font-lg);margin-bottom:var(--space-md)}.tariff-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--space-md)}.tariff-item .tariff-label{font-size:var(--font-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.tariff-item .tariff-value{font-size:var(--font-xl);font-weight:700;margin-top:2px}.session-page{max-width:600px;margin:0 auto;text-align:center}.session-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-2xl);margin-bottom:var(--space-lg)}.session-progress{width:160px;height:160px;border-radius:50%;border:4px solid var(--border-subtle);display:flex;flex-direction:column;align-items:center;justify-content:center;margin:0 auto var(--space-lg);position:relative;animation:pulse-glow 2s ease-in-out infinite}@keyframes pulse-glow{0%,to{box-shadow:0 0 20px var(--accent-green-glow);border-color:var(--accent-green)}50%{box-shadow:0 0 40px var(--accent-green-glow);border-color:var(--accent-green)}}.session-progress .kwh-value{font-size:var(--font-3xl);font-weight:800;color:var(--accent-green)}.session-progress .kwh-label{font-size:var(--font-sm);color:var(--text-secondary)}.session-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:var(--space-md);margin-top:var(--space-lg)}.session-stat .label{font-size:var(--font-xs);color:var(--text-muted)}.session-stat .value{font-size:var(--font-lg);font-weight:600;margin-top:2px}.receipt{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-xl);max-width:500px;margin:0 auto}.receipt-header{text-align:center;margin-bottom:var(--space-lg);padding-bottom:var(--space-lg);border-bottom:1px dashed var(--border-subtle)}.receipt-header h2{font-size:var(--font-2xl);background:var(--gradient-success);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.receipt-row{display:flex;justify-content:space-between;padding:var(--space-sm) 0;font-size:var(--font-sm)}.receipt-row .label{color:var(--text-secondary)}.receipt-row .value{font-weight:500}.receipt-row.total{border-top:2px solid var(--border-medium);margin-top:var(--space-md);padding-top:var(--space-md);font-size:var(--font-lg);font-weight:700}.history-list{display:flex;flex-direction:column;gap:var(--space-md)}.history-item{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-md) var(--space-lg);display:grid;grid-template-columns:1fr auto;gap:var(--space-md);align-items:center;cursor:pointer;transition:all var(--transition-base)}.history-item:hover{border-color:var(--border-medium);transform:translate(4px)}.history-item .history-station{font-weight:600;margin-bottom:2px}.history-item .history-date{font-size:var(--font-sm);color:var(--text-secondary)}.history-item .history-meta{display:flex;gap:var(--space-md);margin-top:var(--space-xs);font-size:var(--font-sm);color:var(--text-muted)}.history-item .history-cost{font-size:var(--font-xl);font-weight:700;color:var(--accent-green);text-align:right}.operator-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-xl)}.operator-header h1{font-size:var(--font-2xl);font-weight:700}.modal-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000;padding:var(--space-lg)}.modal{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-xl);max-width:600px;width:100%;max-height:90vh;overflow-y:auto}.modal h2{font-size:var(--font-xl);margin-bottom:var(--space-lg)}.modal-actions{display:flex;gap:var(--space-md);justify-content:flex-end;margin-top:var(--space-lg)}.amenities{display:flex;gap:var(--space-xs);flex-wrap:wrap}.amenity-tag{padding:2px 8px;border-radius:var(--radius-full);font-size:var(--font-xs);background:var(--bg-glass);color:var(--text-muted);border:1px solid var(--border-subtle)}.loading-spinner{display:flex;align-items:center;justify-content:center;padding:var(--space-2xl)}.spinner{width:40px;height:40px;border:3px solid var(--border-subtle);border-top-color:var(--accent-blue);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:var(--space-2xl);color:var(--text-muted)}.empty-state .empty-icon{font-size:3rem;margin-bottom:var(--space-md)}.chart-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-md)}.chart-card h3{font-size:var(--font-md);font-weight:600;margin-bottom:var(--space-md);color:var(--text-secondary)}.chart-bars{display:flex;align-items:flex-end;gap:4px;height:120px;padding-top:var(--space-md)}.chart-bar{flex:1;background:var(--gradient-primary);border-radius:4px 4px 0 0;min-height:4px;transition:all var(--transition-base);position:relative}.chart-bar:hover{opacity:.8}.chart-bar-label{position:absolute;bottom:-20px;left:50%;transform:translate(-50%);font-size:var(--font-xs);color:var(--text-muted);white-space:nowrap}.uptime-bar{width:100%;height:8px;background:var(--bg-glass);border-radius:var(--radius-full);overflow:hidden}.uptime-fill{height:100%;border-radius:var(--radius-full);transition:width var(--transition-slow)}.uptime-fill.high{background:var(--accent-green)}.uptime-fill.medium{background:var(--accent-amber)}.uptime-fill.low{background:var(--accent-red)}@media(max-width:900px){.discovery-layout{grid-template-columns:1fr;height:auto}.map-container{height:300px}.form-row{grid-template-columns:1fr}.navbar{padding:var(--space-sm) var(--space-md)}.navbar-links{gap:0}}@media(max-width:600px){.page-container{padding:var(--space-md)}.page-header h1{font-size:var(--font-2xl)}.stats-grid,.session-stats{grid-template-columns:1fr}}
