/* ===========================================================================
   Pit Lane Trivia — motorsport theme
   Dark is default; [data-theme="light"] overrides.
   =========================================================================== */
:root{
  --bg:#0b0b12; --bg-2:#10101a; --panel:#14141f; --panel-2:#1c1c2a;
  --border:#262633; --text:#edeff5; --muted:#969cad; --muted-2:#6c7384;
  --accent:#ff2d55; --accent-2:#ff5670; --accent-grad:linear-gradient(95deg,#ff2d55,#c81e42);
  --cyan:#19d3e3; --violet:#7c5cff;
  --green:#2bd576; --green-bg:#10241a; --red:#ff4d5e; --red-bg:#2a0b12;
  --gold:#ffce3a; --amber:#ffb020; --shadow:0 12px 30px rgba(0,0,0,.5);
  --nascar:#ffd200; --nascar-2:#e10600; --f1:#ff2d55; --f1-2:#15151e; --indy:#19a0ff; --indy-2:#0b2b52;
  --font-speed:'Russo One',"Arial Narrow",system-ui,sans-serif;
  --font-display:'Chakra Petch',"Saira Condensed",system-ui,sans-serif;
  --font-body:'Chakra Petch',"Segoe UI",system-ui,Roboto,Helvetica,Arial,sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,"Cascadia Code",Consolas,monospace;
  --carbon:repeating-linear-gradient(45deg,rgba(255,255,255,.018) 0 2px,transparent 2px 5px),
           repeating-linear-gradient(-45deg,rgba(255,255,255,.018) 0 2px,transparent 2px 5px);
  --kerb:repeating-linear-gradient(135deg,#ff2d55,#ff2d55 14px,#ffffff 14px,#ffffff 28px);
}
[data-theme="light"]{
  --bg:#eef0f6; --bg-2:#ffffff; --panel:#ffffff; --panel-2:#f1f2f8;
  --border:#e3e5ef; --text:#15151f; --muted:#5b6276; --muted-2:#8a90a4;
  --accent:#e6003c; --accent-2:#cc1240; --accent-grad:linear-gradient(95deg,#ff2d55,#cc1240);
  --cyan:#0e7d8a; --violet:#5b3fe0;
  --green:#16a34a; --green-bg:#e6f7ec; --red:#dc2626; --red-bg:#fdeaea;
  --gold:#c98a00; --amber:#b87d00; --shadow:0 10px 30px rgba(20,30,60,.08);
  --carbon:repeating-linear-gradient(45deg,rgba(20,30,60,.025) 0 2px,transparent 2px 5px),
           repeating-linear-gradient(-45deg,rgba(20,30,60,.025) 0 2px,transparent 2px 5px);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--font-body);
  background:
    var(--carbon),
    radial-gradient(1100px 560px at 100% -12%, rgba(255,45,85,.07), transparent 60%),
    radial-gradient(900px 520px at -10% 8%, rgba(124,92,255,.06), transparent 55%),
    var(--bg);
  background-attachment:fixed;
  color:var(--text); line-height:1.55; min-height:100vh;
}
a{color:var(--accent-2);text-decoration:none}
a:hover{text-decoration:underline}
.wrap{max-width:1080px;margin:0 auto;padding:0 18px}
.page{padding-top:26px;padding-bottom:60px}
.muted{color:var(--muted)}
.center{text-align:center}
.section-title{font-family:var(--font-speed);font-size:28px;font-weight:400;letter-spacing:.6px;
  text-transform:uppercase;margin:0 0 16px}
/* Display type for UI chrome; Russo One "speed" font for marquee headings/numbers */
.panel-title,.hero-subtitle,.how-step h4,.cat-card h3,.shop-card h3,.quiz-question,
.user-menu-btn,.tab,.btn,.chip,.quiz-cat{font-family:var(--font-display)}
.brand-name,.hero-title,.result-big,.today-big,.stat-num,.lb-table .pts,.rank-badge,
.daily-hero-title,.hof-pts{font-family:var(--font-speed);font-weight:400;letter-spacing:.5px}
.timer-num,.coin-badge,.scoreline strong,.um-static,.review-meta strong,
.quiz-progress,.quiz-points strong,.notif-count{font-family:var(--font-mono)}

