/* ── Theme variables ── */
:root{--bg:#0f0f0f;--bg2:#161616;--bg3:#1a1a1a;--bg-hov:#181818;--bd:#222;--bd2:#1a1a1a;--bd3:#2a2a2a;--t1:#e0e0e0;--t2:#777;--t3:#666;--t4:#555;--t5:#bbb;--t6:#444}
html[data-theme=light]{--bg:#f5f5f5;--bg2:#ffffff;--bg3:#efefef;--bg-hov:#ececec;--bd:#e0e0e0;--bd2:#e8e8e8;--bd3:#d0d0d0;--t1:#111;--t2:#666;--t3:#555;--t4:#777;--t5:#333;--t6:#999}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
@keyframes spin{to{transform:rotate(360deg)}}
/* ── Live timing (OpenF1) ── */
@keyframes livepulse{0%,100%{opacity:1}50%{opacity:.25}}
.live-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:#777;margin-right:5px;vertical-align:middle}
.tbtn .live-dot{margin-right:6px}
/* The dot only turns red and flickers while a session is actually being tracked. */
html.is-live .tbtn[data-tab="live"] .live-dot{background:#e10600;box-shadow:0 0 6px rgba(225,6,0,.8);animation:livepulse 1.1s ease-in-out infinite}
#live-banner .live-dot{background:#e10600;box-shadow:0 0 6px rgba(225,6,0,.8);animation:livepulse 1.1s ease-in-out infinite}
#live-banner{background:linear-gradient(90deg,rgba(225,6,0,.18),rgba(225,6,0,.04));border:1px solid rgba(225,6,0,.45);border-radius:8px;padding:9px 14px;margin-bottom:12px;font-size:13px;color:var(--t1);cursor:pointer;transition:background .15s}
#live-banner:hover{background:linear-gradient(90deg,rgba(225,6,0,.28),rgba(225,6,0,.08))}
.live-head{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;margin-bottom:10px}
.live-pill{display:inline-flex;align-items:center;background:#e10600;color:#fff;font-size:11px;font-weight:700;padding:2px 8px;border-radius:10px;letter-spacing:.03em;margin-right:8px}
.live-pill .live-dot{background:#fff;box-shadow:none;animation:livepulse 1.1s ease-in-out infinite}
.live-sess{font-size:15px;font-weight:700;color:var(--t1)}
.live-loc{font-size:12px;color:var(--t3);margin-left:8px}
.live-meta{font-size:12px;color:var(--t2)}
.live-flag{background:var(--bg3);border-left:3px solid #888;border-radius:5px;padding:8px 12px;margin-bottom:10px;font-size:12px}
.live-tbl td{padding:6px 8px}
.tyre{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border:2px solid #888;border-radius:50%;font-size:10px;font-weight:700}
.live-cd-wrap{font-size:13px;color:var(--t2);margin:6px 0 14px}
.live-cd{font-variant-numeric:tabular-nums;font-weight:700;color:#e10600;font-size:15px}

/* F1 start-light loader: lights illuminate in sequence, then black out */
.f1-lights{display:inline-flex;gap:8px;padding:7px 10px;background:#0a0a0a;border:1px solid #222;border-radius:8px}
.f1-light{width:13px;height:13px;border-radius:50%;background:#2a0606;box-shadow:inset 0 0 0 1px #000;animation:f1pod 2.4s linear infinite}
.f1-light:nth-child(2){animation-delay:.18s}
.f1-light:nth-child(3){animation-delay:.36s}
.f1-light:nth-child(4){animation-delay:.54s}
.f1-light:nth-child(5){animation-delay:.72s}
@keyframes f1pod{
  0%,8%{background:#2a0606;box-shadow:inset 0 0 0 1px #000}
  14%,72%{background:#ff2424;box-shadow:0 0 10px 2px rgba(255,40,40,.8),inset 0 0 0 1px #ff8a8a}
  80%,100%{background:#2a0606;box-shadow:inset 0 0 0 1px #000}
}
/* light mode: lighter gantry + lighter "off" lights so it isn't a black box */
html[data-theme=light] .f1-lights{background:#dcdce1;border-color:#c4c4ca}
html[data-theme=light] .f1-light{animation-name:f1pod_light}
@keyframes f1pod_light{
  0%,8%{background:#c2bcbc;box-shadow:inset 0 0 0 1px #ada6a6}
  14%,72%{background:#ff2424;box-shadow:0 0 10px 2px rgba(255,40,40,.6),inset 0 0 0 1px #ffb0b0}
  80%,100%{background:#c2bcbc;box-shadow:inset 0 0 0 1px #ada6a6}
}
/* "GO" — all lights flash green once data has loaded */
.f1-lights.go .f1-light{animation:none;background:#16c60c;box-shadow:0 0 11px 2px rgba(22,198,12,.85),inset 0 0 0 1px #93f08c}
body{font-family:Arial,sans-serif;background:var(--bg);color:var(--t1);min-height:100vh;padding:16px;transition:background 0.2s,color 0.2s}
.ftbl{width:100%;border-collapse:collapse;font-size:12px}
.ftbl th{font-size:10px;font-weight:600;color:var(--t2);padding:7px 8px;border-bottom:1px solid var(--bd);text-align:left;white-space:nowrap;cursor:default}
.ftbl td{padding:6px 8px;border-bottom:1px solid var(--bd2);white-space:nowrap;vertical-align:middle}
.ftbl tr:last-child td{border-bottom:none}
.ftbl tr:hover td{background:var(--bg-hov)}
.pill{display:inline-flex;align-items:center;justify-content:center;min-width:20px;width:auto;padding:0 3px;height:20px;border-radius:3px;font-size:10px;font-weight:600}
.fpills{display:flex;gap:2px}
.tnav{display:flex;border-bottom:1px solid var(--bd);margin-bottom:14px;flex-wrap:wrap}
.tbtn{background:none;border:none;padding:9px 14px;font-size:12px;color:var(--t2);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;font-weight:400;white-space:nowrap;transition:color 0.15s}
.tbtn:hover{color:var(--t5)}
.tbtn.on{color:var(--t1);border-bottom-color:#e10600;font-weight:600}
.tpnl{display:none}
.tpnl.on{display:block}
.mcards{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:8px;margin-bottom:14px}
.mcard{background:var(--bg2);border-radius:6px;padding:10px 12px;border:1px solid var(--bd)}
.mlbl{font-size:11px;color:var(--t3);margin-bottom:3px}
.mval{font-size:20px;font-weight:600;line-height:1.1;color:var(--t1)}
.msub{font-size:11px;color:var(--t4);margin-top:2px}
.sx{overflow-x:auto}
.note{font-size:11px;color:var(--t4);margin-top:10px;padding:7px 10px;border-left:2px solid var(--bd3)}
.pdot{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:4px;font-size:12px;font-weight:600}
.sbadge{display:inline-block;padding:1px 6px;border-radius:10px;font-size:10px;font-weight:600}
.cbox{background:var(--bg2);border-radius:6px;padding:14px;margin-bottom:12px;border:1px solid var(--bd2)}
.ctitle{font-size:11px;color:var(--t3);margin-bottom:10px;text-transform:uppercase;letter-spacing:0.5px}
.lgnd{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:8px}
.lgnd span{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--t2)}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
.three-col{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;margin-bottom:12px}
@media(max-width:800px){.two-col,.three-col{grid-template-columns:1fr}}
/* ── Landing page (always dark) ── */
#landing{position:fixed;inset:0;background:#0a0a0a;z-index:9999;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;overflow-y:auto;transition:opacity 0.4s ease}
#landing.fade-out{opacity:0;pointer-events:none}
.lnd-stripe{position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#e10600 0%,#ff4444 50%,#e10600 100%)}
.lnd-title{font-size:clamp(28px,5vw,52px);font-weight:700;color:#fff;letter-spacing:-1px;text-align:center;margin-bottom:6px}
.lnd-title span{color:#e10600}
.lnd-sub{font-size:14px;color:#555;text-align:center;margin-bottom:36px;letter-spacing:0.5px;text-transform:uppercase}
.lnd-desc{max-width:600px;text-align:center;font-size:14px;color:#888;line-height:1.7;margin-bottom:36px}
.lnd-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px;max-width:760px;width:100%;margin-bottom:40px}
.lnd-feat{background:#131313;border:1px solid #1e1e1e;border-radius:8px;padding:14px 16px;display:flex;align-items:flex-start;gap:10px}
.lnd-feat i{font-size:18px;color:#e10600;flex-shrink:0;margin-top:1px}
.lnd-feat-text{font-size:12px;color:#777;line-height:1.5}
.lnd-feat-text b{display:block;color:#ccc;font-size:13px;margin-bottom:2px}
.lnd-btn{background:#e10600;color:#fff;border:none;padding:14px 40px;border-radius:7px;font-size:15px;font-weight:600;cursor:pointer;letter-spacing:0.3px;transition:background 0.15s,transform 0.1s}
.lnd-btn:hover{background:#ff1a1a;transform:translateY(-1px)}
.lnd-btn:active{transform:translateY(0)}
.lnd-credit{position:absolute;bottom:18px;font-size:11px;color:#333;text-align:center}
.lnd-note{font-size:11px;color:#444;margin-top:14px;text-align:center}
select.fsel{background:var(--bg3);border:1px solid var(--bd3);color:var(--t1);padding:6px 10px;border-radius:5px;font-size:13px;cursor:pointer;outline:none;transition:background 0.2s,color 0.2s}
select.fsel:hover{border-color:var(--t6)}
.effbar{display:inline-block;height:6px;border-radius:3px;vertical-align:middle}
.h2h-stat{display:flex;align-items:center;justify-content:space-between;padding:5px 0;border-bottom:1px solid var(--bd2)}
.h2h-stat:last-child{border-bottom:none}
.h2h-winner{font-weight:700}
/* ── Theme toggle button ── */
#theme-btn{background:none;border:1px solid var(--bd);color:var(--t2);width:30px;height:30px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:15px;transition:border-color 0.15s,color 0.15s,background 0.2s;flex-shrink:0}
#theme-btn:hover{border-color:var(--t6);color:var(--t1)}
/* ── Auth (Sign in with Google) ── */
#lnd-auth{position:absolute;top:16px;left:16px;z-index:1}
.auth-btn{background:none;border:1px solid var(--bd);color:var(--t2);height:30px;padding:0 10px;border-radius:6px;cursor:pointer;display:flex;align-items:center;gap:5px;font-size:12px;transition:border-color 0.15s,color 0.15s;flex-shrink:0;font-family:inherit}
.auth-btn:hover{border-color:var(--t6);color:var(--t1)}
.user-chip{display:flex;align-items:center;gap:7px;height:30px;padding:0 4px 0 8px;border:1px solid var(--bd);border-radius:16px;flex-shrink:0}
.user-chip img{width:20px;height:20px;border-radius:50%;object-fit:cover;background:var(--bd3);flex-shrink:0}
.user-chip span{font-size:12px;color:var(--t1);max-width:96px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.user-chip button{background:none;border:none;color:var(--t3);cursor:pointer;padding:4px;border-radius:50%;display:flex;align-items:center;transition:color 0.15s,background 0.15s}
.user-chip button:hover{color:var(--t1);background:var(--bg-hov)}

/* ── My Drivers tab ── */
/* H2H collapsible (moved into Drivers tab) */
.h2h-collapse{margin-top:18px;border-top:1px solid var(--bd);padding-top:8px}
.h2h-collapse summary{cursor:pointer;font-size:13px;font-weight:600;color:var(--t5);padding:8px 0;list-style:none;user-select:none}
.h2h-collapse summary::-webkit-details-marker{display:none}
.h2h-collapse summary:hover{color:var(--t1)}
/* guest gate */
.md-gate{max-width:440px;margin:48px auto;text-align:center;background:var(--bg2);border:1px solid var(--bd3);border-radius:12px;padding:36px 28px}
.md-gate-ic{font-size:38px;color:#e10600}
.md-gate-h{font-size:20px;font-weight:700;color:var(--t1);margin:10px 0 6px}
.md-gate-p{font-size:13px;color:var(--t2);line-height:1.6;margin-bottom:20px}
.md-gate-note{font-size:11px;color:var(--t4);margin-top:14px}
.md-signin-btn{display:inline-flex;align-items:center;gap:8px;background:#e10600;color:#fff;border:none;padding:0 20px;height:42px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;transition:transform .1s,filter .15s}
.md-signin-btn:hover{filter:brightness(1.1);transform:translateY(-1px)}
/* header bar */
.md-head{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;margin-bottom:18px}
.md-welcome{font-size:16px;font-weight:700;color:var(--t1)}
.md-sub{font-size:12px;color:var(--t3);margin-top:2px}
.md-head-actions{display:flex;align-items:center;gap:8px}
.md-counter{font-size:12px;color:var(--t2)}
.md-user{display:flex;align-items:center;gap:10px}
.md-user-pic{width:32px;height:32px;border-radius:50%;object-fit:cover;background:var(--bd3)}
.md-user-name{font-size:15px;font-weight:600;color:var(--t1)}
/* driver picker */
.md-pick-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}
.md-pick{position:relative;display:flex;flex-direction:column;align-items:center;text-align:center;gap:4px;background:var(--bg2);border:1px solid var(--bd3);border-radius:10px;padding:16px 10px 12px;cursor:pointer;font-family:inherit;transition:border-color .15s,transform .1s,opacity .15s}
.md-pick:hover{border-color:var(--t6);transform:translateY(-1px)}
.md-pick.on{border-color:var(--md-tc,#e10600);box-shadow:inset 0 0 0 1px var(--md-tc,#e10600)}
.md-pick.dim{opacity:.4}
.md-pick-check{position:absolute;top:6px;right:6px;width:18px;height:18px;border-radius:50%;background:#e10600;color:#fff;display:none;align-items:center;justify-content:center;font-size:11px}
.md-pick.on .md-pick-check{display:flex}
.md-pick-ini{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:14px;margin-bottom:4px}
.md-pick-name{font-size:12px;font-weight:600;color:var(--t1)}
.md-pick-team{font-size:11px;color:var(--t3)}
.md-pick-pos{font-size:11px;color:var(--t4)}
.md-pick-foot{margin-top:18px;text-align:center}
.md-save-btn{background:#e10600;color:#fff;border:none;padding:0 24px;height:42px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;transition:filter .15s}
.md-save-btn:hover:not(:disabled){filter:brightness(1.1)}
.md-save-btn:disabled{opacity:.45;cursor:not-allowed}
/* dashboard cards */
.md-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin-bottom:16px}
.md-card{background:var(--bg2);border:1px solid var(--bd3);border-left:4px solid #888;border-radius:10px;padding:14px;transition:transform .12s,box-shadow .12s}
.md-card:hover{transform:translateY(-2px);box-shadow:0 6px 18px rgba(0,0,0,.35)}
.md-card-top{display:flex;justify-content:space-between;align-items:flex-start;gap:6px}
.md-card-name{font-size:14px;font-weight:700;color:var(--t1)}
.md-card-team{font-size:11px;font-weight:600;margin-top:1px}
.md-card-x{background:none;border:none;color:var(--t4);cursor:pointer;font-size:14px;padding:2px;line-height:1;border-radius:4px;transition:color .15s,background .15s}
.md-card-x:hover{color:#E24B4A;background:var(--bg-hov)}
.md-card-pos{font-size:13px;color:var(--t2);margin-top:8px}
.md-card-gap{font-size:11px;color:var(--t4);margin-left:6px}
.md-card-last{display:flex;gap:4px;margin-top:8px}
.md-card-stats{display:grid;grid-template-columns:repeat(5,1fr);gap:4px;margin-top:10px;text-align:center}
.md-card-stats div{display:flex;flex-direction:column}
.md-card-stats b{font-size:13px;color:var(--t1)}
.md-card-stats span{font-size:9px;color:var(--t4);text-transform:uppercase;letter-spacing:.03em}
.md-spark{position:relative;height:42px;margin-top:10px}
/* comparison / tracker tables */
.md-cmp th,.md-cmp td{text-align:center}
.md-cmp-lbl{text-align:left!important;color:var(--t3);font-size:11px;white-space:nowrap}
.md-best{background:rgba(29,158,117,.16);font-weight:700;color:var(--t1)}
/* next race preview */
.md-next-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px}
.md-next-card{background:var(--bg3);border:1px solid var(--bd3);border-left:3px solid #888;border-radius:8px;padding:12px;text-align:center}
.md-next-name{font-size:14px;font-weight:700}
.md-next-rank{font-size:26px;font-weight:700;color:var(--t1);margin-top:4px}
.md-next-lbl{font-size:10px;color:var(--t4);text-transform:uppercase;letter-spacing:.04em}
.md-next-sub{font-size:10px;color:var(--t3);margin-top:6px}

/* ── My Predictions tab ── */
.mp-gate{display:flex;align-items:center;gap:16px;flex-wrap:wrap;background:var(--bg2);border:1px solid var(--bd3);border-radius:12px;padding:20px 24px;margin-bottom:18px}
.mp-gate-h{font-size:16px;font-weight:700;color:var(--t1)}
.mp-gate-p{font-size:12px;color:var(--t2);margin-top:3px;max-width:520px;line-height:1.5}
.mp-gate .md-signin-btn{margin-left:auto}
.mp-section-title{font-size:13px;font-weight:700;color:var(--t5);text-transform:uppercase;letter-spacing:.05em;margin:22px 0 10px;border-top:1px solid var(--bd);padding-top:16px}
.mp-lock-badge{font-size:11px;font-weight:600;color:#E24B4A;background:rgba(226,75,74,.12);padding:2px 7px;border-radius:5px;margin-left:8px;vertical-align:1px}
.mp-edit-badge{font-size:11px;font-weight:500;color:var(--t3);margin-left:8px;vertical-align:1px}
/* drag list */
.mp-list{display:flex;flex-direction:column;gap:4px;margin-top:6px}
.mp-row{display:flex;align-items:center;gap:10px;background:var(--bg3);border:1px solid var(--bd);border-radius:7px;padding:8px 10px;cursor:grab;user-select:none;transition:border-color .12s,background .12s,opacity .12s}
.mp-row:hover{border-color:var(--t6)}
.mp-row.dragging{opacity:.4;border-color:#e10600;cursor:grabbing}
.mp-row.locked{cursor:default;opacity:.85}
.mp-rank{width:22px;text-align:center;font-weight:700;color:var(--t2);font-size:13px;flex-shrink:0}
.mp-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}
.mp-name{font-size:13px;color:var(--t1);font-weight:600}
.mp-team{font-size:11px;color:var(--t3);margin-left:auto;white-space:nowrap}
.mp-handle{color:var(--t4);font-size:15px;flex-shrink:0;margin-left:6px}
.mp-row.locked .mp-handle{display:none}
/* up/down reorder controls (work on touch + desktop) */
.mp-move{display:flex;gap:4px;margin-left:8px;flex-shrink:0}
.mp-mv{width:34px;height:30px;display:flex;align-items:center;justify-content:center;background:var(--bg2);border:1px solid var(--bd3);color:var(--t2);border-radius:6px;cursor:pointer;padding:0;font-size:15px;line-height:1;transition:border-color .12s,color .12s,background .12s}
.mp-mv:hover:not(:disabled){border-color:var(--t6);color:var(--t1)}
.mp-mv:active:not(:disabled){background:var(--bg-hov)}
.mp-mv:disabled{opacity:.28;cursor:default}
.mp-row.locked .mp-move{display:none}
/* history */
.mp-hist th,.mp-hist td{vertical-align:middle}
.mp-hist-row:hover{background:var(--bg-hov)}
.mp-caret{display:inline-block;transition:transform .15s;color:var(--t3)}
.mp-cmp{display:grid;grid-template-columns:1fr 1fr;gap:14px;padding:10px 4px}
.mp-cmp-col{display:flex;flex-direction:column;gap:3px}
.mp-cmp-h{font-size:11px;font-weight:600;color:var(--t3);margin-bottom:3px}
.mp-cmp-cell{font-size:11px;padding:3px 7px;border-radius:4px;display:flex;align-items:center;gap:6px;background:var(--bg3);color:var(--t2)}
.mp-cmp-pos{font-weight:700;min-width:16px;color:var(--t4)}
.mp-cmp-cell.exact{background:rgba(29,158,117,.22);color:#7fe3c0}
.mp-cmp-cell.partial{background:rgba(232,168,56,.20);color:#e8c07a}
.mp-cmp-cell.miss{background:var(--bg3);color:var(--t3)}
.mp-cmp-cell.actual{background:var(--bg-hov);color:var(--t1)}
.mp-cmp-legend{display:flex;gap:8px;align-items:center;flex-wrap:wrap;font-size:10px;color:var(--t3);padding:6px 4px}
.mp-cmp-legend .mp-cmp-cell{padding:1px 6px}
/* leaderboard */
.mp-lb-me td{background:rgba(225,6,0,.10);box-shadow:inset 3px 0 0 #e10600;font-weight:600}
.mp-lb-gap td{text-align:center;color:var(--t4);padding:2px}
/* toast */
.mp-toast{position:fixed;left:50%;bottom:24px;transform:translateX(-50%) translateY(20px);background:#1D9E75;color:#fff;padding:11px 20px;border-radius:8px;font-size:13px;font-weight:600;z-index:100000;opacity:0;pointer-events:none;transition:opacity .25s,transform .25s;box-shadow:0 8px 24px rgba(0,0,0,.4)}
.mp-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.mp-toast.err{background:#E24B4A}

/* ── Championship calculator (Drivers tab) ── */
.cc-races{display:flex;flex-direction:column;gap:12px}
.cc-race{background:var(--bg2);border:1px solid var(--bd3);border-radius:8px;padding:12px 14px}
.cc-race-h{font-size:12px;font-weight:600;color:var(--t1);margin-bottom:10px}
.cc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:8px}
.cc-pos{display:flex;align-items:center;gap:6px}
.cc-pos-lbl{font-size:11px;font-weight:600;color:var(--t3);width:28px;flex-shrink:0}
.cc-sel{flex:1;min-width:0;font-size:12px}
.cc-reset{background:var(--bg3);border:1px solid var(--bd3);color:var(--t2);height:30px;padding:0 12px;border-radius:6px;cursor:pointer;display:inline-flex;align-items:center;gap:5px;font-size:12px;font-family:inherit;transition:border-color .15s,color .15s}
.cc-reset:hover{border-color:var(--t6);color:var(--t1)}
.cc-champ-banner{background:rgba(239,159,39,.10);border:1px solid rgba(239,159,39,.35);border-radius:7px;padding:10px 14px;font-size:13px;color:var(--t1);margin-bottom:12px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.cc-champ td{background:rgba(239,159,39,.10)}

/* ── Share button (dashboard header) ── */
.share-hdr-btn{background:none;border:1px solid var(--bd);color:var(--t2);height:30px;padding:0 10px;border-radius:6px;cursor:pointer;display:flex;align-items:center;gap:5px;font-size:12px;transition:border-color 0.15s,color 0.15s;flex-shrink:0}
.share-hdr-btn:hover{border-color:var(--t6);color:var(--t1)}
/* ── Share dropdown ── */
#share-menu{position:fixed;background:var(--bg2);border:1px solid var(--bd3);border-radius:8px;padding:5px;z-index:99999;box-shadow:0 8px 28px rgba(0,0,0,.55);min-width:165px}
#share-menu button,#share-menu a{display:flex;align-items:center;gap:9px;width:100%;padding:8px 10px;background:none;border:none;color:var(--t1);font-size:13px;cursor:pointer;text-decoration:none;border-radius:5px;transition:background 0.1s;font-family:inherit}
#share-menu button:hover,#share-menu a:hover{background:var(--bg3)}
#share-menu .smeta{font-size:10px;color:var(--t3);padding:4px 10px 2px;letter-spacing:.04em;text-transform:uppercase}
/* ── CSS vars for position pills/dots (theme-switchable) ── */
:root{--pill-np-bg:#2a2a2a;--pill-np-c:#aaa;--pill-q3m-bg:#2a2a2a;--pill-q3m-c:#999;--pdot-lo-bg:#1e1e1e;--pdot-lo-c:#888}
html[data-theme=light]{--pill-np-bg:#e0e0e0;--pill-np-c:#444;--pill-q3m-bg:#e0e0e0;--pill-q3m-c:#555;--pdot-lo-bg:#e0e0e0;--pdot-lo-c:#555}
/* ── Light mode: override hardcoded dark backgrounds in JS-rendered panels ── */
html[data-theme=light] .tpnl [style*="background:#161616"]{background:var(--bg2)!important}
html[data-theme=light] .tpnl [style*="background:#1a1a1a"]{background:var(--bg3)!important}
html[data-theme=light] .tpnl [style*="background:#2a2a2a"]{background:#e2e2e2!important}
html[data-theme=light] .tpnl [style*="background:#181818"]{background:var(--bg-hov)!important}
html[data-theme=light] .tpnl [style*="background:#131313"]{background:var(--bg3)!important}
/* ── Light mode: override light text that becomes invisible on light backgrounds ── */
html[data-theme=light] .tpnl [style*="color:#e0e0e0"]{color:var(--t1)!important}
html[data-theme=light] .tpnl [style*="color:#bbb"]{color:var(--t2)!important}
html[data-theme=light] .tpnl [style*="color:#ccc"]{color:var(--t2)!important}
html[data-theme=light] .tpnl [style*="color:#aaa"]{color:var(--t3)!important}
html[data-theme=light] .tpnl [style*="color:#888"]{color:var(--t3)!important}
html[data-theme=light] .tpnl [style*="color:#333"]{color:var(--t1)!important}
/* ── Light mode: dark borders become visible borders ── */
html[data-theme=light] .tpnl [style*="border:1px solid #222"]{border-color:var(--bd)!important}
html[data-theme=light] .tpnl [style*="border:1px solid #1e1e1e"]{border-color:var(--bd2)!important}
html[data-theme=light] .tpnl [style*="border:1px solid #2a2a2a"]{border-color:var(--bd3)!important}
html[data-theme=light] .tpnl [style*="border-bottom:1px solid #1a1a1a"]{border-bottom-color:var(--bd2)!important}
/* ── Landing page light mode ── */
html[data-theme=light] #landing{background:#f5f5f5}
html[data-theme=light] .lnd-title{color:#111}
html[data-theme=light] .lnd-sub{color:#888}
html[data-theme=light] .lnd-desc{color:#555}
html[data-theme=light] .lnd-feat{background:#fff;border-color:#ddd}
html[data-theme=light] .lnd-feat-text{color:#555}
html[data-theme=light] .lnd-feat-text b{color:#111}
html[data-theme=light] .lnd-note{color:#777}
html[data-theme=light] .lnd-credit{color:#999}
/* ── Logo theme switching ── */
.logo-for-dark{display:block}
.logo-for-light{display:none}
html[data-theme=light] .logo-for-dark{display:none}
html[data-theme=light] .logo-for-light{display:block}
/* ── Legal modal ── */
#legal-modal.open{display:block!important}
#guide-modal.open{display:block!important}
#driver-modal.open{display:block!important}

/* ── Driver quick-look popup ── */
.drv-name-link{cursor:pointer;transition:color .12s}
.drv-name-link:hover{color:#4d96ff;text-decoration:underline}
.dm-panel{background:var(--bg2);border:1px solid var(--bd3);border-radius:12px;max-width:440px;margin:0 auto;padding:24px;position:relative;color:var(--t2)}
.dm-close{position:absolute;top:12px;right:12px;background:none;border:1px solid var(--bd3);color:var(--t3);width:28px;height:28px;border-radius:6px;cursor:pointer;font-size:15px;display:flex;align-items:center;justify-content:center}
.dm-close:hover{color:var(--t1);border-color:var(--t6)}
.dm-head{display:flex;align-items:center;gap:14px;border-left:4px solid #888;padding-left:12px;margin-bottom:14px}
.dm-num{min-width:42px;height:42px;border-radius:9px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:18px;flex-shrink:0;padding:0 4px}
.dm-name{font-size:18px;font-weight:700;color:var(--t1)}
.dm-team{font-size:12px;font-weight:600;margin-top:2px}
.dm-bio{display:flex;flex-wrap:wrap;gap:8px 16px;font-size:12px;color:var(--t2);padding:10px 0;border-top:1px solid var(--bd);border-bottom:1px solid var(--bd)}
.dm-bio i{color:var(--t4);margin-right:3px;vertical-align:-1px}
.dm-stats-h{font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--t3);margin:14px 0 8px}
.dm-stats-h span{font-weight:500;color:var(--t4);text-transform:none;letter-spacing:0;margin-left:6px}
.dm-stats-load{grid-column:1/-1;color:var(--t4);font-style:italic;font-size:12px;padding:8px 0}
.dm-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin:0 0 14px}
.dm-stat{background:var(--bg3);border:1px solid var(--bd);border-radius:7px;padding:8px 4px;text-align:center}
.dm-stat-v{font-size:15px;font-weight:700;color:var(--t1)}
.dm-stat-l{font-size:9px;color:var(--t4);text-transform:uppercase;letter-spacing:.03em;margin-top:2px}
.dm-wiki{font-size:12px;line-height:1.6}
.dm-wiki-load{color:var(--t4);font-style:italic}
.dm-wiki-text{color:var(--t2);margin-bottom:8px}
.dm-wiki-link{color:#4d96ff;text-decoration:none;font-size:12px}
.dm-wiki-link:hover{text-decoration:underline}
@media(max-width:420px){.dm-stats{grid-template-columns:repeat(2,1fr)}}
html[data-theme=light] #legal-panel{background:#fff!important;border-color:#ddd!important;color:#333!important}
html[data-theme=light] #legal-panel h1{color:#111!important}
html[data-theme=light] #legal-panel h2{color:#888!important}
/* ── Landing page theme toggle ── */
#lnd-theme-btn{position:absolute;top:16px;right:16px;background:rgba(255,255,255,0.07);border:1px solid #2a2a2a;color:#666;width:32px;height:32px;border-radius:7px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:15px;transition:background 0.15s,border-color 0.15s,color 0.15s}
#lnd-theme-btn:hover{background:rgba(255,255,255,0.12);color:#ccc;border-color:#555}
html[data-theme=light] #lnd-theme-btn{background:rgba(0,0,0,0.05);border-color:#ccc;color:#666}
html[data-theme=light] #lnd-theme-btn:hover{background:rgba(0,0,0,0.1);color:#333}
