*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-deep: #05050e;--bg-base: #09091a;--bg-surface: #0e0e1f;--bg-card: #121224;--bg-card-hover: #16162c;--bg-elevated: #121224;--bg-input: #0c0c1e;--bg-modal: #111122;--border-subtle: rgba(255,255,255,.05);--border-normal: rgba(255,255,255,.09);--border-strong: rgba(255,255,255,.14);--border-focus: rgba(120,100,255,.55);--border: rgba(255,255,255,.09);--text-primary: #eeeef8;--text-secondary: #8080b4;--text-muted: #4a4a70;--text-inverse: #09091a;--text: #eeeef8;--accent: #7c64f7;--accent-hover: #9178ff;--accent-dim: rgba(124,100,247,.14);--accent-glow: 0 0 24px rgba(124,100,247,.28);--success: #34d39a;--success-dim: rgba(52,211,154,.13);--warning: #f5a623;--warning-dim: rgba(245,166,35,.13);--danger: #f04455;--danger-dim: rgba(240,68,85,.13);--oil-color: #f5a623;--brake-color: #f04455;--custom-color: #7c64f7;--card-accent: #7c64f7;--font-mono: "JetBrains Mono", monospace;--tick-x: 0%;--tick-y: 0%;--tick-rot: 0deg;--tick-alpha: .05;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 22px;--radius: 10px;--shadow-card: 0 4px 24px rgba(0,0,0,.45);--shadow-modal: 0 20px 60px rgba(0,0,0,.7);--transition: .18s ease}.ui-panel{background:#121224d1;border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:0 12px 38px #0000003d}.ui-section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:16px}.ui-section-head h2,.ui-section-head h3{margin:0}.ui-muted{color:var(--text-muted)}.ui-subtle{color:var(--text-secondary)}.ui-icon-button{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border-radius:var(--radius-sm)}.ui-kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}.service-glyph{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}html{scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-feature-settings:"cv11","ss01";font-variation-settings:"opsz" 14;background-color:var(--bg-base);color:var(--text-primary);line-height:1.5;-webkit-font-smoothing:antialiased;min-height:100vh}a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,[tabindex]:focus-visible{outline:2px solid var(--accent-hover);outline-offset:2px}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.001ms!important}}.app-background{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;overflow:hidden;background:linear-gradient(180deg,rgba(124,100,247,.035) 0%,transparent 34%),linear-gradient(145deg,#09091a,#070714 48%,#05050e)}.background-grid{position:absolute;top:0;right:0;bottom:0;left:0;opacity:.18;background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);background-size:72px 72px;-webkit-mask-image:linear-gradient(to bottom,rgba(0,0,0,.8),transparent 78%);mask-image:linear-gradient(to bottom,rgba(0,0,0,.8),transparent 78%)}.road-mark{position:absolute;width:860px;max-width:80vw;height:auto;color:var(--accent);opacity:.12;filter:drop-shadow(0 0 24px rgba(124,100,247,.16))}.road-mark-primary{top:-92px;right:-120px;transform:rotate(-8deg)}.road-mark-secondary{bottom:-170px;left:-180px;transform:rotate(172deg) scale(.74);opacity:.07}.road-mark path{fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round}.road-mark-edge{stroke-width:3;opacity:.5}.road-mark-center{stroke-width:2;opacity:.26}.road-mark-dash{stroke-width:14;opacity:.36}.road-mark-dash-left,.road-mark-dash-right{stroke-width:9;opacity:.26}.background-ticks{position:absolute;top:0;right:0;bottom:0;left:0}.background-ticks span{position:absolute;left:var(--tick-x);top:var(--tick-y);width:28px;height:2px;background:rgba(238,238,248,var(--tick-alpha));border-radius:99px;transform:rotate(var(--tick-rot))}.background-watermark{position:absolute;right:clamp(24px,8vw,120px);bottom:clamp(28px,9vw,120px);font-size:clamp(4rem,14vw,11rem);font-weight:800;letter-spacing:0;color:#ffffff07;line-height:1;-webkit-user-select:none;user-select:none}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}h1{font-size:1.75rem;font-weight:700;letter-spacing:-.02em}h2{font-size:1.375rem;font-weight:600;letter-spacing:-.015em}h3{font-size:1.125rem;font-weight:600}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:var(--radius-md);font-family:inherit;font-size:.875rem;font-weight:500;cursor:pointer;border:none;transition:all var(--transition);white-space:nowrap;text-decoration:none}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff;box-shadow:0 2px 12px #7c64f759}.btn-primary:hover:not(:disabled){background:var(--accent-hover);box-shadow:var(--accent-glow);transform:translateY(-1px)}.btn-secondary{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border-normal)}.btn-secondary:hover:not(:disabled){background:var(--bg-card-hover);border-color:var(--border-strong)}.btn-ghost{background:transparent;color:var(--text-secondary);padding:8px 12px}.btn-ghost:hover:not(:disabled){background:var(--bg-card);color:var(--text-primary)}.btn-danger{background:var(--danger-dim);color:var(--danger);border:1px solid rgba(240,68,85,.2)}.btn-danger:hover:not(:disabled){background:var(--danger);color:#fff;border-color:var(--danger)}.btn-sm{padding:6px 14px;font-size:.8125rem}.btn-lg{padding:13px 28px;font-size:1rem}.btn-icon{padding:8px;border-radius:var(--radius-sm)}.btn-full{width:100%;justify-content:center}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:.8125rem;font-weight:500;color:var(--text-secondary);letter-spacing:.02em}.form-input,.form-select,.form-textarea{background:var(--bg-input);border:1px solid var(--border-normal);border-radius:var(--radius-md);color:var(--text-primary);font-family:inherit;font-size:.9375rem;padding:11px 14px;transition:border-color var(--transition),box-shadow var(--transition);outline:none;width:100%}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-muted)}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px #7c64f71f}.form-select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}.form-select option{background:var(--bg-modal)}.form-textarea{resize:vertical;min-height:80px}.form-hint{font-size:.75rem;color:var(--text-muted);margin-top:2px}.input-mono{font-family:JetBrains Mono,monospace;letter-spacing:.04em;font-size:.875rem}.card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-card)}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}.auth-container{width:100%;max-width:420px}.auth-logo{text-align:center;margin-bottom:36px}.auth-logo-mark{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;background:var(--accent-dim);border:1px solid rgba(124,100,247,.25);border-radius:var(--radius-lg);margin-bottom:16px}.auth-logo h1{font-size:1.5rem;background:linear-gradient(135deg,#fff 0%,var(--text-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-logo p{color:var(--text-muted);font-size:.8125rem;margin-top:4px}.auth-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:32px;box-shadow:var(--shadow-modal)}.auth-card h2{margin-bottom:6px}.auth-card .auth-subtitle{color:var(--text-secondary);font-size:.875rem;margin-bottom:28px}.auth-form{display:flex;flex-direction:column;gap:18px}.auth-divider{text-align:center;position:relative;color:var(--text-muted);font-size:.8125rem;margin:4px 0}.auth-divider:before,.auth-divider:after{content:"";position:absolute;top:50%;width:calc(50% - 24px);height:1px;background:var(--border-subtle)}.auth-divider:before{left:0}.auth-divider:after{right:0}.auth-switch{text-align:center;font-size:.875rem;color:var(--text-secondary);margin-top:20px}.auth-switch a{color:var(--accent);text-decoration:none;font-weight:500}.auth-switch a:hover{text-decoration:underline}.auth-feedback{margin-bottom:18px}.auth-centered-panel{flex:1}.auth-action-gap{margin-top:8px}.auth-success-positive{color:var(--success)}.auth-legal-consent{align-items:flex-start;padding:12px 13px;border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:#0c0c1e73;line-height:1.5}.auth-legal-consent a{color:var(--accent);font-weight:600;text-decoration:none}.auth-legal-consent a:hover{text-decoration:underline}.auth-legal-footer{display:flex;justify-content:center;flex-wrap:wrap;gap:8px;margin-top:22px;font-size:.78rem;color:var(--text-muted)}.auth-legal-footer a{color:var(--text-muted);text-decoration:none}.auth-legal-footer a:hover{color:var(--accent)}.navbar{position:sticky;top:0;z-index:100;background:#09091a8c;backdrop-filter:blur(24px) saturate(1.4);-webkit-backdrop-filter:blur(24px) saturate(1.4);padding:0 24px;height:60px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 1px #ffffff0e,0 4px 24px #00000059}.navbar:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,rgba(124,100,247,.5) 30%,rgba(52,211,154,.25) 70%,transparent 100%)}.navbar-brand{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--text-primary)}.navbar-brand-mark{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:#05050e59;border:1px solid rgba(124,100,247,.28);border-radius:8px;overflow:hidden;box-shadow:0 0 18px #7c64f729}.navbar-brand-mark img{width:100%;height:100%;object-fit:cover}.navbar-brand-name{font-weight:700;font-size:1rem;letter-spacing:.06em}.navbar-right{display:flex;align-items:center;gap:12px}.desktop-notifications{display:flex;align-items:center}.navbar-user{font-size:.875rem;color:var(--text-secondary)}.navbar-user span{color:var(--text-primary);font-weight:500}.mobile-bottom-nav{display:none}.page{max-width:1080px;margin:0 auto;padding:36px 24px}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:32px;gap:16px}.page-header-text h1{margin-bottom:4px}.page-header-text p{color:var(--text-secondary);font-size:.9375rem}.vehicle-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.analytics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin:-12px 0 28px}.analytics-card{background:#121224b8;border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:14px;display:grid;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:10px;min-height:76px}.analytics-card-icon{width:34px;height:34px;border-radius:var(--radius-sm);background:var(--accent-dim);display:flex;align-items:center;justify-content:center;color:var(--accent);flex-shrink:0;grid-row:span 2}.analytics-card-warn .analytics-card-icon{background:var(--warning-dim);color:var(--warning)}.analytics-card-danger .analytics-card-icon{background:var(--danger-dim);color:var(--danger)}.analytics-card span{grid-column:2;display:block;color:var(--text-muted);font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.analytics-card strong{display:block;grid-column:2;font-size:1.75rem;font-weight:700;letter-spacing:-.02em;line-height:1;color:var(--text-primary)}.analytics-card-warn strong{color:var(--warning)}.analytics-card-danger strong{color:var(--danger)}.vehicle-card{background:linear-gradient(180deg,#121224eb,#0e0e1fdb);border:1px solid var(--border-subtle);border-left:3px solid var(--card-accent, var(--accent));border-radius:var(--radius-lg);padding:0;transition:all var(--transition);display:block;position:relative;overflow:hidden;box-shadow:0 8px 28px #0000003d}.vehicle-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,var(--card-accent, var(--accent)) 0%,transparent 55%);opacity:0;transition:opacity var(--transition)}.vehicle-card:hover{transform:translateY(-2px);border-color:#ffffff1a;box-shadow:0 16px 42px #00000057,0 0 0 1px #ffffff0a}.vehicle-card:hover:before{opacity:.07}.vehicle-card-main{display:block;padding:22px 22px 16px;color:inherit;text-decoration:none;position:relative;z-index:1}.vehicle-card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:14px}.vehicle-card-title-row{display:flex;align-items:center;gap:14px;min-width:0}.vehicle-card-badges{display:flex;flex-direction:column;align-items:flex-end;gap:6px;flex-shrink:0}.vehicle-year{font-size:.75rem;font-weight:600;letter-spacing:.08em;color:var(--accent);text-transform:uppercase;margin-bottom:4px}.vehicle-name{font-size:1.1875rem;font-weight:700;color:var(--text-primary);line-height:1.2}.vehicle-nickname{font-size:.8125rem;color:var(--text-secondary);margin-top:2px}.vehicle-card-arrow{color:var(--text-muted);transition:color var(--transition),transform var(--transition);flex-shrink:0}.vehicle-card:hover .vehicle-card-arrow{color:var(--accent);transform:translate(3px)}.vehicle-vin-row{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--bg-deep);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);margin-bottom:16px}.vehicle-card-status{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}.vehicle-card-status>div{min-width:0;padding:10px 12px;background:#05050e52;border:1px solid var(--border-subtle);border-radius:var(--radius-sm)}.vehicle-status-label{display:block;color:var(--text-muted);font-size:.6875rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;margin-bottom:5px}.vehicle-card-status strong{display:block;color:var(--text-primary);font-size:.8125rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vehicle-card-status span:not(.vehicle-status-label){display:block;color:var(--text-secondary);font-size:.75rem;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vehicle-vin-label{font-size:.6875rem;font-weight:600;letter-spacing:.08em;color:var(--text-muted);text-transform:uppercase;flex-shrink:0}.vehicle-vin-value{font-family:JetBrains Mono,monospace;font-size:.75rem;color:var(--text-secondary);letter-spacing:.04em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vehicle-card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:14px;border-top:1px solid var(--border-subtle)}.vehicle-last-service{font-size:.8125rem}.vehicle-last-service-label{color:var(--text-muted);margin-bottom:2px;font-size:.75rem}.vehicle-last-service-value{color:var(--text-secondary);font-weight:500}.health-ok{color:var(--success)!important}.health-warn{color:var(--warning)!important}.health-danger{color:var(--danger)!important}.vehicle-record-count{display:flex;align-items:center;gap:6px;font-size:.8125rem;color:var(--text-muted)}.record-badge{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 6px;background:var(--accent-dim);color:var(--accent);border-radius:99px;font-size:.75rem;font-weight:600}.vehicle-card-quick-log{display:flex;align-items:center;justify-content:center;width:30px;height:30px;padding:0;background:#7c64f71a;border:1px solid rgba(124,100,247,.2);border-radius:var(--radius-sm);color:var(--accent);font-size:.8125rem;font-weight:500;cursor:pointer;transition:background var(--transition),color var(--transition),border-color var(--transition);font-family:inherit;letter-spacing:.01em}.vehicle-card-action-row{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px 12px 18px;margin:0 14px 14px;border-top:1px solid var(--border-subtle);color:var(--text-muted);font-size:.78rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.vehicle-card-quick-log:hover{background:var(--accent-dim);color:var(--accent);border-color:#7c64f747}.empty-state{grid-column:1 / -1;text-align:center;padding:72px 48px;border:2px dashed rgba(124,100,247,.28);border-radius:20px;background:radial-gradient(ellipse at 50% 0%,rgba(124,100,247,.07) 0%,transparent 68%);position:relative;overflow:hidden}.empty-car-wrap{position:relative;display:inline-flex;align-items:center;justify-content:center;width:96px;height:96px;margin-bottom:28px}.empty-car-glow{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;background:radial-gradient(circle,rgba(124,100,247,.22) 0%,transparent 72%);filter:blur(8px)}.empty-car-icon{position:relative;display:flex;align-items:center;justify-content:center;width:80px;height:80px;background:var(--bg-card);border:1.5px solid rgba(124,100,247,.3);border-radius:50%;color:var(--accent);box-shadow:0 0 0 8px #7c64f70f}.empty-headline{font-size:1.625rem;font-weight:700;color:var(--text-primary);letter-spacing:-.025em;margin-bottom:12px}.empty-sub{color:var(--text-secondary);font-size:.9375rem;line-height:1.65;max-width:380px;margin:0 auto 32px}.empty-features{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-bottom:36px}.empty-feature{display:flex;align-items:center;gap:7px;padding:6px 14px;background:#7c64f712;border:1px solid rgba(124,100,247,.18);border-radius:99px;font-size:.8125rem;color:var(--text-secondary)}.empty-feature svg{color:var(--accent);flex-shrink:0}.vehicle-detail-header{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:28px;margin-bottom:28px;box-shadow:var(--shadow-card)}.insights-panel{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px;margin:-12px 0 28px}.insight-item{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:14px 16px;min-width:0}.insight-item span{display:block;color:var(--text-muted);font-size:.6875rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;margin-bottom:5px}.insight-item strong{display:block;color:var(--text-primary);font-size:.98rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.insight-item small{display:block;color:var(--text-secondary);font-size:.75rem;margin-top:2px}.section-kicker{display:block;color:var(--accent);font-size:.6875rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;margin-bottom:4px}.mileage-panel{background:linear-gradient(135deg,#111122f5,#0d0e1feb);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:22px;margin:0 0 28px;box-shadow:var(--shadow-card);overflow:hidden}.mileage-panel-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px}.mileage-panel-header h2{font-size:1.125rem;margin:0}.mileage-panel-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}.mileage-latest{color:var(--text-secondary);font-size:.8125rem;font-weight:700}.mileage-chart-shell{position:relative;min-height:260px;border:1px solid rgba(124,100,247,.12);border-radius:var(--radius-md);background:linear-gradient(90deg,rgba(125,211,252,.04) 1px,transparent 1px),linear-gradient(0deg,rgba(125,211,252,.035) 1px,transparent 1px),#07081457;background-size:44px 44px;overflow:hidden}.mileage-chart{display:block;width:100%;height:auto;min-height:240px}.mileage-grid-line{stroke:#ffffff14;stroke-width:1}.mileage-axis-line{stroke:#ffffff2e;stroke-width:1}.mileage-axis-label{fill:var(--text-muted);font-size:11px;font-weight:600}.mileage-line{fill:none;stroke:url(#mileageLine);stroke-width:3;stroke-linecap:round;stroke-linejoin:round}.mileage-single-line{stroke:#a855f75c;stroke-width:2;stroke-dasharray:6 7}.mileage-point-group{outline:none;cursor:pointer}.mileage-point-halo{fill:transparent}.mileage-point{stroke:#ffffffc7;stroke-width:2;transition:transform var(--transition),filter var(--transition);transform-origin:center}.mileage-point-group.maintenance .mileage-point{fill:#7dd3fc}.mileage-point-group.manual .mileage-point{fill:#a855f7}.mileage-point-group:hover .mileage-point,.mileage-point-group:focus .mileage-point{filter:drop-shadow(0 0 10px rgba(168,85,247,.75))}.mileage-warning-marker circle{fill:var(--warning);stroke:#ffffffdb;stroke-width:1.5}.mileage-warning-marker text{fill:#112;font-size:13px;font-weight:900}.mileage-tooltip{position:absolute;right:14px;top:14px;display:grid;gap:3px;max-width:min(280px,calc(100% - 28px));padding:12px 14px;background:#090a18eb;border:1px solid var(--border-normal);border-radius:var(--radius-md);box-shadow:var(--shadow-card);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);pointer-events:none}.mileage-tooltip strong{color:var(--text-primary);font-size:.875rem}.mileage-tooltip span,.mileage-tooltip em{color:var(--text-secondary);font-size:.78rem;font-style:normal}.mileage-tooltip em{color:var(--warning);font-weight:800}.mileage-legend{display:flex;flex-wrap:wrap;align-items:center;gap:14px;margin-top:14px;color:var(--text-secondary);font-size:.78rem;font-weight:700}.mileage-legend span{display:inline-flex;align-items:center;gap:7px}.legend-dot{width:10px;height:10px;border-radius:99px;border:2px solid rgba(255,255,255,.72)}.legend-dot.maintenance{background:#7dd3fc}.legend-dot.manual{background:#a855f7}.legend-warning{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:99px;background:var(--warning);color:#112;font-size:.72rem;font-style:normal;font-weight:900}.mileage-empty{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:16px;padding:20px;background:#07081457;border:1px dashed var(--border-normal);border-radius:var(--radius-md)}.mileage-empty-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:var(--radius-md);background:var(--accent-dim);color:var(--accent);flex-shrink:0}.mileage-empty strong,.mileage-empty span{display:block}.mileage-empty strong{color:var(--text-primary);margin-bottom:4px}.mileage-empty span{color:var(--text-secondary);font-size:.875rem;line-height:1.5}.mileage-empty-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.vehicle-detail-top{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:20px}.vehicle-detail-title{display:flex;align-items:center;gap:16px}.vehicle-badge{display:inline-flex;align-items:center;justify-content:center;width:52px;height:52px;background:var(--accent-dim);border:1px solid rgba(124,100,247,.2);border-radius:var(--radius-md);color:var(--accent);flex-shrink:0}.vehicle-detail-meta{display:flex;flex-wrap:wrap;gap:20px}.vehicle-detail-tabs{position:sticky;top:72px;z-index:40;display:inline-grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:4px;padding:5px;margin:-8px 0 24px;background:#121224db;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border:1px solid var(--border-subtle);border-radius:var(--radius-md)}.vehicle-detail-tab{min-width:112px;padding:9px 16px;border:0;border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);cursor:pointer;font:inherit;font-size:.8375rem;font-weight:700;transition:background var(--transition),color var(--transition)}.vehicle-detail-tab:hover{color:var(--text-primary)}.vehicle-detail-tab.active{background:linear-gradient(135deg,#7c64f738,#7c64f71c);color:var(--accent)}.vehicle-detail-section{animation:fadeIn .16s ease}.meta-item{display:flex;flex-direction:column;gap:3px}.meta-label{font-size:.6875rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted)}.meta-value{font-size:.9375rem;color:var(--text-primary);font-weight:500}.meta-value.mono{font-family:JetBrains Mono,monospace;font-size:.875rem;letter-spacing:.04em}.maintenance-section h2{margin-bottom:20px}.maintenance-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.timeline{display:flex;flex-direction:column;gap:22px}.timeline-month{position:relative;display:flex;flex-direction:column;gap:10px;padding-left:18px}.timeline-month:before{content:"";position:absolute;top:28px;bottom:0;left:5px;width:2px;background:linear-gradient(to bottom,rgba(124,100,247,.5),transparent)}.timeline-month-label{position:sticky;top:72px;z-index:2;align-self:flex-start;padding:4px 10px;background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:99px;color:var(--text-secondary);font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.timeline-item{background:#121224c7;border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:16px 18px;display:flex;align-items:flex-start;gap:16px;transition:border-color var(--transition),background var(--transition);position:relative}.timeline-item+.timeline-item:before{content:"";position:absolute;top:-12px;left:38px;width:2px;height:12px;background:linear-gradient(to bottom,transparent,var(--border-normal))}.timeline-item:hover{border-color:var(--border-normal);background:var(--bg-card-hover)}.timeline-icon{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:var(--radius-md);flex-shrink:0;font-size:1.125rem}.timeline-icon.oil{background:var(--warning-dim);color:var(--warning);border:1px solid rgba(245,166,35,.2)}.timeline-icon.brake{background:var(--danger-dim);color:var(--danger);border:1px solid rgba(240,68,85,.2)}.timeline-icon.custom{background:var(--accent-dim);color:var(--accent);border:1px solid rgba(124,100,247,.2)}.timeline-body{flex:1;min-width:0}.timeline-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:6px}.timeline-service-name{font-weight:600;font-size:.9375rem;color:var(--text-primary)}.timeline-date{font-size:.8125rem;color:var(--text-secondary);white-space:nowrap;flex-shrink:0}.timeline-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.chip{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:99px;font-size:.75rem;font-weight:500}.chip-mileage{background:var(--bg-surface);color:var(--text-secondary);border:1px solid var(--border-subtle)}.chip-cost{background:var(--success-dim);color:var(--success);border:1px solid rgba(52,211,154,.15)}.chip-receipt{background:#7c64f71f;color:var(--accent);border:1px solid rgba(124,100,247,.2);padding:3px 8px}.chip-receipt:hover{background:#7c64f72e}.timeline-notes{font-size:.8125rem;color:var(--text-secondary);margin-top:8px;padding-top:8px;border-top:1px solid var(--border-subtle);line-height:1.55}.timeline-actions{flex-shrink:0;opacity:.72;transition:opacity var(--transition),transform var(--transition)}.timeline-item:hover .timeline-actions,.timeline-actions:focus-within{opacity:1}@media (hover: none){.timeline-actions{opacity:1}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#05050ecc;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:24px;z-index:1000;animation:fadeIn .15s ease}.modal{background:var(--bg-modal);border:1px solid var(--border-normal);border-radius:var(--radius-xl);padding:32px;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-modal);animation:scaleIn .18s ease}.modal-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:28px;gap:12px}.modal-title h2{margin-bottom:4px}.modal-title p{color:var(--text-secondary);font-size:.875rem}.modal-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);cursor:pointer;color:var(--text-secondary);transition:all var(--transition);flex-shrink:0}.modal-close:hover{background:var(--bg-card-hover);color:var(--text-primary);border-color:var(--border-normal)}.modal-form{display:flex;flex-direction:column;gap:18px}.modal-footer{display:flex;gap:12px;margin-top:24px}.modal-footer .btn{flex:1;justify-content:center}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-disclosure{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);overflow:hidden}.form-disclosure-head{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;background:transparent;border:0;color:var(--text-secondary);cursor:pointer;font:inherit;text-align:left}.form-disclosure-head span{font-weight:600;color:var(--text-primary)}.form-disclosure-head strong{color:var(--accent);font-size:.75rem;text-transform:uppercase;letter-spacing:.06em}.form-disclosure-body{padding:0 14px 14px;display:flex;flex-direction:column;gap:14px}.service-tabs{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:4px}.service-tab{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 8px;border-radius:var(--radius-md);border:1px solid var(--border-subtle);background:var(--bg-input);cursor:pointer;transition:all var(--transition);font-size:.8125rem;font-weight:500;color:var(--text-secondary);font-family:inherit}.service-tab:hover{border-color:var(--border-normal);color:var(--text-primary)}.service-tab.active-oil{background:var(--warning-dim);border-color:#f5a6234d;color:var(--warning)}.service-tab.active-brake{background:var(--danger-dim);border-color:#f044554d;color:var(--danger)}.service-tab.active-custom{background:var(--accent-dim);border-color:#7c64f74d;color:var(--accent)}.receipt-upload-area{display:flex;align-items:center;gap:10px;width:100%;padding:10px 14px;background:var(--bg-input);border:1.5px dashed var(--border-subtle);border-radius:var(--radius-md);cursor:pointer;color:var(--text-secondary);font-size:.875rem;transition:border-color var(--transition),background var(--transition);text-align:left}.receipt-upload-area:hover{border-color:var(--accent);background:var(--accent-dim)}.receipt-upload-area.has-file{border-style:solid;border-color:#34d39a4d;background:var(--success-dim);cursor:default}.alert{padding:12px 16px;border-radius:var(--radius-md);font-size:.875rem;border:1px solid}.alert-error{background:var(--danger-dim);border-color:#f0445540;color:var(--danger)}.alert-success{background:var(--success-dim);border-color:#34d39a40;color:var(--success)}.alert-warn{background:#f5a6231a;border-color:#f5a6234d;color:#f5a623}.spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.15);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;display:inline-block}.spinner-sm{width:15px;height:15px}.spinner-xs{width:12px;height:12px}.spinner-lg{width:32px;height:32px}.empty-state-compact{padding:32px 24px}.empty-state-title-sm{font-size:1rem}.empty-state-action{margin-top:16px}.timeline-item-readonly{cursor:default}.chip-link{text-decoration:none}.section-total,.section-count{color:var(--text-muted);font-size:.8125rem}.section-total strong{color:var(--success)}.loading-screen{display:flex;align-items:center;justify-content:center;height:200px}.loading-screen-branded{flex-direction:column;gap:18px;height:100vh}.route-loading-logo{width:86px;height:86px;object-fit:contain;filter:drop-shadow(0 14px 28px rgba(124,100,247,.28))}.back-link{display:inline-flex;align-items:center;gap:6px;color:var(--text-secondary);font-size:.875rem;text-decoration:none;margin-bottom:24px;transition:color var(--transition)}.back-link:hover{color:var(--text-primary)}.confirm-dialog{max-width:380px;text-align:center}.confirm-dialog .confirm-icon{display:inline-flex;align-items:center;justify-content:center;width:52px;height:52px;background:var(--danger-dim);border-radius:50%;color:var(--danger);margin-bottom:16px}.confirm-dialog p{color:var(--text-secondary);font-size:.9375rem;margin-bottom:8px;line-height:1.5}.confirm-dialog strong{color:var(--text-primary)}@keyframes skeleton-shimmer{0%{background-position:-400% 0}to{background-position:400% 0}}.skeleton{background:linear-gradient(90deg,var(--bg-surface) 25%,var(--bg-card-hover) 50%,var(--bg-surface) 75%);background-size:400% 100%;animation:skeleton-shimmer 1.8s ease infinite;border-radius:var(--radius-sm)}@keyframes badge-pulse{0%{transform:scale(1)}35%{transform:scale(1.55)}65%{transform:scale(.88)}to{transform:scale(1)}}.notif-badge-pulse{animation:badge-pulse .5s cubic-bezier(.36,.07,.19,.97) both}.meta-item-vin{width:100%;padding-bottom:18px;margin-bottom:4px;border-bottom:1px solid var(--border-subtle)}.vin-display{display:flex;align-items:center;gap:10px;margin-top:4px}.vin-value{font-size:1.0625rem!important;letter-spacing:.12em!important}.vin-copy-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:none;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);cursor:pointer;color:var(--text-muted);transition:all var(--transition);flex-shrink:0}.vin-copy-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.vin-copy-btn.copied{border-color:#34d39a4d;color:var(--success);background:var(--success-dim)}.auth-split{display:grid;grid-template-columns:1fr 1fr;min-height:100vh}.auth-brand-panel{position:relative;overflow:hidden;background:linear-gradient(160deg,#080820,#0c0c26);border-right:1px solid var(--border-subtle);padding:56px 64px;display:flex;flex-direction:column;justify-content:center}.auth-brand-panel:before{content:"";position:absolute;top:-140px;left:-140px;width:520px;height:520px;background:radial-gradient(ellipse,rgba(124,100,247,.2) 0%,transparent 68%);pointer-events:none}.auth-brand-panel:after{content:"";position:absolute;bottom:-180px;right:-180px;width:500px;height:500px;background:radial-gradient(ellipse,rgba(52,211,154,.09) 0%,transparent 68%);pointer-events:none}.auth-brand-logo{display:flex;align-items:center;gap:10px;margin-bottom:60px;font-size:1.125rem;font-weight:800;letter-spacing:-.01em;color:var(--text-primary);position:relative;z-index:1}.auth-brand-logo-mark{display:flex;align-items:center;justify-content:center;width:38px;height:38px;background:#05050e59;border:1px solid rgba(124,100,247,.3);border-radius:10px;overflow:hidden;box-shadow:0 0 24px #7c64f72e}.auth-brand-logo-mark img{width:100%;height:100%;object-fit:cover}.auth-hero-logo{width:min(260px,58%);aspect-ratio:1;object-fit:cover;border-radius:28px;margin:-18px 0 36px;box-shadow:0 22px 70px #00000052,0 0 36px #7c64f72e;position:relative;z-index:1}.auth-brand-headline{font-size:2.125rem;font-weight:700;letter-spacing:-.03em;line-height:1.2;color:var(--text-primary);margin-bottom:14px;position:relative;z-index:1}.auth-brand-headline em{font-style:normal;background:linear-gradient(90deg,var(--accent),#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-brand-sub{font-size:.9375rem;color:var(--text-secondary);line-height:1.65;margin-bottom:44px;position:relative;z-index:1}.auth-features{list-style:none;display:flex;flex-direction:column;gap:13px;position:relative;z-index:1}.auth-features li{display:flex;align-items:center;gap:10px;font-size:.875rem;color:var(--text-secondary)}.auth-feature-icon{width:22px;height:22px;border-radius:6px;background:var(--accent-dim);border:1px solid rgba(124,100,247,.2);display:flex;align-items:center;justify-content:center;color:var(--accent);flex-shrink:0}.auth-form-panel{display:flex;align-items:center;justify-content:center;padding:48px 56px;background:var(--bg-base)}.auth-form-inner{width:100%;max-width:380px}.auth-form-logo{display:none;width:64px;height:64px;object-fit:cover;border-radius:16px;margin-bottom:22px;box-shadow:0 14px 36px #00000047,0 0 24px #7c64f72e}.auth-form-inner h2{margin-bottom:6px}.auth-form-inner .auth-subtitle{color:var(--text-secondary);font-size:.875rem;margin-bottom:28px}@media (max-width: 768px){.auth-split{grid-template-columns:1fr}.auth-brand-panel{display:none}.auth-form-panel{padding:40px 24px}.auth-form-logo{display:block}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}.vin-search-bar{display:flex;align-items:center;gap:10px;background:#0c0c1e94;border:1px solid var(--border-subtle);border-radius:14px;padding:9px 14px;margin-bottom:24px;transition:border-color var(--transition),background var(--transition),box-shadow var(--transition)}.vin-search-bar:focus-within{background:#0c0c1ec7;border-color:#7c64f757;box-shadow:0 0 0 3px #7c64f714}.vin-search-input{flex:1;background:none;border:none;outline:none;color:var(--text-primary);font-size:.9375rem;letter-spacing:.05em}.vin-search-input::placeholder{color:var(--text-muted);letter-spacing:0}.notifications-anchor,.notif-snooze,.notif-bell{position:relative}.notif-badge{position:absolute;top:-3px;right:-3px;background:var(--danger);color:#fff;font-size:.625rem;font-weight:700;min-width:16px;height:16px;border-radius:99px;display:flex;align-items:center;justify-content:center;padding:0 3px;line-height:1;pointer-events:none}.notifications-dropdown{position:fixed;top:68px;right:16px;width:min(340px,calc(100vw - 32px));background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:0 16px 48px #00000073;z-index:500;animation:scaleIn .12s ease;overflow:hidden}.notifications-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 12px;border-bottom:1px solid var(--border-subtle);font-size:.8125rem;font-weight:600;color:var(--text-primary);letter-spacing:.04em;text-transform:uppercase}.notifications-unread-count{color:var(--text-muted);font-size:.75rem;font-weight:400;margin-left:8px}.notifications-loading{display:flex;justify-content:center;padding:24px 0}.notif-header-actions{display:flex;align-items:center;gap:6px}.notif-mini-btn,.notif-icon-btn{border:1px solid var(--border-subtle);background:var(--bg-input);color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer}.notif-mini-btn{padding:5px 8px;font-size:.7rem;font-weight:700;text-transform:none;letter-spacing:0}.notif-icon-btn{width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center}.notif-mini-btn:hover:not(:disabled),.notif-icon-btn:hover{color:var(--text-primary);border-color:#7c64f759}.notif-mini-btn:disabled{opacity:.45;cursor:default}.notif-preferences{padding:10px 14px;border-bottom:1px solid var(--border-subtle);background:#7c64f70f}.notif-pref-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:7px 0;color:var(--text-secondary);font-size:.8125rem;font-weight:500}.notif-pref-row input{accent-color:var(--accent)}.notifications-empty{padding:24px 16px;text-align:center;color:var(--text-muted);font-size:.875rem}.notifications-list{max-height:380px;overflow-y:auto}.notif-group-title{padding:12px 16px 6px;color:var(--text-muted);font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase}.notif-item{display:flex;gap:12px;padding:14px 16px;border-bottom:1px solid var(--border-subtle)}.notif-item:last-child{border-bottom:none}.notif-unread{background:linear-gradient(90deg,rgba(124,100,247,.1),transparent 55%)}.notif-unread .notif-item-name:after{content:"";display:inline-block;width:7px;height:7px;margin-left:7px;border-radius:999px;background:var(--accent);vertical-align:middle}.notif-read{opacity:.72}.notif-avatar{flex-shrink:0;width:34px;height:34px;border-radius:50%;background:var(--accent-dim);color:var(--accent);font-weight:700;font-size:.875rem;display:flex;align-items:center;justify-content:center}.notif-item-body{flex:1;min-width:0}.notif-item-name{font-size:.875rem;font-weight:600;color:var(--text-primary);margin-bottom:2px}.notif-item-desc{font-size:.8125rem;color:var(--text-secondary);line-height:1.45;margin-bottom:10px}.notif-item-desc strong{color:var(--text-primary);font-weight:600}.notif-item-actions{display:flex;gap:6px;flex-wrap:wrap}.notif-action-btn{display:inline-flex;align-items:center;gap:4px;padding:5px 11px;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;cursor:pointer;border:1px solid transparent;transition:opacity var(--transition)}.notif-action-btn:disabled{opacity:.5;cursor:default}.notif-snooze-menu{position:absolute;top:calc(100% + 4px);left:0;z-index:200;min-width:132px;padding:5px;background:#121224fa;border:1px solid var(--border-normal);border-radius:var(--radius-sm);box-shadow:0 12px 28px #00000073}.notif-snooze-menu button{display:block;width:100%;padding:8px 10px;background:none;border:none;border-radius:5px;color:var(--text-secondary);cursor:pointer;font:inherit;font-size:.8rem;text-align:left;white-space:nowrap}.notif-snooze-menu button:hover{background:var(--bg-card-hover);color:var(--text-primary)}.notif-approve{background:var(--success-dim);color:var(--success);border-color:#34d39a4d}.notif-approve:hover:not(:disabled){background:#34d39a2e}.notif-deny{background:var(--danger-dim);color:var(--danger);border-color:#f044554d}.notif-deny:hover:not(:disabled){background:#f044552e}.notif-open{background:var(--accent-dim);color:var(--accent);border-color:#7c64f747;text-decoration:none}.notif-open:hover{background:#7c64f72e}.notif-avatar-reminder{background:#f59e0b1f;color:#f59e0b}.notif-reminder-overdue .notif-avatar-reminder{background:var(--danger-dim);color:var(--danger)}.search-result-box{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:20px 20px 22px;animation:scaleIn .15s ease}.search-result-box-approved{border-color:#34d39a40}.search-result-empty{display:flex;flex-direction:column;align-items:center;padding:36px 20px;text-align:center}.search-result-empty h3{margin-bottom:6px}.search-result-empty p{color:var(--text-secondary);font-size:.9rem}.search-empty-icon{color:var(--text-muted);margin-bottom:12px}.search-result-action{margin-top:16px}.search-result-copy{color:var(--text-secondary);font-size:.9rem;margin:12px 0 16px}.search-result-copy-last{margin-bottom:0}.search-history{margin-top:24px}.search-history-header{margin-bottom:16px}.vin-search-page{max-width:580px}.vin-search-header{margin-bottom:28px}.vin-search-header h1{margin-bottom:6px}.vin-search-header p{color:var(--text-secondary);font-size:.9375rem}.vin-search-form{display:flex;gap:10px;margin-bottom:28px}.vin-search-query{flex:1;letter-spacing:.08em}.vin-search-submit{flex-shrink:0}.search-result-status{display:inline-flex;align-items:center;gap:6px;font-size:.75rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding:4px 10px;border-radius:99px;margin-bottom:14px}.search-result-status-found{background:#7c64f71f;color:var(--accent)}.search-result-status-pending{background:#f59e0b1f;color:#f59e0b}.search-result-status-denied{background:var(--danger-dim);color:var(--danger)}.search-result-status-approved{background:var(--success-dim);color:var(--success)}.search-vehicle-card{display:flex;align-items:center;gap:16px;padding:14px 0;border-top:1px solid var(--border-subtle);border-bottom:1px solid var(--border-subtle);margin-bottom:2px}.search-vehicle-copy{min-width:0}.search-vehicle-year{font-size:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-bottom:2px}.search-vehicle-name{font-size:1.25rem;font-weight:700;color:var(--text-primary);line-height:1.2}.search-vehicle-nickname{color:var(--text-secondary);font-size:.875rem;margin-top:2px}.reminder-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:99px;font-size:.6875rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.reminder-badge-overdue{background:var(--danger-dim);color:var(--danger);border:1px solid rgba(240,68,85,.25)}.reminder-badge-upcoming{background:#f59e0b1f;color:#f59e0b;border:1px solid rgba(245,158,11,.25)}.reminders-section{margin-bottom:28px}.reminders-heading{font-size:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin-bottom:10px}.reminders-list{display:flex;flex-direction:column;gap:8px}.inline-empty{display:flex;justify-content:space-between;gap:14px;align-items:center;padding:14px 16px;background:var(--bg-card);border:1px dashed var(--border-normal);border-radius:var(--radius-md)}.inline-empty strong{display:block;color:var(--text-primary);font-size:.9rem}.inline-empty span{display:block;color:var(--text-secondary);font-size:.8125rem;margin-top:2px}.panel-empty-state{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:16px;min-height:96px;padding:18px;background:#0e0f1f7a;border:1px solid var(--border-subtle);border-radius:var(--radius-md)}.panel-empty-state-compact{min-height:82px;padding:13px 16px}.panel-empty-illustration{width:76px;height:58px;color:var(--accent);border:1px solid rgba(124,100,247,.2);border-radius:var(--radius-md);background:linear-gradient(145deg,#7c64f71f,#0d0d1b4d);overflow:hidden;flex-shrink:0}.panel-empty-state-compact .panel-empty-illustration{width:66px;height:50px}.panel-empty-illustration svg{width:100%;height:100%}.panel-empty-grid{stroke:#998fde14;stroke-width:1}.panel-empty-road{stroke:#9a8bf94d;stroke-width:1.2}.panel-empty-lanes{stroke:#b6aeff52;stroke-width:1.3;stroke-linecap:round;stroke-dasharray:2 2}.panel-empty-symbol{stroke:currentColor;stroke-width:1.55;stroke-linecap:round;stroke-linejoin:round}.panel-empty-fuel{color:var(--warning)}.panel-empty-diagnostics{color:var(--accent)}.panel-empty-reminders{color:var(--success)}.panel-empty-copy{min-width:0}.panel-empty-copy strong{display:block;margin-bottom:4px;color:var(--text-primary);font-size:.9375rem}.panel-empty-copy span{display:block;max-width:54ch;color:var(--text-secondary);font-size:.8125rem;line-height:1.45}.panel-empty-action{display:flex;justify-content:flex-end;align-items:center}.reminder-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:var(--radius-md);border:1px solid var(--border-subtle);background:var(--bg-card)}.reminder-item-overdue{border-color:#f0445540;background:#f044550a}.reminder-item-soon{border-color:#f59e0b40;background:#f59e0b0a}.reminder-emoji{display:flex;align-items:center;justify-content:center;flex-shrink:0}.reminder-body{flex:1;min-width:0}.reminder-service{font-size:.9rem;font-weight:600;color:var(--text-primary)}.reminder-meta{display:flex;gap:10px;align-items:center;margin-top:2px;flex-wrap:wrap}.reminder-status-tag{font-size:.75rem;font-weight:600}.reminder-status-overdue{color:var(--danger)}.reminder-status-soon{color:#f59e0b}.reminder-status-upcoming{color:var(--text-secondary)}.reminder-mileage{font-size:.75rem;color:var(--text-muted)}.reminder-actions{display:flex;align-items:center;gap:4px}.reminder-toggle-section{padding:14px 16px;background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);margin-bottom:4px}.reminder-toggle-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:.9rem;font-weight:500;color:var(--text-secondary);-webkit-user-select:none;user-select:none}.diagnostics-section{margin-bottom:28px}.diagnostics-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:14px;gap:12px}.diagnostics-last-scanned{font-size:.8125rem;color:var(--text-muted);margin-bottom:3px}.diagnostics-scan-card{background:var(--bg-card);border:1px solid var(--border-normal);border-radius:var(--radius-md);padding:18px;margin-bottom:10px}.diagnostics-scan-card.has-faults{border-color:#f0445540}.diagnostics-scan-card.clean{border-color:#34d39a33}.diagnostics-scan-top{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.diagnostics-status-badge{display:flex;align-items:center;gap:7px;font-size:.875rem;font-weight:600;padding:5px 12px;border-radius:99px}.badge-fault{background:var(--danger-dim);color:var(--danger)}.badge-clean{background:var(--success-dim);color:var(--success)}.diagnostics-scan-time{font-size:.8125rem;color:var(--text-muted)}.dtc-list{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.dtc-item{display:flex;align-items:baseline;gap:12px;background:var(--danger-dim);border-radius:var(--radius-sm);padding:8px 12px}.dtc-code{font-family:JetBrains Mono,Fira Code,Courier New,monospace;font-size:.8125rem;font-weight:700;color:var(--danger);flex-shrink:0;letter-spacing:.04em}.dtc-desc{font-size:.8125rem;color:var(--text-secondary);line-height:1.4}.pid-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px;margin-top:12px}.pid-item{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:10px 12px;display:flex;flex-direction:column;gap:3px}.pid-label{font-size:.725rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.pid-value{font-size:.9375rem;font-weight:600;color:var(--text-primary);font-variant-numeric:tabular-nums}.diagnostics-notes{font-size:.85rem;color:var(--text-secondary);margin-top:10px;font-style:italic}.diagnostics-history{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);overflow:hidden}.diagnostics-history-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;background:none;border:none;cursor:pointer;padding:12px 16px;font-size:.8375rem;color:var(--text-secondary);transition:color var(--transition)}.diagnostics-history-toggle:hover{color:var(--text-primary)}.diagnostics-history-list{border-top:1px solid var(--border-subtle)}.diagnostics-history-item{display:flex;align-items:center;gap:12px;padding:10px 16px;border-bottom:1px solid var(--border-subtle)}.diagnostics-history-item:last-child{border-bottom:none}.diagnostics-history-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.dot-fault{background:var(--danger)}.dot-clean{background:var(--success)}.diagnostics-history-body{flex:1;display:flex;align-items:center;gap:10px;flex-wrap:wrap;min-width:0}.diagnostics-history-date{font-size:.8125rem;color:var(--text-secondary)}.diagnostics-history-result{font-size:.8rem;font-weight:600;padding:2px 8px;border-radius:99px}.result-fault{background:var(--danger-dim);color:var(--danger)}.result-clean{background:var(--success-dim);color:var(--success)}.diagnostics-history-codes{font-size:.775rem;color:var(--text-muted);font-family:JetBrains Mono,Courier New,monospace}.schedule-section{margin-bottom:28px}.template-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.template-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:16px;display:flex;flex-direction:column;gap:8px}.template-card strong{color:var(--text-primary)}.template-card p{color:var(--text-secondary);font-size:.8125rem;line-height:1.45}.template-card span{color:var(--text-muted);font-size:.75rem}.receipt-file-list{display:flex;flex-direction:column;gap:6px;margin-bottom:8px}.receipt-file-item{display:flex;align-items:center;gap:8px;padding:7px 12px;background:var(--success-dim);border:1px solid rgba(52,211,154,.2);border-radius:var(--radius-sm)}.share-url-box{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md)}.share-url-text{flex:1;font-size:.8125rem;color:var(--text-secondary);font-family:var(--font-mono, monospace);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.share-controls{margin-top:16px;display:grid;gap:12px}.toggle-row{display:flex;align-items:center;gap:8px;color:var(--text-secondary);font-size:.875rem}.toggle-row input{width:15px;height:15px;accent-color:var(--accent)}.shared-report-page{max-width:820px;margin:0 auto;padding:40px 24px 64px}.public-report-state{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}.public-report-password{max-width:380px;width:100%}.public-report-password h2{margin-bottom:8px}.public-report-password p{color:var(--text-secondary);margin-bottom:18px}.public-report-submit{margin-top:14px}.public-report-error{flex-direction:column;gap:16px}.public-report-error-icon{color:var(--text-muted)}.public-report-error h2{color:var(--text-primary)}.public-report-error p{color:var(--text-secondary);text-align:center}.shared-report-header{display:grid;grid-template-columns:1fr auto;align-items:end;gap:18px;padding:22px;border:1px solid var(--border-subtle);border-radius:var(--radius-lg);background:linear-gradient(135deg,rgba(124,100,247,.12),transparent 42%),#121224bd;box-shadow:0 18px 48px #00000038;margin-bottom:28px}.shared-report-brand{display:flex;align-items:center;gap:8px;font-size:.875rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);margin-bottom:20px}.shared-report-brand img{width:28px;height:28px;object-fit:cover;border-radius:7px;box-shadow:0 0 18px #7c64f72e}.shared-report-eyebrow{font-size:.75rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-bottom:6px}.shared-report-title-block h1{font-size:1.75rem}.shared-report-nickname{color:var(--text-secondary);font-size:.9375rem;margin-top:4px}.shared-report-download{margin-top:14px}.shared-report-verification{background:#05050e5c;border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:12px 14px;min-width:220px}.shared-report-verification span{display:block;color:var(--text-muted);font-size:.75rem;margin-bottom:4px}.shared-report-verification strong{display:block;color:var(--success);font-size:.875rem}.shared-report-summary{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:20px}.shared-report-summary>div{background:#121224b8;border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:12px 14px;min-width:0}.shared-report-summary span{display:block;color:var(--text-muted);font-size:.6875rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;margin-bottom:5px}.shared-report-summary strong{display:block;color:var(--text-primary);font-size:.95rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.shared-report-meta{display:flex;flex-wrap:wrap;gap:0;background:#121224ad;border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:8px}.shared-report-meta .meta-item{flex:1 1 120px;padding:12px 16px;border-right:1px solid var(--border-subtle);border-bottom:1px solid var(--border-subtle)}.shared-report-footer{display:flex;align-items:center;gap:10px;margin-top:40px;padding-top:20px;border-top:1px solid var(--border-subtle);font-size:.8125rem;color:var(--text-muted)}.shared-report-history{margin-top:32px}.shared-report-history-header{margin-bottom:16px}.shared-report-home{color:var(--accent);text-decoration:none}.stats-panel{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);margin-bottom:28px;overflow:hidden}.stats-panel-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;padding:14px 20px;background:none;border:none;cursor:pointer;font:inherit;font-size:.875rem;font-weight:600;color:var(--text-primary);letter-spacing:.02em}.stats-panel-toggle:hover{background:var(--bg-card-hover)}.stats-panel-body{padding:4px 20px 20px;display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px;border-top:1px solid var(--border-subtle)}.stats-section-title{font-size:.75rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);margin:16px 0 10px}.stats-bar-row{display:grid;grid-template-columns:110px 1fr 56px 52px;align-items:center;gap:8px;margin-bottom:6px}.stats-bar-label{font-size:.8125rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stats-bar-track{height:6px;background:var(--bg-surface);border-radius:99px;overflow:hidden}.stats-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),#a78bfa);border-radius:99px;transition:width .4s ease;min-width:4px}.stats-bar-value{font-size:.8125rem;font-weight:600;color:var(--text-primary);text-align:right}.stats-bar-count{font-size:.75rem;color:var(--text-muted);text-align:right}.timeline-filters{display:flex;align-items:center;gap:10px;margin-bottom:20px;flex-wrap:wrap}.timeline-filter-chips{display:flex;gap:6px;flex-wrap:wrap}.timeline-filter-chip{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;border-radius:99px;font-size:.8125rem;font-weight:500;cursor:pointer;border:1px solid var(--border-normal);background:var(--bg-card);color:var(--text-secondary);font-family:inherit;transition:all var(--transition);white-space:nowrap}.timeline-filter-chip:hover{border-color:var(--border-strong);color:var(--text-primary)}.timeline-filter-chip.active{background:var(--accent-dim);border-color:#7c64f759;color:var(--accent)}.timeline-search{max-width:200px;padding:6px 12px;font-size:.8125rem;height:auto}@media (max-width: 640px){.timeline-filters{flex-direction:column;align-items:stretch}.timeline-search{max-width:none}}.toast-container{position:fixed;bottom:24px;right:24px;z-index:2000;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast{display:flex;align-items:center;gap:10px;padding:11px 14px;background:var(--bg-card);border:1px solid var(--border-normal);border-radius:var(--radius-md);box-shadow:0 8px 32px #00000073;font-size:.875rem;font-weight:500;color:var(--text-primary);animation:toastIn .2s ease;pointer-events:all;max-width:320px}.toast-success{border-left:3px solid var(--success);color:var(--success)}.toast-success span{color:var(--text-primary)}.toast-error{border-left:3px solid var(--danger);color:var(--danger)}.toast-error span{color:var(--text-primary)}.toast-close{margin-left:auto;background:none;border:none;cursor:pointer;color:var(--text-muted);padding:0;display:flex;align-items:center;flex-shrink:0;transition:color var(--transition)}.toast-close:hover{color:var(--text-secondary)}@keyframes toastIn{0%{opacity:0;transform:translateY(6px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@media (max-width: 640px){.toast-container{left:12px;right:12px;bottom:84px}.toast{max-width:none}}.print-only{display:none}@media print{.print-only{display:block}.no-print,.navbar,.back-link,.timeline-actions,.modal-overlay,.vehicle-detail-top>div:last-child{display:none!important}body{background:#fff!important;color:#111!important}.page{padding:0!important}.print-report-header{display:flex;flex-direction:column;gap:4px;margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid #eee;font-size:.875rem;color:#555}.print-report-header strong{font-size:1.125rem;color:#111}.vehicle-detail-meta{background:#f8f8f8!important;border-color:#ddd!important;break-inside:avoid}.meta-label{color:#666!important}.meta-value{color:#111!important}.timeline-item{break-inside:avoid}.timeline-body{color:#111!important}.chip{border-color:#ccc!important;color:#333!important;background:#f0f0f0!important}}@media (max-width: 900px){.analytics-grid,.insights-panel{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (min-width: 641px) and (max-width: 899px){.page{padding:28px 18px}.vehicle-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.analytics-card{padding:12px 14px}.analytics-card-icon{width:30px;height:30px}.analytics-card span{font-size:.7rem}.analytics-card strong{font-size:1.25rem}.vehicle-card-status{gap:10px}.insight-item{padding:12px 14px}.modal{padding:24px}}@media (max-width: 640px){.page{padding:24px 16px 92px}.navbar-user,.navbar-right>.btn,.server-status,.desktop-notifications{display:none}.mobile-bottom-nav{position:fixed;left:12px;right:12px;bottom:12px;z-index:900;display:grid;grid-template-columns:repeat(4,1fr);gap:4px;padding:7px;background:#0e0e1fdb;border:1px solid var(--border-normal);border-radius:18px;box-shadow:0 16px 48px #00000073;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.mobile-bottom-nav a,.mobile-bottom-nav button{display:flex;flex-direction:column;align-items:center;gap:3px;padding:8px 4px;background:transparent;border:0;border-radius:12px;color:var(--text-secondary);font:inherit;font-size:.72rem;text-decoration:none}.mobile-bottom-nav a.active{background:var(--accent-dim);color:var(--accent)}.mobile-nav-notifications{display:flex;align-items:center;justify-content:center}.mobile-nav-notifications .notif-bell{width:100%;height:100%;min-height:46px;padding:0;color:var(--text-secondary);background:transparent}.mobile-nav-notifications .notifications-dropdown{position:fixed;left:12px;right:12px;bottom:74px;top:auto;width:auto;max-height:min(70vh,560px)}.page-header{flex-direction:column}.analytics-grid,.insights-panel{grid-template-columns:repeat(2,minmax(0,1fr))}.vehicle-detail-tabs{display:grid;width:100%}.vehicle-detail-tab{min-width:0;padding:9px 8px}.mileage-panel{padding:16px}.mileage-panel-header{flex-direction:column;align-items:stretch}.mileage-panel-actions{justify-content:space-between}.mileage-panel-actions .btn{flex:1;justify-content:center}.mileage-chart-shell{min-height:220px;overflow-x:hidden}.mileage-chart{min-height:220px}.mileage-tooltip{left:10px;right:10px;top:10px;max-width:none}.mileage-empty{grid-template-columns:1fr;text-align:left}.mileage-empty-actions{justify-content:stretch}.mileage-empty-actions .btn{flex:1;justify-content:center}.vehicle-card-status{grid-template-columns:1fr}.vehicle-detail-top{flex-direction:column}.maintenance-section-header{align-items:stretch;flex-direction:column;gap:12px}.maintenance-section-header .btn,.maintenance-section-header .form-input{width:100%;max-width:none!important;justify-content:center}.form-row{grid-template-columns:1fr}.service-tabs{grid-template-columns:1fr 1fr 1fr}.modal{padding:24px}.modal-footer{flex-direction:column}.inline-empty{align-items:flex-start;flex-direction:column}.panel-empty-state{grid-template-columns:auto minmax(0,1fr);align-items:start;gap:12px;padding:14px}.panel-empty-illustration{width:62px;height:50px}.panel-empty-action{grid-column:1 / -1;width:100%}.panel-empty-action .btn{width:100%;justify-content:center}.shared-report-header{grid-template-columns:1fr}.shared-report-summary{grid-template-columns:repeat(2,minmax(0,1fr))}}.admin-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px;border-bottom:1px solid var(--border-subtle);padding-bottom:8px}.admin-tab{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:9px 14px;font-size:.875rem;font-weight:500;color:var(--text-muted);cursor:pointer;transition:color var(--transition),border-color var(--transition),background var(--transition);white-space:nowrap}.admin-tab:hover{color:var(--text);border-color:var(--border-normal)}.admin-tab-active{color:var(--text);background:var(--accent-dim);border-color:var(--border-focus)}.error-boundary{min-height:100vh;display:grid;place-items:center;padding:24px}.error-boundary-panel{width:min(420px,100%);padding:28px;background:var(--bg-card);border:1px solid var(--border-normal);border-radius:var(--radius-md);box-shadow:var(--shadow-card);text-align:center}.error-boundary-panel img{width:64px;height:64px;object-fit:contain;margin-bottom:14px}.error-boundary-panel p{color:var(--text-secondary);margin:8px 0 18px}.error-boundary-actions{display:flex;justify-content:center;gap:10px;flex-wrap:wrap}.quality-panel,.shared-trust-panel{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:18px;margin-top:18px}.quality-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.quality-header h2{font-size:1.05rem}.quality-score{width:46px;height:46px;display:grid;place-items:center;border-radius:50%;background:var(--success-dim);color:var(--success);font-weight:800}.quality-score.warn{background:var(--warning-dim);color:var(--warning)}.quality-list{display:grid;gap:10px}.quality-item{display:flex;justify-content:space-between;gap:12px;padding:12px;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);background:var(--bg-surface)}.quality-item strong,.quality-item span{display:block}.quality-item span{color:var(--text-secondary);font-size:.84rem;margin-top:3px}.quality-warning{border-color:#f5a62342}.quality-danger{border-color:#f0445547}.quality-transfer-note{margin-top:12px;color:var(--text-muted);font-size:.84rem}.receipt-status-dot{width:6px;height:6px;border-radius:50%;background:var(--success);box-shadow:0 0 0 2px #34d39a29}.shared-trust-panel{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:18px}.shared-trust-panel div{padding:12px;background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-sm)}.shared-trust-panel span{display:block;color:var(--text-muted);font-size:.72rem;text-transform:uppercase;letter-spacing:.06em}.shared-trust-panel strong{display:block;font-size:1.15rem;margin-top:4px}.shared-trust-panel p{grid-column:1 / -1;color:var(--text-secondary);font-size:.86rem;margin:0}.trust-warn strong,.chip-warning{color:var(--warning)}.chip-verified{color:var(--success);border-color:#34d39a3d;background:var(--success-dim)}@media (max-width: 700px){.shared-trust-panel{grid-template-columns:1fr}.quality-item{flex-direction:column}}@media (max-width: 760px){.admin-toolbar{align-items:stretch;flex-direction:column}.admin-search-wrap,.admin-audit-filter,.admin-audit-date{max-width:none;width:100%}.admin-table-wrap{border:0;overflow:visible;background:transparent}.admin-table,.admin-table thead,.admin-table tbody,.admin-table tr,.admin-table td{display:block;width:100%}.admin-table colgroup,.admin-table thead{display:none}.admin-table tbody{display:grid;gap:12px}.admin-table tbody tr{border:1px solid var(--border-subtle);border-radius:var(--radius-md);overflow:hidden;box-shadow:0 10px 26px #00000038}.admin-table td{display:grid;grid-template-columns:112px minmax(0,1fr);gap:12px;white-space:normal;text-align:right}.admin-table td:before{content:attr(data-label);color:var(--text-muted);font-size:.7rem;font-weight:800;letter-spacing:.06em;text-align:left;text-transform:uppercase}.admin-table td.admin-actions-cell{display:flex;justify-content:flex-end}.admin-table td.admin-actions-cell:before{content:none}}.admin-panel-body{padding-top:4px}.admin-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:20px}.admin-filter-chips{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin:-10px 0 18px}.admin-filter-chips span,.admin-filter-chips button{display:inline-flex;align-items:center;min-height:26px;padding:4px 10px;border:1px solid var(--border-normal);border-radius:99px;background:#7c64f714;color:var(--text-secondary);font:inherit;font-size:.75rem;font-weight:700}.admin-filter-chips button{background:transparent;color:var(--accent);cursor:pointer}.admin-search-wrap{display:flex;align-items:center;gap:8px;background:var(--bg-input);border:1px solid var(--border-normal);border-radius:var(--radius-sm);padding:0 12px;flex:1;max-width:320px}.admin-search-input{background:none;border:none;outline:none;color:var(--text);font-size:.875rem;padding:8px 0;width:100%}.admin-search-input::placeholder{color:var(--text-muted)}.admin-table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--border-subtle)}.admin-table{width:100%;border-collapse:collapse;font-size:.875rem;table-layout:fixed}.admin-table th{padding:10px 12px;text-align:left;font-size:.72rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);background:var(--bg-surface);border-bottom:1px solid var(--border-subtle);white-space:nowrap}.admin-table td{padding:11px 12px;border-bottom:1px solid var(--border-subtle);vertical-align:middle;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-table td.admin-td-wrap{white-space:normal;overflow:visible}.admin-col-name{width:22%}.admin-col-email{width:27%}.admin-col-role{width:9%}.admin-col-status{width:10%}.admin-col-stats{width:14%}.admin-col-joined{width:12%}.admin-col-actions{width:6%}.admin-actions-cell{position:relative;overflow:visible!important;text-align:right}.admin-actions-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;border:none;background:transparent;color:var(--text-muted);cursor:pointer;transition:background var(--transition),color var(--transition)}.admin-actions-btn:hover{background:var(--bg-surface);color:var(--text)}.admin-dropdown{position:absolute;right:0;top:calc(100% + 4px);min-width:130px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;box-shadow:0 8px 24px #00000059;z-index:200;overflow:hidden}.admin-dropdown-item{display:flex;align-items:center;gap:8px;width:100%;padding:9px 14px;background:none;border:none;font-size:.875rem;color:var(--text);cursor:pointer;text-align:left;transition:background var(--transition)}.admin-dropdown-item:hover{background:var(--bg-surface)}.admin-dropdown-item.danger{color:var(--danger)}.admin-dropdown-item.danger:hover{background:#f0445514}.admin-table tbody tr:last-child td{border-bottom:none}.admin-table tbody tr{background:var(--bg-card);transition:background var(--transition)}.admin-table tbody tr:hover{background:var(--bg-card-hover)}.admin-table tbody tr:hover td:first-child{box-shadow:inset 3px 0 0 var(--accent)}.admin-row-inactive td{opacity:.5}.admin-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:99px;font-size:.7rem;font-weight:600;letter-spacing:.04em}.admin-badge-admin{background:#7c64f72e;color:#a590ff}.admin-badge-user{background:#ffffff0f;color:var(--text-muted)}.admin-badge-active{background:#34d39924;color:#34d399}.admin-badge-inactive{background:#f0445524;color:#f04455}.admin-badge-you{background:#f5a62324;color:#f5a623;margin-left:6px}.admin-btn-delete{color:var(--danger)!important}.admin-btn-delete:hover{background:#f044551a!important}.admin-pagination{display:flex;align-items:center;justify-content:space-between;padding:14px 4px 4px;flex-wrap:wrap;gap:10px}.admin-pagination-info{font-size:.8125rem;color:var(--text-muted)}.admin-pagination-btns{display:flex;gap:4px;align-items:center}.admin-stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px}.admin-settings-section{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius);overflow:hidden}.admin-settings-heading{font-size:.75rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--text-muted);padding:12px 18px;border-bottom:1px solid var(--border-subtle);background:var(--bg-surface)}.admin-settings-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 18px;border-bottom:1px solid var(--border-subtle)}.admin-settings-row:last-child{border-bottom:none}.admin-settings-label{font-size:.875rem;font-weight:500;color:var(--text);margin-bottom:3px}.admin-settings-hint{font-size:.78rem;color:var(--text-muted)}.admin-audit-filter{max-width:220px;min-width:180px}.admin-audit-date{width:144px}.admin-audit-table td{vertical-align:top}.admin-audit-action{text-transform:capitalize}.admin-audit-metadata{margin-top:7px;color:var(--text-muted);font-size:.75rem}.admin-audit-metadata summary{cursor:pointer;color:var(--accent);font-weight:700}.admin-audit-metadata pre{max-width:320px;margin:8px 0 0;padding:10px;overflow:auto;border-radius:var(--radius-sm);background:var(--bg-surface);border:1px solid var(--border-subtle);color:var(--text-secondary);font-size:.72rem;line-height:1.45}.admin-toggle{position:relative;display:inline-flex;align-items:center;cursor:pointer;flex-shrink:0}.admin-toggle input{position:absolute;opacity:0;width:0;height:0}.admin-toggle-track{width:40px;height:22px;background:var(--bg-surface);border:1px solid var(--border-normal);border-radius:99px;transition:background .2s,border-color .2s;position:relative}.admin-toggle-track:after{content:"";position:absolute;top:3px;left:3px;width:14px;height:14px;background:var(--text-muted);border-radius:50%;transition:transform .2s,background .2s}.admin-toggle input:checked+.admin-toggle-track{background:var(--accent);border-color:var(--accent)}.admin-toggle input:checked+.admin-toggle-track:after{transform:translate(18px);background:#fff}.settings-modal{max-width:520px}.settings-section{border-top:1px solid var(--border-subtle);padding-top:24px;margin-top:24px}.settings-section-title{font-size:.75rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--text-muted);margin:0 0 16px}.settings-form{display:flex;flex-direction:column;gap:16px}.settings-form .form-group{margin-bottom:0}.settings-row{display:flex;flex-direction:column;gap:10px}.settings-row-label span{font-size:.875rem;font-weight:500;color:var(--text-primary);display:block}.settings-row-label small{font-size:.75rem;color:var(--text-muted);display:block;margin-top:2px}.settings-toggle-group{display:flex;gap:4px;width:100%}.settings-toggle-btn{flex:1;padding:8px 12px;border-radius:var(--radius-sm);border:1px solid var(--border-normal);background:var(--bg-input);color:var(--text-secondary);font-size:.8125rem;font-weight:500;cursor:pointer;font-family:inherit;transition:background var(--transition),color var(--transition),border-color var(--transition);text-align:center;white-space:nowrap}.settings-toggle-btn.active{background:var(--accent-dim);color:var(--accent);border-color:#7c64f759}.settings-toggle-btn:hover:not(.active){background:var(--bg-card-hover);color:var(--text-primary)}.settings-select{width:100%;box-sizing:border-box}.settings-form-footer{display:flex;justify-content:flex-end}.server-status{display:flex;align-items:center;gap:6px}.server-stat{display:flex;align-items:center;gap:4px;font-size:.7rem;background:var(--bg-card);border:1px solid var(--border);border-radius:999px;padding:2px 8px 2px 6px;cursor:default;-webkit-user-select:none;user-select:none}.server-stat-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.server-stat-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.65rem}.server-stat-value{color:var(--text-primary);font-weight:600}.navbar-user-btn{background:none;border:none;cursor:pointer;font:inherit;padding:4px 6px;border-radius:var(--radius-sm);transition:background var(--transition),color var(--transition)}.navbar-user-btn:hover{background:var(--bg-card);color:var(--text-primary)}.auth-forgot-link{color:var(--text-secondary);font-size:.875rem;text-decoration:none;transition:color var(--transition)}.auth-forgot-link:hover{color:var(--accent)}.auth-split-centered{align-items:center;justify-content:center}.auth-success-icon{width:56px;height:56px;border-radius:50%;background:var(--accent-dim);color:var(--accent);display:flex;align-items:center;justify-content:center;margin:0 auto 20px}.quick-log-modal{max-width:460px}.pdf-options-modal{max-width:420px}.pdf-options-body{display:flex;flex-direction:column;gap:10px;padding:4px 0 8px}.pdf-options-label{font-size:.8125rem;color:var(--text-muted);margin:0 0 4px}.pdf-option-row{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:8px;border:1px solid var(--border);background:var(--bg-card);cursor:pointer;transition:border-color .15s}.pdf-option-row:hover:not(.pdf-option-disabled){border-color:var(--accent)}.pdf-option-row input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}.pdf-option-disabled{opacity:.5;cursor:not-allowed}.pdf-option-info{display:flex;flex-direction:column;gap:2px;flex:1}.pdf-option-title{font-size:.9375rem;font-weight:500;color:var(--text)}.pdf-option-desc{font-size:.8rem;color:var(--text-muted)}.pdf-option-badge{font-size:.7rem;color:var(--text-muted);background:var(--bg-deep);border:1px solid var(--border);border-radius:4px;padding:2px 6px;white-space:nowrap}.quick-log-form{display:flex;flex-direction:column;gap:16px}.quick-log-form .form-group{margin-bottom:0}.quick-log-notes{min-height:72px;resize:vertical}.health-value-row{display:flex;align-items:center;gap:6px}.health-dot{width:7px;height:7px;border-radius:50%;display:inline-block;flex-shrink:0}.health-dot-ok{background:var(--success);box-shadow:0 0 5px #34d39a8c}.health-dot-warn{background:var(--warning);box-shadow:0 0 5px #f5a6238c}.health-dot-danger{background:var(--danger);box-shadow:0 0 5px #f044558c;animation:pulse-dot 1.8s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.3}}.status-section{border-radius:var(--radius-lg);border:1px solid;overflow:hidden;margin-bottom:20px;box-shadow:var(--shadow-card)}.status-section-danger{border-color:#f0445538;background:#f0445508}.status-section-warn{border-color:#f5a62338;background:#f5a62308}.status-section-header{display:flex;align-items:center;gap:8px;padding:10px 16px;font-size:.8125rem;font-weight:600;border-bottom:1px solid}.status-section-danger .status-section-header{color:var(--danger);border-bottom-color:#f0445526;background:#f044550f}.status-section-warn .status-section-header{color:var(--warning);border-bottom-color:#f5a62326;background:#f5a6230f}.status-items{display:flex;flex-direction:column}.status-item{display:flex;align-items:center;gap:12px;padding:10px 16px;text-decoration:none;color:inherit;border-bottom:1px solid var(--border-subtle);transition:background var(--transition)}.status-item:last-child{border-bottom:none}.status-item:hover{background:var(--bg-card-hover)}.status-item-body{flex:1;display:flex;align-items:center;gap:7px;min-width:0;overflow:hidden}.status-item-vehicle{font-size:.875rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-shrink:1;min-width:0}.status-item-sep{color:var(--text-muted);font-size:.875rem;flex-shrink:0}.status-item-service{font-size:.8125rem;color:var(--text-secondary);white-space:nowrap;flex-shrink:0}.status-item-due{font-size:.8125rem;font-weight:600;flex-shrink:0;white-space:nowrap}.status-item-due-overdue{color:var(--danger)}.status-item-due-soon{color:var(--warning)}@media (max-width: 640px){.status-item-sep,.status-item-service{display:none}.status-item-vehicle{font-size:.8125rem}}.apikey-section{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:16px}.apikey-display{display:flex;align-items:center;gap:6px;background:var(--bg-input);border:1px solid var(--border-normal);border-radius:var(--radius-md);padding:10px 12px}.apikey-value{flex:1;font-family:JetBrains Mono,monospace;font-size:.8125rem;letter-spacing:.04em;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.apikey-empty{display:flex;align-items:center;gap:10px;padding:14px;background:var(--bg-input);border:1px dashed var(--border-normal);border-radius:var(--radius-md);color:var(--text-muted);font-size:.875rem}.apikey-code{display:block;background:var(--bg-deep);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:10px 14px;font-family:JetBrains Mono,monospace;font-size:.78rem;color:var(--text-secondary);letter-spacing:.01em;overflow-x:auto;white-space:nowrap}.apikey-code-block{white-space:pre;line-height:1.7}.apikey-field-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.apikey-field-name{font-family:JetBrains Mono,monospace;font-size:.8125rem;color:var(--accent);background:var(--accent-dim);padding:2px 7px;border-radius:var(--radius-sm);white-space:nowrap}.apikey-field-type{font-size:.75rem;color:var(--text-muted);white-space:nowrap}.apikey-field-desc{font-size:.8125rem;color:var(--text-secondary)}.idle-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#05050ebf}.idle-modal{max-width:380px;text-align:center;padding:36px 32px 28px}.idle-icon{display:flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:50%;background:#f5a6231f;border:1px solid rgba(245,166,35,.3);color:#f5a623;margin:0 auto 20px}.idle-title{font-size:1.25rem;font-weight:700;color:var(--text);margin:0 0 10px}.idle-desc{font-size:.9rem;color:var(--text-muted);margin:0 0 20px;line-height:1.5}.idle-countdown{font-size:2.5rem;font-weight:700;color:#f5a623;margin-bottom:28px;font-variant-numeric:tabular-nums}.idle-actions{display:flex;gap:10px;justify-content:center}.idle-actions .btn{min-width:130px}.fuel-section{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:24px;margin-bottom:20px}.fuel-section-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px;gap:12px}.fuel-section-header h2{font-size:1.125rem;font-weight:600;margin-top:4px}.fuel-avg-badge{font-size:.8125rem;font-weight:600;padding:4px 10px;border-radius:99px;letter-spacing:.01em}.fuel-avg-badge.eff-good{background:var(--success-dim);color:var(--success)}.fuel-avg-badge.eff-warn{background:var(--warning-dim);color:var(--warning)}.fuel-avg-badge.eff-bad{background:var(--danger-dim);color:var(--danger)}.fuel-section .panel-empty-state{padding:14px 0 2px;border:0;background:transparent}.fuel-table-wrap{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--border-subtle)}.fuel-table{width:100%;border-collapse:collapse;font-size:.875rem}.fuel-table th{text-align:left;padding:10px 14px;font-size:.75rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);background:var(--bg-surface);border-bottom:1px solid var(--border-subtle)}.fuel-table td{padding:11px 14px;border-bottom:1px solid var(--border-subtle);color:var(--text-primary);vertical-align:middle}.fuel-table tr:last-child td{border-bottom:none}.fuel-table tr:hover td{background:var(--bg-card-hover)}.fuel-date{font-weight:500}.fuel-full-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--success);margin-left:6px;vertical-align:middle;opacity:.8}.fuel-eff-chip{font-size:.8rem;font-weight:600;padding:3px 8px;border-radius:99px;display:inline-block}.fuel-eff-chip.eff-good{background:var(--success-dim);color:var(--success)}.fuel-eff-chip.eff-warn{background:var(--warning-dim);color:var(--warning)}.fuel-eff-chip.eff-bad{background:var(--danger-dim);color:var(--danger)}
