  :root{
    --bg:#f6f6f7; --surface:#ffffff; --ink:#171717; --muted:#868a8f; --faint:#a9adb3;
    --line:rgba(23,23,23,.11); --line-2:rgba(23,23,23,.06); --accent:#0071e3;
    --cat-license:#c47d12; --cat-own:#0071e3; --cat-drive:#1ea672; --cat-spot:#c6359b; --cat-culture:#6b54e6;
    --r:2px; --sh:0 1px 2px rgba(23,23,23,.04);
    --font:"Inter","Inter Placeholder",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
    --num:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
    --maxw:1000px;
    /* themed surfaces (night overrides below) */
    --bg-grad-a:#fafafa; --bg-grad-b:#f4f4f5; --ghost:#ececed; --spk:#d6d7da; --sub:#55585e;
    --nav-bg:rgba(241,241,242,.9); --nav-border:rgba(23,23,23,.05);
    /* racing-line phase + record semantics */
    --phase-peak:#1ea672; --phase-cruise:#c47d12; --phase-brake:#e5484d;
    --rec-alltime:#8b5cf6; --rec-improve:#1ea672; --rec-below:#caa53d;
    --on-ink:#fff; --ph-bg:#edeef1; --focus-ring:rgba(0,113,227,.12); --drop-border:#cdd0d5; --drop-hover:#f4f9ff;
    color-scheme:light;
  }
  [data-theme="night"]{
    --bg:#0a0b0e; --surface:#101218; --ink:#f4f5f7; --muted:#9aa0ab; --faint:#5b616d;
    --line:rgba(255,255,255,.12); --line-2:rgba(255,255,255,.06); --accent:#e8a33d;
    --cat-license:#e8a33d; --cat-own:#3a93ff; --cat-drive:#2ed18a; --cat-spot:#e06ad0; --cat-culture:#9b8cff;
    --sh:0 1px 2px rgba(0,0,0,.5);
    --bg-grad-a:#0c0d12; --bg-grad-b:#070809; --ghost:#14161c; --spk:#1d212b; --sub:#b6bcc6;
    --nav-bg:rgba(16,18,24,.82); --nav-border:rgba(255,255,255,.08);
    --phase-cruise:#e8a33d;
    --on-ink:#0a0b0e; --ph-bg:#16181f; --focus-ring:rgba(232,163,61,.22); --drop-border:rgba(255,255,255,.16); --drop-hover:rgba(232,163,61,.08);
    color-scheme:dark;
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
  body{background:var(--bg);color:var(--ink);transition:background .3s,color .3s;font-family:var(--font);font-weight:450;font-feature-settings:"cv11","ss01";
    -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;min-height:100svh;position:relative;letter-spacing:-.01em}
  body::before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;background:linear-gradient(180deg,var(--bg-grad-a),var(--bg-grad-b))}
  a{color:inherit}
  sup{font-size:.4em;font-weight:500;vertical-align:super;top:-.2em;position:relative;color:var(--muted);letter-spacing:0}
  .lab{font-weight:550;font-size:10.5px;letter-spacing:.02em;color:var(--faint)}

  /* subtle pill nav (RavaLabs) */
  .navwrap{position:sticky;top:0;z-index:40;display:flex;justify-content:center;padding:18px 16px 4px;pointer-events:none}
  .bar{pointer-events:auto;display:flex;align-items:center;gap:14px;background:var(--nav-bg);
    backdrop-filter:saturate(1.5) blur(16px);-webkit-backdrop-filter:saturate(1.5) blur(16px);
    border:1px solid var(--nav-border);border-radius:999px;padding:7px 7px 7px 16px}
  .brand{display:flex;align-items:center;gap:8px;text-decoration:none;font-weight:560;font-size:14px;letter-spacing:-.02em}
  .brand img{height:14px;width:auto;display:block}
  .navlink{text-decoration:none;color:var(--muted);font-weight:500;font-size:13px;letter-spacing:-.01em;padding:0 4px;transition:.18s}
  .navlink:hover{color:var(--ink)}
  .navicon{width:30px;height:30px;display:flex;align-items:center;justify-content:center;text-decoration:none;
    background:var(--surface);border:1px solid var(--line);border-radius:999px;color:var(--ink);font-size:13px;transition:.3s}
  .navicon:hover{transform:rotate(90deg);color:var(--accent)}
  .themebtn{cursor:pointer;font:inherit;line-height:1;padding:0}
  .themebtn:hover{transform:none;color:var(--accent)}

  .wrap{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:0 clamp(16px,5vw,30px)}

  /* hero — ghost wordmark + sparkles */
  header.hero{position:relative;z-index:2;text-align:center;padding:clamp(54px,10vh,120px) clamp(20px,5vw,40px) clamp(34px,6vh,60px);
    display:flex;flex-direction:column;align-items:center;gap:20px;max-width:780px;margin:0 auto}
  .ghost{position:absolute;z-index:-1;top:46%;left:50%;transform:translate(-50%,-50%);
    font-weight:800;font-size:clamp(7rem,24vw,19rem);line-height:.8;letter-spacing:-.05em;color:var(--ghost);
    filter:blur(2px);opacity:.9;white-space:nowrap;pointer-events:none;user-select:none}
  .spk{position:absolute;z-index:-1;color:var(--spk);font-size:15px;pointer-events:none;user-select:none}
  .spk.a{top:12%;left:16%}.spk.b{top:20%;right:18%;font-size:20px}.spk.c{top:62%;left:11%;font-size:19px}
  .spk.d{top:70%;right:14%;font-size:13px}.spk.e{top:40%;right:8%}.spk.f{top:54%;left:30%;font-size:12px}
  .kicker{display:inline-flex;align-items:center;gap:.55em;font-weight:550;font-size:12px;letter-spacing:.02em;color:var(--muted)}
  .spark{display:inline-block;color:var(--accent);animation:spin 9s linear infinite}
  @keyframes spin{to{transform:rotate(360deg)}}
  h1{font-weight:600;font-size:clamp(2.7rem,8.5vw,5rem);line-height:.98;letter-spacing:-.05em;color:var(--ink)}
  .sub{max-width:580px;color:var(--sub);font-size:clamp(1.02rem,2.2vw,1.2rem);line-height:1.55;font-weight:450}
  .sub b{color:var(--ink);font-weight:550}
  .sub .brandblue{color:var(--accent);font-weight:560}
  .priv{display:inline-flex;align-items:center;gap:.55em;font-weight:500;font-size:11.5px;letter-spacing:0;color:var(--muted);
    background:var(--surface);border:1px solid var(--line);border-radius:2px;padding:7px 12px}
  .priv .lockdot{width:6px;height:6px;border-radius:50%;background:var(--cat-drive)}

  /* stats */
  .stats{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;margin:10px 0 6px}
  .stat{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:16px 12px;text-align:center}
  .stat .n{font-weight:600;font-size:1.75rem;line-height:1;letter-spacing:-.02em;font-variant-numeric:tabular-nums;font-family:var(--num)}
  .sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
  .stat .l{margin-top:7px;font-weight:550;font-size:10px;letter-spacing:.01em;color:var(--faint)}
  @media(max-width:720px){.stats{grid-template-columns:repeat(3,1fr)}}

  /* toolbar + filters */
  .toolbar{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin:22px 0 10px}
  .btn{display:inline-flex;align-items:center;gap:.5em;border:1px solid var(--line);background:var(--surface);color:var(--ink);
    border-radius:var(--r);padding:10px 16px;cursor:pointer;font-family:var(--font);font-weight:550;font-size:13px;letter-spacing:-.01em;transition:.16s}
  .btn:hover{border-color:var(--faint)}
  .btn.primary{background:var(--ink);color:var(--on-ink);border-color:var(--ink)}
  .btn.primary:hover{filter:brightness(.92)}
  .btn.ghost{background:transparent;color:var(--muted);border-color:transparent}
  .btn.ghost:hover{color:var(--ink);background:var(--surface);border-color:var(--line)}
  .toolbar .spacer{flex:1}
  .filters{display:flex;flex-wrap:wrap;gap:6px;margin:4px 0}
  .chip{cursor:pointer;border:1px solid var(--line);background:var(--surface);border-radius:var(--r);padding:7px 11px;
    font-weight:550;font-size:11px;letter-spacing:-.005em;color:var(--muted);display:inline-flex;align-items:center;gap:.5em;transition:.16s}
  .chip .d{width:7px;height:7px;border-radius:50%}
  .chip[aria-pressed="true"]{color:var(--ink);border-color:var(--faint)}
  .chip.off{opacity:.42}

  /* dropzone */
  .drop{margin:14px 0;border:1px dashed var(--drop-border);border-radius:var(--r);padding:34px 20px;text-align:center;cursor:pointer;transition:.2s;background:var(--surface)}
  .drop:hover,.drop.drag{border-color:var(--accent);background:var(--drop-hover)}
  .drop .big{font-size:1.05rem;font-weight:550;margin-bottom:6px;letter-spacing:-.02em}
  .drop .small{color:var(--muted);font-size:.92rem;font-weight:450}
  .drop.compact{padding:15px;display:flex;align-items:center;justify-content:center;gap:14px}
  .drop.compact .big{font-size:.95rem;margin:0}.drop.compact .small{display:none}

  /* empty */
  .empty{text-align:center;padding:52px 16px 76px;color:var(--muted)}
  .empty h2{font-weight:600;font-size:clamp(1.7rem,5vw,2.4rem);color:var(--ink);margin-bottom:12px;letter-spacing:-.04em}
  .empty p{max-width:520px;margin:0 auto 24px;line-height:1.6;font-size:1.02rem;font-weight:450}
  .empty .row{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}

  /* timeline */
  #timeline{position:relative;padding:12px 0 40px}
  .spine{position:absolute;left:19px;top:0;bottom:0;width:1px;background:var(--line);overflow:hidden}
  .spine{display:none}
  #timeline svg.ribbon{position:absolute;left:0;top:0;width:100%;pointer-events:none;z-index:1;overflow:visible}
  .ribbon-line{stroke:url(#phaseGrad);stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;opacity:.95;stroke-dasharray:1;stroke-dashoffset:0}
  #timeline svg.ribbon .head{fill:var(--accent);filter:drop-shadow(0 0 5px var(--accent)) drop-shadow(0 0 2px var(--accent));transition:opacity .25s}
  @media (prefers-reduced-motion:reduce){ .ribbon-line{stroke-dashoffset:0 !important} #timeline svg.ribbon .head{display:none} .ev.in .node.mile::before{animation:none} }
  .yr{position:relative;margin:32px 0 16px;padding-left:54px;font-weight:550;font-size:13px;letter-spacing:0;color:var(--faint)}
  .yr b{color:var(--ink);font-size:22px;letter-spacing:-.04em;margin-right:.5em;font-weight:600}
  .ev{position:relative;padding-left:54px;margin:0 0 14px}
  .ev .node{position:absolute;left:13px;top:21px;width:14px;height:14px;border-radius:50%;background:#fff;
    border:1.5px solid var(--c,var(--accent));box-shadow:0 0 0 4px var(--bg);z-index:2}
  .ev .node::after{content:"";position:absolute;inset:3px;border-radius:50%;background:var(--c,var(--accent));opacity:0;transition:opacity .4s}
  .ev.in .node::after{opacity:1}
  .card{display:flex;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;
    transition:border-color .25s,transform .25s}
  .card:hover{border-color:var(--faint)}
  .card .ph{position:relative;flex:0 0 36%;max-width:290px;min-height:150px;overflow:hidden;background:var(--ph-bg)}
  .card .ph img{width:100%;height:100%;object-fit:cover;display:block;
    filter:url(#m-h) saturate(.97);transform:translateX(-12px) scale(1.05);opacity:.5;
    transition:filter .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1),opacity .7s}
  .ev.in .card .ph img{filter:none;transform:none;opacity:1}
  .card.nophoto .ph{flex-basis:4px;min-height:0;max-width:4px;background:var(--c,var(--accent))}
  .card.nophoto .ph img{display:none}
  .body{flex:1;padding:16px 18px;min-width:0}
  .tagrow{display:flex;align-items:center;gap:9px;margin-bottom:9px;flex-wrap:wrap}
  .tag{display:inline-flex;align-items:center;gap:.45em;font-weight:550;font-size:11px;letter-spacing:-.005em;
    color:var(--c,var(--accent));background:color-mix(in srgb,var(--c,var(--accent)) 8%,#fff);
    border:1px solid color-mix(in srgb,var(--c,var(--accent)) 20%,transparent);border-radius:var(--r);padding:4px 9px}
  .date{font-weight:450;font-size:12px;color:var(--faint);font-variant-numeric:tabular-nums}
  .card h3{font-size:1.18rem;font-weight:600;letter-spacing:-.03em;margin-bottom:5px;color:var(--ink)}
  .meta{display:flex;flex-wrap:wrap;gap:5px 16px;margin:8px 0 0;font-size:13px;color:var(--sub);font-weight:450}
  .meta span{display:inline-flex;gap:.4em}
  .meta i{color:var(--faint);font-style:normal;font-weight:550;font-size:10px;letter-spacing:.02em;text-transform:uppercase;align-self:center}
  .note{margin-top:10px;color:var(--sub);font-size:.97rem;line-height:1.55}
  .acts{display:flex;gap:6px;margin-top:13px}
  .acts button{background:var(--surface);border:1px solid var(--line);color:var(--muted);border-radius:var(--r);padding:6px 11px;cursor:pointer;
    font-family:var(--font);font-weight:550;font-size:11px;transition:.16s}
  .acts button:hover{color:var(--ink);border-color:var(--faint)}
  .acts .del:hover{color:#e5484d;border-color:#e5484d}
  @media(max-width:620px){.card{flex-direction:column}.card .ph{flex-basis:auto;max-width:none;height:200px}.card.nophoto .ph{height:4px}}

  /* modal */
  .scrim{position:fixed;inset:0;z-index:60;background:rgba(23,23,23,.32);backdrop-filter:blur(3px);display:none;align-items:center;justify-content:center;padding:24px 14px;overflow:auto}
  .scrim.on{display:flex}
  .modal{width:min(680px,100%);max-height:90vh;display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line);border-radius:4px;overflow:hidden;box-shadow:0 24px 70px rgba(23,23,23,.18)}
  .modal>header,.modal>footer{flex:0 0 auto}
  .modal>header{display:flex;align-items:center;justify-content:space-between;padding:17px 22px;border-bottom:1px solid var(--line-2)}
  .modal>header .t{font-weight:550;font-size:13px;letter-spacing:-.01em;color:var(--muted)}
  .modal>header .x{cursor:pointer;color:var(--faint);background:none;border:none;font-size:24px;line-height:1}
  .modal .pad{padding:20px 22px 24px;overflow:auto;flex:1 1 auto;min-height:0}
  .mphoto-wrap{position:relative;margin-bottom:16px}
  .mphoto{width:100%;height:200px;border-radius:var(--r);object-fit:cover;background:var(--ph-bg);border:1px solid var(--line);display:block}
  .mphoto-x{position:absolute;top:8px;right:8px;width:28px;height:28px;border-radius:999px;background:rgba(23,23,23,.62);color:#fff;border:none;cursor:pointer;font-size:17px;line-height:1;display:flex;align-items:center;justify-content:center}
  .mphoto-x:hover{background:rgba(23,23,23,.85)}
  .photoadd{width:100%;display:flex;align-items:center;justify-content:center;gap:.5em;cursor:pointer;font-family:var(--font);font-weight:500;font-size:13.5px;color:var(--muted);background:var(--bg);border:1.5px dashed var(--drop-border);border-radius:var(--r);padding:16px;transition:.16s}
  .photoadd:hover{border-color:var(--accent);color:var(--accent);background:var(--drop-hover)}
  .photoadd .pa-ic{font-size:17px;line-height:1}
  .pad .lab{display:block;margin:16px 0 9px}
  .types{display:flex;flex-wrap:wrap;gap:6px}
  .tbtn{cursor:pointer;border:1px solid var(--line);background:var(--surface);border-radius:var(--r);padding:8px 11px;
    font-family:var(--font);font-size:13px;font-weight:450;color:var(--sub);display:inline-flex;align-items:center;gap:.45em;transition:.16s}
  .tbtn:hover{color:var(--ink);border-color:var(--faint)}
  .tbtn[aria-pressed="true"]{color:var(--on-ink);background:var(--c);border-color:var(--c);font-weight:550}
  .grid2{display:grid;grid-template-columns:1fr 1fr;gap:13px}
  .fld label{display:block;font-weight:550;font-size:10px;letter-spacing:.02em;text-transform:uppercase;color:var(--faint);margin-bottom:7px}
  .fld input,.fld textarea{width:100%;background:var(--bg);border:1px solid var(--line);border-radius:var(--r);color:var(--ink);
    padding:10px 12px;font-family:var(--font);font-size:14px;font-weight:450;transition:.15s}
  .fld input::placeholder,.fld textarea::placeholder{color:var(--faint)}
  .fld input:focus,.fld textarea:focus{outline:none;border-color:var(--accent);background:var(--surface);box-shadow:0 0 0 3px var(--focus-ring)}
  .fld textarea{resize:vertical;min-height:64px;line-height:1.5}
  .fld.hide{display:none}
  .modal>footer{display:flex;justify-content:flex-end;gap:9px;padding:15px 22px;border-top:1px solid var(--line-2);background:var(--surface)}

  footer.foot{position:relative;z-index:2;text-align:center;padding:48px 20px 64px;border-top:1px solid var(--line);margin-top:40px;
    display:flex;flex-direction:column;gap:12px;align-items:center}
  footer.foot .line{font-weight:600;font-size:clamp(1.5rem,5vw,2.1rem);letter-spacing:-.05em;color:var(--ink)}
  footer.foot .m{font-weight:450;font-size:13px;color:var(--muted)}
  footer.foot a{color:var(--accent);text-decoration:none}footer.foot a:hover{text-decoration:underline}
  input[type=file]{display:none}
  @media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}.spark{animation:none}.ghost{filter:none}
    .ev .card .ph img{filter:none!important;transform:none!important;opacity:1!important}.ev .node::after{opacity:1}}
  .btn[hidden]{display:none!important}
  /* progressive wizard */
  .wsteps{display:flex;align-items:center;margin-bottom:18px}
  .wstep{width:22px;height:22px;border-radius:999px;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:var(--faint);background:var(--surface)}
  .wstep.on{border-color:var(--ink);color:var(--ink)} .wstep.cur{background:var(--ink);color:var(--on-ink);border-color:var(--ink)}
  .wsep{width:18px;height:1px;background:var(--line);margin:0 6px}
  .qhead{font-size:1.12rem;font-weight:600;letter-spacing:-.03em;color:var(--ink);margin:0 0 16px}
  .qhead::before{content:"";display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--c,var(--accent));margin-right:9px;vertical-align:middle}
  .chapters{display:grid;grid-template-columns:1fr 1fr;gap:9px}
  .chcard{cursor:pointer;text-align:left;border:1px solid var(--line);background:var(--surface);border-radius:var(--r);padding:15px;display:flex;flex-direction:column;gap:2px;transition:.16s;font-family:var(--font)}
  .chcard:hover{border-color:var(--c);transform:translateY(-1px)}
  .chico{font-size:19px;margin-bottom:6px}
  .chname{font-weight:600;font-size:14.5px;letter-spacing:-.02em;color:var(--ink)}
  .chdesc{font-size:11.5px;color:var(--muted);line-height:1.35}
  .tlist{display:flex;flex-direction:column;gap:6px}
  .trow{cursor:pointer;text-align:left;display:flex;align-items:center;gap:11px;border:1px solid var(--line);background:var(--surface);border-radius:var(--r);padding:12px 14px;transition:.14s;font-family:var(--font)}
  .trow:hover{border-color:var(--c)}
  .tico{font-size:16px;width:20px;text-align:center;flex:0 0 20px}
  .tlabel{font-weight:550;font-size:14px;color:var(--ink);flex:1;letter-spacing:-.01em}
  .tonce{font-size:8.5px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--c);border:1px solid color-mix(in srgb,var(--c) 30%,transparent);border-radius:2px;padding:2px 5px}
  .tdone{font-size:11px;font-weight:550;color:var(--cat-drive)}
  .trow.isdone .tlabel{color:var(--muted)}
  .fbadge{font-size:8.5px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--c,var(--accent));border:1px solid color-mix(in srgb,var(--c,var(--accent)) 30%,transparent);border-radius:2px;padding:3px 6px}
  .ev .node.mile{background:var(--c,var(--accent));border-width:2px}
  .ev .node.mile::after{opacity:1;background:#fff;inset:4px}
  .ev .node.mile::before{content:"";position:absolute;inset:-1px;border-radius:50%;border:2px solid var(--c,var(--accent));opacity:0;pointer-events:none}
  .ev.in .node.mile::before{animation:checkpoint .85s cubic-bezier(.2,.7,.2,1) .12s 1}
  @keyframes checkpoint{0%{opacity:.85;transform:scale(1)}100%{opacity:0;transform:scale(3.4)}}

  /* view tabs + map */
  .viewtabs{display:inline-flex;gap:2px;background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:3px;margin:6px 0 4px}
  .viewtabs button{border:none;background:transparent;color:var(--muted);font-family:var(--font);font-weight:550;font-size:12.5px;letter-spacing:-.01em;padding:7px 18px;border-radius:999px;cursor:pointer;transition:.16s}
  .viewtabs button[aria-pressed="true"]{background:var(--ink);color:var(--on-ink)}
  .wrap.view-map .toolbar,.wrap.view-map .filters,.wrap.view-map .drop,.wrap.view-map #timeline,.wrap.view-map #empty,
  .wrap.view-garage .toolbar,.wrap.view-garage .filters,.wrap.view-garage .drop,.wrap.view-garage #timeline,.wrap.view-garage #empty{display:none !important}
  .wrap:not(.view-map) #mapview{display:none !important}
  .wrap:not(.view-garage) #garageview{display:none !important}
  #mapview{position:relative;margin:8px 0 40px}
  .mapwrap{position:relative;border:1px solid var(--line);border-radius:var(--r);background:linear-gradient(180deg,var(--bg-grad-a),var(--bg-grad-b));overflow:hidden}
  .mapwrap svg{display:block;width:100%;height:auto}
  .grat{stroke:var(--line);stroke-width:1;opacity:.7}
  .maproute{fill:none;stroke:var(--accent);stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;filter:drop-shadow(0 0 4px color-mix(in srgb,var(--accent) 55%,transparent));stroke-dasharray:1;stroke-dashoffset:1;animation:mapdraw 1.2s cubic-bezier(.6,0,.2,1) forwards}
  @keyframes mapdraw{to{stroke-dashoffset:0}}
  .mappin{cursor:pointer;stroke:var(--surface);stroke-width:2;transition:.16s}
  .mappin:hover{stroke:var(--ink)}
  .maptray{margin-top:12px;font-size:12.5px;color:var(--muted);font-weight:500}
  .maptray b{color:var(--ink);font-weight:600;font-variant-numeric:tabular-nums}
  .mapempty{padding:64px 20px;text-align:center;color:var(--muted);font-size:1rem;line-height:1.6}
  @media (prefers-reduced-motion:reduce){ .maproute{animation:none;stroke-dashoffset:0} }

  .land{fill:color-mix(in srgb,var(--ink) 9%,transparent);stroke:color-mix(in srgb,var(--ink) 30%,transparent);stroke-width:1.1;vector-effect:non-scaling-stroke}
  .gtick{fill:var(--faint);font-family:var(--num);font-size:9px;font-weight:500;opacity:.65}

  #pauseFloat{display:none;position:fixed;left:50%;bottom:22px;transform:translateX(-50%);z-index:70;align-items:center;gap:.5em;background:var(--ink);color:var(--on-ink);border:none;border-radius:999px;padding:12px 24px;font-family:var(--font);font-weight:600;font-size:13px;letter-spacing:-.01em;cursor:pointer;box-shadow:0 10px 34px rgba(0,0,0,.32)}
  body.playing #pauseFloat{display:inline-flex}
  @media (prefers-reduced-motion:reduce){ #playBtn{display:none} }

  #pbBar{display:none;position:fixed;top:0;left:0;width:100%;height:5px;z-index:75;background:color-mix(in srgb,var(--ink) 12%,transparent);cursor:pointer}
  #pbFill{height:100%;width:0;background:var(--accent);box-shadow:0 0 8px var(--accent);transition:width .08s linear}
  body.playing #pbBar{display:block}

  #toast{position:fixed;left:50%;bottom:24px;transform:translateX(-50%) translateY(20px);z-index:80;background:var(--ink);color:var(--on-ink);padding:11px 20px;border-radius:999px;font-family:var(--font);font-weight:550;font-size:13px;letter-spacing:-.01em;box-shadow:0 10px 34px rgba(0,0,0,.3);opacity:0;pointer-events:none;transition:opacity .25s,transform .25s;max-width:86vw;text-align:center}
  #toast.on{opacity:1;transform:translateX(-50%) translateY(0)}

  #garageview{margin:8px 0 40px}
  .garage{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px}
  .carcard{cursor:pointer;text-align:left;border:1px solid var(--line);background:var(--surface);border-radius:var(--r);padding:16px;display:flex;flex-direction:column;gap:9px;transition:.16s;font-family:var(--font)}
  .carcard:hover{border-color:var(--faint);transform:translateY(-1px)}
  .carmk{font-weight:600;font-size:1.05rem;letter-spacing:-.02em;color:var(--ink)}
  .carmeta{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted);font-weight:500}
  .carinit{width:22px;height:22px;border-radius:50%;background:var(--bg-grad-b);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:11px;color:var(--ink);flex:0 0 auto}
  .carstrip{display:flex;gap:2px;height:6px}
  .carstrip span{flex:1;border-radius:1px;min-width:2px}
  .carstats{font-size:12px;color:var(--faint);font-variant-numeric:tabular-nums}
  .carstats b{color:var(--ink);font-weight:600}
  .carstats .owned{color:var(--phase-peak);font-weight:600}

  #carfilterbar{display:flex;align-items:center;gap:8px;margin:8px 0 2px;font-size:12.5px;color:var(--muted);font-weight:500}
  #carfilterbar[hidden]{display:none}
  #carfilterbar b{color:var(--ink);font-weight:600}
  #carfilterbar .cfdot{width:8px;height:8px;border-radius:50%;background:var(--accent)}
  #carfilterbar .cfx{margin-left:2px;border:1px solid var(--line);background:var(--surface);color:var(--muted);border-radius:999px;width:20px;height:20px;cursor:pointer;font-size:13px;line-height:1;display:inline-flex;align-items:center;justify-content:center}
  #carfilterbar .cfx:hover{color:var(--ink);border-color:var(--faint)}
  .telemetry{margin-top:20px;border-top:1px solid var(--line-2);padding-top:16px}
  .telemetry h4{font-weight:550;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);margin-bottom:8px}
  .telrow{display:flex;justify-content:space-between;align-items:baseline;gap:12px;padding:8px 0;border-bottom:1px solid var(--line-2)}
  .telrow .tl{color:var(--muted);font-size:11px;letter-spacing:.04em;text-transform:uppercase;font-weight:500;font-family:var(--font)}
  .telrow .tv{color:var(--ink);font-size:14px;font-weight:600;text-align:right;font-family:var(--num);font-variant-numeric:tabular-nums}
