@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";
@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/8a480f0b521d4e75-s.8e0177b5.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/7178b3e590c64307-s.b97b3418.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/caa3a2e1cccd8315-s.p.853070df.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Geist Fallback;src:local(Arial);ascent-override:95.94%;descent-override:28.16%;line-gap-override:0.0%;size-adjust:104.76%}.geist_a71539c9-module__T19VSG__className{font-family:Geist,Geist Fallback;font-style:normal}.geist_a71539c9-module__T19VSG__variable{--font-geist-sans:"Geist","Geist Fallback"}
@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/4fa387ec64143e14-s.c1fdd6c2.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/bbc41e54d2fcbd21-s.799d8ef8.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/797e433ab948586e-s.p.dbea232f.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Geist Mono Fallback;src:local(Arial);ascent-override:74.67%;descent-override:21.92%;line-gap-override:0.0%;size-adjust:134.59%}.geist_mono_8d43a2aa-module__8Li5zG__className{font-family:Geist Mono,Geist Mono Fallback;font-style:normal}.geist_mono_8d43a2aa-module__8Li5zG__variable{--font-geist-mono:"Geist Mono","Geist Mono Fallback"}
:root{--bg-primary:#1a1d23;--bg-secondary:#14171c;--bg-card:#14171c;--border-color:#252931;--text-primary:#fff;--text-secondary:#9ca3af;--text-muted:#6b7280;--accent-green:#a8c57a;--accent-purple:#8b5cf6;--accent-orange:#f97316;--success-bg:#d1fae5;--success-text:#059669;--danger-bg:#fee2e2;--danger-text:#dc2626;--spacing-xs:4px;--spacing-sm:8px;--spacing-md:16px;--spacing-lg:24px;--spacing-xl:32px;--spacing-2xl:48px;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px}*{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6;overflow-x:hidden}.auth-page{background:var(--bg-primary);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.auth-container{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:24px;grid-template-columns:1fr 1fr;gap:0;width:100%;max-width:1200px;display:grid;overflow:hidden;box-shadow:0 20px 60px #00000080}.auth-branding{background:linear-gradient(135deg,var(--bg-secondary)0%,#0f1116 100%);flex-direction:column;justify-content:center;padding:60px;display:flex;position:relative;overflow:hidden}.auth-branding:before{content:"";pointer-events:none;background:radial-gradient(circle at 30%,#a8c57a14 0%,#0000 50%);width:200%;height:200%;position:absolute;top:-50%;left:-50%}.auth-branding-content{z-index:1;position:relative}.auth-logo-large{align-items:center;gap:16px;margin-bottom:40px;display:flex}.auth-logo-icon{background:var(--accent-green);width:56px;height:56px;color:var(--bg-secondary);border-radius:14px;justify-content:center;align-items:center;font-size:28px;font-weight:900;display:flex;box-shadow:0 8px 24px #a8c57a4d}.auth-logo-text{color:var(--text-primary);letter-spacing:-1px;font-size:32px;font-weight:800}.auth-branding-title{color:var(--text-primary);letter-spacing:-1px;margin-bottom:16px;font-size:36px;font-weight:800;line-height:1.2}.auth-branding-subtitle{color:var(--text-secondary);margin-bottom:48px;font-size:16px;line-height:1.6}.auth-features{flex-direction:column;gap:24px;display:flex}.auth-feature{align-items:flex-start;gap:16px;display:flex}.auth-feature-icon{background:#a8c57a1a;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:24px;display:flex}.auth-feature-text{flex:1}.auth-feature-title{color:var(--text-primary);margin-bottom:4px;font-size:16px;font-weight:600}.auth-feature-desc{color:var(--text-secondary);font-size:14px;line-height:1.5}.auth-form-side{background:var(--bg-primary);justify-content:center;align-items:center;padding:60px;display:flex}.auth-form-container{width:100%;max-width:420px}.auth-form-header{text-align:center;margin-bottom:32px}.auth-form-title{color:var(--text-primary);letter-spacing:-.5px;margin-bottom:8px;font-size:28px;font-weight:700}.auth-form-subtitle{color:var(--text-secondary);font-size:14px}.auth-error{border-radius:var(--radius-lg);background:#ef44441a;border:1px solid #ef44444d;align-items:center;gap:12px;margin-bottom:24px;padding:14px 16px;display:flex}.auth-error-icon{flex-shrink:0;font-size:20px}.auth-error-text{color:#fca5a5;flex:1;font-size:14px}.auth-form{flex-direction:column;gap:20px;display:flex}.auth-input-group{flex-direction:column;gap:8px;display:flex}.auth-label{color:var(--text-primary);font-size:14px;font-weight:500}.auth-input{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);width:100%;color:var(--text-primary);padding:12px 16px;font-size:14px;transition:all .2s}.auth-input:focus{border-color:var(--accent-green);background:var(--bg-card);outline:none}.auth-input::placeholder{color:var(--text-muted)}.auth-input-hint{color:var(--text-muted);font-size:12px}.auth-submit-btn{background:var(--accent-green);width:100%;color:var(--bg-secondary);border-radius:var(--radius-md);cursor:pointer;border:none;margin-top:8px;padding:12px 24px;font-size:15px;font-weight:600;transition:all .2s}.auth-submit-btn:hover:not(:disabled){background:#b8d58a;transform:translateY(-1px)}.auth-submit-btn:active:not(:disabled){transform:translateY(0)}.auth-submit-btn:disabled{opacity:.5;cursor:not-allowed}.auth-switch{text-align:center;color:var(--text-secondary);padding-top:8px;font-size:14px}.auth-switch-link{color:var(--accent-green);cursor:pointer;background:0 0;border:none;font-weight:600;text-decoration:none;transition:all .2s}.auth-switch-link:hover{color:#b8d58a}.auth-footer{text-align:center;color:var(--text-muted);border-top:1px solid var(--border-color);margin-top:32px;padding-top:24px;font-size:12px}.auth-footer-link{color:var(--accent-green);text-decoration:none}.auth-footer-link:hover{text-decoration:underline}.dashboard-shell{width:100%;min-height:100vh;display:flex}.dashboard-sidebar{background:var(--bg-secondary);border-right:1px solid var(--border-color);z-index:100;flex-direction:column;width:260px;height:100vh;transition:width .3s;display:flex;position:fixed;top:0;left:0}.dashboard-sidebar.collapsed{width:70px}.sidebar-logo{border-bottom:1px solid var(--border-color);align-items:center;gap:12px;padding:24px;display:flex}.logo-icon{background:var(--accent-green);width:36px;height:36px;color:var(--bg-secondary);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;font-size:16px;font-weight:900;display:flex}.logo-text{color:var(--text-primary);font-size:20px;font-weight:700}.sidebar-vehicle{border-bottom:1px solid var(--border-color);padding:16px}.vehicle-select{border:1px solid var(--border-color);border-radius:var(--radius-md);width:100%;color:var(--text-primary);cursor:pointer;background:#1f2229;padding:10px 12px;font-size:14px;font-weight:500;transition:all .2s}.vehicle-select:hover{border-color:var(--accent-green)}.vehicle-select:focus{border-color:var(--accent-green);outline:none}.sidebar-nav{flex:1;padding:8px 0;overflow-y:auto}.nav-section{margin-bottom:24px}.nav-section-label{text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);margin-top:16px;margin-bottom:8px;padding:0 24px;font-size:11px;font-weight:600}.nav-section:first-child .nav-section-label{margin-top:0}.nav-item{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;align-items:center;gap:12px;width:100%;padding:10px 24px;font-size:14px;font-weight:500;text-decoration:none;transition:all .2s;display:flex;position:relative}.nav-item:hover{color:var(--text-primary);background:#1f2229}.nav-item.active{color:var(--accent-green);background:#1f2229}.nav-item.active:before{content:"";background:var(--accent-green);border-radius:0 2px 2px 0;width:3px;height:20px;position:absolute;top:50%;left:0;transform:translateY(-50%)}.nav-icon{flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;font-size:16px;display:flex}.nav-label{flex:1}.nav-badge{background:var(--accent-green);color:var(--bg-secondary);border-radius:10px;padding:2px 8px;font-size:11px;font-weight:700}.sidebar-footer{border-top:1px solid var(--border-color);padding:16px}.sidebar-collapse-btn{border:1px solid var(--border-color);border-radius:var(--radius-sm);width:100%;color:var(--text-secondary);cursor:pointer;background:0 0;margin-bottom:8px;padding:8px;font-size:14px;transition:all .2s}.sidebar-collapse-btn:hover{color:var(--text-primary);background:#1f2229}.dashboard-main{flex-direction:column;flex:1;min-height:100vh;margin-left:260px;transition:margin-left .3s;display:flex}.dashboard-sidebar.collapsed~.dashboard-main{margin-left:70px}.dashboard-topbar{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);z-index:90;justify-content:space-between;align-items:center;height:70px;padding:0 32px;display:flex;position:sticky;top:0}.topbar-left{align-items:center;gap:16px;display:flex}.topbar-menu-btn{width:36px;height:36px;color:var(--text-secondary);cursor:pointer;background:0 0;border:none;font-size:20px;transition:all .2s;display:none}.topbar-menu-btn:hover{color:var(--text-primary)}.topbar-search{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);align-items:center;gap:12px;min-width:300px;padding:8px 16px;display:flex}.search-icon{color:var(--text-muted);font-size:16px}.search-input{color:var(--text-primary);background:0 0;border:none;outline:none;flex:1;font-size:14px}.search-input::placeholder{color:var(--text-muted)}.topbar-right{align-items:center;gap:12px;display:flex}.topbar-icon-btn{width:40px;height:40px;color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-md);background:0 0;border:none;justify-content:center;align-items:center;font-size:18px;transition:all .2s;display:flex;position:relative}.topbar-icon-btn:hover{background:var(--bg-primary);color:var(--text-primary)}.topbar-notification{position:relative}.notification-badge{color:#fff;background:#ef4444;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:10px;font-weight:700;display:flex;position:absolute;top:6px;right:6px}.topbar-profile{margin-left:8px}.profile-avatar{background:var(--accent-green);width:40px;height:40px;color:var(--bg-secondary);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;font-size:14px;font-weight:700;transition:all .2s;display:flex}.profile-avatar:hover{transform:scale(1.05)}.dashboard-content{padding:var(--spacing-xl)40px;background:var(--bg-primary);flex:1;overflow-y:auto}.dashboard-page{max-width:1800px;margin:0 auto}.dashboard-header{margin-bottom:var(--spacing-xl);justify-content:space-between;align-items:flex-start;display:flex}.dashboard-welcome{color:var(--text-primary);margin-bottom:4px;font-size:28px;font-weight:700}.dashboard-subtitle{color:var(--text-secondary);font-size:14px}.dashboard-add-btn{background:var(--accent-green);color:var(--bg-secondary);border-radius:var(--radius-md);cursor:pointer;border:none;padding:10px 20px;font-size:14px;font-weight:600;text-decoration:none;transition:all .2s;display:inline-block}.dashboard-add-btn:hover{background:#b8d58a;transform:translateY(-1px)}.stats-grid{grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:28px;display:grid}.stat-card{border-radius:var(--radius-xl);background:#fff;padding:24px;transition:all .3s;position:relative;overflow:hidden;box-shadow:0 1px 3px #0000001a}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.stat-label{color:#6b7280;margin-bottom:12px;font-size:13px;font-weight:500}.stat-value{color:#1a1d23;align-items:baseline;gap:8px;margin-bottom:12px;font-size:32px;font-weight:700;display:flex}.stat-trend{border-radius:var(--radius-sm);align-items:center;gap:4px;padding:4px 10px;font-size:12px;font-weight:600;display:inline-flex}.stat-trend.up{background:var(--success-bg);color:var(--success-text)}.stat-trend.down{background:var(--danger-bg);color:var(--danger-text)}.stat-sparkline{opacity:.6;width:120px;height:50px;position:absolute;bottom:0;right:0}.charts-grid{grid-template-columns:1.5fr 1fr;gap:20px;margin-bottom:28px;display:grid}.chart-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:28px}.chart-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.chart-title{color:var(--text-primary);font-size:18px;font-weight:600}.chart-legend{gap:20px;font-size:12px;display:flex}.legend-item{align-items:center;gap:6px;display:flex}.legend-dot{border-radius:50%;width:8px;height:8px}.legend-label{color:var(--text-secondary)}.bar-chart{justify-content:space-between;align-items:flex-end;gap:16px;height:280px;padding:20px 0;display:flex}.bar-group{flex-direction:column;flex:1;align-items:center;gap:8px;display:flex}.bar-pair{align-items:flex-end;gap:4px;width:100%;height:240px;display:flex}.bar{border-radius:4px 4px 0 0;flex:1;transition:all .3s}.bar:hover{opacity:.8}.bar.online{background:var(--accent-purple)}.bar.offline{background:var(--accent-orange)}.bar-label{color:var(--text-muted);font-size:11px;font-weight:500}.donut-container{flex-direction:column;justify-content:center;align-items:center;height:280px;display:flex}.donut-chart{width:200px;height:200px;margin-bottom:24px;position:relative}.donut-center{text-align:center;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.donut-value{color:var(--text-primary);font-size:36px;font-weight:700}.donut-label{color:var(--text-muted);font-size:12px}.donut-legend{flex-direction:column;gap:12px;display:flex}.donut-legend-item{justify-content:space-between;align-items:center;gap:40px;display:flex}.donut-legend-left{align-items:center;gap:8px;display:flex}.donut-legend-color{border-radius:3px;width:12px;height:12px}.donut-legend-label{color:var(--text-secondary);font-size:13px}.donut-legend-value{color:var(--text-primary);font-size:13px;font-weight:600}.bottom-grid{grid-template-columns:1.5fr 1fr;gap:20px;display:grid}.table-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:28px}.table-title{color:var(--text-primary);margin-bottom:20px;font-size:18px;font-weight:600}.data-table{width:100%}.data-table thead{border-bottom:1px solid var(--border-color)}.data-table th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;padding:12px 16px;font-size:12px;font-weight:600}.data-table td{color:var(--text-primary);border-bottom:1px solid var(--border-color);padding:16px;font-size:14px}.data-table tr:last-child td{border-bottom:none}.table-user{align-items:center;gap:12px;display:flex}.table-avatar{background:var(--accent-green);width:36px;height:36px;color:var(--bg-secondary);border-radius:50%;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:flex}.status-badge{border-radius:var(--radius-sm);padding:4px 12px;font-size:12px;font-weight:600}.status-badge.charging{color:var(--accent-green);background:#a8c57a33}.status-badge.idle{color:var(--text-secondary);background:#9ca3af33}.activity-grid{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}.activity-card{border:1px solid var(--border-color);border-radius:var(--radius-lg);background:#1f2229;justify-content:space-between;align-items:center;padding:20px;display:flex}.activity-left{align-items:center;gap:12px;display:flex}.activity-icon{border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;font-size:20px;display:flex}.activity-icon.green{background:#a8c57a33}.activity-icon.orange{background:#f9731633}.activity-info{flex-direction:column;gap:4px;display:flex}.activity-label{color:var(--text-muted);font-size:12px;font-weight:500}.activity-value{color:var(--text-primary);font-size:16px;font-weight:700}.activity-right{text-align:right}.activity-percentage{color:var(--accent-green);font-size:20px;font-weight:700}.activity-change{color:var(--text-muted);font-size:11px}.dashboard-loading{flex-direction:column;justify-content:center;align-items:center;gap:20px;min-height:60vh;display:flex}.loading-spinner{border:4px solid var(--border-color);border-top-color:var(--accent-green);border-radius:50%;width:48px;height:48px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{color:var(--text-secondary);font-size:15px}.dashboard-error{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:60vh;padding:40px 20px;display:flex}.error-icon{font-size:48px}.error-title{color:var(--text-primary);font-size:20px;font-weight:600}.error-text{color:var(--text-secondary);max-width:400px;font-size:15px}.error-btn{background:var(--accent-green);color:var(--bg-secondary);border-radius:var(--radius-md);margin-top:8px;padding:10px 20px;font-size:14px;font-weight:600;text-decoration:none;transition:all .2s;display:inline-block}.error-btn:hover{background:#b8d58a}@media (max-width:1400px){.stats-grid{grid-template-columns:repeat(2,1fr)}.charts-grid,.bottom-grid{grid-template-columns:1fr}}@media (max-width:968px){.auth-container{grid-template-columns:1fr}.auth-branding{display:none}.auth-form-side{padding:40px 24px}.dashboard-sidebar{transform:translate(-100%)}.dashboard-sidebar.mobile-open{transform:translate(0)}.dashboard-main{margin-left:0}.topbar-menu-btn{display:flex}.topbar-search{display:none}}@media (max-width:768px){.dashboard-content{padding:20px 16px}.dashboard-topbar{padding:0 16px}.stats-grid,.activity-grid{grid-template-columns:1fr}.bar-chart{gap:8px}.topbar-icon-btn{width:36px;height:36px}}.settings-tabs{border-bottom:1px solid var(--border-color);gap:8px;margin-bottom:32px;display:flex}.settings-tab{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;padding:12px 24px;font-size:14px;font-weight:600;transition:all .2s}.settings-tab:hover{color:var(--text-primary)}.settings-tab.active{color:var(--accent-green);border-bottom-color:var(--accent-green)}.settings-message{border-radius:var(--radius-lg);align-items:center;gap:12px;margin-bottom:24px;padding:14px 16px;font-size:14px;display:flex}.settings-message.success{color:#10b981;background:#10b9811a;border:1px solid #10b9814d}.settings-message.error{color:#fca5a5;background:#ef44441a;border:1px solid #ef44444d}.settings-message-icon{font-size:20px}.settings-content{max-width:800px}.settings-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);margin-bottom:24px;padding:32px}.settings-section-title{color:var(--text-primary);margin-bottom:8px;font-size:20px;font-weight:700}.settings-section-desc{color:var(--text-secondary);margin-bottom:24px;font-size:14px}.settings-form{flex-direction:column;gap:20px;display:flex}.settings-form-group{flex-direction:column;gap:8px;display:flex}.settings-label{color:var(--text-primary);font-size:14px;font-weight:600}.settings-input{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);padding:12px 16px;font-size:14px;transition:all .2s}.settings-input:focus{border-color:var(--accent-green);outline:none}.settings-input:disabled{opacity:.5;cursor:not-allowed}.settings-input-hint{color:var(--text-muted);font-size:12px}.settings-form-actions{gap:12px;padding-top:8px;display:flex}.settings-btn{border-radius:var(--radius-md);cursor:pointer;border:none;padding:10px 20px;font-size:14px;font-weight:600;transition:all .2s}.settings-btn.primary{background:var(--accent-green);color:var(--bg-secondary)}.settings-btn.primary:hover:not(:disabled){background:#b8d58a}.settings-btn.danger{color:#fff;background:#ef4444}.settings-btn.danger:hover:not(:disabled){background:#dc2626}.settings-btn:disabled{opacity:.5;cursor:not-allowed}.settings-danger-zone{border-top:1px solid var(--border-color);margin-top:48px;padding-top:32px}.settings-preference-list{flex-direction:column;gap:20px;display:flex}.settings-preference-item{background:var(--bg-primary);border-radius:var(--radius-lg);justify-content:space-between;align-items:center;padding:16px;display:flex}.settings-preference-info{flex:1}.settings-preference-label{color:var(--text-primary);margin-bottom:4px;font-size:15px;font-weight:600}.settings-preference-desc{color:var(--text-secondary);font-size:13px}.settings-toggle{width:48px;height:28px;display:inline-block;position:relative}.settings-toggle input{opacity:0;width:0;height:0}.settings-toggle-slider{cursor:pointer;background-color:#ccc;border-radius:28px;transition:all .3s;position:absolute;inset:0}.settings-toggle-slider:before{content:"";background-color:#fff;border-radius:50%;width:20px;height:20px;transition:all .3s;position:absolute;bottom:4px;left:4px}.settings-toggle input:checked+.settings-toggle-slider{background-color:var(--accent-green)}.settings-toggle input:checked+.settings-toggle-slider:before{transform:translate(20px)}.add-vehicle-container{max-width:800px;margin:0 auto}.add-vehicle-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);text-align:center;padding:48px}.add-vehicle-icon{background:#a8c57a1a;border-radius:50%;justify-content:center;align-items:center;width:100px;height:100px;margin:0 auto 32px;display:flex}.add-vehicle-icon-inner{font-size:48px}.add-vehicle-title{color:var(--text-primary);margin-bottom:12px;font-size:28px;font-weight:700}.add-vehicle-subtitle{color:var(--text-secondary);margin-bottom:32px;font-size:16px}.add-vehicle-error{border-radius:var(--radius-lg);color:#fca5a5;background:#ef44441a;border:1px solid #ef44444d;justify-content:center;align-items:center;gap:12px;margin-bottom:24px;padding:14px 16px;font-size:14px;display:flex}.add-vehicle-error-icon{font-size:20px}.add-vehicle-features{text-align:left;grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:32px;display:grid}.add-vehicle-feature{background:var(--bg-primary);border-radius:var(--radius-lg);gap:16px;padding:20px;display:flex}.add-vehicle-feature-icon{background:#a8c57a1a;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:24px;display:flex}.add-vehicle-feature-text{flex:1}.add-vehicle-feature-title{color:var(--text-primary);margin-bottom:4px;font-size:15px;font-weight:600}.add-vehicle-feature-desc{color:var(--text-secondary);font-size:13px;line-height:1.5}.add-vehicle-connect-btn{background:var(--accent-green);width:100%;color:var(--bg-secondary);border-radius:var(--radius-lg);cursor:pointer;border:none;justify-content:center;align-items:center;gap:12px;margin-bottom:24px;padding:16px 32px;font-size:16px;font-weight:700;transition:all .2s;display:flex}.add-vehicle-connect-btn:hover:not(:disabled){background:#b8d58a;transform:translateY(-2px)}.add-vehicle-connect-btn:disabled{opacity:.7;cursor:not-allowed}.add-vehicle-spinner{border:2px solid var(--bg-secondary);border-top-color:#0000;border-radius:50%;width:16px;height:16px;animation:.8s linear infinite spin}.add-vehicle-info{border-radius:var(--radius-lg);text-align:left;color:var(--text-secondary);background:#a8c57a1a;gap:12px;margin-bottom:32px;padding:16px;font-size:13px;display:flex}.add-vehicle-info-icon{flex-shrink:0;font-size:20px}.add-vehicle-info-text strong{color:var(--text-primary)}.add-vehicle-steps{text-align:center;grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.add-vehicle-step{flex-direction:column;align-items:center;gap:12px;display:flex}.add-vehicle-step-number{width:40px;height:40px;color:var(--accent-green);background:#a8c57a33;border-radius:50%;justify-content:center;align-items:center;font-weight:700;display:flex}.add-vehicle-step-text{color:var(--text-secondary);font-size:12px}.add-vehicle-help{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);text-align:center;margin-top:32px;padding:24px}.add-vehicle-help-title{color:var(--text-primary);margin-bottom:8px;font-size:18px;font-weight:700}.add-vehicle-help-text{color:var(--text-secondary);font-size:14px}.add-vehicle-help-link{color:var(--accent-green);font-weight:600;text-decoration:none}.add-vehicle-help-link:hover{text-decoration:underline}.dashboard-add-btn.secondary{color:var(--text-primary);border:1px solid var(--border-color);background:0 0}.dashboard-add-btn.secondary:hover{background:var(--bg-card);border-color:var(--accent-green)}@media (max-width:768px){.add-vehicle-card{padding:32px 24px}.add-vehicle-features{grid-template-columns:1fr}.add-vehicle-steps{grid-template-columns:repeat(2,1fr)}.settings-tabs{-webkit-overflow-scrolling:touch;overflow-x:auto}}.battery-hero-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);margin-bottom:32px;padding:40px}.battery-hero-content{grid-template-columns:1.5fr 1fr;align-items:center;gap:48px;display:grid}.battery-hero-percent{color:var(--accent-green);margin-bottom:12px;font-size:72px;font-weight:900;line-height:1}.battery-hero-label{color:var(--text-secondary);margin-bottom:24px;font-size:16px}.battery-hero-bar{background:#ffffff0d;border-radius:6px;width:100%;height:12px;margin-bottom:24px;overflow:hidden}.battery-hero-bar-fill{background:linear-gradient(90deg,var(--accent-green),#8da566);border-radius:6px;height:100%;transition:width .8s}.battery-hero-range{gap:32px;display:flex}.battery-range-item{flex-direction:column;gap:4px;display:flex}.battery-range-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:12px}.battery-range-value{color:var(--text-primary);font-size:20px;font-weight:700}.battery-visual{flex-direction:column;align-items:center;gap:8px;display:flex}.battery-outline{border:4px solid var(--border-color);border-radius:12px;flex-direction:column;justify-content:flex-end;width:120px;height:240px;display:flex;position:relative;overflow:hidden}.battery-fill{background:linear-gradient(180deg,var(--accent-green),#8da566);border-radius:0 0 8px 8px;width:100%;transition:height .8s}.battery-terminal{background:var(--border-color);border-radius:4px 4px 0 0;width:40px;height:12px}.battery-chart-placeholder{height:240px}.battery-tips{flex-direction:column;gap:20px;padding:8px 0;display:flex}.battery-tip{background:var(--bg-primary);border-radius:var(--radius-lg);gap:16px;padding:16px;display:flex}.battery-tip-icon{flex-shrink:0;font-size:24px}.battery-tip-text{flex:1}.battery-tip-title{color:var(--text-primary);margin-bottom:4px;font-size:15px;font-weight:600}.battery-tip-desc{color:var(--text-secondary);font-size:13px;line-height:1.5}.charging-status-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);margin-bottom:32px;padding:40px}.charging-status-header{justify-content:space-between;align-items:center;margin-bottom:32px;display:flex}.charging-status-badge{color:var(--text-secondary);background:#9ca3af33;border-radius:20px;padding:8px 16px;font-size:14px;font-weight:600}.charging-status-badge[data-charging=true]{color:var(--accent-green);background:#a8c57a33}.charging-time-remaining{color:var(--text-secondary);font-size:14px}.charging-progress{margin-bottom:32px}.charging-progress-bar{background:#ffffff0d;border-radius:8px;width:100%;height:16px;margin-bottom:12px;position:relative;overflow:visible}.charging-progress-fill{background:linear-gradient(90deg,var(--accent-green),#8da566);border-radius:8px;height:100%;transition:width .8s}.charging-progress-limit{background:var(--accent-orange);border-radius:2px;width:3px;height:24px;position:absolute;top:-4px}.charging-progress-labels{color:var(--text-muted);justify-content:space-between;font-size:12px;display:flex}.charging-limit-label{color:var(--accent-orange);font-weight:600}.charging-stats{gap:48px;margin-bottom:32px;display:flex}.charging-stat{text-align:center}.charging-stat-value{color:var(--text-primary);margin-bottom:8px;font-size:36px;font-weight:800}.charging-stat-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:13px}.charging-actions{gap:16px;display:flex}.charging-btn{border-radius:var(--radius-lg);cursor:pointer;border:none;flex:1;padding:14px 24px;font-size:15px;font-weight:700;transition:all .2s}.charging-btn.start{background:var(--accent-green);color:var(--bg-secondary)}.charging-btn.start:hover:not(:disabled){background:#b8d58a}.charging-btn.stop{background:var(--accent-orange);color:#fff}.charging-btn.stop:hover:not(:disabled){background:#f97316}.charging-btn:disabled{opacity:.5;cursor:not-allowed}.climate-hero-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);margin-bottom:32px;padding:40px}.climate-status{text-align:center;margin-bottom:32px}.climate-status-badge{color:var(--text-secondary);background:#9ca3af33;border-radius:20px;padding:8px 20px;font-size:15px;font-weight:600;display:inline-block}.climate-status-badge[data-active=true]{color:var(--accent-green);background:#a8c57a33}.climate-temps{justify-content:center;align-items:center;gap:24px;margin-bottom:32px;display:flex}.climate-temp-display{text-align:center}.climate-temp-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:12px}.climate-temp-value{color:var(--text-primary);font-size:48px;font-weight:900}.climate-temp-divider{color:var(--text-muted);font-size:24px}.climate-temp-control{align-items:center;gap:16px;margin-bottom:32px;display:flex}.climate-temp-btn{border:1px solid var(--border-color);width:48px;height:48px;color:var(--accent-green);cursor:pointer;background:#a8c57a1a;border-radius:50%;font-size:24px;transition:all .2s}.climate-temp-btn:hover{background:#a8c57a33;transform:scale(1.05)}.climate-temp-slider{-webkit-appearance:none;background:#ffffff0d;border-radius:4px;outline:none;flex:1;height:8px}.climate-temp-slider::-webkit-slider-thumb{-webkit-appearance:none;background:var(--accent-green);cursor:pointer;border-radius:50%;width:24px;height:24px}.climate-temp-slider::-moz-range-thumb{background:var(--accent-green);cursor:pointer;border:none;border-radius:50%;width:24px;height:24px}.climate-toggle-btn{border-radius:var(--radius-lg);width:100%;color:var(--accent-green);cursor:pointer;background:#a8c57a1a;border:2px solid #a8c57a4d;padding:16px 32px;font-size:16px;font-weight:700;transition:all .2s}.climate-toggle-btn[data-active=true]{background:var(--accent-green);color:var(--bg-secondary);border-color:var(--accent-green)}.climate-toggle-btn:hover:not(:disabled){transform:translateY(-2px)}.climate-seats-section,.climate-quick-actions{margin-bottom:32px}.climate-section-title{color:var(--text-primary);margin-bottom:20px;font-size:20px;font-weight:700}.climate-seats-grid{grid-template-columns:repeat(4,1fr);gap:20px;display:grid}.climate-seat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);text-align:center;padding:24px}.climate-seat-icon{margin-bottom:12px;font-size:32px}.climate-seat-label{color:var(--text-primary);margin-bottom:16px;font-size:14px;font-weight:600}.climate-seat-levels{gap:4px;display:flex}.climate-level-btn{border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;background:#ffffff0d;flex:1;padding:8px 4px;font-size:11px;transition:all .2s}.climate-level-btn:hover{color:var(--accent-green);background:#a8c57a1a}.climate-level-btn.active{background:var(--accent-green);color:var(--bg-secondary);border-color:var(--accent-green)}.climate-actions-grid{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.climate-action-btn{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;flex-direction:column;align-items:center;gap:12px;padding:20px;transition:all .2s;display:flex}.climate-action-btn:hover{background:#a8c57a0d;border-color:#a8c57a4d;transform:translateY(-2px)}.climate-action-icon{font-size:32px}.climate-action-label{color:var(--text-primary);font-size:13px;font-weight:600}.location-map-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);margin-bottom:32px;padding:40px}.location-map-placeholder{background:var(--bg-primary);border-radius:var(--radius-lg);text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:400px;display:flex}.location-map-icon{margin-bottom:20px;font-size:64px}.location-map-title{color:var(--text-primary);margin-bottom:8px;font-size:20px;font-weight:700}.location-map-desc{color:var(--text-secondary);margin-bottom:16px;font-size:14px}.location-map-coords{color:var(--text-muted);border-radius:var(--radius-sm);background:#a8c57a1a;padding:8px 16px;font-family:monospace;font-size:12px}.location-actions{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.location-action-btn{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;color:var(--text-primary);flex-direction:column;align-items:center;gap:8px;padding:16px;font-size:13px;font-weight:600;transition:all .2s;display:flex}.location-action-btn:hover{background:#a8c57a0d;border-color:#a8c57a4d;transform:translateY(-2px)}.location-action-icon{font-size:24px}.sessions-filters{gap:12px;margin-bottom:32px;display:flex}.sessions-filter-btn{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);color:var(--text-secondary);cursor:pointer;padding:10px 20px;font-size:14px;font-weight:600;transition:all .2s}.sessions-filter-btn:hover{color:var(--text-primary);background:#a8c57a0d}.sessions-filter-btn.active{background:var(--accent-green);color:var(--bg-secondary);border-color:var(--accent-green)}.sessions-loading,.sessions-empty{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:80px 20px;display:flex}.sessions-empty-icon{margin-bottom:20px;font-size:64px}.sessions-empty-title{color:var(--text-primary);margin-bottom:8px;font-size:20px;font-weight:700}.sessions-empty-text{color:var(--text-secondary);font-size:14px}.sessions-list{flex-direction:column;gap:16px;display:flex}.session-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);align-items:center;gap:20px;padding:24px;transition:all .2s;display:flex}.session-card:hover{border-color:#a8c57a4d;transform:translateY(-2px)}.session-icon{background:#a8c57a1a;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;font-size:28px;display:flex}.session-info{flex:1}.session-header{align-items:center;gap:12px;margin-bottom:8px;display:flex}.session-type{color:var(--text-primary);font-size:16px;font-weight:700}.session-date{color:var(--text-secondary);margin-bottom:8px;font-size:14px}.session-details{gap:16px;display:flex}.session-detail{color:var(--text-muted);font-size:13px}.session-view-btn{border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;background:0 0;padding:8px 16px;font-size:13px;font-weight:600;transition:all .2s}.session-view-btn:hover{color:var(--accent-green);background:#a8c57a0d;border-color:#a8c57a4d}.fleet-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px;display:grid}.fleet-empty{text-align:center;flex-direction:column;grid-column:1/-1;justify-content:center;align-items:center;padding:80px 20px;display:flex}.fleet-empty-icon{margin-bottom:20px;font-size:64px}.fleet-empty-title{color:var(--text-primary);margin-bottom:8px;font-size:20px;font-weight:700}.fleet-empty-text{color:var(--text-secondary);margin-bottom:24px;font-size:14px}.fleet-vehicle-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);cursor:pointer;padding:24px;transition:all .2s}.fleet-vehicle-card:hover{border-color:#a8c57a4d;transform:translateY(-2px)}.fleet-vehicle-card.active{border-color:var(--accent-green);box-shadow:0 0 0 1px var(--accent-green)}.fleet-vehicle-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.fleet-vehicle-icon{background:#a8c57a1a;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;font-size:28px;display:flex}.fleet-vehicle-active-badge{color:var(--accent-green);text-transform:uppercase;background:#a8c57a33;border-radius:12px;padding:4px 12px;font-size:11px;font-weight:700}.fleet-vehicle-info{margin-bottom:20px}.fleet-vehicle-name{color:var(--text-primary);margin-bottom:4px;font-size:18px;font-weight:700}.fleet-vehicle-vin{color:var(--text-muted);font-family:monospace;font-size:12px}.fleet-vehicle-stats{border-top:1px solid var(--border-color);border-bottom:1px solid var(--border-color);grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:20px;padding:16px 0;display:grid}.fleet-vehicle-stat{text-align:center}.fleet-stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-size:11px;display:block}.fleet-stat-value{color:var(--text-primary);font-size:16px;font-weight:700;display:block}.fleet-vehicle-actions{gap:8px;display:flex}.fleet-action-btn{border-radius:var(--radius-md);color:var(--accent-green);cursor:pointer;background:#a8c57a1a;border:1px solid #a8c57a4d;flex:1;padding:10px;font-size:13px;font-weight:600;transition:all .2s}.fleet-action-btn:hover{background:#a8c57a33}.fleet-action-btn.secondary{border-color:var(--border-color);color:var(--text-secondary);background:0 0}.fleet-action-btn.secondary:hover{background:#ffffff0d}.help-search-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);align-items:center;gap:16px;margin-bottom:32px;padding:20px 24px;display:flex}.help-search-icon{color:var(--text-muted);font-size:24px}.help-search-input{color:var(--text-primary);background:0 0;border:none;outline:none;flex:1;font-size:16px}.help-search-input::placeholder{color:var(--text-muted)}.help-quick-links{margin-bottom:48px}.help-section-title{color:var(--text-primary);margin-bottom:20px;font-size:20px;font-weight:700}.help-links-grid{grid-template-columns:repeat(4,1fr);gap:20px;display:grid}.help-link-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:24px;text-decoration:none;transition:all .2s}.help-link-card:hover{border-color:#a8c57a4d;transform:translateY(-2px)}.help-link-icon{margin-bottom:16px;font-size:32px}.help-link-title{color:var(--text-primary);margin-bottom:8px;font-size:16px;font-weight:700}.help-link-desc{color:var(--text-secondary);font-size:13px}.help-faqs{margin-bottom:48px}.help-faq-category{margin-bottom:32px}.help-category-title{color:var(--text-primary);margin-bottom:16px;font-size:18px;font-weight:700}.help-faq-list{flex-direction:column;gap:12px;display:flex}.help-faq-item{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden}.help-faq-question{color:var(--text-primary);cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:20px 24px;font-size:15px;font-weight:600;list-style:none;display:flex}.help-faq-question:hover{background:#a8c57a0d}.help-faq-icon{transition:transform .2s}.help-faq-item[open] .help-faq-icon{transform:rotate(90deg)}.help-faq-answer{color:var(--text-secondary);padding:0 24px 20px;font-size:14px;line-height:1.6}.help-contact-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);align-items:center;gap:24px;padding:32px;display:flex}.help-contact-icon{background:#a8c57a1a;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:64px;height:64px;font-size:32px;display:flex}.help-contact-content{flex:1}.help-contact-title{color:var(--text-primary);margin-bottom:8px;font-size:20px;font-weight:700}.help-contact-text{color:var(--text-secondary);margin-bottom:16px;font-size:14px}.help-contact-btn{background:var(--accent-green);color:var(--bg-secondary);border-radius:var(--radius-md);cursor:pointer;border:none;padding:12px 24px;font-size:14px;font-weight:600;transition:all .2s}.help-contact-btn:hover{background:#b8d58a}@media (max-width:968px){.battery-hero-content,.climate-seats-grid,.climate-actions-grid,.help-links-grid,.location-actions{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.battery-hero-content{grid-template-columns:1fr}.climate-temps{flex-direction:column;gap:16px}.climate-temp-divider{transform:rotate(90deg)}.climate-seats-grid,.climate-actions-grid,.location-actions,.help-links-grid{grid-template-columns:1fr}.sessions-filters{-webkit-overflow-scrolling:touch;overflow-x:auto}.fleet-grid{grid-template-columns:1fr}}
