:root{color-scheme:light;--bg: #f6f7f4;--surface: #ffffff;--surface-2: #eef4f1;--text: #17211d;--muted: #62706b;--line: #dce4df;--accent: #2560E1;--accent-strong: #1D4ED8;--accent-soft: #DBEAFE;--accent-subtle: rgba(37, 96, 225, .12);--accent-contrast: #ffffff;--teal: var(--accent);--teal-strong: var(--accent-strong);--teal-soft: var(--accent-soft);--blue: var(--accent);--blue-soft: var(--accent-soft);--green: #15803d;--green-soft: #dcfce7;--amber: #b45309;--amber-soft: #fef3c7;--purple: #7c3aed;--purple-soft: #ede9fe;--coral: #e11d48;--coral-soft: #ffe4e6;--danger: #dc2626;--shadow: 0 14px 35px rgba(23, 33, 29, .08);--radius: 8px;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}:root[data-accent=blue]{--accent: #2560E1;--accent-strong: #1D4ED8;--accent-soft: #DBEAFE;--accent-subtle: rgba(37, 96, 225, .12);--accent-contrast: #ffffff}:root[data-accent=green]{--accent: #0F766E;--accent-strong: #0D5F59;--accent-soft: #CCFBF1;--accent-subtle: rgba(15, 118, 110, .12);--accent-contrast: #ffffff}:root[data-accent=purple]{--accent: #7C3AED;--accent-strong: #6D28D9;--accent-soft: #EDE9FE;--accent-subtle: rgba(124, 58, 237, .12);--accent-contrast: #ffffff}:root[data-accent=red]{--accent: #E11D48;--accent-strong: #BE123C;--accent-soft: #FFE4E6;--accent-subtle: rgba(225, 29, 72, .12);--accent-contrast: #ffffff}:root[data-accent=orange]{--accent: #EA580C;--accent-strong: #C2410C;--accent-soft: #FFEDD5;--accent-subtle: rgba(234, 88, 12, .12);--accent-contrast: #ffffff}:root[data-accent=slate]{--accent: #334155;--accent-strong: #1E293B;--accent-soft: #E2E8F0;--accent-subtle: rgba(51, 65, 85, .12);--accent-contrast: #ffffff}:root[data-theme=dark]{color-scheme:dark;--bg: #101412;--surface: #191f1c;--surface-2: #202924;--text: #edf5f1;--muted: #9ca9a3;--line: #314039;--accent: #60A5FA;--accent-strong: #93C5FD;--accent-soft: #172554;--accent-subtle: rgba(96, 165, 250, .14);--accent-contrast: #0f172a;--green: #4ade80;--green-soft: #143d24;--amber: #fbbf24;--amber-soft: #4a3512;--purple: #c084fc;--purple-soft: #38244f;--coral: #fb7185;--coral-soft: #4a1824;--danger: #f87171;--shadow: 0 18px 38px rgba(0, 0, 0, .28)}:root[data-theme=dark][data-accent=blue]{--accent: #60A5FA;--accent-strong: #93C5FD;--accent-soft: #172554;--accent-subtle: rgba(96, 165, 250, .14);--accent-contrast: #0f172a}:root[data-theme=dark][data-accent=green]{--accent: #2DD4BF;--accent-strong: #5EEAD4;--accent-soft: #134E4A;--accent-subtle: rgba(45, 212, 191, .14);--accent-contrast: #0f172a}:root[data-theme=dark][data-accent=purple]{--accent: #A78BFA;--accent-strong: #C4B5FD;--accent-soft: #3B0764;--accent-subtle: rgba(167, 139, 250, .14);--accent-contrast: #0f172a}:root[data-theme=dark][data-accent=red]{--accent: #FB7185;--accent-strong: #FDA4AF;--accent-soft: #4C0519;--accent-subtle: rgba(251, 113, 133, .14);--accent-contrast: #0f172a}:root[data-theme=dark][data-accent=orange]{--accent: #FB923C;--accent-strong: #FDBA74;--accent-soft: #431407;--accent-subtle: rgba(251, 146, 60, .14);--accent-contrast: #0f172a}:root[data-theme=dark][data-accent=slate]{--accent: #CBD5E1;--accent-strong: #F1F5F9;--accent-soft: #334155;--accent-subtle: rgba(203, 213, 225, .14);--accent-contrast: #0f172a}*,*:before,*:after{box-sizing:border-box;letter-spacing:0}html,body{width:100%;min-width:0;overflow-x:hidden}#root{width:100%;min-width:0}body{margin:0;background:var(--bg);color:var(--text)}body,input,select,textarea,button{font:inherit}a{color:inherit;text-decoration:none}button,input,select,textarea{border-radius:var(--radius)}button{cursor:pointer}button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:3px solid var(--accent-subtle);outline-offset:2px}img,svg,canvas,video{display:block;max-width:100%}.screen-center,.loading-panel{min-height:55vh;display:grid;place-items:center}.spinner{width:34px;height:34px;border:3px solid var(--line);border-top-color:var(--teal);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.auth-page{min-height:100vh;display:grid;grid-template-columns:minmax(320px,520px) minmax(360px,1fr);min-width:0;max-width:100%}.auth-panel{min-width:0;padding:clamp(28px,7vw,72px);display:flex;flex-direction:column;justify-content:center;background:var(--surface)}.auth-panel h1{margin:36px 0 8px;font-size:clamp(2rem,4vw,3.2rem);line-height:1}.auth-panel p{margin:0 0 24px;color:var(--muted)}.auth-brand-block{display:flex;align-items:center;justify-content:center;min-width:0;max-width:100%}.auth-brand-logo{width:min(100%,260px);max-height:76px;object-fit:contain}.auth-brand-logo-fallback{display:block;max-width:100%;overflow-wrap:anywhere;color:var(--text);font-size:1.35rem;line-height:1.1}.auth-side{min-width:0;display:flex;flex-direction:column;justify-content:center;gap:26px;padding:clamp(32px,8vw,96px);color:#f8fafc;background:linear-gradient(135deg,color-mix(in srgb,var(--accent) 78%,black),color-mix(in srgb,var(--accent-strong) 70%,black)),radial-gradient(circle at 80% 20%,color-mix(in srgb,var(--accent-soft) 38%,transparent),transparent 34%),var(--accent)}.auth-hero-logo-frame{width:min(100%,320px);display:grid;place-items:center;padding:14px 18px;border:1px solid rgba(255,255,255,.34);border-radius:var(--radius);background:#ffffffeb;box-shadow:0 14px 32px var(--accent-subtle)}.auth-hero-logo{width:min(100%,280px);max-height:112px;object-fit:contain}.auth-hero-logo-fallback{display:block;max-width:100%;overflow-wrap:anywhere;color:var(--accent);font-size:clamp(1.35rem,3vw,2rem);font-weight:850;line-height:1.05;text-align:center}.auth-side h2{max-width:620px;margin:0;font-size:clamp(2rem,5vw,4.4rem);line-height:1}.auth-grid{display:grid;grid-template-columns:repeat(3,minmax(0,110px));gap:10px}.auth-grid span{border:1px solid rgba(255,255,255,.32);border-radius:var(--radius);padding:12px;background:#ffffff1c}.brand{display:flex;align-items:center;gap:12px;min-width:0}.brand.compact{gap:10px}.brand strong{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:1rem}.brand span{display:block;color:var(--muted);font-size:.84rem}.brand-mark{width:42px;height:42px;border-radius:var(--radius);display:grid;place-items:center;flex:0 0 auto;background:var(--teal);color:var(--accent-contrast);font-weight:800}.brand-logo{width:auto;height:42px;max-width:150px;object-fit:contain;flex:0 0 auto}.brand-copy{min-width:0}.auth-brand .brand-mark{width:48px;height:48px}.auth-brand .brand-logo{height:48px;max-width:190px}.auth-form{display:grid;gap:16px}.auth-form label,.field{display:grid;gap:7px;color:var(--muted);font-weight:650;font-size:.9rem}.input-with-icon{display:flex;align-items:center;gap:10px;border:1px solid var(--line);border-radius:var(--radius);padding:0 12px;background:var(--surface-2);color:var(--muted)}.input-with-icon input{width:100%;border:0;padding:13px 0;outline:0;background:transparent;color:var(--text)}.inline-field-action{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px}.inline-field-action .button{white-space:nowrap}.auth-switch{margin-top:18px;color:var(--muted)}.demo-login-box{display:grid;gap:9px;margin-top:14px;padding:14px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-2)}.demo-login-box p{margin:0;color:var(--muted);font-size:.88rem}.install-login-box{display:grid;gap:6px;margin-top:14px;margin-bottom:24px;padding:14px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-2)}.install-login-box p{margin:0;color:var(--muted);font-size:.88rem}.install-login-box a{color:var(--teal);font-weight:800}.auth-switch a,.panel-header a,.back-link{color:var(--teal);font-weight:750}.fine-print{color:var(--muted);font-size:.87rem}.muted{color:var(--muted)}.inline-code{display:block;padding:10px 12px;border-radius:var(--radius);background:var(--surface-2);color:var(--text);overflow-wrap:anywhere}.auth-alert{margin-bottom:16px;padding:12px;border:1px solid var(--coral);border-radius:var(--radius);background:var(--coral-soft);color:var(--coral);font-weight:750}.app-shell{min-height:100vh;display:grid;grid-template-columns:270px minmax(0,1fr);width:100%;min-width:0;max-width:100%;overflow-x:clip}.sidebar{min-width:0;position:sticky;top:0;height:100vh;padding:20px;display:flex;flex-direction:column;gap:22px;border-right:1px solid var(--line);background:var(--surface)}.sidebar>.brand{width:100%;justify-content:center}.nav-list{display:grid;gap:6px}.nav-item,.mobile-nav a{display:flex;align-items:center;gap:10px;min-height:42px;border-radius:var(--radius);padding:10px 12px;color:var(--muted);font-weight:700}.nav-item>span{display:grid;gap:1px;min-width:0}.nav-item small{color:var(--muted);font-size:.68rem;font-weight:650;line-height:1.15;overflow-wrap:anywhere}.nav-item.active,.mobile-nav a.active{background:var(--teal-soft);color:var(--teal-strong)}.sidebar-footer{margin-top:auto;display:grid;gap:12px}.user-pill{display:grid;grid-template-columns:38px minmax(0,1fr);align-items:center;gap:10px;padding:10px;border-radius:var(--radius);background:var(--surface-2)}.user-pill>span{width:38px;height:38px;display:grid;place-items:center;border-radius:50%;background:var(--teal);color:var(--accent-contrast);font-weight:800}.user-pill strong,.user-pill small{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-pill small{color:var(--muted)}.main-column{min-width:0}.topbar{position:sticky;top:0;z-index:10;height:72px;display:flex;align-items:center;gap:14px;min-width:0;max-width:100%;padding:14px clamp(16px,3vw,32px);border-bottom:1px solid var(--line);background:color-mix(in srgb,var(--bg) 88%,transparent);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.search-box{flex:1;min-width:0;display:flex;align-items:center;gap:10px;max-width:540px;padding:0 13px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);color:var(--muted)}.search-box input{width:100%;border:0;outline:0;padding:12px 0;background:transparent;color:var(--text)}.content{min-width:0;max-width:100%;padding:clamp(18px,3vw,32px);padding-bottom:110px}.page-stack{display:grid;gap:22px;min-width:0;max-width:100%}.page-header{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;min-width:0;max-width:100%}.page-header h1{margin:0;font-size:clamp(2rem,4vw,3.2rem);line-height:1}.page-header p{margin:8px 0 0;color:var(--muted)}.eyebrow{display:block;margin-bottom:8px;color:var(--teal);font-size:.78rem;font-weight:850;text-transform:uppercase}.header-actions,.form-actions,.card-actions,.document-actions,.table-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap;min-width:0}.button,.icon-button{border:0;display:inline-flex;align-items:center;justify-content:center;gap:8px;max-width:100%;font-weight:800;transition:transform .15s ease,background .15s ease}.button{min-height:42px;padding:0 15px;white-space:normal}.button:hover,.icon-button:hover{transform:translateY(-1px)}.button.primary{background:var(--teal);color:var(--accent-contrast)}.button.ghost{border:1px solid var(--line);background:var(--surface);color:var(--text)}.button.danger{background:var(--danger);color:#fff}.button.full{width:100%}.button:disabled,.icon-button:disabled{cursor:not-allowed;opacity:.48;transform:none}.compact-button{min-height:36px;padding:0 12px}.icon-button{width:38px;height:38px;border:1px solid var(--line);background:var(--surface);color:var(--text)}.danger-text{color:var(--danger)}.stat-grid{display:grid;grid-template-columns:repeat(6,minmax(150px,1fr));gap:14px;min-width:0}.stat-grid.four{grid-template-columns:repeat(4,minmax(180px,1fr))}.stat-card{min-height:118px;display:grid;grid-template-columns:44px minmax(0,1fr);align-items:center;gap:13px;padding:18px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow);color:var(--text);text-decoration:none;transition:border-color .16s ease,box-shadow .16s ease,transform .16s ease}.stat-card-link{cursor:pointer}.stat-card-link:hover,.stat-card-link:focus-visible{border-color:var(--teal);box-shadow:var(--shadow-strong);transform:translateY(-1px);outline:0}.stat-card span{color:var(--muted);font-weight:700;font-size:.88rem}.stat-card strong{display:block;margin-top:6px;overflow-wrap:anywhere;font-size:clamp(1.45rem,2.5vw,2.05rem);line-height:1}.stat-icon{width:44px;height:44px;display:grid;place-items:center;border-radius:var(--radius);background:var(--teal-soft);color:var(--teal-strong)}.garage-overview{display:grid;gap:14px}.overview-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;min-width:0}.overview-item{min-width:0;min-height:88px;display:grid;grid-template-columns:1fr;gap:3px;align-content:center;justify-items:start;padding:10px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-2);color:var(--text);text-decoration:none}.overview-item[href],a.overview-item{cursor:pointer}a.overview-item:hover,a.overview-item:focus-visible{border-color:var(--teal);outline:0}.overview-item span:not(.overview-icon),.overview-item strong,.overview-item small{min-width:0;overflow-wrap:anywhere}.overview-item strong{font-size:1.35rem;line-height:1}.overview-item small{color:var(--muted);font-weight:750}.overview-icon{width:26px;height:26px;display:grid;place-items:center;border-radius:var(--radius);background:var(--surface);color:var(--muted)}.overview-icon.completed{background:var(--green-soft);color:var(--green)}.overview-icon.due_soon{background:var(--amber-soft);color:var(--amber)}.overview-icon.overdue{background:var(--coral-soft);color:var(--coral)}.overview-attention-list{display:grid;gap:8px}.overview-alert{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:4px 10px;padding:10px 12px;border:1px solid var(--line);border-radius:var(--radius);color:var(--text);text-decoration:none;background:var(--surface-2)}.overview-alert strong,.overview-alert span,.overview-alert small{min-width:0;overflow-wrap:anywhere}.overview-alert small{color:var(--muted)}.vehicle-card.focused{border-color:var(--amber);box-shadow:0 0 0 2px var(--amber-soft)}.focus-banner{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);color:var(--text);font-size:.9rem}.focus-banner span,.focus-banner a{min-width:0;overflow-wrap:anywhere}.focus-banner a{color:var(--blue);font-weight:700;text-decoration:none}.focus-banner a:hover,.focus-banner a:focus-visible{text-decoration:underline}.onboarding-callout{display:grid;gap:6px;padding:14px;border:1px solid var(--line);border-radius:var(--radius);background:var(--teal-soft)}.onboarding-callout h3,.onboarding-callout p{margin:0}.next-step-actions{display:flex;flex-wrap:wrap;gap:8px}.tone-blue .stat-icon{background:var(--blue-soft);color:var(--blue)}.tone-green .stat-icon{background:var(--green-soft);color:var(--green)}.tone-amber .stat-icon{background:var(--amber-soft);color:var(--amber)}.tone-purple .stat-icon{background:var(--purple-soft);color:var(--purple)}.tone-coral .stat-icon{background:var(--coral-soft);color:var(--coral)}.dashboard-grid,.report-grid,.settings-grid{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(320px,.85fr);gap:18px;min-width:0;max-width:100%}.settings-grid{align-items:start}.panel{min-width:0;max-width:100%;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow);padding:18px}.panel-header{min-height:36px;display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px;min-width:0;flex-wrap:wrap}.panel-header h2{margin:0;min-width:0;overflow-wrap:anywhere;font-size:1.12rem}.list,.timeline{display:grid;gap:10px}.list-row,.timeline-item{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;padding:12px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-2);min-width:0;max-width:100%}.timeline-item{grid-template-columns:14px minmax(0,1fr) auto}.timeline-dot{width:10px;height:10px;border-radius:50%;background:var(--teal)}.list-row strong,.timeline-item strong{display:block;overflow-wrap:anywhere}.list-row span,.timeline-item span,.timeline-item p,.vehicle-card p,.inventory-card p,.document-card p,.reminder-card p{margin:3px 0 0;color:var(--muted);font-size:.9rem}.row-meta{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap;text-align:right}.badge{display:inline-flex;align-items:center;min-height:26px;max-width:100%;overflow:hidden;text-overflow:ellipsis;border-radius:999px;padding:0 9px;background:var(--teal-soft);color:var(--teal-strong);font-size:.75rem;font-weight:850;text-transform:capitalize;white-space:nowrap}.badge.overdue{background:var(--coral-soft);color:var(--coral)}.badge.due_soon,.badge.ordered{background:var(--amber-soft);color:var(--amber)}.badge.completed,.badge.fitted,.badge.active{background:var(--green-soft);color:var(--green)}.badge.archived,.badge.returned,.badge.neutral{background:var(--surface-2);color:var(--muted)}.badge.sold{background:var(--blue-soft);color:var(--blue)}.badge.high,.badge.urgent{background:var(--coral-soft);color:var(--coral)}.badge.medium{background:var(--amber-soft);color:var(--amber)}.badge.low{background:var(--surface-2);color:var(--muted)}.badge.admin{background:var(--purple-soft);color:var(--purple);gap:5px}.attention-strip,.vehicle-grid,.vehicle-status-grid,.inventory-grid,.reminder-grid,.note-grid,.admin-action-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(230px,100%),1fr));gap:14px;min-width:0}.attention-card,.vehicle-status-card,.vehicle-card,.inventory-card,.reminder-card,.note-card,.document-card,.admin-action-card{position:relative;min-width:0;max-width:100%;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface)}.attention-card{display:grid;gap:8px;padding:16px;color:var(--coral)}.vehicle-status-card{display:grid;gap:12px;padding:14px;background:var(--surface-2)}.vehicle-status-card strong,.vehicle-status-card span{display:block}.vehicle-status-card>div:first-child span{margin-top:3px;color:var(--muted);font-size:.9rem}.admin-action-card{display:grid;gap:9px;padding:16px;color:var(--text);background:var(--surface-2)}.admin-action-card svg{color:var(--teal)}.admin-action-card span{color:var(--muted)}.admin-email-form{display:grid;gap:14px;min-width:0}.admin-csv-import{display:grid;grid-template-columns:minmax(0,1fr) minmax(180px,260px) auto;gap:12px;align-items:end;min-width:0}.admin-import-summary{display:grid;gap:8px;margin-top:14px;padding:12px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-2)}.admin-import-errors{display:grid;gap:5px;max-height:180px;overflow:auto}.admin-import-errors p{margin:0;color:var(--coral);overflow-wrap:anywhere}.admin-email-preview{display:grid;gap:8px;min-width:0;padding:14px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-2)}.admin-email-preview .eyebrow{margin-bottom:0}.admin-email-preview strong,.admin-email-preview p,.admin-email-preview small{min-width:0;overflow-wrap:anywhere}.admin-email-preview p{margin:0;color:var(--muted);white-space:pre-wrap}.admin-email-preview small{color:var(--muted)}.vehicle-card{overflow:hidden;box-shadow:var(--shadow)}.vehicle-media{position:relative;aspect-ratio:16 / 9;display:grid;place-items:center;overflow:hidden;background:linear-gradient(135deg,color-mix(in srgb,var(--teal-soft) 80%,transparent),color-mix(in srgb,var(--blue-soft) 70%,transparent)),var(--surface-2);color:var(--teal)}.vehicle-media img{width:100%;height:100%;object-fit:cover}.vehicle-media .badge{position:absolute;top:10px;left:10px}.photo-form-panel{display:grid;grid-template-columns:minmax(min(180px,100%),260px) minmax(0,1fr);gap:14px;min-width:0;max-width:100%;padding:14px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-2)}.photo-preview{min-width:0;max-width:100%;min-height:150px;display:grid;place-items:center;overflow:hidden;border-radius:var(--radius);background:var(--surface);color:var(--teal)}.photo-preview img{width:100%;height:100%;object-fit:cover}.photo-form-controls,.profile-photo-controls{display:grid;align-content:start;gap:10px}.photo-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.advanced-field{color:var(--muted)}.advanced-field summary{cursor:pointer;font-weight:800}.advanced-field .field{margin-top:10px}.vehicle-card-body{padding:15px}.vehicle-card h2,.inventory-card h2,.reminder-card h2,.document-card h2{margin:8px 0 3px;font-size:1.15rem;overflow-wrap:anywhere}.mini-stats{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}.dvla-mini-row{display:flex;align-items:center;gap:7px;flex-wrap:wrap;margin-top:12px}.dvla-mini-row small{color:var(--muted);font-weight:700}.mini-stats span{min-height:30px;max-width:100%;display:inline-flex;align-items:center;overflow-wrap:anywhere;border-radius:var(--radius);padding:0 9px;background:var(--surface-2);color:var(--muted);font-weight:750;font-size:.82rem}.vehicle-card .card-actions{padding:0 12px 12px}.quick-add-wrapper{position:relative}.quick-add-menu{position:absolute;right:0;top:calc(100% + 8px);z-index:20;width:220px;max-width:calc(100vw - 32px);display:grid;gap:4px;padding:8px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow)}.quick-add-menu button{min-height:40px;border:0;display:flex;align-items:center;gap:9px;padding:0 10px;border-radius:var(--radius);background:transparent;color:var(--text);font-weight:750;text-align:left}.quick-add-menu button:hover{background:var(--surface-2)}.attention-row-title{display:grid;grid-template-columns:22px minmax(0,1fr);align-items:center;gap:10px}.jobs-panel{align-self:start}.job-list{display:grid;gap:10px}.job-row{display:grid;grid-template-columns:38px minmax(0,1fr) auto;align-items:center;gap:12px;padding:12px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-2);min-width:0}.job-row.completed{opacity:.72}.job-row.completed strong{text-decoration:line-through}.job-check{width:36px;height:36px;border:1px solid var(--line);display:grid;place-items:center;border-radius:50%;background:var(--surface);color:var(--muted)}.job-row.completed .job-check{background:var(--green-soft);color:var(--green)}.job-row strong,.job-row span,.job-row p{display:block}.job-row span{margin-top:4px;color:var(--muted);font-size:.9rem}.job-row span .badge{margin-right:6px}.job-row p{margin:6px 0 0;color:var(--muted);font-size:.9rem}.job-actions{display:flex;gap:6px}.unified-timeline{max-height:620px;overflow:auto;padding-right:4px}.unified-timeline .timeline-item{align-items:start}.timeline-dot.completed{background:var(--green)}.timeline-dot.due_soon,.timeline-dot.medium,.timeline-dot.ordered{background:var(--amber)}.timeline-dot.overdue,.timeline-dot.high,.timeline-dot.urgent{background:var(--coral)}.timeline-dot.low,.timeline-dot.neutral{background:var(--muted)}.filter-bar{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(170px,100%),1fr));gap:10px;min-width:0;max-width:100%;padding:12px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface)}.filter-bar input,.filter-bar select,.field input,.field select,.field textarea{width:100%;min-width:0;max-width:100%;border:1px solid var(--line);background:var(--surface-2);color:var(--text);outline:0}.filter-bar input,.filter-bar select,.field input,.field select{min-height:42px;padding:0 11px}.field textarea{min-height:104px;padding:11px;resize:vertical}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;min-width:0;max-width:100%}.form-grid.single{grid-template-columns:1fr}.dvla-preview{display:grid;gap:13px;min-width:0;padding:14px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-2)}.vehicle-wizard{display:grid;gap:16px;min-width:0;max-width:100%}.wizard-progress{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(130px,100%),1fr));gap:8px;min-width:0}.wizard-progress button{min-height:42px;border:1px solid var(--line);display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--radius);background:var(--surface-2);color:var(--muted);font-weight:800;text-align:left}.wizard-progress button span{width:24px;height:24px;display:grid;place-items:center;flex:0 0 auto;border-radius:50%;background:var(--surface);color:var(--muted);font-size:.8rem}.wizard-progress button.active,.wizard-progress button.complete{border-color:transparent;background:var(--teal-soft);color:var(--teal-strong)}.wizard-progress button.active span,.wizard-progress button.complete span{background:var(--teal);color:var(--accent-contrast)}.wizard-step-panel{display:grid;gap:16px;min-width:0}.wizard-step-header{display:grid;gap:6px;min-width:0}.wizard-step-header h3{margin:0;font-size:1.35rem}.wizard-step-header p{margin:0;color:var(--muted)}.guided-field span{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.guided-field em,.required-marker{font-style:normal;font-size:.74rem;font-weight:850}.guided-field em{color:var(--muted)}.required-marker{color:var(--teal)}.source-marker{padding:2px 6px;border-radius:999px;background:var(--blue-soft);color:var(--blue);font-size:.72rem;font-weight:850}.field-help,.char-counter,.field-error{font-size:.82rem;font-weight:700}.field-help,.char-counter{color:var(--muted)}.char-counter.limit,.field-error{color:var(--danger)}.guided-field.has-error input,.guided-field.has-error select,.guided-field.has-error textarea,.field.has-error input{border-color:var(--danger);background:color-mix(in srgb,var(--coral-soft) 48%,var(--surface))}.review-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(180px,100%),1fr));gap:10px;min-width:0}.review-grid>div{display:grid;gap:5px;padding:12px;border-radius:var(--radius);background:var(--surface-2)}.review-grid span{color:var(--muted);font-size:.86rem;font-weight:750}.review-grid strong{overflow-wrap:anywhere}.wizard-actions{display:flex;justify-content:flex-end;gap:8px;flex-wrap:wrap;min-width:0}.dvla-preview-actions{display:flex;flex-wrap:wrap;gap:8px}.dvla-preview h3{margin:0 0 4px;font-size:1.3rem}.dvla-preview p{margin:0;color:var(--muted)}.dvla-preview-grid,.dvla-status-grid,.integration-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(170px,100%),1fr));gap:10px;min-width:0}.dvla-preview-grid span,.dvla-status-grid>div,.integration-grid>div{display:grid;gap:5px;padding:12px;border-radius:var(--radius);background:var(--surface);color:var(--muted)}.dvla-preview-grid strong,.dvla-status-grid strong,.integration-grid strong{color:var(--text);overflow-wrap:anywhere}.add-vehicle-page{width:min(100%,820px);margin:0 auto}.add-vehicle-panel{width:100%;max-width:100%}.add-vehicle-step{display:grid;gap:16px;min-width:0;max-width:100%}.add-vehicle-step h2{margin:0;font-size:1.35rem}.add-vehicle-step .form-actions{justify-content:flex-start}.back-button{border:0;padding:0;background:transparent;color:var(--blue);font:inherit;font-weight:800}.lookup-confirm-card{display:grid;grid-template-columns:52px minmax(0,1fr);gap:12px;min-width:0;max-width:100%}.lookup-confirm-card .dvla-preview-grid{grid-column:1 / -1}.lookup-confirm-icon{width:52px;height:52px;display:grid;place-items:center;border-radius:var(--radius);background:var(--teal-soft);color:var(--teal-strong)}.lookup-confirm-summary{display:grid;align-content:center;gap:4px;min-width:0}.lookup-confirm-summary strong,.lookup-confirm-summary span{min-width:0;overflow-wrap:anywhere}.lookup-confirm-summary span{color:var(--muted);font-weight:750}.compact-photo-panel{grid-template-columns:112px minmax(0,1fr);padding:12px}.compact-photo-panel .photo-preview{min-height:104px}.add-vehicle-page input[type=file]{min-width:0;max-width:100%;overflow:hidden}.dvla-status-panel .badge,.integration-grid .badge{width:fit-content}.mot-history-list{display:grid;gap:10px;margin-top:14px}.mot-history-item{display:grid;gap:10px;padding:14px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);min-width:0}.mot-history-summary,.mot-history-meta{display:flex;flex-wrap:wrap;gap:8px 14px;align-items:center;justify-content:space-between;min-width:0}.mot-history-summary>div,.mot-history-meta{min-width:0}.mot-history-summary strong,.mot-history-summary span,.mot-history-meta span,.mot-history-details li{overflow-wrap:anywhere}.mot-history-details{color:var(--muted)}.mot-history-details summary{cursor:pointer;color:var(--text);font-weight:750}.mot-history-details ul{margin:8px 0 0;padding-left:20px}.check-row{display:flex;align-items:center;gap:9px;color:var(--text);font-weight:750}.check-row input{width:18px;height:18px}.span-2{grid-column:1 / -1}.modal-backdrop,.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40;display:grid;place-items:center;padding:18px;overflow-x:hidden;background:#1014128f}.modal{width:min(100%,720px);max-width:calc(100vw - 36px);min-width:0;max-height:min(88vh,980px);overflow:auto;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow);padding:18px}.modal>*{min-width:0;max-width:100%}.modal-large{width:min(100%,980px);max-width:calc(100vw - 36px)}.modal-small{width:min(100%,440px);max-width:calc(100vw - 36px)}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;min-width:0}.modal-header h2{margin:0;min-width:0;overflow-wrap:anywhere;font-size:1.28rem}.empty-state{min-height:230px;display:grid;place-items:center;align-content:center;gap:10px;padding:26px;border:1px dashed var(--line);border-radius:var(--radius);color:var(--muted);text-align:center;background:var(--surface)}.empty-state h3{margin:0;color:var(--text)}.empty-state p{margin:0;max-width:42rem}.vehicle-profile{display:grid;grid-template-columns:minmax(260px,360px) minmax(0,1fr);gap:18px;min-width:0;max-width:100%;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow);padding:18px}.profile-image{min-width:0;max-width:100%;min-height:260px;display:grid;place-items:center;overflow:hidden;border-radius:var(--radius);background:var(--surface-2);color:var(--teal)}.profile-image img{width:100%;height:100%;object-fit:cover}.profile-details h2{margin:10px 0 16px;font-size:clamp(1.7rem,3vw,2.6rem)}.profile-photo-controls{margin-top:16px;padding:12px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-2)}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(150px,100%),1fr));gap:10px;min-width:0}.detail-grid span{display:grid;gap:4px;padding:12px;border-radius:var(--radius);background:var(--surface-2);color:var(--muted)}.detail-grid strong{color:var(--text)}.profile-notes{margin:16px 0 0;color:var(--muted)}.back-link{display:inline-flex;align-items:center;gap:6px;margin-bottom:10px}.inventory-card,.reminder-card{display:grid;grid-template-columns:46px minmax(0,1fr);gap:12px;min-width:0;padding:15px;box-shadow:var(--shadow)}.inventory-card .card-actions,.reminder-card .card-actions{grid-column:1 / -1}.inventory-icon,.reminder-icon,.document-icon{width:44px;height:44px;display:grid;place-items:center;border-radius:var(--radius);background:var(--surface-2);color:var(--teal)}.document-list{display:grid;gap:12px}.document-card{display:grid;grid-template-columns:48px minmax(0,1fr) auto;align-items:center;gap:13px;padding:14px;min-width:0}.note-card{min-height:170px;padding:15px}.note-card h3{margin:12px 0 8px}.note-card p{color:var(--muted);white-space:pre-wrap}.note-card .icon-button{position:absolute;top:10px;right:10px}.table-panel{padding:0;overflow:hidden;min-width:0;max-width:100%}.table-panel .panel-header{padding:18px 18px 0}.responsive-table{display:block;width:100%;max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}table{width:100%;min-width:720px;max-width:none;border-collapse:collapse}th,td{padding:14px 16px;border-bottom:1px solid var(--line);text-align:left;vertical-align:middle}th{color:var(--muted);font-size:.78rem;text-transform:uppercase}td strong,.table-sub{display:block}.table-sub{color:var(--muted);font-size:.84rem}.chart-panel{min-height:360px;min-width:0;max-width:100%;overflow:hidden}.chart-panel .recharts-responsive-container{max-width:100%}.segmented{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.segmented button{min-height:42px;border:1px solid var(--line);display:inline-flex;align-items:center;justify-content:center;gap:8px;background:var(--surface-2);color:var(--muted);font-weight:800;text-transform:capitalize}.segmented button.active{background:var(--teal-soft);color:var(--teal-strong);border-color:transparent}.theme-accent-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(210px,100%),1fr));gap:10px;min-width:0;margin-bottom:14px}.theme-accent-option{position:relative;min-width:0;min-height:76px;display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:12px;padding:12px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-2);color:var(--text);text-align:left}.theme-accent-option.active{border-color:var(--accent);background:var(--accent-subtle)}.theme-accent-swatch{width:34px;height:34px;border:2px solid color-mix(in srgb,#ffffff 70%,transparent);border-radius:50%;background:var(--theme-accent-color);box-shadow:0 0 0 1px var(--line)}.theme-accent-option strong,.theme-accent-option small{display:block;min-width:0;overflow-wrap:anywhere}.theme-accent-option small{margin-top:3px;color:var(--muted);font-size:.78rem;font-weight:800}.theme-accent-preview{width:48px;display:grid;gap:5px}.theme-accent-preview span:first-child{height:12px;border-radius:999px;background:var(--theme-accent-color)}.theme-accent-preview span:last-child{height:8px;border-radius:999px;background:color-mix(in srgb,var(--theme-accent-color) 22%,var(--surface))}.theme-accent-check{position:absolute;top:8px;right:8px;color:var(--accent)}.code-card{display:grid;gap:10px}.code-card code{display:block;padding:12px;border-radius:var(--radius);background:var(--surface-2);overflow-wrap:anywhere}.notification-settings{display:grid;gap:16px;min-width:0}.notification-status-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px 12px;align-items:center;padding:12px;border-radius:var(--radius);background:var(--surface-2)}.notification-status-row span,.notification-status-row small{min-width:0;overflow-wrap:anywhere}.notification-status-row small{grid-column:1 / -1;color:var(--muted)}.notification-controls-grid,.lead-time-group>div{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(190px,100%),1fr));gap:10px;min-width:0}.notification-controls-grid .check-row,.lead-time-group .check-row{min-height:42px;padding:10px 12px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-2)}.lead-time-group{display:grid;gap:8px;color:var(--muted);font-weight:750}.notification-log-list .list-row{align-items:start}.install-helper{display:grid;gap:16px;min-width:0}.install-intro{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;min-width:0;padding:14px;border-radius:var(--radius);background:var(--surface-2)}.install-intro p{margin:0;color:var(--muted)}.install-instruction-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;min-width:0}.install-card{min-width:0;padding:14px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-2)}.install-card-heading{display:flex;align-items:center;gap:9px;margin-bottom:10px;color:var(--teal)}.install-card-heading h3{margin:0;color:var(--text);font-size:1rem}.install-card ol{margin:0;padding-left:24px;color:var(--text)}.install-card li{margin:7px 0;padding-left:2px}.admin-user-header{display:grid;grid-template-columns:minmax(0,1fr) minmax(260px,360px);gap:18px;align-items:start;min-width:0;max-width:100%}.admin-button-stack{display:grid;gap:10px}.access-denied{min-height:55vh;display:grid;place-items:center;align-content:center;gap:10px;text-align:center}.access-denied h1{margin:0}.access-denied p{margin:0;color:var(--muted)}.install-public-page{min-height:100vh;display:grid;place-items:center;padding:clamp(18px,4vw,42px);background:var(--bg)}.install-public-shell{width:min(100%,960px);display:grid;gap:18px;min-width:0}.install-public-panel{display:grid;gap:18px}.install-public-actions{justify-content:flex-start}.car-check-page,.car-check-page *{min-width:0}.car-check-hero{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(320px,.9fr);gap:20px;align-items:start}.car-check-hero h1{margin:0;font-size:clamp(2rem,4vw,3.1rem);line-height:1}.car-check-hero p{max-width:780px;margin:10px 0 0;color:var(--muted);overflow-wrap:anywhere}.car-check-tagline{color:var(--text)!important;font-size:1.15rem;font-weight:800}.car-check-form{display:grid;gap:12px;padding:14px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-2)}.car-check-form input{min-height:54px;border:1px solid var(--line);background:var(--surface);color:var(--text);font-size:1.2rem;font-weight:850;text-transform:uppercase}.car-check-state,.car-check-error{display:flex;align-items:center;gap:12px}.car-check-error{border-color:color-mix(in srgb,var(--danger) 42%,var(--line));background:var(--coral-soft);color:var(--coral)}.car-check-error h2,.car-check-error p{margin:0 0 6px;overflow-wrap:anywhere}.car-check-summary-grid,.car-category-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(190px,100%),1fr));gap:10px}.car-check-detail,.car-category-card{display:grid;gap:5px;padding:12px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-2);overflow-wrap:anywhere}.car-check-detail span,.car-category-card p{color:var(--muted);font-size:.88rem}.car-check-detail strong,.car-category-card strong{overflow-wrap:anywhere}.car-risk-card{border-left:5px solid var(--accent)}.car-risk-card.risk-high{border-left-color:var(--coral)}.car-risk-card.risk-medium{border-left-color:var(--amber)}.car-risk-card.risk-low{border-left-color:var(--green)}.car-risk-heading{display:flex;justify-content:space-between;gap:16px;align-items:flex-start}.car-risk-heading h2,.car-risk-heading p,.car-check-disclaimer,.car-check-footer-disclaimer{margin:0;overflow-wrap:anywhere}.car-risk-heading p,.car-check-disclaimer,.car-check-footer-disclaimer{color:var(--muted)}.car-check-disclaimer{margin-top:12px;padding-top:12px;border-top:1px solid var(--line);font-size:.9rem}.car-finding-list,.car-mot-list,.watched-list{display:grid;gap:10px}.car-finding{display:grid;grid-template-columns:22px minmax(0,1fr);gap:10px;padding:12px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-2)}.car-finding.high{border-color:color-mix(in srgb,var(--coral) 40%,var(--line))}.car-finding.medium{border-color:color-mix(in srgb,var(--amber) 44%,var(--line))}.car-finding.completed{border-color:color-mix(in srgb,var(--green) 36%,var(--line))}.car-finding strong,.car-finding p{display:block;margin:0;overflow-wrap:anywhere}.car-finding p{margin-top:3px;color:var(--muted)}.car-category-card>div,.car-mot-main,.watched-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.common-issues-note{margin-top:-4px;margin-bottom:14px;overflow-wrap:anywhere}.common-issues-sections{display:grid;grid-template-columns:minmax(0,.85fr) minmax(0,1.15fr);gap:16px;align-items:start}.common-issues-sections h3{margin:0 0 10px;font-size:1rem}.car-finding-list.compact .car-finding{padding:10px}.common-issue-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(240px,100%),1fr));gap:10px}.common-issue-card{display:grid;gap:8px;padding:12px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-2);overflow-wrap:anywhere}.common-issue-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.common-issue-meta{display:flex;gap:8px;flex-wrap:wrap;color:var(--muted);font-size:.84rem;text-transform:capitalize}.common-issue-card p{margin:0;color:var(--muted);overflow-wrap:anywhere}.common-issue-card a{color:var(--teal);font-weight:800}.common-issues-toggle{margin-top:10px}.car-check-split{display:grid;grid-template-columns:minmax(0,1fr) minmax(240px,.8fr);gap:16px}.clean-list{display:grid;gap:8px;margin:0;padding-left:18px;color:var(--muted);overflow-wrap:anywhere}.mileage-timeline{display:grid;gap:8px}.mileage-timeline div{display:flex;justify-content:space-between;gap:10px;padding:9px 10px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-2)}.mileage-timeline span{color:var(--muted)}.car-mot-item{display:grid;gap:10px;padding:12px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-2)}.car-mot-main p{margin:3px 0 0;color:var(--muted);overflow-wrap:anywhere}.car-mot-badges{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}.car-mot-item summary{cursor:pointer;color:var(--teal);font-weight:800}.car-defect-list{display:grid;gap:8px;margin-top:10px}.car-defect-list div{display:grid;gap:5px;padding:10px;border-radius:var(--radius);background:var(--surface)}.car-defect-list p{margin:0;color:var(--muted);overflow-wrap:anywhere}.car-question-list{color:var(--text)}.car-action-grid{display:grid;grid-template-columns:minmax(220px,.8fr) minmax(0,1.2fr);gap:14px;align-items:start}.car-add-garage-form{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:end}.success-strip{display:flex;align-items:center;gap:8px;margin-bottom:12px;padding:10px 12px;border:1px solid color-mix(in srgb,var(--green) 36%,var(--line));border-radius:var(--radius);background:var(--green-soft);color:var(--green);font-weight:750;flex-wrap:wrap}.success-strip a{text-decoration:underline}.watched-row{padding:10px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-2)}.watched-main{display:grid;gap:3px;min-width:0;border:0;background:transparent;color:var(--text);text-align:left;padding:0}.watched-main span{color:var(--muted);font-size:.9rem;overflow-wrap:anywhere}.car-check-footer-disclaimer{font-size:.9rem}.toast-stack{position:fixed;right:18px;bottom:18px;z-index:80;display:grid;gap:10px;width:min(380px,calc(100vw - 36px))}.toast{display:grid;grid-template-columns:20px minmax(0,1fr) 38px;align-items:center;gap:10px;padding:10px 10px 10px 14px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow)}.toast-success{color:var(--green)}.toast-error{color:var(--danger)}.toast-info{color:var(--blue)}.mobile-nav,.mobile-menu-button,.mobile-drawer{display:none}@media (max-width: 1180px){.stat-grid,.stat-grid.four{grid-template-columns:repeat(2,minmax(0,1fr))}.dashboard-grid,.report-grid,.settings-grid{grid-template-columns:1fr}}@media (max-width: 820px){html,body,#root{width:100%;max-width:100%;overflow-x:hidden}.auth-page{grid-template-columns:1fr;width:100%;max-width:100%}.auth-brand-logo{width:min(100%,340px);max-height:120px;object-fit:contain}.auth-side{display:none}.app-shell{width:100%;max-width:100%;display:block;overflow-x:hidden}.sidebar{display:none}.mobile-menu-button{display:inline-flex}.content{width:100%;max-width:100%;padding:16px 16px 98px}.topbar{height:64px;padding:10px 12px;gap:10px;width:100%;max-width:100%;overflow:hidden}.search-box{max-width:none}.brand-logo{height:36px;max-width:122px}.brand strong{font-size:.95rem}.page-header{align-items:stretch;flex-direction:column}.header-actions{justify-content:flex-start;width:100%}.stat-grid,.stat-grid.four,.vehicle-profile,.admin-user-header{grid-template-columns:1fr}.profile-image{min-height:210px}.document-card,.job-row,.list-row,.timeline-item,.car-check-hero,.car-check-split,.common-issues-sections,.car-action-grid,.car-add-garage-form{grid-template-columns:1fr}.car-risk-heading,.car-mot-main,.watched-row{align-items:flex-start;flex-direction:column}.car-mot-badges{justify-content:flex-start}.document-card,.job-row,.list-row,.timeline-item,.vehicle-profile,.panel,.empty-state{width:100%;max-width:100%}.photo-form-panel{grid-template-columns:1fr}.row-meta,.job-actions,.document-actions{justify-content:flex-start;text-align:left}.form-grid,.admin-csv-import{grid-template-columns:1fr}.modal-backdrop{padding:12px}.modal,.modal-large,.modal-small{width:100%;max-width:calc(100vw - 24px);padding:16px}.modal-header{align-items:flex-start}.mobile-nav{position:fixed;left:10px;right:10px;bottom:20px;z-index:30;display:grid;grid-template-columns:repeat(4,1fr);gap:4px;width:auto;max-width:calc(100% - 20px);padding:6px;border:1px solid var(--line);border-radius:14px;background:var(--surface);box-shadow:var(--shadow)}.mobile-nav a{min-width:0;min-height:54px;justify-content:center;flex-direction:column;gap:3px;padding:7px 4px;font-size:.72rem;overflow:hidden}.mobile-nav a span{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-nav a small{display:none}.mobile-drawer{width:min(100%,330px);max-width:100%;height:100%;margin-left:0;margin-right:auto;display:flex;flex-direction:column;gap:16px;padding:18px;border-radius:0 var(--radius) var(--radius) 0;background:var(--surface)}.drawer-backdrop{place-items:stretch;padding:0}}@media (max-width: 768px){input,textarea,select{font-size:16px}.modal-backdrop{width:100%;max-width:100%;place-items:center;padding:12px;overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch}.modal,.modal-large,.modal-small{width:calc(100vw - 24px);max-width:calc(100vw - 24px);min-width:0;max-height:calc(100vh - 24px);max-height:calc(100dvh - 24px);margin-left:auto;margin-right:auto;overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch}.modal .form-grid,.modal form,.modal .vehicle-wizard,.modal .wizard-progress,.modal .wizard-step-panel,.modal .review-grid,.modal .photo-form-panel,.modal .dvla-preview,.modal .dvla-preview-grid,.modal .field,.modal .input-with-icon,.modal .inline-field-action,.modal .form-actions,.modal .photo-actions,.modal .dvla-preview-actions{min-width:0;max-width:100%}.modal .form-grid{grid-template-columns:minmax(0,1fr)}.modal .span-2{grid-column:1 / -1}.modal input,.modal textarea,.modal select,.modal button{min-width:0;max-width:100%}.modal input[type=file]{min-width:0;overflow:hidden;text-overflow:ellipsis}.modal .form-actions,.modal .wizard-actions,.modal .photo-actions,.modal .dvla-preview-actions{display:flex;flex-wrap:wrap;justify-content:flex-start}.modal .form-actions .button,.modal .wizard-actions .button,.modal .photo-actions .button,.modal .dvla-preview-actions .button{flex:1 1 180px}.modal .wizard-progress{grid-template-columns:1fr}.modal .wizard-progress button,.modal .dvla-preview,.modal .dvla-preview *{overflow-wrap:anywhere}.modal .photo-preview,.modal .photo-preview img{max-width:100%}.overview-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.add-vehicle-page,.add-vehicle-page *,.lookup-confirm-card,.compact-photo-panel{min-width:0;max-width:100%}.add-vehicle-step .form-actions{align-items:stretch}.add-vehicle-step .form-actions .button{flex:1 1 180px}.compact-photo-panel{grid-template-columns:1fr}.lookup-confirm-card{grid-template-columns:44px minmax(0,1fr)}.car-check-page input,.car-check-page select,.car-check-page textarea{font-size:16px}.lookup-confirm-icon{width:44px;height:44px}.overview-alert,.install-intro,.install-instruction-grid{grid-template-columns:1fr}.install-intro .button{width:100%}}@media (max-width: 520px){.auth-panel{padding:24px 16px}.auth-brand-logo{width:min(100%,210px);max-height:62px}.button{width:100%}.car-category-card>div,.mileage-timeline div{align-items:flex-start;flex-direction:column}.car-check-state,.car-check-error{align-items:flex-start}.icon-button{width:40px;flex:0 0 40px}.filter-bar{grid-template-columns:1fr;padding:10px}.inline-field-action{grid-template-columns:1fr}.quick-add-wrapper,.quick-add-wrapper>.button{width:100%}.quick-add-menu{left:0;right:0;width:100%;max-width:100%}.toast-stack{left:12px;right:12px;width:auto;max-width:calc(100% - 24px);bottom:84px}.content{padding:14px 12px 98px}.page-stack{gap:16px}.panel,.vehicle-profile,.empty-state,.photo-form-panel{padding:14px}.profile-image{min-height:190px}.stat-card,.vehicle-card-body,.inventory-card,.reminder-card,.document-card,.note-card{padding:14px}.table-panel .panel-header{padding:14px 14px 0}th,td{padding:12px}}@media print{:root{--bg: #ffffff;--surface: #ffffff;--surface-2: #f4f4f4;--text: #111111;--muted: #444444;--line: #cccccc;--shadow: none}.sidebar,.topbar,.mobile-nav,.print-hidden,.toast-stack{display:none!important}.app-shell{display:block}.content{padding:0}.panel,.vehicle-profile{box-shadow:none;break-inside:avoid}}