/* ---- Top bar -------------------------------------------------------------- */
.topbar{position:sticky;top:0;z-index:50;background:rgba(11,13,18,.85);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--border)}
[data-theme="light"] .topbar{background:rgba(255,255,255,.85)}
.topbar-inner{display:flex;align-items:center;gap:18px;height:62px}
.brand{display:flex;align-items:center;gap:9px;font-weight:900;font-size:19px;color:var(--text)}
.brand:hover{text-decoration:none}
.brand-flag{font-size:22px}
.brand-name{background:var(--accent-grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.brand-logo{height:32px;width:auto;max-width:190px;object-fit:contain;display:block}
@media (max-width:560px){.brand-logo{height:26px;max-width:150px}}
.mainnav{display:flex;gap:6px;margin-left:6px;flex:1}
.mainnav a{color:var(--muted);padding:8px 12px;border-radius:8px;font-weight:600;font-size:15px}
.mainnav a:hover{color:var(--text);background:var(--panel);text-decoration:none}
.mainnav a.active{color:var(--text);background:var(--panel-2)}
.mainnav a.admin-link{color:var(--accent-2)}
.topbar-right{display:flex;align-items:center;gap:10px}
.coin-badge{background:var(--panel-2);border:1px solid var(--border);padding:6px 10px;border-radius:20px;font-weight:700;font-size:14px}
.theme-btn{background:var(--panel-2);border:1px solid var(--border);width:38px;height:38px;border-radius:10px;cursor:pointer;font-size:16px;color:var(--text)}
[data-theme="dark"] .theme-icon-light{display:none}
[data-theme="light"] .theme-icon-dark{display:none}
.nav-toggle{display:none;background:none;border:0;color:var(--text);font-size:24px;cursor:pointer}

/* User dropdown menu */
.user-menu{position:relative}
.user-menu-btn{display:flex;align-items:center;gap:7px;background:var(--panel-2);border:1px solid var(--border);
  border-radius:22px;padding:4px 10px 4px 4px;cursor:pointer;color:var(--text);font-weight:700}
.user-menu-btn:hover{filter:brightness(1.08)}
.user-menu-name{font-size:14px;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.user-menu .caret{font-size:11px;color:var(--muted)}
.user-menu-panel{position:absolute;right:0;top:calc(100% + 8px);min-width:210px;background:var(--bg-2);
  border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);padding:6px;display:none;z-index:60}
.user-menu-panel.open{display:block}
.um-item{display:flex;align-items:center;gap:9px;width:100%;text-align:left;padding:10px 12px;border-radius:8px;
  background:none;border:0;color:var(--text);font-size:14px;font-weight:600;cursor:pointer;text-decoration:none;font-family:inherit}
.um-item:hover{background:var(--panel-2);text-decoration:none}
.um-static{cursor:default;color:var(--gold);font-weight:800}
.um-divider{height:1px;background:var(--border);margin:5px 4px}
.um-coins{margin-left:auto;font-family:var(--font-mono);font-weight:700;color:var(--gold);display:inline-flex;align-items:center;gap:5px}
.coin-ico{display:inline-block;width:14px;height:14px;border-radius:50%;flex:0 0 14px;
  background:radial-gradient(circle at 35% 30%,#ffe9a0,#f5c542 55%,#c8941f);border:1px solid #b8860b}
.um-nav{display:none}

/* ---- Buttons -------------------------------------------------------------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;
  border:1px solid var(--border);background:var(--panel-2);color:var(--text);
  padding:11px 18px;border-radius:10px;font-weight:700;font-size:15px;cursor:pointer;
  text-transform:uppercase;letter-spacing:.6px;
  transition:transform .08s ease,filter .15s ease}
.btn:hover{text-decoration:none;filter:brightness(1.08)}
.btn{white-space:nowrap;max-width:100%}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--accent-grad);border-color:transparent;color:#fff;
  box-shadow:0 6px 18px rgba(225,6,0,.35)}
.btn-ghost{background:var(--panel-2);border-color:var(--border)}
.btn-danger{background:#3a1014;border-color:#7a1d22;color:#ffb4b4}
.btn-sm{padding:7px 12px;font-size:13px;border-radius:8px}
.btn-lg{padding:14px 26px;font-size:17px}
.btn-block{width:100%}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn-cat{margin-bottom:10px;font-size:16px;border-left:5px solid var(--accent)}
.btn-cat.nascar{border-left-color:var(--nascar)}
.btn-cat.formula1{border-left-color:var(--f1)}
.btn-cat.indycar{border-left-color:var(--indy)}

/* ---- Hero ----------------------------------------------------------------- */
.hero{position:relative;overflow:hidden;border-radius:20px;margin-top:24px;
  background:linear-gradient(135deg,#15151e,#1c1320);border:1px solid var(--border);
  padding:56px 40px}
[data-theme="light"] .hero{background:linear-gradient(135deg,#fff,#fef0ec)}
.hero-stripes{display:none}
.hero-content{position:relative;max-width:680px}
.hero-title{font-family:var(--font-display);font-size:clamp(44px,7vw,76px);font-weight:800;line-height:.96;margin:0 0 12px;
  letter-spacing:1px;text-transform:uppercase;background:var(--accent-grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-subtitle{font-size:20px;font-weight:600;margin:0 0 14px}
.hero-body{color:var(--muted);font-size:16px;margin:0 0 26px}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap}

/* ---- Category cards ------------------------------------------------------- */
.cat-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:16px 0}
.cat-card{background:var(--panel);border:1px solid var(--border);border-top:3px solid var(--accent);
  border-radius:14px;padding:22px 20px;text-align:center;box-shadow:var(--shadow);
  transition:transform .15s ease,border-color .15s ease}
.cat-card:hover{transform:translateY(-3px)}
.cat-card.nascar{border-top-color:var(--nascar)}
.cat-card.f1{border-top-color:var(--f1)}
.cat-card.indycar{border-top-color:var(--indy)}
.cat-icon{height:74px;display:flex;align-items:center;justify-content:center;margin-bottom:8px}
.cat-icon .car-icon{width:120px;height:auto;display:block}
.cat-card h3{margin:0 0 6px;font-size:20px}
.cat-card p{margin:0 0 16px;color:var(--muted);font-size:14px;min-height:40px}

/* ---- How it works --------------------------------------------------------- */
.how{margin:40px 0}
.how-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.how-step{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:18px}
.how-num{display:inline-flex;width:34px;height:34px;align-items:center;justify-content:center;
  border-radius:50%;background:var(--accent-grad);color:#fff;font-weight:800;margin-bottom:8px}
.how-step h4{margin:4px 0}
.how-step p{margin:0;color:var(--muted);font-size:14px}

/* ---- Forms / auth --------------------------------------------------------- */
.auth-card{max-width:430px;margin:30px auto;background:var(--panel);border:1px solid var(--border);
  border-radius:16px;padding:30px;box-shadow:var(--shadow)}
.form label{display:block;margin:14px 0 5px;font-size:13px;font-weight:600;color:var(--muted)}
.form input,.form select,.form textarea,.inline-form input,.inline-form select{
  width:100%;padding:11px 13px;border-radius:9px;border:1px solid var(--border);
  background:var(--bg-2);color:var(--text);font-size:16px;font-family:inherit}
.form input:focus,.form select:focus,.form textarea:focus{outline:2px solid var(--accent-2);outline-offset:0}
.form button{margin-top:18px}
.inline-form{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.inline-form input,.inline-form select{width:auto}
.alert{padding:12px 14px;border-radius:10px;margin:14px 0;font-size:14px;font-weight:600}
.alert.error{background:var(--red-bg);border:1px solid var(--red);color:#ffb4b4}
.alert.ok{background:var(--green-bg);border:1px solid var(--green);color:#9cf0bd}
[data-theme="light"] .alert.error{color:#9c1a1a}
[data-theme="light"] .alert.ok{color:#137a39}

/* ---- Stats / panels ------------------------------------------------------- */
.stat-row{display:flex;gap:14px;flex-wrap:wrap;margin:18px 0}
.stat{flex:1;min-width:120px;background:var(--panel);border:1px solid var(--border);
  border-radius:14px;padding:16px;text-align:center}
.stat-num{font-size:26px;font-weight:900}
.stat-lbl{color:var(--muted);font-size:13px;margin-top:2px}
.cta-bar{display:flex;gap:12px;flex-wrap:wrap;margin:22px 0}
.panel{background:var(--panel);border:1px solid var(--border);border-radius:16px;
  padding:22px;margin:18px 0;box-shadow:var(--shadow)}
.panel-title{margin:0 0 14px;font-size:18px;font-weight:800}
.list-row{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--border);flex-wrap:wrap}
.list-row:last-child{border-bottom:0}
.list-row .btn{margin-left:auto}
.result-tag{font-weight:800;font-size:12px;padding:3px 9px;border-radius:6px}
.result-tag.win{background:var(--green-bg);color:var(--green)}
.result-tag.loss{background:var(--red-bg);color:var(--red)}
.result-tag.draw{background:var(--panel-2);color:var(--muted)}
.chip{font-size:12px;font-weight:700;padding:3px 10px;border-radius:20px;background:var(--panel-2);
  border:1px solid var(--border);color:var(--muted)}

/* ---- Match grid ----------------------------------------------------------- */
.match-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:18px}
.form input,.form select,.form textarea{max-width:100%}
.form input[type=file],.inline-form input[type=file]{max-width:100%;min-width:0}

/* ---- Quiz ----------------------------------------------------------------- */
.quiz{max-width:680px;margin:20px auto;background:var(--panel);border:1px solid var(--border);
  border-radius:18px;padding:26px;box-shadow:var(--shadow)}
.quiz-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.quiz-cat{font-weight:800;padding:5px 12px;border-radius:8px;background:var(--accent-grad);color:#fff;font-size:13px}
.quiz-cat.cat-nascar{background:linear-gradient(90deg,#e10600,#ffd200)}
.quiz-cat.cat-formula1{background:linear-gradient(90deg,#e10600,#15151e)}
.quiz-cat.cat-indycar{background:linear-gradient(90deg,#1f7ae0,#0b2b52)}
.quiz-progress{color:var(--muted);font-weight:700}
/* Tachometer countdown + start lights */
.tach-wrap{text-align:center;margin:4px 0 12px}
.lights{display:flex;gap:12px;justify-content:center;margin-bottom:8px}
.lights .light{width:30px;height:30px;border-radius:50%;background:#2a0a0a;border:2px solid #45161a;transition:background .1s,box-shadow .1s}
.lights .light.on{background:#ff2a1a;border-color:#ff8a7a;box-shadow:0 0 14px 3px rgba(255,42,26,.75)}
.tach{display:block;width:230px;max-width:80%;margin:0 auto}
.tach-track{stroke:var(--panel-2)}
.tach-red{stroke:var(--accent)}
.tach-needle{stroke:var(--amber)}
.tach-hub{fill:var(--accent)}
.tach-readout{margin-top:-10px}
.timer-num{font-family:var(--font-mono);font-size:30px;font-weight:700;color:var(--amber);font-variant-numeric:tabular-nums}
.tach-u{color:var(--muted);font-size:14px;font-weight:700;margin-left:2px}
.go-label{height:18px;margin-top:2px;font-family:var(--font-display);font-weight:800;letter-spacing:4px;
  text-transform:uppercase;color:var(--green);visibility:hidden}
.go-label.show{visibility:visible}
.quiz-question{font-size:22px;font-weight:800;margin:6px 0 20px;min-height:60px}
.answers{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.answer{display:flex;align-items:center;gap:12px;text-align:left;padding:16px;border-radius:12px;
  border:2px solid var(--border);background:var(--bg-2);color:var(--text);font-size:16px;font-weight:600;cursor:pointer;
  transition:border-color .1s,transform .08s}
.answer:hover{border-color:var(--muted)}
.answer:focus{outline:none;border-color:var(--muted)}
.answer:active{transform:scale(.99)}
.answer.disabled{pointer-events:none;opacity:.95}
.answer-key{display:inline-flex;width:30px;height:30px;flex:0 0 30px;align-items:center;justify-content:center;
  border-radius:8px;background:var(--panel-2);font-weight:700;font-family:var(--font-mono)}
.answer.correct{border-color:var(--green);background:var(--green-bg);box-shadow:inset 4px 0 0 var(--green)}
.answer.correct .answer-key{background:var(--green);color:#04210f}
.answer.wrong{border-color:var(--red);background:var(--red-bg);box-shadow:inset 4px 0 0 var(--red)}
.answer.wrong .answer-key{background:var(--red);color:#2a0608}
.quiz-foot{display:flex;justify-content:space-between;align-items:center;margin-top:20px;gap:12px;flex-wrap:wrap}
.quiz-points strong{color:var(--cyan)}
.powerups{display:flex;gap:8px;flex-wrap:wrap}
.pu-btn .pu-n,#passCount{font-weight:800;color:var(--accent-2)}
.answer.removed{opacity:.3;pointer-events:none;filter:grayscale(1)}
.quiz.dbl-active .quiz-points::before{content:"✨ 2× ";color:var(--gold);font-weight:800}
.quiz-cat.cat-mixed{background:linear-gradient(90deg,#7c3aed,#1f7ae0,#22c55e)}
.btn-cat.mixed{border-left-color:#7c3aed}

/* ---- Victory checkered-flag sweep ----------------------------------------- */
.flag-sweep{position:fixed;top:0;left:0;height:100%;width:60vw;z-index:200;pointer-events:none;
  transform:skewX(-12deg) translateX(-90vw);
  background-image:conic-gradient(#15151e 90deg,#f5f5f5 90deg 180deg,#15151e 180deg 270deg,#f5f5f5 270deg);
  background-size:34px 34px;opacity:.95;animation:flagSweep 1.15s ease-in-out forwards}
@keyframes flagSweep{
  0%{transform:skewX(-12deg) translateX(-90vw);opacity:.97}
  70%{opacity:.85}
  100%{transform:skewX(-12deg) translateX(200vw);opacity:0}}
@media (prefers-reduced-motion:reduce){.flag-sweep{display:none}}

/* ---- Animations ----------------------------------------------------------- */
@keyframes qIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
@keyframes ansIn{from{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:none}}
@keyframes correctPulse{0%{transform:scale(1)}40%{transform:scale(1.04)}100%{transform:scale(1)}}
@keyframes wrongShake{0%,100%{transform:translateX(0)}20%{transform:translateX(-6px)}40%{transform:translateX(6px)}60%{transform:translateX(-4px)}80%{transform:translateX(4px)}}
@keyframes bannerPop{from{opacity:0;transform:scale(.92)}to{opacity:1;transform:none}}
@keyframes trophyPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.12)}}
.quiz-question{animation:qIn .3s ease both}
.answers .answer{animation:ansIn .28s ease both}
.answers .answer:nth-child(2){animation-delay:.05s}
.answers .answer:nth-child(3){animation-delay:.1s}
.answers .answer:nth-child(4){animation-delay:.15s}
.answer.correct{animation:correctPulse .45s ease}
.answer.wrong{animation:wrongShake .4s ease}
.result-banner{animation:bannerPop .4s ease both}
.result-banner.win .result-big{display:inline-block;animation:trophyPulse .8s ease 2}
@media (prefers-reduced-motion:reduce){*{animation:none !important}}

/* ---- Result --------------------------------------------------------------- */
.result-banner{border-radius:18px;padding:28px;text-align:center;margin:18px 0;border:1px solid var(--border)}
.result-banner.win{background:linear-gradient(135deg,var(--green-bg),transparent);border-color:var(--green)}
.result-banner.loss{background:linear-gradient(135deg,var(--red-bg),transparent);border-color:var(--red)}
.result-banner.draw,.result-banner.pending{background:var(--panel)}
.result-big{font-size:32px;font-weight:900;margin-bottom:10px}
.scoreline{display:flex;align-items:center;justify-content:center;gap:24px;margin-top:10px;font-size:18px}
.scoreline strong{font-size:34px;display:block}
.scoreline .vs{color:var(--muted);font-weight:700}
.review-item{border:1px solid var(--border);border-radius:10px;padding:10px 12px;margin-bottom:8px;border-left:4px solid var(--muted)}
.review-item.ok{border-left-color:var(--green)}
.review-item.no{border-left-color:var(--red)}
.review-q{font-weight:600;display:flex;align-items:center;gap:7px;margin-bottom:7px;font-size:14px}
.review-n{display:inline-flex;width:20px;height:20px;flex:0 0 20px;align-items:center;justify-content:center;
  border-radius:5px;background:var(--panel-2);font-size:11px;font-family:var(--font-mono)}
.review-q .diff{font-size:9px;padding:1px 6px;letter-spacing:.3px;flex:0 0 auto}
.review-opts{display:grid;grid-template-columns:1fr 1fr;gap:5px;margin-bottom:6px}
.review-opt{padding:5px 9px;border-radius:6px;background:var(--bg-2);border:1px solid var(--border);font-size:12.5px}
.review-opt.correct{background:var(--green-bg);border-color:var(--green)}
.review-opt.wrong{background:var(--red-bg);border-color:var(--red)}
.review-meta{color:var(--muted);font-size:12px}
@media (max-width:560px){.review-opts{grid-template-columns:1fr}}

/* ---- Tabs / tables -------------------------------------------------------- */
.tabs{display:flex;gap:8px;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;margin:10px 0 6px}
.tabs::-webkit-scrollbar{display:none}
.tab{padding:9px 16px;border-radius:10px;background:var(--panel);border:1px solid var(--border);
  color:var(--muted);font-weight:700;flex:0 0 auto;white-space:nowrap}
.tab:hover{text-decoration:none;color:var(--text)}
.tab.active{color:#fff;background:var(--accent-grad);border-color:transparent}
.lb-table{width:100%;border-collapse:collapse}
.lb-table th,.lb-table td{padding:11px 10px;text-align:left;border-bottom:1px solid var(--border)}
.lb-table th{color:var(--muted);font-size:13px;text-transform:uppercase;letter-spacing:.5px}
.lb-table .rank{font-weight:800;font-size:18px;width:50px}
.lb-table .pts{font-weight:800;color:var(--accent-2)}
.lb-table tr.me{background:rgba(124,92,255,.12);outline:1px solid rgba(124,92,255,.30)}
.lb-name{display:flex;align-items:center;gap:7px;min-width:0;font-weight:700;color:var(--text)}
.lb-name .avatar-sm,.lb-name img{flex:0 0 auto}
.lb-name .uname{display:inline-block;min-width:0;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;vertical-align:middle}
/* Broadcast "timing tower" styling */
.lb-table thead th{font-family:var(--font-mono);font-size:11px;letter-spacing:1px}
.lb-table tbody tr{transition:background .1s}
.lb-table tbody tr:hover{background:var(--panel-2)}
.lb-table td.rank{border-left:3px solid var(--border)}
.lb-table tbody tr:nth-child(1) td.rank{border-left-color:#ffce3a}
.lb-table tbody tr:nth-child(2) td.rank{border-left-color:#c0c6d4}
.lb-table tbody tr:nth-child(3) td.rank{border-left-color:#e08b4c}
.lb-table tr.me td.rank{border-left-color:var(--violet)}
.lb-table .pts{font-size:16px}

/* ---- Seasons / Hall of Fame ---------------------------------------------- */
.lb-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:8px}
.period-toggle{display:inline-flex;gap:4px;background:var(--panel);border:1px solid var(--border);
  border-radius:10px;padding:4px;margin:6px 0 12px}
.period-toggle a{padding:7px 14px;border-radius:8px;color:var(--muted);font-weight:700;font-size:14px}
.period-toggle a:hover{text-decoration:none;color:var(--text)}
.period-toggle a.active{background:var(--accent-grad);color:#fff}
.hof-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}
.hof-card{margin:0;padding:16px}
.hof-cat{font-weight:800;font-size:15px;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--border)}
.hof-row{display:flex;align-items:center;gap:9px;padding:7px 0;color:var(--text)}
.hof-row:hover{text-decoration:none;color:var(--accent-2)}
.hof-place{font-size:18px}
.hof-name{font-weight:700;flex:1}
.hof-pts{font-size:13px}

/* ---- Achievements --------------------------------------------------------- */
.ach-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}
.ach{background:var(--panel-2);border:1px solid var(--border);border-radius:12px;padding:14px;text-align:center}
.ach-emoji{font-size:30px;line-height:1.2}
.ach-name{font-weight:800;font-size:14px;margin-top:4px}
.ach-desc{font-size:12px;margin-top:2px}
.ach.locked{opacity:.5;filter:grayscale(.7)}
.ach.locked .ach-name{color:var(--muted)}

/* ---- Profile "super license" card ----------------------------------------- */
.license{position:relative;background:linear-gradient(135deg,var(--panel),var(--panel-2));
  border:1px solid var(--border);border-radius:16px;overflow:hidden;box-shadow:var(--shadow);margin-bottom:18px}
.license .kerb{height:4px;background:var(--accent-grad)}
.license .kerb.has-banner{height:38px;box-shadow:inset 0 -14px 22px rgba(0,0,0,.28)}
.license-body{display:flex;gap:20px;align-items:center;padding:20px 22px;flex-wrap:wrap}
.license-photo{display:flex;flex-direction:column;align-items:center;gap:8px;flex:0 0 auto}
.license-main{flex:1;min-width:220px}
.license-name{font-family:var(--font-speed);font-size:30px;font-weight:400;letter-spacing:.5px;line-height:1.05;margin:0}
.license-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin:9px 0 14px}
.license-meta .title-chip{margin:0}
.dash-license{margin-bottom:16px}
.dash-hello{font-family:var(--font-mono);font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--muted-2);margin-bottom:4px}
.license-fields{display:flex;gap:22px;flex-wrap:wrap;margin-bottom:10px}
.license-fields .lf-k{display:block;font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--muted-2)}
.license-fields .lf-v{font-family:var(--font-mono);font-size:18px;font-weight:700;color:var(--text)}

/* ---- Profile -------------------------------------------------------------- */
.profile-head{display:flex;gap:18px;align-items:center;margin-bottom:14px;flex-wrap:wrap}
/* Avatars (uploaded image or coloured initial) */
.avatar{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;
  border-radius:50%;overflow:hidden;flex:0 0 auto;color:#fff;font-weight:800;font-size:16px;
  border:2px solid var(--border);vertical-align:middle}
.avatar img{width:100%;height:100%;object-fit:cover;display:block}
.avatar-sm{width:28px;height:28px;font-size:12px}
.avatar-lg{width:78px;height:78px;font-size:34px;border-width:3px}
/* Driver rank badges */
.rank-badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:800;padding:4px 11px;
  border-radius:999px;text-transform:uppercase;letter-spacing:.6px;color:#fff;vertical-align:middle;
  border:1px solid rgba(255,255,255,.16);box-shadow:inset 0 1px 0 rgba(255,255,255,.28);
  text-shadow:0 1px 1px rgba(0,0,0,.35)}
.rank-badge .rq-ico{opacity:.95;flex:0 0 auto}
.rank-rookie{background:linear-gradient(160deg,#8b93a1,#565e6c)}
.rank-privateer{background:linear-gradient(160deg,#1bbd8d,#0b6850)}
.rank-contender{background:linear-gradient(160deg,#3f8bf7,#16459f)}
.rank-pro{background:linear-gradient(160deg,#a36cff,#5a2cc6)}
.rank-veteran{background:linear-gradient(160deg,#f2a01e,#a85f08)}
.rank-ace{background:linear-gradient(160deg,#ff5a5a,#9e1126)}
.rank-champion{background:linear-gradient(160deg,#ff8a00,#e10600);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.32),0 0 12px rgba(255,90,0,.4)}
.rank-legend{background:linear-gradient(110deg,#7c5cff,#e10600,#ffce3a);background-size:220% 100%;
  animation:legendShine 5s linear infinite;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.38),0 0 15px rgba(255,140,40,.45)}
@keyframes legendShine{to{background-position:220% 0}}
@media (prefers-reduced-motion:reduce){.rank-legend{animation:none}}

/* Metallic leaderboard medals (gold / silver / bronze) */
.medal{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;
  font-family:var(--font-speed);font-weight:400;font-size:13px;line-height:1;
  border:1px solid rgba(0,0,0,.28);box-shadow:inset 0 1px 1px rgba(255,255,255,.55),0 2px 5px rgba(0,0,0,.4);text-shadow:0 1px 0 rgba(255,255,255,.35)}
.medal-1{background:conic-gradient(from 200deg,#fff1b0,#e0a800,#ffe169,#c8941f,#fff1b0);color:#5a3d00;
  box-shadow:inset 0 1px 1px rgba(255,255,255,.7),0 0 10px rgba(255,206,58,.5)}
.medal-2{background:conic-gradient(from 200deg,#f7f9fd,#aeb4c2,#ffffff,#8b919f,#f7f9fd);color:#3a3f4a}
.medal-3{background:conic-gradient(from 200deg,#f6cda0,#cd7f32,#f3bd8c,#9c5a1e,#f6cda0);color:#4a2a0c}
.badge{font-size:11px;font-weight:800;padding:2px 8px;border-radius:6px;vertical-align:middle}
.badge.admin{background:var(--accent-grad);color:#fff}
.badge.banned{background:var(--red-bg);color:var(--red)}
.bio{max-width:540px}

/* ---- Shop ----------------------------------------------------------------- */
.shop-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;margin-top:16px}
.shop-card{background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:22px;text-align:center;box-shadow:var(--shadow)}
.shop-emoji{font-size:42px}
.shop-card h3{margin:8px 0}
.shop-card p{color:var(--muted);font-size:14px;min-height:54px}
.shop-price{font-size:22px;font-weight:900;color:var(--gold);margin:8px 0 14px}

/* ---- Admin ---------------------------------------------------------------- */
.adminnav{display:flex;gap:6px;flex-wrap:wrap;margin:6px 0 18px;padding:8px;background:var(--panel);
  border:1px solid var(--border);border-radius:12px}
.adminnav a{padding:8px 14px;border-radius:8px;color:var(--muted);font-weight:700}
.adminnav a:hover{color:var(--text);text-decoration:none;background:var(--panel-2)}
.adminnav a.active{background:var(--accent-grad);color:#fff}
.admin-tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px}
.admin-tile{display:flex;flex-direction:column;align-items:center;gap:8px;padding:22px;border-radius:14px;
  background:var(--panel-2);border:1px solid var(--border);color:var(--text);font-weight:700}
.admin-tile span{font-size:28px}
.admin-tile:hover{text-decoration:none;border-color:var(--accent-2)}
.opt-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:6px}
.opt-grid .hint{font-size:11px;color:var(--muted);font-weight:600}
.qrow{display:flex;gap:12px;align-items:flex-start;padding:12px 0;border-bottom:1px solid var(--border)}
.qrow-main{flex:1}
.qrow-ans{color:var(--green);font-size:13px;margin-top:4px;font-weight:700}
.qrow-actions{display:flex;gap:6px}
.qrow-actions form{margin:0}
.qrow-move{display:flex;gap:6px;align-items:center;margin-top:8px;flex-wrap:wrap}
.qrow-move form{margin:0}
.diff{display:inline-block;font-size:11px;font-weight:800;padding:2px 8px;border-radius:6px;margin-right:6px;text-transform:uppercase;letter-spacing:.4px}
.diff.easy{background:rgba(34,197,94,.18);color:#22c55e}
.diff.medium{background:rgba(255,206,58,.18);color:#e0a800}
.diff.hard{background:rgba(239,68,68,.18);color:#ef4444}
.diff-btn.easy.current{background:var(--green);color:#04210f;border-color:transparent}
.diff-btn.medium.current{background:var(--gold);color:#3a2c00;border-color:transparent}
.diff-btn.hard.current{background:var(--red);color:#2a0608;border-color:transparent}
.diff-btn.current{opacity:1}
.lb-edit-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap;padding:10px 0;border-bottom:1px solid var(--border)}
.lb-edit-row label{font-size:12px;color:var(--muted);display:flex;flex-direction:column;gap:3px}
.lb-edit-row input{width:90px}
.lb-edit-name{font-weight:800;min-width:120px}
.row-actions{display:flex;gap:6px;flex-wrap:wrap}
.row-actions form{margin:0}
.banned-row{opacity:.6}

/* Admin tables: keep in-cell controls on one line. */
.table-wrap{overflow:visible}
.admin-table td{vertical-align:middle}
.admin-table .inline-form{flex-wrap:nowrap}
.admin-table td .inline-form input[type=number]{width:78px}
.admin-table td .inline-form .btn{white-space:nowrap}

/* Row "Actions" dropdown menu */
.dd-wrap{position:relative;display:inline-block}
.actions-menu{position:absolute;right:0;top:calc(100% + 6px);z-index:30;min-width:168px;
  background:var(--bg-2);border:1px solid var(--border);border-radius:10px;
  box-shadow:0 12px 30px rgba(0,0,0,.4);padding:6px}
.actions-menu form{margin:0;display:block}
.actions-menu .btn{display:flex;width:100%;justify-content:flex-start;text-align:left;
  background:transparent;border:0;border-radius:6px;padding:8px 10px;font-size:13px}
.actions-menu .btn:hover{background:var(--panel-2)}
.actions-menu .btn-danger{color:var(--accent-2);background:transparent}

/* Bulk-delete toolbar on the Questions admin page */
.bulk-bar{display:flex;gap:14px;align-items:center;flex-wrap:wrap;margin:4px 0 14px;
  padding:10px 12px;background:var(--panel-2);border:1px solid var(--border);border-radius:10px}
.bulk-bar form{margin:0}
.bulk-all{display:flex;align-items:center;gap:7px;font-weight:700}
.qcheck-wrap{display:inline-flex;align-items:center;margin-right:8px}
.qcheck{transform:scale(1.2);cursor:pointer}

/* First-session welcome modal */
.intro-overlay{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;
  padding:18px;background:rgba(0,0,0,.6);backdrop-filter:blur(3px);animation:introIn .2s ease;
  overflow-y:auto;-webkit-overflow-scrolling:touch}
.intro-overlay.closing{opacity:0;transition:opacity .2s ease}
.intro-modal{width:100%;max-width:460px;background:var(--bg-2);border:1px solid var(--border);
  border-radius:18px;padding:26px;box-shadow:0 24px 60px rgba(0,0,0,.5);text-align:center;
  max-height:92vh;overflow-y:auto;margin:auto}
.intro-flag{font-size:40px;line-height:1}
.intro-modal h2{margin:8px 0 4px;font-family:var(--font-display)}
.intro-steps{list-style:none;margin:16px 0 20px;padding:0;text-align:left;display:flex;flex-direction:column;gap:12px}
.intro-steps li{display:flex;gap:12px;align-items:flex-start}
.intro-num{flex:0 0 26px;width:26px;height:26px;border-radius:50%;background:var(--accent-grad);color:#fff;
  display:flex;align-items:center;justify-content:center;font-weight:800;font-size:14px}
@keyframes introIn{from{opacity:0}to{opacity:1}}

/* Keep wide admin tables contained on small screens */
@media (max-width:760px){
  .table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .admin-table{min-width:620px}
  .actions-menu{position:fixed;left:10px;right:10px;top:auto;bottom:10px;min-width:0}
}

/* ---- Advertisements (neutral class names to survive ad blockers) ---------- */
.plt-feature{max-width:1080px;margin:18px auto;padding:0 18px}
.plt-feature-tag{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted-2);text-align:center;margin-bottom:5px}
.plt-feature-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;align-items:center}
.plt-feature-link{display:block;line-height:0;max-width:100%}
/* Auto-fit any uploaded image: scale down to the slot, keep aspect ratio. */
.plt-feature-link img{display:block;width:auto;height:auto;max-width:100%;max-height:110px;
  border-radius:10px;border:1px solid var(--border);object-fit:contain;
  transition:transform .12s ease,box-shadow .12s ease}
.plt-feature-link:hover img{transform:translateY(-2px);box-shadow:var(--shadow)}
/* The dashboard panel can show a slightly larger image. */
.plt-feature-dashboard .plt-feature-link img{max-height:240px}
.ad-preview{max-width:100%;max-height:160px;border-radius:10px;border:1px solid var(--border);margin:6px 0}
.check-line{display:flex !important;align-items:center;gap:8px;margin-top:14px;flex-direction:row !important}
.check-line input{width:auto}
.ad-admin-row{display:flex;gap:14px;align-items:center;padding:12px 0;border-bottom:1px solid var(--border);flex-wrap:wrap}
.ad-admin-row:last-child{border-bottom:0}
.ad-admin-row.inactive{opacity:.55}
.ad-admin-thumb{width:140px;max-height:80px;object-fit:contain;border-radius:8px;border:1px solid var(--border);background:var(--bg-2)}
.ad-admin-info{flex:1;min-width:200px;display:flex;flex-direction:column;gap:3px}
.ad-admin-actions{display:flex;gap:6px;flex-wrap:wrap}
.ad-admin-actions form{margin:0}

/* ---- Notifications & daily ------------------------------------------------ */
.notif-menu{position:relative}
.notif-bell{position:relative;font-size:18px;text-decoration:none;padding:4px 8px;border-radius:8px;
  background:none;border:0;cursor:pointer;color:inherit;line-height:1.4}
.notif-bell:hover{text-decoration:none;background:var(--panel-2)}
.dd-panel{display:none}
.dd-panel.open{display:block}
.notif-panel{min-width:320px;max-width:360px;padding:0;right:0}
.notif-panel-head{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--border)}
.link-btn{background:none;border:0;color:var(--accent-2);font-weight:700;font-size:13px;cursor:pointer;font-family:inherit}
.link-btn:hover{text-decoration:underline}
.notif-panel-list{max-height:340px;overflow-y:auto}
.notif-panel-list .notif-item{padding:11px 14px}
.notif-empty{padding:20px 14px;text-align:center}
.notif-see-all{display:block;text-align:center;padding:11px;border-top:1px solid var(--border);font-weight:700;font-size:14px}
.notif-see-all:hover{background:var(--panel-2);text-decoration:none}
.notif-count{position:absolute;top:-2px;right:-2px;background:var(--accent);color:#fff;font-size:10px;
  font-weight:800;min-width:16px;height:16px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 3px}
.notif-item{display:block;padding:12px 14px;border-bottom:1px solid var(--border);color:var(--text);text-decoration:none}
.notif-item:last-child{border-bottom:0}
.notif-item{font-size:13px;line-height:1.4}
.notif-item.unread{background:rgba(225,6,0,.08);border-left:3px solid var(--accent)}
a.notif-item:hover{background:var(--panel-2);text-decoration:none}
.notif-time{font-size:12px;margin-top:3px}
.daily-hero{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;
  background:linear-gradient(135deg,rgba(225,6,0,.20),var(--panel) 70%);border:1px solid var(--accent);
  border-radius:16px;padding:22px 24px;margin-bottom:18px;box-shadow:var(--shadow)}
.daily-hero-eyebrow{font-family:var(--font-mono);font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--accent-2)}
.daily-hero-title{font-family:var(--font-display);font-size:28px;text-transform:uppercase;letter-spacing:.5px;margin:2px 0 4px}
.daily-hero .muted{margin:0;max-width:520px}
.today-grid{display:grid;grid-template-columns:200px 1fr;gap:14px;margin:18px 0}
.today-grid.one{grid-template-columns:1fr}
.today-card{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:18px;
  display:flex;align-items:center;gap:14px;box-shadow:var(--shadow)}
.streak-card{flex-direction:column;justify-content:center;text-align:center;gap:2px}
.today-big{font-size:40px;font-weight:900;line-height:1}
.today-lbl{color:var(--muted);font-size:13px}
.daily-card{justify-content:space-between}
.today-card-title{font-weight:800;font-size:17px;margin-bottom:2px}
@media (max-width:600px){.today-grid{grid-template-columns:1fr}}

/* ---- Verified, referrals, online, buy coins, freeze ----------------------- */
.uname{display:inline-flex;align-items:center;gap:4px;color:var(--text)}
.uname.verified{color:#3ea6ff;font-weight:700}
.uname.admin-name{color:var(--gold);font-weight:700}
.verified-check{display:inline-flex;align-items:center;justify-content:center;width:15px;height:15px;
  border-radius:50%;background:#3ea6ff;color:#fff;font-size:10px;font-weight:900;line-height:1}
.copy-row{display:flex;gap:8px;align-items:center;margin-bottom:8px}
.copy-row input{flex:1;min-width:0;padding:11px 13px;border-radius:9px;border:1px solid var(--border);
  background:var(--bg-2);color:var(--text);font-family:var(--font-mono);font-size:13px}
.code-pill{font-family:var(--font-mono);background:var(--panel-2);border:1px solid var(--border);
  padding:3px 10px;border-radius:8px;letter-spacing:2px}
.online-badge{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:600;color:var(--muted)}
.online-dot{width:9px;height:9px;border-radius:50%;background:var(--green);animation:onlinePulse 2s infinite}
@keyframes onlinePulse{0%{box-shadow:0 0 0 0 rgba(34,197,94,.5)}70%{box-shadow:0 0 0 7px rgba(34,197,94,0)}100%{box-shadow:0 0 0 0 rgba(34,197,94,0)}}
.buy-layout{display:grid;grid-template-columns:1.1fr 1fr;gap:16px;align-items:start;margin:8px 0}
.buy-info{margin:0}
@media (max-width:700px){.buy-layout{grid-template-columns:1fr}}
.pkg-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px;margin:0}
.pkg{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:20px;text-align:center;box-shadow:var(--shadow)}
.pkg-coins{font-family:var(--font-mono);font-size:23px;font-weight:700;color:var(--gold);
  white-space:nowrap;font-variant-numeric:tabular-nums;line-height:1.2}
.pkg-price{font-family:var(--font-display);font-size:26px;margin:6px 0 12px;font-variant-numeric:tabular-nums}
.quiz{position:relative}
.freeze-overlay{position:absolute;inset:0;background:rgba(10,28,56,.82);display:flex;flex-direction:column;
  align-items:center;justify-content:center;border-radius:18px;z-index:5;color:#bfe3ff;text-align:center;padding:20px}
.freeze-overlay .fz-ice{font-size:46px}
.freeze-overlay .fz-t{font-family:var(--font-display);font-size:24px;letter-spacing:2px;text-transform:uppercase;margin-top:6px}

/* ---- Rivals, activity, clubs, cosmetics, share ---------------------------- */
/* Avatar cosmetic frames — premium metallic / themed CSS rings */
.avatar-frame{position:relative;display:inline-block;border-radius:50%;padding:3.5px;line-height:0;vertical-align:middle;isolation:isolate}
.avatar-frame::before{content:"";position:absolute;inset:0;border-radius:50%;z-index:0}
.avatar-frame::after{content:"";position:absolute;inset:3.5px;border-radius:50%;z-index:2;pointer-events:none;
  box-shadow:inset 0 0 0 1.5px rgba(0,0,0,.35)}     /* thin bezel between ring and face */
.avatar-frame > *{position:relative;z-index:1;border-radius:50%;border:0}
.frame-silver::before{background:conic-gradient(from 220deg,#f6f8fc,#aeb4c2,#ffffff,#8b919f,#e3e7f0,#9aa0ad,#f6f8fc)}
.frame-gold::before{background:conic-gradient(from 220deg,#fff4c2,#e0a800,#ffe27a,#b8860b,#fff4c2)}
.frame-gold{box-shadow:0 0 13px rgba(255,206,58,.5)}
.frame-flowers::before{background:conic-gradient(from 220deg,#ffe0e8,#ff7aa2,#ffd6a0,#ff8fb0,#ffe0e8)} /* rose gold */
.frame-flowers{box-shadow:0 0 11px rgba(255,122,162,.4)}
.frame-skulls::before{background:conic-gradient(from 220deg,#3e4555,#0e0f12,#5a6276,#0e0f12,#3e4555)} /* gunmetal */
.frame-skulls{box-shadow:0 0 11px rgba(255,45,85,.4)}
.frame-usflag::before{background:conic-gradient(from -30deg,#b22234 0 25%,#ffffff 25% 50%,#3c3b6e 50% 75%,#ffffff 75% 100%)}
.frame-checkered::before{background:repeating-conic-gradient(#16161f 0deg 22.5deg,#f2f3f7 22.5deg 45deg)}
.frame-dollars::before{background:conic-gradient(from 220deg,#1f7a3d,#36d97e,#d4b106,#36d97e,#1f7a3d)} /* money */
.frame-dollars{box-shadow:0 0 11px rgba(54,217,126,.4)}
.frame-fire::before{background:conic-gradient(from 0deg,#ff8a00,#ff2d00,#ffd000,#ff5a00,#ff2d00,#ffae00,#ff8a00);
  animation:frameSpin 3s linear infinite}
.frame-fire{box-shadow:0 0 15px rgba(255,90,0,.55)}
@keyframes frameSpin{to{transform:rotate(360deg)}}
@media (prefers-reduced-motion:reduce){.frame-fire::before{animation:none}}
.footer-actions{display:flex;align-items:center;justify-content:center;gap:14px;margin-bottom:12px}
.footer-link{color:var(--muted);font-weight:600;font-size:14px}
.footer-link:hover{color:var(--text)}
.recent-row{flex-wrap:nowrap}
.recent-row .recent-vs{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.recent-row .result-tag,.recent-row .chip,.recent-row .recent-score,.recent-row .btn{flex:0 0 auto}
@media (max-width:560px){
  .recent-row{gap:8px;font-size:13px}
  .recent-row .chip{display:none}
  .recent-row .recent-score{font-size:12px}
}
.rival-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.rival-info{flex:1;min-width:140px}
.rival-name{font-weight:700;font-size:17px;color:var(--text)}
.rival-score{font-family:var(--font-mono);font-size:22px;font-weight:700;margin-top:2px}
.rival-score .win{color:var(--green)} .rival-score .loss{color:var(--red)}
.rival-revenge{margin-left:auto}
.activity{display:flex;flex-direction:column}
.activity-item{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border);font-size:14px}
.activity-item:last-child{border-bottom:0}
.activity-ic{font-size:16px}
.activity-t{margin-left:auto;font-size:12px;white-space:nowrap}
.club-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;flex-wrap:wrap;gap:10px}
.club-tag{font-family:var(--font-mono);color:var(--accent-2);font-weight:700}
.club-name{font-size:18px}
.cosmetic-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px}
.cosmetic{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:16px;text-align:center;box-shadow:var(--shadow)}
.cosmetic.equipped{border-color:var(--green)}
.cos-preview{min-height:104px;display:flex;align-items:center;justify-content:center;margin-bottom:8px}
.cos-name{font-family:var(--font-display);font-size:20px;font-weight:800}
.cos-banner{display:block;width:100%;height:30px;border-radius:6px;box-shadow:inset 0 -8px 14px rgba(0,0,0,.2)}
.cos-label{font-weight:700;font-size:14px}
.cos-price{font-family:var(--font-mono);color:var(--gold);font-weight:700;margin:2px 0 10px}
.share-card{border-radius:12px;padding:18px;text-align:center;border:1px solid var(--border);margin-bottom:12px}
.share-card.win{background:linear-gradient(135deg,var(--green-bg),transparent);border-color:var(--green)}
.share-card.loss{background:linear-gradient(135deg,var(--red-bg),transparent);border-color:var(--red)}
.share-card.draw{background:var(--panel-2)}
.share-card-head{font-family:var(--font-mono);font-size:11px;letter-spacing:2px;color:var(--muted);text-transform:uppercase}
.share-card-result{font-family:var(--font-display);font-size:30px;font-weight:800;letter-spacing:1px;margin:4px 0}
.share-card-score{font-size:15px}.share-card-score strong{font-family:var(--font-mono)}
.share-btns{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}

/* ---- Profile tabs & flags ------------------------------------------------- */
.tab-pane[hidden]{display:none}
.profile-tabs{margin-bottom:6px;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.profile-tabs::-webkit-scrollbar{display:none}
.profile-tabs .tab{font-family:var(--font-display);cursor:pointer;flex:0 0 auto;white-space:nowrap}
.flag{height:18px;width:auto;border-radius:2px;vertical-align:-3px;border:1px solid var(--border)}

/* ---- Prize wheel ---------------------------------------------------------- */
.wheel-wrap{position:relative;width:240px;height:240px;margin:14px auto}
.wheel-pointer{position:absolute;top:-4px;left:50%;transform:translateX(-50%);z-index:3;
  border-left:13px solid transparent;border-right:13px solid transparent;border-top:22px solid var(--accent)}
.wheel{width:240px;height:240px;border-radius:50%;border:5px solid var(--border);position:relative;
  transition:transform 4.2s cubic-bezier(.15,.7,.15,1);
  background:conic-gradient(var(--accent) 0 60deg,var(--panel-2) 60deg 120deg,var(--accent) 120deg 180deg,
    var(--panel-2) 180deg 240deg,var(--accent) 240deg 300deg,var(--panel-2) 300deg 360deg)}
.wheel-labels{position:absolute;inset:0}
.wheel-label{position:absolute;top:50%;left:50%;transform:rotate(var(--a)) translateY(-86px)}
.wheel-label>span{display:inline-block;transform:translate(-50%,-50%) rotate(calc(-1 * var(--a)));
  font:700 15px var(--font-mono);color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.5)}
.wheel-hub{position:absolute;top:50%;left:50%;width:30px;height:30px;margin:-15px;border-radius:50%;
  background:var(--panel);border:3px solid var(--border);z-index:2}

/* ---- Footer --------------------------------------------------------------- */
.sitefooter{border-top:1px solid var(--border);margin-top:40px;padding:24px 0;color:var(--muted);font-size:14px;text-align:center}
.footer-stripe{height:1px;border-radius:0;margin-bottom:16px;background:var(--border)}

/* ---- Responsive ----------------------------------------------------------- */
@media (max-width:860px){
  .cat-cards,.how-grid{grid-template-columns:1fr}
  .match-grid{grid-template-columns:minmax(0,1fr)}
  .mainnav{display:none}            /* nav lives in the avatar dropdown on mobile */
  .um-nav{display:block}
  .topbar-battle{display:inline-flex}   /* obvious one-tap battle button on mobile */
  .topbar-inner{position:relative;flex-wrap:nowrap;gap:8px}
  .brand-name{font-size:16px}
  .topbar-right{margin-left:auto}
  .answers,.review-opts{grid-template-columns:1fr}
  .opt-grid{grid-template-columns:1fr}
  .user-menu-name{display:none}
  .user-menu-panel,.notif-panel{position:fixed;left:8px;right:8px;top:64px;min-width:0;max-width:none;width:auto}
}
@media (max-width:560px){
  .wrap{padding:0 12px}
  .section-title{font-size:24px}
  .hero{padding:40px 18px}
  .stat-row{gap:8px}
  .stat{min-width:0;flex:1 1 40%;padding:12px 8px}
  .stat-num{font-size:20px}
  .today-grid{grid-template-columns:1fr}
  .cta-bar{flex-direction:column}
  .cta-bar .btn{width:100%}
  /* Compact battle/daily screen so timer + question + answers fit without scrolling */
  .quiz-screen .page{padding-top:8px;padding-bottom:8px}
  .quiz{margin:6px auto;padding:14px}
  .quiz-head{margin-bottom:6px}
  .tach-wrap{margin:0 0 4px}
  .tach{width:120px;max-width:46%}
  .tach-readout{margin-top:-6px}
  .lights .light{width:20px;height:20px}
  .quiz-question{font-size:17px;min-height:0;margin:2px 0 10px}
  .answers{gap:8px}
  .answer{padding:11px 12px;font-size:14px;border-radius:10px}
  .answer-key{width:24px;height:24px;flex:0 0 24px}
  .quiz-foot{margin-top:10px;gap:8px}
  .powerups{flex-wrap:nowrap;overflow-x:auto;width:100%;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .powerups::-webkit-scrollbar{display:none}
  .powerups .btn{flex:0 0 auto;padding:6px 9px;font-size:12px}
  .lb-table th,.lb-table td{padding:9px 5px;font-size:13px}
  .lb-table .pts{font-size:14px}
  .profile-tabs{gap:6px}
  .profile-tabs .tab{padding:8px 11px;font-size:13px}
  /* Fixed columns so long names truncate (stay on one line) instead of wrapping */
  .lb-main{table-layout:fixed}
  .lb-main th:nth-child(1),.lb-main td:nth-child(1){width:36px;padding-left:2px;padding-right:2px}
  .lb-main th:nth-child(3),.lb-main td:nth-child(3){width:48px}
  .lb-main th:nth-child(4),.lb-main td:nth-child(4),
  .lb-main th:nth-child(5),.lb-main td:nth-child(5){width:24px}
  .lb-main th:nth-child(6),.lb-main td:nth-child(6){width:38px}
  /* Other tables: never let a cell overflow its box on mobile */
  .lb-table td,.lb-table th{overflow:hidden;text-overflow:ellipsis}
  .lb-table .rank{font-size:15px}
  /* Smaller medallions so they aren't clipped in the narrow rank column */
  .medal{width:22px;height:22px;font-size:11px}
  /* Profile/dashboard identity card — keep avatar + name on one tidy row */
  .license-body{gap:14px;padding:16px}
  .license-main{min-width:0}
  .license-name{font-size:24px}
  .avatar-lg{width:64px;height:64px;font-size:28px}
}

/* ===========================================================================
   Phase 2 — icon system + component polish (esports/racing HUD)
   =========================================================================== */
.rq-ico{display:inline-block;vertical-align:-.18em;flex:0 0 auto}
.btn .rq-ico{vertical-align:-.2em}

/* Brand mark */
.brand-mark{width:30px;height:30px;border-radius:8px;background:var(--accent-grad);
  display:inline-flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 4px 14px rgba(255,45,85,.35)}
.brand-mark .rq-ico{vertical-align:0}

/* Hero (centered) */
.hero{position:relative;padding:52px 24px 38px;text-align:center}
.hero-content{max-width:680px;margin:0 auto}
.hero-title{font-size:clamp(34px,6vw,56px);line-height:1.02;margin:10px 0;color:var(--text)}
.hero-subtitle{color:var(--accent-2);font-size:18px;margin:0 0 6px}
.hero-body{color:var(--muted);max-width:480px;margin:0 auto;font-size:16px}
.hero-cta{display:flex;gap:12px;margin-top:24px;flex-wrap:wrap;justify-content:center}
.online-badge{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:600;
  color:var(--green);background:var(--green-bg);padding:5px 12px;border-radius:999px}
.online-dot{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 0 0 var(--green);
  animation:onlinePulse 2.4s ease-out infinite}
@keyframes onlinePulse{0%{box-shadow:0 0 0 0 rgba(43,213,118,.5)}70%{box-shadow:0 0 0 7px rgba(43,213,118,0)}100%{box-shadow:0 0 0 0 rgba(43,213,118,0)}}

/* Series cards: flat with a colored top edge + icon */
.cat-card{position:relative;background:var(--panel);border:1px solid var(--border);border-radius:14px;
  padding:18px 16px;overflow:hidden;transition:transform .12s ease,border-color .15s ease}
.cat-card::before{content:"";position:absolute;left:0;top:0;height:3px;width:100%;background:var(--accent)}
.cat-card.nascar::before{background:var(--nascar)} .cat-card.f1::before{background:var(--f1)} .cat-card.indycar::before{background:var(--indy)}
.cat-card:hover{transform:translateY(-3px);border-color:var(--muted-2)}
.cat-card h3{font-family:var(--font-speed);letter-spacing:.5px;margin:10px 0 4px}

/* Answer cards in battle */
.answer{border:1px solid var(--border);background:var(--panel);border-radius:12px;transition:border-color .12s ease,background .12s ease}
.answer:hover{border-color:var(--cyan)}
.answer .answer-key{background:var(--panel-2);color:var(--muted);font-family:var(--font-speed);border-radius:7px}
.answer.correct{border-color:var(--green);background:var(--green-bg)}
.answer.correct .answer-key{background:var(--green);color:#06210f}
.answer.wrong{border-color:var(--red);background:var(--red-bg)}

/* Power-up buttons */
.powerups .btn{display:inline-flex;align-items:center;gap:6px}

/* Tachometer accent */
.tach-red{stroke:var(--accent)} .tach-needle{stroke:var(--cyan)}
.timer-num{color:var(--cyan)}

/* Icon coloring in cards/modals */
.shop-emoji{color:var(--cyan)}
.intro-flag{color:var(--accent-2);line-height:1}
.powerups .btn .rq-ico{color:var(--cyan)}

/* Obvious mobile battle button (hidden on desktop where the nav shows it) */
.topbar-battle{display:none}

/* Achievement icons (SVG) */
.ach .ach-emoji{color:var(--gold);line-height:1;margin-bottom:6px}
.ach.locked .ach-emoji{color:var(--muted-2)}

/* "Live from the paddock" — pulsing red live indicator */
.live-title{color:var(--accent);animation:livePulse 1.5s ease-in-out infinite}
@keyframes livePulse{0%,100%{opacity:1}50%{opacity:.5}}
.live-dot{display:inline-block;width:9px;height:9px;border-radius:50%;background:var(--accent);
  margin-right:8px;vertical-align:middle;animation:liveDotRing 1.5s ease-in-out infinite}
@keyframes liveDotRing{0%,100%{box-shadow:0 0 0 0 rgba(255,45,85,.6)}50%{box-shadow:0 0 0 6px rgba(255,45,85,0)}}
@media (prefers-reduced-motion:reduce){.live-title,.live-dot{animation:none}}

/* Season pass + event banner */
.event-banner{display:flex;align-items:center;gap:9px;margin:14px 0;padding:12px 15px;border-radius:12px;text-decoration:none;color:var(--text);
  background:linear-gradient(90deg,rgba(124,92,255,.18),rgba(25,211,227,.10));border:1px solid rgba(124,92,255,.4)}
.event-banner:hover{text-decoration:none;filter:brightness(1.06)}
.event-banner .rq-ico{color:var(--violet);flex:0 0 auto}
.pass-xp{display:flex;align-items:baseline;gap:6px}
.pass-xp-num{font-family:var(--font-speed);font-size:24px;color:var(--cyan)}
.pass-overall{height:8px;border-radius:4px;background:var(--border);margin-top:10px;overflow:hidden}
.pass-overall span{display:block;height:100%;background:var(--accent-grad)}
.pass-track{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;margin-top:6px}
.pass-tier{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:14px;text-align:center;position:relative}
.pass-tier.locked{opacity:.6}
.pass-tier.ready{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent) inset}
.pass-tier.claimed{border-color:var(--green);background:var(--green-bg)}
.pass-tier-no{font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--muted-2)}
.pass-tier-ic{color:var(--gold);margin:6px 0 4px}
.pass-tier.claimed .pass-tier-ic{color:var(--green)}
.pass-tier-label{font-weight:700;font-size:14px;min-height:34px;display:flex;align-items:center;justify-content:center}
.pass-tier-xp{font-family:var(--font-mono);font-size:12px;color:var(--muted);margin-bottom:8px}
.pass-tier-state{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:700;color:var(--muted)}
.pass-tier-state.done{color:var(--green)}

/* Earned title chip + guided first battle */
.title-chip{display:inline-flex;align-items:center;gap:5px;margin:6px 0;padding:3px 10px;border-radius:999px;
  background:rgba(255,206,58,.14);border:1px solid rgba(255,206,58,.4);color:var(--gold);font-weight:700;font-size:12px}
.title-chip .rq-ico{color:var(--gold)}
.first-battle-hero{border-color:var(--cyan);
  background:linear-gradient(135deg,rgba(25,211,227,.16),var(--panel) 70%)}

/* Daily quests + on-fire banner */
.onfire-banner{display:flex;align-items:center;gap:8px;margin:14px 0;padding:11px 14px;border-radius:12px;
  background:linear-gradient(90deg,rgba(255,45,85,.16),rgba(255,176,32,.10));border:1px solid rgba(255,45,85,.35);color:var(--text)}
.onfire-banner .rq-ico{color:var(--accent-2)}
.quest-list{display:flex;flex-direction:column;gap:10px}
.quest{display:flex;gap:12px;align-items:center;background:var(--panel-2);border:1px solid var(--border);border-radius:12px;padding:11px 13px}
.quest.done{border-color:var(--green);background:var(--green-bg)}
.quest-ic{flex:0 0 auto;color:var(--cyan)}
.quest.done .quest-ic{color:var(--green)}
.quest-body{flex:1;min-width:0}
.quest-top{display:flex;justify-content:space-between;gap:8px;align-items:center}
.quest-label{font-weight:700;font-size:14px}
.quest-reward{display:inline-flex;align-items:center;gap:4px;font-weight:700;color:var(--gold);font-size:13px;white-space:nowrap}
.quest-bar{height:6px;border-radius:3px;background:var(--border);margin:6px 0 3px;overflow:hidden}
.quest-bar span{display:block;height:100%;background:var(--accent-grad);border-radius:3px}
.quest.done .quest-bar span{background:var(--green)}
.quest-prog{font-size:12px}

/* Friends + daily rank */
.um-badge{margin-left:auto;background:var(--accent);color:#fff;font-size:11px;font-weight:800;
  min-width:18px;height:18px;border-radius:9px;display:inline-flex;align-items:center;justify-content:center;padding:0 5px}
.friend-dot{width:9px;height:9px;border-radius:50%;background:var(--muted-2);flex:0 0 auto}
.friend-dot.on{background:var(--green);box-shadow:0 0 0 3px rgba(43,213,118,.18)}
.friend-row{gap:10px}
.friend-badge{display:inline-flex;align-items:center;gap:5px;color:var(--green);font-weight:700;font-size:13px}
.profile-cta{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.daily-rank{font-size:17px;color:var(--cyan)}

/* Mobile bottom navigation */
.bottomnav{display:none}
.quiz-screen .bottomnav{display:none}      /* full focus during a battle */
body.quiz-screen{padding-bottom:0}
@media (max-width:640px){
  .bottomnav{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:80;
    background:var(--bg-2);border-top:1px solid var(--border);
    padding:6px 4px calc(6px + env(safe-area-inset-bottom,0px));justify-content:space-around}
  .bn-item{flex:1 1 0;display:flex;flex-direction:column;align-items:center;gap:2px;
    padding:4px 2px;color:var(--muted);font-size:11px;font-weight:600;text-decoration:none}
  .bn-item.active{color:var(--accent-2)}
  .bn-item:hover{text-decoration:none;color:var(--text)}
  body{padding-bottom:62px}        /* clear space for the fixed bar */
  .um-nav .um-dup{display:none}    /* these live in the bottom bar on phones */
}

/* Slow pulse on the home "Race now" CTA */
.hero-cta .btn-primary{animation:racemePulse 1.8s ease-in-out infinite;transform-origin:center;will-change:transform}
@keyframes racemePulse{
  0%,100%{transform:scale(1);box-shadow:0 6px 18px rgba(255,45,85,.35)}
  50%{transform:scale(1.06);box-shadow:0 12px 28px rgba(255,45,85,.6)}
}
@media (prefers-reduced-motion:reduce){
  .hero-cta .btn-primary{animation:none}
  .online-dot{animation:none}
}
