.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(135deg,var(--background-dark) 0%,#1a1a3e 100%)}.login-container{width:100%;max-width:480px}.login-header{text-align:center;margin-bottom:2.5rem}.login-logo{display:inline-flex;align-items:center;justify-content:center;margin-bottom:1rem}} .torque-logo-img{margin-bottom:1rem;width:180px;height:auto;object-fit:contain}.login-header h1{font-size:2rem;font-weight:700;margin-bottom:.5rem}.login-header p{color:var(--text-secondary)}.login-content{background:var(--background-card);border-radius:16px;padding:2rem;border:1px solid var(--border-color)}.features{display:flex;flex-direction:column;gap:1.25rem;margin-bottom:2rem}.feature{display:flex;align-items:center;gap:1rem}.feature-icon{font-size:1.5rem;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--background-card-hover);border-radius:12px}.feature h3{font-size:.9375rem;font-weight:600;margin-bottom:.125rem}.feature p{font-size:.8125rem;color:var(--text-secondary)}.login-btn{width:100%;padding:1rem 1.5rem;background:var(--primary-color);color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.75rem;transition:all .2s ease}.login-btn:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 8px 24px #e821274d}.login-btn .tesla-logo{width:80px;height:auto}.login-disclaimer{margin-top:1.5rem;font-size:.75rem;color:var(--text-muted);text-align:center;line-height:1.5}.callback-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:var(--background-dark)}.callback-container{text-align:center;max-width:400px}.callback-spinner{width:64px;height:64px;border:4px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1.5rem}.callback-container h2{font-size:1.5rem;margin-bottom:.75rem}.callback-container p{color:var(--text-secondary);margin-bottom:1.5rem}.callback-icon{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem;margin:0 auto 1.5rem}.callback-icon.error{background:#ef444426;color:var(--error-color)}.dashboard{min-height:calc(100vh - 4rem);padding-bottom:2rem}.dashboard .page-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.error-banner button{margin-left:auto;padding:.375rem .75rem;background:var(--error-color);color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500;font-size:.8125rem}.error-banner button:hover{opacity:.9}.vehicles-list{display:flex;flex-direction:column;gap:1rem}.vehicle-row{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;overflow:hidden;transition:all .3s ease;box-shadow:0 2px 8px #0000001a}.vehicle-row:hover{border-color:var(--primary-color);box-shadow:0 4px 16px #00000026}.vehicle-row.expanded{border-color:var(--primary-color)}.vehicle-row-header{display:flex;align-items:center;padding:1rem 1.5rem;cursor:pointer;gap:1rem}.vehicle-main-info{display:flex;align-items:center;gap:1rem;flex:1;min-width:0}.vehicle-emoji-icon{font-size:2.5rem;flex-shrink:0}.vehicle-name-section{display:flex;flex-direction:column;gap:.25rem;min-width:0}.vehicle-name{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.vehicle-model-badge{font-size:.75rem;color:var(--text-secondary);background:var(--bg-secondary);padding:.2rem .5rem;border-radius:4px;width:fit-content}.vehicle-badges-row{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.vehicle-status-badge{display:flex;align-items:center;gap:.5rem;padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:500}.status-success{background:#10b98126;color:var(--success-color)}.status-warning{background:#f59e0b26;color:var(--warning-color)}.status-error{background:#ef444426;color:var(--error-color)}.vehicle-expand-btn{color:var(--text-secondary);padding:.5rem;transition:transform .3s ease}.vehicle-row.expanded .vehicle-expand-btn{transform:rotate(180deg)}.vehicle-expanded-content{padding:0 1.5rem 1.5rem;border-top:1px solid var(--border-color);animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.details-loading{display:flex;align-items:center;justify-content:center;gap:1rem;padding:2rem;color:var(--text-secondary)}.loading-spinner.small{width:24px;height:24px}.summary-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-top:1rem}.summary-stat-card{display:flex;align-items:center;gap:.75rem;padding:1rem;background:var(--bg-secondary);border-radius:10px;border:1px solid var(--border-color)}.stat-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:10px;background:var(--bg-primary);color:var(--text-secondary);flex-shrink:0}.stat-icon.battery{color:var(--success-color)}.stat-icon.charging{color:var(--warning-color)}.stat-icon.charging.active{color:var(--success-color);background:#10b9811a}.stat-icon.climate{color:#60a5fa}.stat-icon.climate.active{color:#f97316;background:#f973161a}.stat-icon.lock.locked{color:var(--success-color)}.stat-icon.lock.unlocked{color:var(--warning-color)}.stat-icon.location{color:var(--primary-color)}.stat-icon.software{color:#a78bfa}.stat-content{display:flex;flex-direction:column;gap:.125rem;flex:1;min-width:0}.stat-value{font-size:1rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stat-value.small-text{font-size:.875rem}.stat-value.location-text{text-transform:capitalize}.stat-label{font-size:.75rem;color:var(--text-secondary)}.stat-extra{font-size:.75rem;color:var(--text-secondary);text-align:right;flex-shrink:0}.stat-extra.highlight{color:var(--primary-color);font-weight:500}.quick-info-bar{display:flex;flex-wrap:wrap;gap:1.5rem;padding:1rem 0;margin-top:1rem;border-top:1px solid var(--border-color)}.quick-info-item{display:flex;gap:.5rem;font-size:.875rem}.quick-label{color:var(--text-secondary)}.quick-value{color:var(--text-primary);font-weight:500}.vehicle-actions{display:flex;justify-content:flex-end;padding-top:1rem}.view-details-btn{padding:.75rem 1.5rem}.details-error{display:flex;align-items:center;gap:.75rem;padding:1.5rem;background:#ef44441a;border-radius:8px;color:var(--text-secondary);margin-top:1rem}.details-error svg{color:var(--error-color);flex-shrink:0}.details-error span{flex:1}.empty-state{text-align:center;padding:4rem 2rem}.empty-icon{font-size:4rem;margin-bottom:1rem}.empty-state h3{font-size:1.25rem;margin-bottom:.5rem}.empty-state p{color:var(--text-secondary)}@media (max-width: 1024px){.summary-stats-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 768px){.dashboard .page-header{flex-direction:column;align-items:stretch}.dashboard .page-header .btn{width:100%;justify-content:center}.vehicle-row-header{padding:1rem;flex-wrap:nowrap;gap:.75rem}.vehicle-main-info{width:auto;margin-bottom:0;flex:1;min-width:0}.vehicle-expand-btn{padding:.25rem}.summary-stats-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}.summary-stat-card{padding:.75rem}.stat-icon{width:36px;height:36px}.quick-info-bar{flex-direction:column;gap:.5rem}.vehicle-actions{justify-content:stretch}.view-details-btn{width:100%;justify-content:center}}@media (max-width: 480px){.vehicle-emoji-icon{font-size:2rem}.vehicle-name{font-size:1rem}.summary-stats-grid{grid-template-columns:1fr}.vehicle-expanded-content{padding:0 1rem 1rem}}.vehicle-detail{min-height:calc(100vh - 4rem);padding-bottom:2rem}.detail-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.header-info{flex:1}.header-actions{display:flex;gap:.75rem}.btn.loading{opacity:.7;cursor:wait}.detail-content{display:flex;flex-direction:column;gap:1rem}.status-overview{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:.5rem}.status-card{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px}.status-card.primary{background:linear-gradient(135deg,var(--primary-color),#2563eb);border:none;color:#fff}.status-card.primary .status-label,.status-card.primary .status-extra{color:#fffc}.status-icon{width:50px;height:50px;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);border-radius:12px;color:var(--primary-color);flex-shrink:0}.status-card.primary .status-icon{background:#fff3;color:#fff}.status-info{display:flex;flex-direction:column;min-width:0}.status-value{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.status-card.primary .status-value{color:#fff}.status-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.status-extra{font-size:.8rem;color:var(--text-secondary);margin-top:.25rem}.control-section{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;overflow:hidden}.section-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;cursor:pointer;transition:background .2s}.section-header:hover{background:var(--bg-secondary)}.section-title{display:flex;align-items:center;gap:.75rem;font-weight:600;color:var(--text-primary)}.section-status{display:flex;align-items:center;gap:.75rem;color:var(--text-secondary)}.status-badge{padding:.3rem .75rem;border-radius:20px;font-size:.75rem;font-weight:500;background:var(--bg-secondary);color:var(--text-secondary)}.status-badge.active{background:#10b98126;color:var(--success-color)}.status-badge.warning{background:#f59e0b26;color:var(--warning-color)}.section-content{padding:0 1.25rem 1.25rem;border-top:1px solid var(--border-color)}.control-row{display:flex;justify-content:space-between;align-items:center;padding:1rem 0;border-bottom:1px solid var(--border-color);gap:1rem}.control-row:last-child{border-bottom:none}.control-info{flex:1;min-width:0}.control-label{display:block;font-weight:500;color:var(--text-primary);margin-bottom:.25rem}.control-value{font-size:.875rem;color:var(--text-secondary)}.control-actions{display:flex;gap:.5rem;flex-shrink:0}.control-actions.multi{flex-wrap:wrap;justify-content:flex-end}.control-btn{padding:.5rem 1rem;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.375rem}.control-btn:hover:not(:disabled){border-color:var(--primary-color);color:var(--primary-color)}.control-btn:disabled{opacity:.5;cursor:not-allowed}.control-btn.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.control-btn.toggle.active{background:#10b98126;border-color:var(--success-color);color:var(--success-color)}.control-btn.loading{opacity:.7;pointer-events:none}.control-btn.success{background:#10b98126;border-color:var(--success-color);color:var(--success-color)}.control-btn.error{background:#ef444426;border-color:var(--error-color);color:var(--error-color)}.seat-controls{display:flex;align-items:center;gap:.375rem;font-size:.8rem;color:var(--text-secondary)}.seat-btn{padding:.375rem .625rem;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-secondary);color:var(--text-primary);font-size:.75rem;cursor:pointer;transition:all .2s}.seat-btn:hover{border-color:var(--primary-color)}.seat-btn.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.slider-control{display:flex;align-items:center;gap:.75rem;margin-top:.5rem}.slider{flex:1;height:6px;border-radius:3px;background:var(--bg-secondary);-webkit-appearance:none;-moz-appearance:none;appearance:none}.slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:var(--primary-color);cursor:pointer}.slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--primary-color);cursor:pointer;border:none}.slider-value{font-weight:600;min-width:40px;text-align:right}.charging-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1rem;padding:1rem 0;border-bottom:1px solid var(--border-color)}.stat-item{text-align:center}.stat-item .stat-label{display:block;font-size:.75rem;color:var(--text-secondary);margin-bottom:.25rem}.stat-item .stat-value{font-size:1.125rem;font-weight:600;color:var(--text-primary)}.quick-controls-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.75rem;padding:1rem 0;border-bottom:1px solid var(--border-color)}.quick-controls-grid .control-btn{flex-direction:column;padding:1rem;text-align:center}.quick-controls-grid .control-btn span{margin-top:.5rem;font-size:.8rem}.software-info{padding:1rem 0;border-bottom:1px solid var(--border-color)}.info-row{display:flex;justify-content:space-between;padding:.5rem 0}.info-label{color:var(--text-secondary)}.info-value{font-weight:500;color:var(--text-primary)}.error-banner{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:10px;color:var(--error-color);margin-bottom:1.5rem}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1rem}@media (max-width: 768px){.detail-header{flex-direction:column;align-items:flex-start}.header-actions{width:100%}.header-actions .btn{flex:1;justify-content:center}.status-overview{grid-template-columns:repeat(2,1fr)}.control-row{flex-direction:column;align-items:flex-start}.control-actions{width:100%;justify-content:flex-start;flex-wrap:wrap}.control-actions.multi{justify-content:flex-start}.seat-controls{width:100%;justify-content:space-between}.quick-controls-grid,.charging-stats{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.status-overview{grid-template-columns:1fr}.status-card{padding:1rem}.quick-controls-grid{grid-template-columns:repeat(2,1fr)}.quick-controls-grid .control-btn{padding:.75rem}.charging-stats{grid-template-columns:repeat(2,1fr)}}.battery-health-section .section-content{display:flex;flex-direction:column;gap:1.5rem}.battery-gauges{display:flex;justify-content:center;gap:2rem;flex-wrap:wrap;padding:1rem 0}.gauge-container{display:flex;flex-direction:column;align-items:center;gap:.5rem}.circular-gauge{position:relative;display:flex;align-items:center;justify-content:center}.circular-gauge svg{width:100%;height:100%}.gauge-content{position:absolute;display:flex;flex-direction:column;align-items:center;justify-content:center}.gauge-value{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.gauge-label{font-size:.7rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.gauge-subtitle{font-size:.75rem;color:var(--text-secondary);text-align:center}.battery-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}.battery-stat-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:1rem}.stat-header{display:flex;align-items:center;gap:.5rem;color:var(--text-primary);font-weight:600;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-color)}.stat-body{display:flex;flex-direction:column;gap:.5rem}.stat-row{display:flex;justify-content:space-between;align-items:center;font-size:.875rem}.stat-row span:first-child{color:var(--text-secondary)}.stat-value{font-weight:600;color:var(--text-primary)}.stat-value.highlight{color:var(--primary-color)}.stat-value.good{color:#22c55e}.range-comparison{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:1rem}.comparison-title{font-size:.875rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem}.range-bars{display:flex;flex-direction:column;gap:.75rem}.range-bar-item{display:flex;flex-direction:column;gap:.25rem}.range-bar-label{display:flex;justify-content:space-between;font-size:.75rem}.range-bar-label span:first-child{color:var(--text-secondary)}.range-bar-label span:last-child{font-weight:600;color:var(--text-primary)}.range-bar-track{height:8px;background:var(--border-color);border-radius:4px;overflow:hidden}.range-bar-fill{height:100%;border-radius:4px;transition:width .5s ease}.range-bar-fill.epa{background:linear-gradient(90deg,#6366f1,#8b5cf6)}.range-bar-fill.ideal{background:linear-gradient(90deg,#22c55e,#16a34a)}.range-bar-fill.estimated{background:linear-gradient(90deg,#f59e0b,#d97706)}.range-bar-fill.rated{background:linear-gradient(90deg,#3b82f6,#2563eb)}.current-range-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.75rem}.range-stat{display:flex;flex-direction:column;align-items:center;padding:.75rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px}.range-stat-label{font-size:.7rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.range-stat-value{font-size:1.1rem;font-weight:600;color:var(--text-primary)}@media (max-width: 640px){.battery-gauges{gap:1rem}.gauge-container{flex:1;min-width:100px}.circular-gauge{width:100px!important;height:100px!important}.gauge-value{font-size:1.2rem}.battery-stats-grid{grid-template-columns:1fr}.current-range-stats{grid-template-columns:repeat(2,1fr)}}.spinning{animation:spin 1s linear infinite}.btn.refreshing{opacity:.7;cursor:not-allowed}.vehicle-card{cursor:pointer;transition:all .3s ease}.vehicle-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px #0000004d}.vehicle-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.25rem}.vehicle-name{font-size:1.25rem;font-weight:600;margin-bottom:.25rem}.vehicle-vin{font-size:.75rem;color:var(--text-muted);font-family:monospace}.vehicle-card-body{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.vehicle-image{width:120px;height:80px;display:flex;align-items:center;justify-content:center;background:var(--background-card-hover);border-radius:10px}.vehicle-emoji{font-size:3rem}.vehicle-quick-stats{display:flex;flex-direction:column;gap:.75rem}.quick-stat{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary);font-size:.875rem}.vehicle-card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:1rem;border-top:1px solid var(--border-color)}.vehicle-model{font-size:.8125rem;font-weight:500;color:var(--text-secondary)}.tap-hint{font-size:.75rem;color:var(--primary-color)}.charging-page{padding:2rem}.charging-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.charging-card{background:linear-gradient(135deg,#1e1e2e,#2d2d44);border-radius:16px;padding:1.5rem;border:1px solid rgba(255,255,255,.1)}.charging-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.charging-card-header h3{font-size:1.25rem;font-weight:600;color:#fff;margin:0}.charging-status-badge{padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;color:#fff}.vehicle-offline{text-align:center;padding:2rem;color:#9ca3af}.charging-details{display:flex;flex-direction:column;gap:1.5rem}.charge-level{display:flex;align-items:center;gap:1rem}.battery-visual{flex:1;height:24px;background:#ffffff1a;border-radius:12px;overflow:hidden}.battery-fill{height:100%;border-radius:12px;transition:width .3s ease}.battery-percent{font-size:1.5rem;font-weight:700;color:#fff;min-width:60px;text-align:right}.charging-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.stat{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:#ffffff0d;border-radius:8px}.stat svg{color:#e879f9}.stat>div{display:flex;flex-direction:column}.stat-value{font-size:1rem;font-weight:600;color:#fff}.stat-label{font-size:.75rem;color:#9ca3af}.retry-btn{margin-top:1rem;padding:.5rem 1rem;background:#e879f9;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:500}.retry-btn:hover{background:#d946ef}.refresh-btn{padding:.5rem 1rem;background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2);border-radius:8px;cursor:pointer;font-weight:500;display:flex;align-items:center;gap:.5rem;transition:all .2s}@media (max-width: 768px){.charging-page{padding:1rem}.page-header{flex-direction:column;align-items:flex-start;gap:1rem}.charging-grid,.charging-stats{grid-template-columns:1fr}}.location-page{padding:2rem}.location-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:1.5rem}.location-card{background:linear-gradient(135deg,#1e1e2e,#2d2d44);border-radius:16px;padding:1.5rem;border:1px solid rgba(255,255,255,.1)}.location-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.location-card-header h3{font-size:1.25rem;font-weight:600;color:#fff;margin:0}.status-badge{padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;color:#fff}.status-badge.online{background:#22c55e}.status-badge.asleep,.status-badge.offline{background:#6b7280}.vehicle-offline{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;color:#9ca3af;text-align:center}.vehicle-offline svg{margin-bottom:1rem;opacity:.5}.vehicle-offline p{margin:0;font-size:1rem}.vehicle-offline small{display:block;margin-top:.5rem;font-size:.875rem;opacity:.7}.location-details{display:flex;flex-direction:column;gap:1rem}.location-map-placeholder{background:#ffffff0d;border-radius:12px;padding:3rem;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;border:2px dashed rgba(255,255,255,.2)}.location-map-placeholder:hover{background:#ffffff1a;border-color:#e879f9}.location-map-placeholder svg{color:#e879f9;margin-bottom:.5rem}.location-map-placeholder span{color:#9ca3af;font-size:.875rem}.location-info{display:flex;flex-direction:column;gap:.75rem}.info-row{display:flex;align-items:center;gap:.75rem;color:#d1d5db;font-size:.875rem}.info-row svg{color:#e879f9;flex-shrink:0}.maps-btn{width:100%;padding:.75rem;background:linear-gradient(135deg,#e879f9,#8b5cf6);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.maps-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #e879f94d}.loading-container,.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;color:#9ca3af}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.refresh-btn{padding:.5rem 1rem;background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2);border-radius:8px;cursor:pointer;font-weight:500}.refresh-btn:hover{background:#ffffff26}.retry-btn{margin-top:1rem;padding:.5rem 1rem;background:#e879f9;color:#fff;border:none;border-radius:8px;cursor:pointer}@media (max-width: 768px){.location-page{padding:1rem}.location-grid{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:flex-start;gap:1rem}}.settings-page{padding:2rem;max-width:800px}.page-header h1{font-size:2rem;font-weight:600;color:#fff;margin:0}.page-header .subtitle{color:#9ca3af;margin-top:.25rem}.settings-sections{display:flex;flex-direction:column;gap:2rem}.settings-section h2{font-size:1rem;font-weight:600;color:#9ca3af;margin:0 0 1rem;display:flex;align-items:center;gap:.5rem;text-transform:uppercase;letter-spacing:.05em}.settings-card{background:linear-gradient(135deg,#1e1e2e,#2d2d44);border-radius:16px;border:1px solid rgba(255,255,255,.1);overflow:hidden}.setting-item{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid rgba(255,255,255,.05)}.setting-item:last-child{border-bottom:none}.setting-info h3{font-size:1rem;font-weight:600;color:#fff;margin:0}.setting-info p{font-size:.875rem;color:#9ca3af;margin:.25rem 0 0}.logout-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#ef44441a;color:#ef4444;border:1px solid rgba(239,68,68,.3);border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s}.logout-btn:hover{background:#ef444433}.github-link{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2);border-radius:8px;text-decoration:none;font-weight:500;font-size:.875rem;transition:all .2s}.github-link:hover{background:#ffffff26}@media (max-width: 768px){.settings-page{padding:1rem}.setting-item{flex-direction:column;align-items:flex-start;gap:1rem}}.sidebar{position:fixed;left:0;top:0;bottom:0;width:250px;background:var(--background-card);border-right:1px solid var(--border-color);display:flex;flex-direction:column;z-index:100;transition:transform .3s ease}.sidebar-header{padding:1.5rem;border-bottom:1px solid var(--border-color)}.logo{display:flex;align-items:center;justify-content:center}.logo-img{width:210px;height:auto;object-fit:contain}.sidebar-nav{flex:1;padding:1rem .75rem;display:flex;flex-direction:column;gap:.25rem}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:8px;color:var(--text-secondary);text-decoration:none;font-size:.875rem;font-weight:500;transition:all .2s ease;cursor:pointer;border:none;background:transparent;width:100%;text-align:left}.nav-item:hover{background:var(--background-card-hover);color:var(--text-primary)}.nav-item.active{background:#e8212726;color:var(--primary-color)}.sidebar-footer{padding:1rem .75rem;border-top:1px solid var(--border-color)}.logout-btn{color:var(--text-secondary)}.logout-btn:hover{background:#ef444426;color:var(--error-color)}.version-display{text-align:center;font-size:.75rem;color:var(--text-muted, #666);padding-top:.75rem;opacity:.7}.mobile-menu-btn{display:none;position:fixed;top:1rem;left:1rem;z-index:101;padding:.5rem;background:var(--background-card);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);cursor:pointer}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:99}@media (max-width: 768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.mobile-menu-btn{display:flex}.sidebar-overlay{display:block}}:root{--primary-color: #e82127;--primary-dark: #c91b20;--background-dark: #0f0f23;--background-card: #1a1a2e;--background-card-hover: #252542;--text-primary: #ffffff;--text-secondary: #a0a0b2;--text-muted: #6b6b80;--border-color: #2a2a4a;--success-color: #10b981;--warning-color: #f59e0b;--error-color: #ef4444;--info-color: #3b82f6;--card-bg: var(--background-card);--bg-secondary: var(--background-card-hover);--bg-primary: var(--background-dark)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background-color:var(--background-dark);color:var(--text-primary);line-height:1.6;min-height:100vh}#root{min-height:100vh}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:1rem}.loading-spinner{width:48px;height:48px;border:4px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.app-layout{display:flex;min-height:100vh}.main-content{flex:1;padding:2rem;margin-left:250px;transition:margin-left .3s ease}@media (max-width: 768px){.main-content{margin-left:0;padding:1rem}.page-header h1.page-title{margin-left:3rem}}.card{background:var(--background-card);border-radius:12px;padding:1.5rem;border:1px solid var(--border-color);transition:all .3s ease}.card:hover{background:var(--background-card-hover);border-color:var(--primary-color)}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.card-title{font-size:1.125rem;font-weight:600}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:8px;font-weight:500;font-size:.875rem;cursor:pointer;transition:all .2s ease;border:none;text-decoration:none}.btn-primary{background:var(--primary-color);color:#fff}.btn-primary:hover{background:var(--primary-dark);transform:translateY(-1px)}.btn-secondary{background:var(--background-card);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--background-card-hover);border-color:var(--primary-color)}.btn-icon{padding:.5rem;border-radius:8px;background:transparent;color:var(--text-secondary);border:1px solid var(--border-color)}.btn-icon:hover{background:var(--background-card-hover);color:var(--text-primary)}.badge{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:500}.badge-success{background:#22c55e26;color:var(--success-color)}.badge-warning{background:#f59e0b26;color:var(--warning-color)}.badge-error{background:#ef444426;color:var(--error-color)}.badge-info{background:#3b82f626;color:var(--info-color)}.grid{display:grid;gap:1.5rem}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}@media (max-width: 1024px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}@media (max-width: 640px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}.page-header{margin-bottom:2rem}.page-title{font-size:1.875rem;font-weight:700;margin-bottom:.5rem}.page-subtitle{color:var(--text-secondary);font-size:.875rem}.metric-card{display:flex;flex-direction:column;gap:.5rem}.metric-label{color:var(--text-secondary);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em}.metric-value{font-size:1.75rem;font-weight:700}.metric-unit{font-size:.875rem;color:var(--text-secondary);margin-left:.25rem}.progress-bar{height:8px;background:var(--border-color);border-radius:4px;overflow:hidden}.progress-fill{height:100%;border-radius:4px;transition:width .5s ease}.progress-fill.success{background:linear-gradient(90deg,var(--success-color),#4ade80)}.progress-fill.warning{background:linear-gradient(90deg,var(--warning-color),#fbbf24)}.progress-fill.error{background:linear-gradient(90deg,var(--error-color),#f87171)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--background-dark)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.error-message{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center;gap:1rem}.error-message svg{color:var(--error-color)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;gap:1rem;color:var(--text-secondary)}
