:root{
  --f1:'Titillium Web','Arial Narrow',Arial,sans-serif;
  --thai:'Pridi','Sarabun','Noto Sans Thai',sans-serif;
  --red:#E8002D;--dkred:#A8001F;
  --blk:#06060C;--d1:#0E0E18;--d2:#15151E;--d3:#1E1E28;--d4:#2A2A38;--d5:#38384A;
  --blue:#003F8A;--blu2:#1565C0;
  --wht:#FFFFFF;--silv:#C8C8D0;--gray:#888898;--dkgry:#444455;
  --gold:#FFD040;--grn:#00C853;--grn2:#00E676;--danger:#FF1744;--warn:#FFB300;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden}
body{background:var(--blk);color:var(--wht);font-family:var(--thai);font-size:15px;line-height:1.6;overflow-x:hidden;padding:0 env(safe-area-inset-right) 0 env(safe-area-inset-left)}
/* ── FONT STRATEGY
   body = Pridi (Thai) เป็น default
   class .en = Titillium Web สำหรับ label, badge, heading เท่านั้น
   Browser จะ fallback Titillium → Pridi อัตโนมัติสำหรับตัวอักษรไทย
── */
.en, .brand-full, .brand-sub,
.nav-status,
.spon-lbl, .si, .news-lbl,
.hero-pill, .hero-eye, .hero-h1, .kpi-lbl,
.btn, .sec-tag,
.pos-num, .drv-tag, .pts-val, .pts-u, .wins-b, .trend,
.nc-date, .nc-tag,
.ap-title, .ap-tab,
.race-name, .race-date, .rri-pts, .rri-pos,
.spon-row-head, .social-mgr-head,
.stnd-tbl thead th,
.reg-tbl th,
.modal-title,
.suc-title, .foot-logo, .foot-copy,
.sb, .tt-link,
footer { font-family: var(--f1); }
::-webkit-scrollbar{width:3px;height:3px}::-webkit-scrollbar-track{background:var(--d1)}::-webkit-scrollbar-thumb{background:var(--red)}

/* ── LIVE STATUS BAR ── */
.live-status-bar{background:var(--red);height:34px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.live-bar-inner{display:flex;align-items:center;gap:10px;font-family:var(--f1);font-size:10px;font-weight:700;letter-spacing:2px;color:#fff;text-transform:uppercase;white-space:nowrap}
.live-bar-dot{width:7px;height:7px;border-radius:50%;background:#fff;flex-shrink:0;animation:pulse-white 1.5s ease-in-out infinite}
@keyframes pulse-white{0%,100%{opacity:1}50%{opacity:.25}}

/* ── NAV ── */
nav#siteNav{position:sticky;top:0;z-index:900;background:var(--blk);border-bottom:1px solid var(--d4);box-shadow:0 2px 20px rgba(0,0,0,.7);padding-top:env(safe-area-inset-top,0)}
.nav-in{position:relative;z-index:920;background:var(--blk);max-width:1400px;margin:0 auto;padding:0 max(12px, env(safe-area-inset-right)) 0 max(12px, env(safe-area-inset-left));display:flex;align-items:stretch;width:100%;gap:0;height:60px}
.nav-toggle{
  display:none;align-items:center;justify-content:center;width:44px;height:44px;margin:auto 6px auto 10px;padding:0;flex-shrink:0;
  border:1px solid var(--d4);background:rgba(255,255,255,.06);color:var(--wht);font-size:20px;line-height:1;cursor:pointer;border-radius:2px;
  -webkit-tap-highlight-color:transparent;
}
.nav-toggle:hover{border-color:var(--red);background:rgba(232,0,45,.08)}
.nav-overlay{display:none;position:fixed;left:0;right:0;bottom:0;top:calc(60px + env(safe-area-inset-top, 0px));background:rgba(0,0,0,.52);z-index:910;-webkit-tap-highlight-color:transparent}
#siteNav.nav-open .nav-overlay{display:block}
.nav-brand{display:flex;align-items:center;gap:12px;padding-right:24px;border-right:1px solid var(--d4);cursor:pointer;flex-shrink:0}
.nav-logo-img{height:32px;width:auto;display:block;object-fit:contain;filter:drop-shadow(0 0 6px rgba(232,0,45,.25))}
.nav-brand-text{display:flex;flex-direction:column;gap:1px}
.brand-full{display:block;font-size:8px;letter-spacing:2.5px;color:var(--silv);text-transform:uppercase;font-weight:300;font-family:var(--f1)}
.brand-sub{display:block;font-weight:700;font-size:7.5px;letter-spacing:3.5px;color:var(--red);text-transform:uppercase;font-family:var(--f1)}
.nav-links{display:flex;list-style:none;flex:1;padding-left:4px}
.nav-links li{display:flex}
.nav-links li a{display:flex;align-items:center;padding:0 16px;font-weight:700;font-size:10.5px;letter-spacing:2px;text-transform:uppercase;color:var(--gray);text-decoration:none;border-bottom:3px solid transparent;margin-bottom:-1px;transition:color .15s,border-color .15s;cursor:pointer;white-space:nowrap}
.nav-links li a:hover{color:var(--wht)}.nav-links li a.active{color:var(--wht);border-bottom-color:var(--red)}

/* NAV RIGHT — admin btn + status */
.nav-right{display:flex;align-items:center;gap:12px;margin-left:auto;flex-shrink:0}
/* uiverse admin button (augustin_4687) */
.uv-admin-wrap{
  --stone-800:#292524;--yellow-300:#fde047;--yellow-400:#facc15;--yellow-500:#eab308;--uv-blk:.25;
  position:relative;display:block;width:4rem;height:4rem;cursor:pointer;
  transform:scale(0.6);margin:-0.8rem;flex-shrink:0;
}
.uv-admin-wrap > button{
  cursor:pointer;display:inline-block;height:100%;width:100%;
  appearance:none;border:2px solid var(--stone-800);border-radius:.25rem;
  background-color:var(--yellow-400);outline:2px solid transparent;outline-offset:2px;transition:background-color .2s;
}
.uv-admin-wrap > button:hover{background-color:var(--yellow-300)}
.uv-admin-wrap.logged > button{background-color:var(--stone-800);border-color:var(--stone-800)}
.uv-admin-wrap.logged > button:hover{background-color:#44403c}
.uv-admin-wrap > button:active{outline-color:var(--stone-800)}
.uv-admin-wrap > button:focus-visible{outline-color:var(--stone-800);outline-style:dashed}
.uv-admin-wrap > span:nth-child(2){
  position:absolute;inset:3px;pointer-events:none;
  background-color:var(--yellow-400);border-bottom:2px solid rgba(0,0,0,.25);transition:transform 75ms;
}
.uv-admin-wrap > span:nth-child(2)::before{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(rgba(255,255,255,.8) 20%,transparent 20%),radial-gradient(rgba(255,255,255,1) 20%,transparent 20%);
  background-position:0 0,4px 4px;background-size:8px 8px;
  mix-blend-mode:hard-light;opacity:.5;animation:uv-dots .5s infinite linear;
}
.uv-admin-wrap > span:nth-child(3){position:absolute;pointer-events:none;inset:0}
.uv-admin-wrap > span:nth-child(3)::before{
  content:"";width:.375rem;height:.375rem;position:absolute;top:.25rem;left:.25rem;
  background-color:var(--stone-800);border-radius:.125rem;
  box-shadow:3.125em 0 var(--stone-800),0 3.125em var(--stone-800),3.125em 3.125em var(--stone-800);
}
.uv-admin-wrap > span:nth-child(4){
  position:absolute;pointer-events:none;inset:0;
  filter:drop-shadow(.25em .25em 0 rgba(0,0,0,.2));transition:all 75ms;
}
.uv-admin-wrap > span:nth-child(4)::after{
  content:"";width:.25rem;height:.25rem;position:absolute;top:.875rem;left:1rem;
  border-radius:.0625px;background-color:var(--stone-800);
  box-shadow:.75em 2em var(--stone-800),1em 2em var(--stone-800),.75em 1.75em var(--stone-800),1em 1.75em var(--stone-800),.75em 1.25em var(--stone-800),1em 1.25em var(--stone-800),.75em 1em var(--stone-800),1em 1em var(--stone-800),1em .75em var(--stone-800),1.5em .75em var(--stone-800),1.25em .75em var(--stone-800),1.25em -.25em var(--stone-800),1.5em 0 var(--stone-800),1.25em .5em var(--stone-800),1.5em .5em var(--stone-800),1.25em .25em var(--stone-800),1.5em .25em var(--stone-800),1.25em 0 var(--stone-800),1em -.25em var(--stone-800),.75em -.25em var(--stone-800),.5em -.25em var(--stone-800),.25em -.25em var(--stone-800),.25em 0 var(--stone-800),0 .25em var(--stone-800),0 .5em var(--stone-800),.25em .25em var(--stone-800),.25em .5em var(--stone-800);
}
.uv-admin-wrap > span:nth-child(5){
  position:absolute;background-color:var(--yellow-400);border:2px solid var(--stone-800);
  border-radius:.75rem;pointer-events:none;z-index:-1;inset:.5rem 1.5rem;
  box-shadow:7px 0 0 0 var(--stone-800),inset 0 2px 0 0 var(--yellow-300),inset 0 -2px 0 0 var(--yellow-500);
  transition:all 0ms cubic-bezier(0,.5,.4,1);
}
.uv-admin-wrap > button:active ~ span:nth-child(5){transform:translateY(-200%);transition-duration:200ms;opacity:0}
.uv-admin-wrap > button:hover ~ span:nth-child(4){filter:drop-shadow(.125em .125em 0 rgba(0,0,0,.2))}
@keyframes uv-dots{
  0%{background-position:0 0,4px 4px}
  100%{background-position:8px 0,12px 4px}
}
.nav-status{display:flex;align-items:center;gap:5px;font-size:8.5px;font-weight:700;letter-spacing:2px;color:var(--gray)}
.sdot{width:6px;height:6px;border-radius:50%;background:var(--d5)}.sdot.on{background:var(--grn);box-shadow:0 0 5px var(--grn)}.sdot.off{background:var(--danger)}

/* ── SPONSOR TICKER ── */
.spon-bar{background:var(--d2);border-bottom:1px solid var(--d4);height:38px;display:flex;align-items:center;overflow:hidden}
.spon-lbl{background:var(--red);height:100%;display:flex;align-items:center;padding:0 20px 0 12px;font-weight:900;font-size:9px;letter-spacing:3px;color:#fff;white-space:nowrap;flex-shrink:0;clip-path:polygon(0 0,90% 0,100% 100%,0 100%)}
.spon-track{overflow:hidden;flex:1}
.spon-scroll{display:inline-flex;animation:rtl 30s linear infinite;white-space:nowrap}
@keyframes rtl{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.si{display:inline-flex;align-items:center;gap:7px;padding:0 26px;height:38px;border-right:1px solid var(--d4);font-weight:700;font-size:10px;letter-spacing:2px;color:var(--silv);text-transform:uppercase;text-decoration:none;transition:color .15s}
.si:hover{color:var(--wht)}.si.gld{color:var(--gold)}.si.blu{color:#7EC8F5}.si.red{color:#FF8080}
.si-dot{width:5px;height:5px;border-radius:50%;background:currentColor;flex-shrink:0}

/* ── NEWS TICKER ── */
.news-bar{background:var(--red);height:34px;display:flex;align-items:center;overflow:hidden}
.news-lbl{background:var(--dkred);height:100%;display:flex;align-items:center;padding:0 20px 0 14px;font-weight:900;font-size:9px;letter-spacing:3px;color:#fff;flex-shrink:0;white-space:nowrap;clip-path:polygon(0 0,88% 0,100% 100%,0 100%)}
.news-track{overflow:hidden;flex:1}
.news-scroll{display:inline-flex;animation:rtl 50s linear infinite;white-space:nowrap}
.ni{font-weight:600;font-size:11px;letter-spacing:1px;padding:0 36px;color:#fff;font-family:var(--thai)}
.ni::before{content:'◆';margin-right:10px;font-size:7px;vertical-align:middle;opacity:.7}

/* ── SOCIAL BAR (footer area) ── */
.social-bar{background:var(--d1);border-top:1px solid var(--d4);padding:10px max(16px, env(safe-area-inset-right)) 10px max(16px, env(safe-area-inset-left));display:flex;align-items:center;justify-content:center;gap:0;flex-wrap:wrap}
.soc-btn{display:flex;align-items:center;gap:7px;padding:8px 20px;color:var(--gray);text-decoration:none;font-weight:700;font-size:10px;letter-spacing:1.5px;text-transform:uppercase;border-right:1px solid var(--d4);transition:color .15s,background .15s}
.soc-btn:first-child{border-left:1px solid var(--d4)}
.soc-btn:hover{color:var(--wht);background:rgba(255,255,255,.04)}
.soc-btn svg{width:16px;height:16px;fill:currentColor;flex-shrink:0}

/* ── PAGES ── */
.page{display:none}.page.active{display:block}
.wrap{max-width:1400px;margin:0 auto;padding:0 max(16px, env(safe-area-inset-right)) 0 max(16px, env(safe-area-inset-left))}
.sec{padding:56px 0}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;padding-bottom:16px;border-bottom:1px solid var(--d4);margin-bottom:32px;flex-wrap:wrap}
.sec-tag{font-weight:700;font-size:9px;letter-spacing:4px;color:var(--red);text-transform:uppercase;margin-bottom:3px}
.sec-title{font-weight:900;font-size:clamp(18px,3vw,28px);letter-spacing:1px;text-transform:uppercase;line-height:1;color:var(--wht)}

/* ── HERO ── */
.hero{position:relative;overflow:hidden;background:var(--blk);padding:76px 24px 84px;text-align:center}
.hgrid{position:absolute;inset:0;background-image:linear-gradient(rgba(232,0,45,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(232,0,45,.05) 1px,transparent 1px);background-size:64px 64px;pointer-events:none}
.hglow{position:absolute;inset:0;background:radial-gradient(ellipse 60% 50% at 50% 55%,rgba(0,63,138,.2) 0%,transparent 70%);pointer-events:none}
.hvl{position:absolute;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,transparent,var(--red),transparent);left:50%;transform:translateX(-50%);opacity:.12;pointer-events:none}
.hero-pill{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--d5);background:rgba(255,255,255,.03);padding:5px 14px;font-size:9px;font-weight:700;letter-spacing:4px;color:var(--silv);text-transform:uppercase;margin-bottom:24px}
.hp-dot{width:6px;height:6px;border-radius:50%;background:var(--red);flex-shrink:0}
.hero-eye{font-weight:900;font-size:10px;letter-spacing:6px;color:var(--red);text-transform:uppercase;margin-bottom:12px}
.hero-h1{font-weight:900;font-size:clamp(32px,7.5vw,80px);line-height:.9;letter-spacing:-1px;text-transform:uppercase;margin-bottom:6px;color:var(--wht)}
.hero-h1 em{color:var(--red);font-style:normal}
.hero-h2{font-weight:200;font-size:clamp(10px,1.8vw,16px);letter-spacing:8px;color:var(--gray);text-transform:uppercase;margin-bottom:40px;font-family:var(--thai)}
.cta-row{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;margin-bottom:56px}
.kpi-strip{display:flex;max-width:560px;margin:0 auto;border:1px solid var(--d4);background:rgba(255,255,255,.02)}
.kpi-cell{flex:1;padding:20px 6px;border-right:1px solid var(--d4);text-align:center;transition:background .3s}.kpi-cell:last-child{border-right:none}
.kpi-cell:hover{background:rgba(232,0,45,.06)}
.kpi-num{display:block;font-weight:900;font-size:32px;line-height:1;color:var(--red);transition:transform .3s,text-shadow .3s}
.kpi-num.counted{text-shadow:0 0 20px rgba(232,0,45,.4)}
.kpi-lbl{display:block;font-size:9px;font-weight:700;letter-spacing:3px;color:var(--gray);margin-top:3px;text-transform:uppercase}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:7px;font-family:var(--f1);font-weight:700;font-size:10.5px;letter-spacing:2px;text-transform:uppercase;padding:11px 26px;border:none;cursor:pointer;text-decoration:none;transition:background .15s,color .15s,border-color .15s;clip-path:polygon(0 0,96% 0,100% 100%,4% 100%);white-space:nowrap}
.btn-red{background:var(--red);color:#fff;position:relative;overflow:hidden;z-index:1;transition:background .2s,box-shadow .3s,transform .15s,text-shadow .3s}
.btn-red::before,.btn-red::after{content:'';position:absolute;top:0;width:6px;height:100%;background:linear-gradient(180deg,transparent,rgba(255,255,255,.45),transparent);transform:skewX(-18deg);opacity:0;transition:opacity .3s;z-index:2;pointer-events:none}
.btn-red::before{left:-20%;animation:none}
.btn-red::after{right:-20%;animation:none}
.btn-red:hover{background:linear-gradient(90deg,#ff0030,#e8002d,#ff0030);box-shadow:0 0 15px rgba(232,0,45,.5),0 0 40px rgba(232,0,45,.3),0 0 80px rgba(232,0,45,.15),inset 0 0 15px rgba(255,255,255,.06);transform:scale(1.04);text-shadow:0 0 12px rgba(255,255,255,.5)}
.btn-red:hover::before{opacity:1;animation:speedLine .6s ease-out forwards}
.btn-red:hover::after{opacity:1;animation:speedLine .6s .1s ease-out forwards}
@keyframes speedLine{0%{left:-20%;opacity:0}20%{opacity:1}100%{left:120%;opacity:0}}
.btn-red:active{transform:scale(.97);box-shadow:0 0 8px rgba(232,0,45,.6)}
.btn-blue{background:var(--blu2);color:#fff}.btn-blue:hover{background:var(--blue)}
.btn-grn{background:rgba(0,200,83,.15);color:var(--grn);border:1px solid rgba(0,200,83,.3);clip-path:none}.btn-grn:hover{background:rgba(0,200,83,.25)}
.btn-ghost{background:transparent;color:var(--silv);border:1px solid var(--d5);clip-path:none}.btn-ghost:hover{border-color:var(--red);color:var(--wht)}
.btn-danger{background:rgba(255,23,68,.12);color:var(--danger);border:1px solid rgba(255,23,68,.25);clip-path:none}.btn-danger:hover{background:rgba(255,23,68,.25)}
.btn-sm{font-size:9px;padding:7px 16px;letter-spacing:1.5px}.btn-xs{font-size:8px;padding:4px 10px;letter-spacing:1px;clip-path:none}

/* ── STANDINGS ── */
.stnd-wrap{overflow-x:auto}
.stnd-tbl{width:100%;border-collapse:collapse;min-width:620px}
.stnd-tbl thead th{font-weight:700;font-size:9px;letter-spacing:3px;color:var(--gray);text-transform:uppercase;padding:10px 12px;text-align:left;border-bottom:1px solid var(--d3);white-space:nowrap}
.stnd-tbl tbody tr{border-bottom:1px solid var(--d2);transition:background .1s}.stnd-tbl tbody tr:hover{background:rgba(232,0,45,.04)}
.stnd-tbl td{padding:12px 12px;vertical-align:middle}
.pos-w{display:flex;align-items:center;gap:7px}
.pos-bar{width:3px;height:32px;border-radius:2px;background:var(--d5)}
.pos-num{font-weight:900;font-size:20px;color:var(--silv);min-width:28px}
tr.p1 .pos-bar{background:var(--gold)}tr.p2 .pos-bar{background:#C0C0C0}tr.p3 .pos-bar{background:#CD7F32}
tr.p1 .pos-num{color:var(--gold)}tr.p2 .pos-num{color:#C8C8C8}tr.p3 .pos-num{color:#CD9040}
.trend{display:inline-flex;align-items:center;gap:2px;padding:2px 6px;font-weight:700;font-size:10px}
.t-up{color:var(--red);background:rgba(232,0,45,.12)}.t-dn{color:var(--gray);background:rgba(136,136,152,.12)}.t-eq{color:var(--dkgry)}
.drv-cell{display:flex;align-items:center;gap:12px}
.drv-av{width:38px;height:38px;border-radius:50%;border:2px solid var(--d4);background:var(--d3);display:flex;align-items:center;justify-content:center;font-weight:900;font-size:12px;color:var(--silv);text-transform:uppercase;overflow:hidden;flex-shrink:0}
.drv-av img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.drv-name{font-weight:700;font-size:15px;letter-spacing:.3px;color:var(--wht);line-height:1.2;font-family:var(--thai)}
.drv-tag{font-size:9px;letter-spacing:2px;color:var(--gray);font-weight:700;font-family:var(--f1)}
.wins-b{font-size:9px;font-weight:700;letter-spacing:1px;padding:2px 8px;background:rgba(232,0,45,.12);border:1px solid rgba(232,0,45,.25);color:var(--red);text-transform:uppercase}
.pts-val{font-weight:900;font-size:22px;color:var(--wht)}.pts-u{font-size:9px;color:var(--gray);font-weight:700;letter-spacing:1px}

/* ── F1 BROADCAST STANDINGS ── */
.f1-standings-board {
  background: #15151e;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 10px 30px rgba(0,0,0,0.5);
  border: 1px solid var(--d4);
  font-family: var(--f1);
}
.f1-sb-head {
  display: grid;
  grid-template-columns: 60px 50px 1fr 80px 100px 40px;
  background: rgba(0,0,0,0.6);
  padding: 12px 16px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 2px;
  color: var(--gray);
  text-transform: uppercase;
  border-bottom: 2px solid var(--d4);
}
.f1-sb-list { display: flex; flex-direction: column; position: relative; }
.f1-sb-row {
  display: grid;
  grid-template-columns: 60px 50px 1fr 80px 100px 40px;
  align-items: center;
  padding: 10px 16px;
  border-bottom: 1px solid rgba(255,255,255,0.05);
  background: #15151e;
  position: relative;
}
.f1-sb-row:hover { background: rgba(255,255,255,0.04); }
.f1-pos-box { display: flex; align-items: center; justify-content: center; }
.f1-pos-num { font-size: 24px; font-weight: 900; color: var(--wht); }
.p1 .f1-pos-num { color: var(--gold); }
.p2 .f1-pos-num { color: #C0C0C0; }
.p3 .f1-pos-num { color: #CD9040; }

.f1-trend-box { display: flex; justify-content: center; align-items: center; }
.f1-trend-icon { width: 16px; height: 16px; fill: currentColor; }
.f1-trend-icon.up { color: var(--red); filter: drop-shadow(0 0 4px rgba(232,0,45,0.5)); }
.f1-trend-icon.dn { color: var(--gray); }
.f1-trend-icon.eq { width: 8px; height: 3px; background: var(--dkgry); border-radius: 2px; }

.f1-drv-col { display: flex; align-items: center; gap: 12px; }
.f1-team-bar { width: 4px; height: 36px; border-radius: 2px; box-shadow: 0 0 8px rgba(255,255,255,0.1); }
.f1-drv-info { display: flex; flex-direction: column; }
.f1-drv-name { font-family: var(--thai); font-size: 18px; font-weight: 700; color: var(--wht); line-height: 1.1; cursor: pointer; text-transform: uppercase; transition: color 0.15s; }
.f1-drv-name:hover { color: var(--red); }
.f1-drv-tag { font-family: var(--f1); font-size: 10px; color: var(--gray); font-weight: 700; letter-spacing: 1px; text-transform: uppercase; margin-top: 2px; }

.f1-wins-box { text-align: center; }
.f1-pts-box { text-align: right; }
.f1-pts-val { display: inline-block; background: rgba(255,255,255,0.06); padding: 4px 12px; border-radius: 4px; font-size: 20px; font-weight: 900; color: var(--wht); border: 1px solid rgba(255,255,255,0.04); min-width: 60px; text-align: center; }
.f1-pts-u { font-size: 10px; font-weight: 700; color: var(--gray); margin-left: 2px; }

.f1-action-box { display: flex; justify-content: flex-end; }

@media(max-width: 768px) {
  .f1-sb-head,.f1-sb-row{grid-template-columns:52px 52px 1fr 90px}
  .f1-wins-box,.races-cell,.hidden-m{display:none!important}
  .f1-drv-name{font-size:14px}
  .pts-new-num{font-size:18px}
}

/* ── RACE HISTORY (F1 Style) ── */
.race-card{margin-bottom:32px;overflow:hidden;border:1px solid var(--d4);background:var(--d2)}
.f1r-card-head{background:linear-gradient(135deg,#1a0005 0%,var(--d3) 70%);padding:22px 24px;border-bottom:1px solid var(--d4);display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.f1r-round{font-family:var(--f1);font-size:9px;letter-spacing:3px;color:var(--red);font-weight:700;margin-bottom:6px}
.f1r-race-name{font-family:var(--f1);font-size:20px;font-weight:900;color:var(--wht);letter-spacing:.5px;text-transform:uppercase;line-height:1.2;margin-bottom:8px}
.f1r-race-meta{font-size:11px;color:var(--gray);display:flex;gap:8px;flex-wrap:wrap;align-items:center;font-family:var(--thai)}
.f1r-sep{color:var(--d4)}
.f1r-head-right{flex-shrink:0;padding-top:4px}
.f1r-tbl-head,.f1r-row{display:grid;grid-template-columns:4px 60px 1fr 190px 80px;align-items:center}
.f1r-tbl-head{padding:8px 0;background:var(--d3);border-bottom:2px solid var(--d4)}
.f1r-tbl-head>div{font-family:var(--f1);font-size:9px;letter-spacing:2px;color:var(--gray);font-weight:700;text-transform:uppercase;padding:0 10px}
.f1r-pts-h{text-align:right;padding-right:18px!important}
.f1r-row{padding:10px 0;border-bottom:1px solid var(--d3);transition:background .15s}
.f1r-row:hover{background:rgba(255,255,255,.03)}
.f1r-row:last-child{border-bottom:none}
.f1r-row.f1r-p1{background:rgba(255,215,0,.05)}
.f1r-row.f1r-p2{background:rgba(192,192,192,.03)}
.f1r-row.f1r-p3{background:rgba(205,144,64,.03)}
.f1r-bar{align-self:stretch;min-height:52px}
.f1r-pos{font-family:var(--f1);font-size:20px;font-weight:900;color:var(--gray);text-align:center;padding:0 4px}
.f1r-p1 .f1r-pos{color:var(--gold)}.f1r-p2 .f1r-pos{color:#C0C0C0}.f1r-p3 .f1r-pos{color:#CD9040}
.f1r-drv-cell{display:flex;align-items:center;gap:12px;padding:0 10px;min-width:0}
.f1r-avatar{width:38px;height:38px;border-radius:50%;object-fit:cover;flex-shrink:0}
.f1r-av-ph{width:38px;height:38px;border-radius:50%;background:var(--d4);flex-shrink:0}
.f1r-drv-name{font-family:var(--f1);font-size:13px;font-weight:700;color:var(--wht);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.f1r-drv-sub{font-size:10px;color:var(--gray);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family:var(--thai)}
.f1r-team-cell{display:flex;align-items:center;gap:8px;padding:0 10px;min-width:0}
.f1r-team-logo{width:28px;height:28px;object-fit:contain;flex-shrink:0;filter:drop-shadow(0 0 3px rgba(255,255,255,.1))}
.f1r-team-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.f1r-team-name{font-size:11px;color:var(--silv);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family:var(--thai)}
.f1r-pts-cell{text-align:right;padding-right:18px}
.f1r-pts{font-family:var(--f1);font-size:16px;font-weight:900;color:var(--wht)}
@media(max-width:640px){
  .f1r-tbl-head,.f1r-row{grid-template-columns:4px 46px 1fr 72px}
  .f1r-hide-sm,.f1r-team-cell{display:none!important}
  .f1r-race-name{font-size:15px}
  .f1r-pos{font-size:16px}
  .f1r-pts{font-size:13px}
  .f1r-card-head{padding:16px}
}

/* ── ADMIN PANEL ── */
.admin-panel{display:none;background:var(--d2);border:1px solid var(--d4);border-top:3px solid var(--blu2);padding:28px;margin-top:24px}
.admin-panel.open{display:block}
.ap-title{font-weight:700;font-size:11px;letter-spacing:3px;color:#7EC8F5;margin-bottom:20px;text-transform:uppercase}
.ap-tabs{display:flex;border-bottom:1px solid var(--d4);margin-bottom:24px;overflow-x:auto;-webkit-overflow-scrolling:touch;gap:0;scrollbar-width:thin}
.ap-tab{background:none;border:none;font-family:var(--f1);font-weight:700;font-size:10px;letter-spacing:2px;color:var(--gray);padding:9px 18px;border-bottom:2px solid transparent;margin-bottom:-1px;cursor:pointer;white-space:nowrap;text-transform:uppercase;transition:color .15s;flex-shrink:0}
.ap-tab.on{color:var(--wht);border-bottom-color:var(--blu2)}
.ap-pane{display:none}.ap-pane.open{display:block}
/* pts-grid replaced by adm-pts-row table layout */
.pts-grid{display:flex;flex-direction:column;gap:0;border:1px solid var(--d4);border-radius:4px;overflow:hidden}

/* Column headers */
.adm-pts-header{
  display:grid;
  grid-template-columns:48px 1fr 100px 100px 100px 120px;
  padding:8px 0;margin-bottom:0;
  font-family:var(--f1);font-size:8px;font-weight:700;
  letter-spacing:2px;color:var(--gray);text-transform:uppercase;
  border-bottom:2px solid var(--d4);
}
.adm-pts-header > div{padding:0 12px;text-align:center}
.adm-pts-header > div:nth-child(2){text-align:left;padding-left:16px}

/* ── Admin Points Table ── */
.adm-pts-row{
  display:grid;
  grid-template-columns:48px 1fr 100px 100px 100px 120px;
  align-items:center;
  gap:0;
  border-bottom:1px solid var(--d4);
  background:var(--d2);
  transition:background .12s;
  min-height:62px;
}
.adm-pts-row:last-child{border-bottom:none}
.adm-pts-row:hover{background:var(--d3)}

/* Rank column */
.adm-pts-pos{
  display:flex;align-items:center;justify-content:center;
  font-family:var(--f1);font-size:16px;font-weight:900;color:var(--dkgry);
  height:100%;border-right:1px solid var(--d4);
}
.adm-rank-1{color:var(--gold)}.adm-rank-2{color:#C0C0C0}.adm-rank-3{color:#CD9040}

/* Driver column */
.adm-pts-drv{
  display:flex;align-items:center;gap:10px;
  padding:10px 16px;border-right:1px solid var(--d4);min-width:0;
}
.adm-pts-av{
  width:36px;height:36px;border-radius:50%;
  border:2px solid var(--d5);background:var(--d3);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;flex-shrink:0;
}
.adm-pts-name{
  font-family:var(--thai);font-size:14px;font-weight:700;
  color:var(--wht);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.adm-pts-tag{
  font-family:var(--f1);font-size:9px;letter-spacing:2px;
  color:var(--gray);font-weight:700;margin-top:1px;
}
.adm-team-bar{width:3px;height:28px;border-radius:2px;flex-shrink:0}

/* Input fields */
.adm-pts-field{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:4px;padding:8px 12px;border-right:1px solid var(--d4);height:100%;
}
.adm-field-lbl{
  font-family:var(--f1);font-size:8px;font-weight:700;
  letter-spacing:2px;color:var(--gray);text-transform:uppercase;
}
.adm-field-in{
  background:var(--d3);border:1px solid var(--d4);border-bottom:2px solid var(--d5);
  color:var(--wht);font-family:var(--f1);font-size:16px;font-weight:900;
  padding:5px 8px;text-align:center;outline:none;width:72px;
  transition:border-color .15s;
}
.adm-field-in:focus{border-bottom-color:var(--red)}
.adm-field-in:hover{border-color:var(--d5)}

/* Delete button */
.adm-del-btn{
  display:flex;align-items:center;justify-content:center;gap:6px;
  margin:0 12px;padding:7px 14px;
  background:rgba(255,23,68,.08);border:1px solid rgba(255,23,68,.2);
  color:var(--danger);font-family:var(--f1);font-size:9px;font-weight:700;
  letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;
  transition:all .15s;border-radius:2px;white-space:nowrap;
}
.adm-del-btn:hover{background:rgba(255,23,68,.2);border-color:var(--danger)}

@media(max-width:900px){
  .adm-pts-row{grid-template-columns:40px 1fr 80px 80px 80px}
  .adm-del-btn{display:none}
}
@media(max-width:600px){
  .adm-pts-row{grid-template-columns:36px 1fr 70px 70px}
  .adm-pts-field:last-of-type{display:none}
}
.rr-list{display:flex;flex-direction:column;gap:5px;max-height:400px;overflow-y:auto}
.rr-row{display:grid;grid-template-columns:38px 1fr 74px;gap:7px;align-items:center;background:var(--d3);padding:8px 12px;border:1px solid var(--d4)}
.rr-pos-lbl{font-weight:900;font-size:16px;color:var(--gray);text-align:center}

/* Sponsor manager */
.spon-manager{display:flex;flex-direction:column;gap:7px}
.spon-row-head{display:grid;grid-template-columns:1fr 90px 1fr 36px 36px;gap:8px;padding:0 14px 6px;font-size:8px;letter-spacing:2px;color:var(--gray);font-weight:700;text-transform:uppercase;border-bottom:1px solid var(--d4);margin-bottom:4px}
.spon-row{display:grid;grid-template-columns:1fr 90px 1fr 36px 36px;gap:8px;align-items:center;background:var(--d3);padding:9px 14px;border:1px solid var(--d4)}
.spon-icon-btn{width:32px;height:32px;border:none;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:13px;border-radius:2px;transition:background .15s;flex-shrink:0}
.spon-icon-btn:hover{background:rgba(255,255,255,.08)}

/* Social manager */
.social-mgr{display:flex;flex-direction:column;gap:7px}
.social-mgr-row{display:grid;grid-template-columns:140px 1fr 80px 36px;gap:8px;align-items:center;background:var(--d3);padding:9px 14px;border:1px solid var(--d4)}
.social-platform{display:flex;align-items:center;gap:8px;font-weight:700;font-size:12px;color:var(--silv)}
.social-platform svg{width:16px;height:16px;fill:currentColor;flex-shrink:0}
.toggle-btn{display:flex;align-items:center;justify-content:center;padding:5px 12px;font-size:9px;font-weight:700;letter-spacing:1px;border:none;cursor:pointer;transition:all .15s;white-space:nowrap}
.toggle-on{background:rgba(0,200,83,.15);color:var(--grn);border:1px solid rgba(0,200,83,.3)}
.toggle-off{background:rgba(255,255,255,.06);color:var(--gray);border:1px solid var(--d4)}

/* Reg table */
.reg-tbl{width:100%;border-collapse:collapse;min-width:680px}
.reg-tbl th{font-size:9px;letter-spacing:2px;color:var(--gray);padding:8px 10px;text-align:left;border-bottom:1px solid var(--d3);text-transform:uppercase;font-weight:700;white-space:nowrap}
.reg-tbl td{padding:10px 10px;border-bottom:1px solid var(--d2);font-size:13px;vertical-align:middle;font-family:var(--thai)}
.reg-tbl tr:hover td{background:rgba(255,255,255,.02)}
.sb{font-size:8px;font-weight:700;letter-spacing:1px;padding:2px 8px;text-transform:uppercase}
.sb-pend{color:var(--warn);background:rgba(255,179,0,.1);border:1px solid rgba(255,179,0,.3)}
.sb-ok{color:var(--grn);background:rgba(0,200,83,.1);border:1px solid rgba(0,200,83,.3)}
.sb-rej{color:var(--danger);background:rgba(255,23,68,.1);border:1px solid rgba(255,23,68,.3)}
.tt-link{font-size:10px;color:#64B5F6;text-decoration:none;letter-spacing:1px;font-weight:700;font-family:var(--f1)}.tt-link:hover{text-decoration:underline}

/* ── FORM ── */
.f-wrap{max-width:840px;margin:0 auto;background:var(--d2);border:1px solid var(--d4);padding:44px}
.f-sec{font-weight:700;font-size:13px;letter-spacing:1px;color:var(--red);text-transform:none;padding-bottom:10px;border-bottom:1px solid var(--d4);margin-bottom:22px;font-family:var(--thai)}
.f-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.f-grid.g1{grid-template-columns:1fr}
.f-grp{display:flex;flex-direction:column;gap:5px}
.f-lbl{font-weight:600;font-size:11px;letter-spacing:0.5px;color:var(--gray);text-transform:none;font-family:var(--thai)}
.f-in,.f-sel,.f-ta{background:var(--d3);border:1px solid var(--d4);border-bottom:2px solid var(--d5);color:var(--wht);font-family:var(--thai);font-size:14px;padding:10px 13px;outline:none;transition:border-color .15s;width:100%;border-radius:0}
.f-in:focus,.f-sel:focus,.f-ta:focus{border-bottom-color:var(--red)}
.f-in{font-family:var(--thai)} /* inputs ใช้ thai font */
.f-ta{min-height:88px;resize:vertical;font-family:var(--thai)}.f-sel{appearance:none;cursor:pointer;font-family:var(--thai)}
.circ-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(192px,1fr));gap:5px}
.ci{display:flex;align-items:center;gap:7px;padding:6px 10px;background:var(--d3);border:1px solid var(--d4);cursor:pointer;transition:border-color .12s}
.ci:hover{border-color:var(--red)}.ci input{accent-color:var(--red);width:13px;height:13px;flex-shrink:0}
.ci span{font-size:13px;color:var(--silv);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family:var(--thai)}
.uz{border:2px dashed var(--d5);background:var(--d3);padding:24px 16px;text-align:center;cursor:pointer;transition:border-color .15s,background .15s}
.uz:hover{border-color:var(--red);background:rgba(232,0,45,.04)}.uz.filled{border-color:var(--grn);border-style:solid}
.uz-icon{font-size:20px;color:var(--gray);margin-bottom:5px}
.uz-text{font-weight:600;font-size:12px;letter-spacing:0;color:var(--gray);text-transform:none;font-family:var(--thai)}
.uz-hint{font-size:11px;color:var(--dkgry);margin-top:4px;font-family:var(--thai)}.uz-fn{font-size:11px;color:var(--grn);margin-top:5px;font-weight:600;letter-spacing:0;font-family:var(--thai)}
.av-row{display:flex;align-items:center;gap:18px}
.av-circle{width:74px;height:74px;border-radius:50%;border:2px solid var(--d4);background:var(--d3);overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:28px;flex-shrink:0}
.av-circle img{width:100%;height:100%;object-fit:cover;display:none}
.f-sp{margin-bottom:32px}
.suc-screen{display:none;text-align:center;padding:72px 20px}
.suc-ring{width:80px;height:80px;border-radius:50%;border:2px solid var(--grn);background:rgba(0,200,83,.1);display:flex;align-items:center;justify-content:center;font-size:36px;margin:0 auto 24px}
.suc-title{font-weight:900;font-size:22px;letter-spacing:2px;color:var(--grn);text-transform:uppercase;margin-bottom:8px;font-family:var(--f1)}
.suc-sub{font-size:14px;color:var(--gray);line-height:1.7;font-family:var(--thai)}

/* ── NEWS CARDS ── */
.ngrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1px;background:var(--d4)}
.nc{background:var(--d1);padding:24px;transition:background .15s;position:relative}
.nc:hover{background:var(--d2)}
.nc-date{font-size:9px;font-weight:700;letter-spacing:3px;color:var(--gray);margin-bottom:8px;text-transform:uppercase;font-family:var(--f1)}
.nc-tag{display:inline-block;font-size:9px;font-weight:700;letter-spacing:2px;padding:2px 8px;margin-bottom:10px;text-transform:uppercase;font-family:var(--f1)}
.nt-red{background:rgba(232,0,45,.14);color:var(--red);border-left:2px solid var(--red)}
.nt-blue{background:rgba(0,63,138,.2);color:#7EC8F5;border-left:2px solid var(--blu2)}
.nt-gold{background:rgba(255,208,64,.1);color:var(--gold);border-left:2px solid var(--gold)}
.nc-title{font-weight:700;font-size:16px;color:var(--wht);margin-bottom:8px;line-height:1.4;font-family:var(--thai)}
.nc-body{font-size:13px;color:var(--gray);line-height:1.7;font-family:var(--thai)}
.nc-del{position:absolute;top:12px;right:12px;background:none;border:none;cursor:pointer;color:var(--gray);font-size:14px;opacity:0;transition:opacity .15s,color .15s;padding:4px}
.nc:hover .nc-del{opacity:1}.nc-del:hover{color:var(--danger)}

/* ── MODAL ── */
.modal-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.88);z-index:9000;align-items:center;justify-content:center;padding:max(16px, env(safe-area-inset-top)) max(16px, env(safe-area-inset-right)) max(16px, env(safe-area-inset-bottom)) max(16px, env(safe-area-inset-left))}
.modal-bg.open{display:flex}
.modal-box{background:var(--d2);border:1px solid var(--d4);border-top:3px solid var(--blu2);width:100%;max-width:420px;padding:36px}
.modal-title{font-weight:900;font-size:13px;letter-spacing:2px;color:#7EC8F5;margin-bottom:22px;text-transform:uppercase;font-family:var(--f1)}
.modal-foot{display:flex;gap:10px;justify-content:flex-end;margin-top:24px}

/* ── TOAST ── */
.toast{position:fixed;bottom:max(20px, env(safe-area-inset-bottom));right:max(16px, env(safe-area-inset-right));left:auto;max-width:min(340px, calc(100vw - 32px - env(safe-area-inset-left) - env(safe-area-inset-right)));background:var(--d2);border:1px solid var(--d4);border-left:4px solid var(--grn);padding:13px 20px;font-weight:700;font-size:11px;letter-spacing:1px;color:var(--grn);z-index:99999;transform:translateY(80px);opacity:0;transition:all .3s ease;line-height:1.5;font-family:var(--thai)}
.toast.show{transform:translateY(0);opacity:1}.toast.terr{border-left-color:var(--danger);color:var(--danger)}

/* ── SKELETON ── */
.skel{background:linear-gradient(90deg,var(--d3) 25%,var(--d4) 50%,var(--d3) 75%);background-size:200%;animation:shimmer 1.6s infinite;border-radius:1px}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.empty-state{padding:48px;text-align:center;color:var(--gray);font-size:11px;letter-spacing:2px;font-weight:700;font-family:var(--thai)}

/* ── FOOTER ── */
footer{background:var(--d2);border-top:1px solid var(--d4);padding:36px max(24px, env(safe-area-inset-right)) calc(36px + env(safe-area-inset-bottom, 0px)) max(24px, env(safe-area-inset-left))}
.foot-in{max-width:1400px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}
.foot-logo-img{height:40px;width:auto;object-fit:contain;filter:drop-shadow(0 0 8px rgba(232,0,45,.2))}
.foot-right{text-align:right}
.foot-title{font-size:10px;letter-spacing:2px;color:var(--silv);font-weight:600;margin-bottom:3px;font-family:var(--thai)}
.foot-copy{font-size:9px;letter-spacing:2px;color:var(--gray);font-family:var(--f1)}

/* ── CONFIRM ── */
.modal-box.danger-box{border-top-color:var(--danger)}
.danger-title{color:#FF8080}
.confirm-msg{color:var(--silv);font-size:14px;font-family:var(--thai)}


/* ── CALENDAR ── */
.cal-grid{display:flex;flex-direction:column;gap:8px}
.cal-row{display:grid;grid-template-columns:100px 44px 36px minmax(0,1fr) 150px 96px 76px;gap:0;align-items:stretch;background:var(--d2);border:1px solid var(--d4);padding:0;overflow:hidden;transition:background .15s}
.cal-row:hover{background:var(--d3)}
.cal-thumb-wrap{position:relative;background:linear-gradient(145deg,var(--d4),var(--d3));min-height:76px;border-right:1px solid var(--d4)}
.cal-thumb-img{position:absolute;inset:0;width:100%;height:100%;display:block}
.cal-thumb-img.cal-flag-photo{object-fit:contain;padding:12px;box-sizing:border-box;background:var(--d3)}
.cal-thumb-ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:28px;line-height:1;background:linear-gradient(160deg,var(--d4),var(--d2))}
.cal-thumb-wrap.cal-thumb-loaded .cal-thumb-ph{display:none}
.cal-thumb-img.cal-thumb-broken{display:none !important}
.cal-round{font-weight:900;font-size:18px;color:var(--gray);padding:0 14px;text-align:center;border-right:1px solid var(--d4);height:100%;display:flex;align-items:center;justify-content:center;min-height:60px}
.cal-flag{font-size:22px;padding:0 10px;text-align:center;display:flex;align-items:center;justify-content:center;border-right:1px solid var(--d4)}
.cal-info{padding:10px 14px}
.cal-name{font-weight:700;font-size:14px;color:var(--wht);letter-spacing:.5px}
.cal-circuit{font-size:12px;color:var(--gray);margin-top:2px;font-family:var(--thai)}
.cal-date{font-size:12px;color:var(--silv);padding:0 12px;font-family:var(--f1);text-align:center}
.cal-date-main{font-weight:700;font-size:13px}
.cal-date-time{font-size:10px;color:var(--gray);margin-top:2px}
.cal-status-cell{padding:0 12px;text-align:center}
.cs-badge{display:inline-block;font-size:9px;font-weight:700;letter-spacing:1.5px;padding:4px 10px;text-transform:uppercase}
.cs-upcoming{background:rgba(0,63,138,.2);color:#7EC8F5;border:1px solid rgba(21,101,192,.4)}
.cs-live{background:rgba(232,0,45,.2);color:#FF6B6B;border:1px solid rgba(232,0,45,.4)}
.cs-done{background:rgba(0,200,83,.1);color:var(--grn);border:1px solid rgba(0,200,83,.3)}
.cal-actions{padding:0 12px;display:flex;justify-content:center;gap:6px}
.cal-next{border-left:3px solid var(--red) !important}
.cal-countdown{font-size:11px;color:var(--red);font-weight:700;letter-spacing:1px;font-family:var(--f1)}
.cal-admin-xscroll{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -8px;padding:0 8px 12px}
.cal-admin-xscroll #calAdminGrid > div{min-width:900px;box-sizing:border-box}

/* Calendar Admin */
.cal-admin-row{display:grid;grid-template-columns:60px 1fr 1fr 80px 100px 80px 36px 36px;gap:7px;align-items:center;background:var(--d3);padding:9px 12px;border:1px solid var(--d4);margin-bottom:6px}

/* ── DRIVER PROFILE ── */
.profile-hero{background:var(--d2);border:1px solid var(--d4);border-top:3px solid var(--red);padding:32px 36px;display:flex;gap:28px;align-items:flex-start;margin-bottom:24px;flex-wrap:wrap}
.profile-av{width:96px;height:96px;border-radius:50%;border:3px solid var(--d4);background:var(--d3);display:flex;align-items:center;justify-content:center;font-weight:900;font-size:32px;color:var(--silv);text-transform:uppercase;overflow:hidden;flex-shrink:0}
.profile-av img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.profile-name{font-weight:900;font-size:clamp(22px,4vw,36px);color:var(--wht);letter-spacing:1px;font-family:var(--thai);line-height:1.1}
.profile-tag{font-size:11px;letter-spacing:4px;color:var(--red);font-weight:700;font-family:var(--f1);margin-top:4px}
.profile-meta{display:flex;gap:20px;margin-top:14px;flex-wrap:wrap}
.pm-item{font-size:12px;color:var(--gray)}
.pm-item span{color:var(--silv);font-weight:600}
.profile-stats{display:grid;grid-template-columns:repeat(6,1fr);gap:1px;background:var(--d4);border:1px solid var(--d4);margin-bottom:24px}
.pstat{background:var(--d2);padding:20px 16px;text-align:center}
.pstat-num{font-weight:900;font-size:28px;color:var(--red);font-family:var(--f1)}
.pstat-lbl{font-size:9px;letter-spacing:3px;color:var(--gray);font-weight:700;margin-top:4px;font-family:var(--f1);text-transform:uppercase}
.pstat.gold .pstat-num{color:var(--gold)}
.pstat.silv .pstat-num{color:#C0C0C0}

.profile-race-tbl{width:100%;border-collapse:collapse}
.profile-race-tbl thead th{font-size:9px;letter-spacing:3px;color:var(--gray);padding:8px 12px;text-align:left;border-bottom:1px solid var(--d3);font-weight:700;text-transform:uppercase;font-family:var(--f1)}
.profile-race-tbl tbody tr{border-bottom:1px solid var(--d2);transition:background .1s}
.profile-race-tbl tbody tr:hover{background:rgba(232,0,45,.04)}
.profile-race-tbl td{padding:11px 12px;font-size:13px;vertical-align:middle}
.pos-fin{font-weight:900;font-size:18px;font-family:var(--f1)}
.pos-fin.p1{color:var(--gold)}.pos-fin.p2{color:#C0C0C0}.pos-fin.p3{color:#CD9040}
.pts-gained{font-weight:700;color:var(--red);font-family:var(--f1)}

/* ── RACE MONITOR ── */
.mon-status{display:flex;align-items:center;gap:10px;margin-bottom:20px;padding:12px 16px;background:var(--d2);border:1px solid var(--d4)}
.mon-dot{width:10px;height:10px;border-radius:50%;background:var(--gray);flex-shrink:0}
.mon-dot.live{background:var(--danger);box-shadow:0 0 8px var(--danger);animation:pulse 1s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.mon-label{font-size:11px;font-weight:700;letter-spacing:2px;color:var(--gray);font-family:var(--f1)}
.mon-label.live{color:var(--danger)}
.mon-info{margin-left:auto;font-size:11px;color:var(--gray);font-family:var(--f1)}

/* HUD strip */
.hud-strip{display:grid;grid-template-columns:1fr 1fr 1fr 1fr 1fr;gap:1px;background:var(--d4);margin-bottom:16px}
.hud-cell{background:var(--d2);padding:16px 12px;text-align:center}
.hud-val{font-size:28px;font-weight:900;color:var(--wht);font-family:var(--f1);line-height:1}
.hud-val.red{color:var(--red)}.hud-val.grn{color:var(--grn)}.hud-val.gold{color:var(--gold)}
.hud-lbl{font-size:9px;letter-spacing:3px;color:var(--gray);font-weight:700;font-family:var(--f1);text-transform:uppercase;margin-top:4px}
.rpm-bar{height:4px;background:var(--d4);margin-top:8px;border-radius:2px;overflow:hidden}
.rpm-fill{height:100%;background:linear-gradient(90deg,var(--grn),var(--gold),var(--danger));transition:width .1s}
.ers-bar{height:4px;background:var(--d4);margin-top:8px;border-radius:2px;overflow:hidden}
.ers-fill{height:100%;background:var(--grn);transition:width .15s}

/* Leaderboard table */
.lb-tbl{width:100%;border-collapse:collapse;font-family:var(--f1)}
.lb-tbl thead th{font-size:9px;letter-spacing:3px;color:var(--gray);text-transform:uppercase;padding:8px 10px;text-align:left;border-bottom:1px solid var(--d3)}
.lb-tbl tbody tr{border-bottom:1px solid var(--d2);transition:background .1s}
.lb-tbl tbody tr:hover{background:rgba(232,0,45,.04)}
.lb-tbl td{padding:9px 10px;vertical-align:middle;font-size:13px}
.lb-pos{font-weight:900;font-size:16px;color:var(--silv);min-width:28px}
.lb-pos.p1{color:var(--gold)}.lb-pos.p2{color:#C0C0C0}.lb-pos.p3{color:#CD9040}
.lb-num{font-size:11px;color:var(--gray);min-width:28px;text-align:center}
.lb-name{font-weight:700;font-size:14px;color:var(--wht)}
.lb-team{font-size:10px;color:var(--gray);margin-top:1px}
.lb-tyre{display:inline-block;width:22px;height:22px;border-radius:50%;font-size:10px;font-weight:900;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#000}
.ty-S{background:#E8002D}.ty-M{background:#FFD040}.ty-H{background:#fff}
.ty-I{background:#39C6D3}.ty-W{background:#39C6D3}
.lb-gap{font-size:12px;color:var(--silv);font-family:var(--f1)}
.lb-me{background:rgba(232,0,45,.06)!important;border-left:2px solid var(--red)}
.lb-pit{font-size:9px;background:rgba(255,183,0,.15);color:var(--warn);padding:2px 6px;letter-spacing:1px}
.lb-drs{font-size:9px;background:rgba(0,200,83,.15);color:var(--grn);padding:2px 6px;letter-spacing:1px}

/* Save result button */
.save-result-box{background:var(--d2);border:1px solid var(--d4);border-left:3px solid var(--grn);padding:16px 20px;margin-top:16px;display:flex;align-items:center;gap:16px;flex-wrap:wrap}

/* ── GRAPHIC GENERATOR ── */
.gfx-tabs{display:flex;gap:0;border-bottom:1px solid var(--d4);margin-bottom:24px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin}
.gfx-tab{background:none;border:none;font-family:var(--f1);font-weight:700;font-size:11px;letter-spacing:2px;color:var(--gray);padding:10px 24px;border-bottom:2px solid transparent;margin-bottom:-1px;cursor:pointer;text-transform:uppercase;transition:color .15s;flex-shrink:0;white-space:nowrap}
.gfx-tab.on{color:var(--wht);border-bottom-color:var(--red)}
.gfx-pane{display:none}.gfx-pane.open{display:block}

/* canvas preview */
.canvas-wrap{position:relative;display:inline-block;max-width:100%}
.canvas-wrap canvas{max-width:100%;height:auto;display:block;border:1px solid var(--d4)}
.gfx-controls{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap;align-items:center}
.gfx-input-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(180px,100%),1fr));gap:10px;margin-bottom:16px}
@media(max-width:1040px){
  .nav-toggle{display:flex}
  .nav-brand{border-right:none;padding-right:10px;min-width:0}
  .nav-links{
    display:none;
    position:absolute;
    left:0;
    right:0;
    top:100%;
    flex:0 1 auto;
    flex-direction:column;
    flex-wrap:nowrap;
    padding:6px 0 14px;
    margin:0;
    background:var(--blk);
    border-bottom:1px solid var(--d4);
    box-shadow:0 16px 36px rgba(0,0,0,.55);
    max-height:min(72vh,calc(100dvh - 52px));
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
    z-index:920;
    gap:0;
  }
  #siteNav.nav-open .nav-links{display:flex}
  .nav-links li{display:block;width:100%}
  .nav-links li a{
    padding:13px 18px;
    width:100%;
    box-sizing:border-box;
    justify-content:flex-start;
    border-bottom:1px solid var(--d2);
    margin:0;
  }
  .nav-links li a.active{
    border-bottom-color:var(--d2);
    border-left:3px solid var(--red);
    padding-left:15px;
    background:rgba(232,0,45,.06);
  }
}
@media(max-width:768px){
  .f-grid{grid-template-columns:1fr}
  .f-wrap{padding:22px 16px;margin:0}
  .hero{padding:44px max(14px, env(safe-area-inset-right)) 52px max(14px, env(safe-area-inset-left))}
  .kpi-strip{flex-wrap:wrap;max-width:none}
  .kpi-cell{min-width:45%;padding:14px 8px}
  .stnd-tbl{min-width:520px}
  .stnd-tbl td{padding:9px 6px}
  .drv-tag{display:none}
  .sec{padding:36px 0}
  .sec-head{flex-direction:column;align-items:flex-start;gap:10px}
  .spon-row,.spon-row-head{grid-template-columns:1fr 80px 36px 36px}
  .spon-row .url-f,.spon-row-head .url-h{display:none}
  .social-mgr-row{grid-template-columns:minmax(100px,1fr) minmax(0,1fr) minmax(64px,70px) 36px}
  .nav-right{gap:6px;flex-shrink:0}
  .nav-status{font-size:7.5px}
  .nav-status #sLbl{max-width:64px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .ngrid{grid-template-columns:1fr}
  .profile-stats{grid-template-columns:repeat(3,1fr)}
  .foot-in{flex-direction:column;text-align:center;align-items:center}
  .foot-right{text-align:center}
  .toast{
    left:max(14px, env(safe-area-inset-left));
    right:max(14px, env(safe-area-inset-right));
    max-width:none;
    bottom:max(14px, env(safe-area-inset-bottom));
  }
  .pts-grid{grid-template-columns:1fr}
  .btn-sm,.btn-xs{min-height:40px;touch-action:manipulation}
  .soc-btn{flex:1 1 42%;min-width:140px;border-left:1px solid var(--d4)}
  .cal-row{
    display:flex;
    flex-wrap:wrap;
    align-items:stretch;
  }
  .cal-thumb-wrap{
    flex:1 1 100%;
    height:112px;
    min-height:112px;
    max-height:140px;
    border-right:none;
    border-bottom:1px solid var(--d4);
  }
  .cal-round{
    flex:0 0 52px;
    min-height:46px;
    border-right:1px solid var(--d4);
    border-bottom:1px solid var(--d4);
  }
  .cal-flag{
    flex:0 0 46px;
    min-height:46px;
    border-right:1px solid var(--d4);
    border-bottom:1px solid var(--d4);
  }
  .cal-status-cell{
    flex:1 1 auto;
    display:flex;
    align-items:center;
    justify-content:center;
    min-height:46px;
    border-bottom:1px solid var(--d4);
    padding:6px 8px;
  }
  .cal-info{flex:1 1 100%;padding:12px 14px}
  .cal-date{
    flex:1 1 55%;
    text-align:left;
    padding:10px 12px;
    border-top:none;
    border-right:1px solid var(--d4);
  }
  .cal-actions{
    flex:1 1 45%;
    padding:10px 12px;
    justify-content:flex-end;
    border-top:none;
  }
}
@media(max-width:420px){
  .brand-full{display:none}
  .brand-sub{letter-spacing:2px;font-size:7px}
  .nav-logo-img{height:26px}
}


/* ═══════════════════════════════════════
   NAV REGISTER BUTTON
═══════════════════════════════════════ */
.nav-reg-btn{padding:8px 18px;font-size:9.5px;letter-spacing:1.5px;clip-path:polygon(0 0,96% 0,100% 100%,4% 100%)}
@media(max-width:900px){.nav-reg-btn{display:none}}

/* ═══════════════════════════════════════
   HERO V2
═══════════════════════════════════════ */
.hero-v2{
  position:relative;overflow:hidden;background:var(--blk);
  min-height:460px;display:flex;align-items:center;
}

/* ── Full-bleed background image ── */
.hero-bg-img{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  object-position:60% center;
  z-index:0;
  animation:carReveal 1.1s cubic-bezier(.22,.61,.36,1) .2s both;
}
@keyframes carReveal{
  from{opacity:0;transform:scale(1.06) translateX(30px)}
  to{opacity:1;transform:scale(1) translateX(0)}
}

/* ── Dark gradient overlay: dark left → transparent right ── */
.hero-bg-overlay{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    /* ซ้าย: มืดมากสำหรับ text */
    linear-gradient(
      to right,
      rgba(6,6,12,1)    0%,
      rgba(6,6,12,.97)  20%,
      rgba(6,6,12,.85)  38%,
      rgba(6,6,12,.45)  58%,
      rgba(6,6,12,.12)  75%,
      rgba(6,6,12,.04)  100%
    ),
    /* ล่าง: มืดให้ blend กับ section ถัดไป */
    linear-gradient(
      to top,
      rgba(6,6,12,.7) 0%,
      transparent 30%
    );
}

/* ── Grid pattern (ลด opacity ลง ไม่ให้บังรูป) ── */
.hero-v2-grid{
  position:absolute;inset:0;pointer-events:none;z-index:2;
  background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:60px 60px;
  /* เฉพาะ 40% ซ้าย */
  -webkit-mask-image:linear-gradient(to right,black 0%,black 35%,transparent 60%);
  mask-image:linear-gradient(to right,black 0%,black 35%,transparent 60%);
}

/* ── Text container ── */
.hero-v2-inner{
  display:block;
  position:relative;z-index:3;
  padding-top:80px;padding-bottom:80px;
  width:100%;
}
.hero-v2-left{
  display:flex;flex-direction:column;gap:22px;
  max-width:600px;
}
.hero-badge-pill{
  display:inline-flex;align-items:center;gap:10px;
  border:1px solid rgba(255,255,255,.15);background:rgba(6,6,12,.6);
  padding:7px 18px;font-size:9px;font-weight:700;letter-spacing:3px;
  color:var(--silv);text-transform:uppercase;font-family:var(--f1);
  width:fit-content;backdrop-filter:blur(4px);
}
.hero-v2-h1{
  font-family:var(--f1);font-weight:900;
  font-size:clamp(42px,7vw,86px);line-height:.9;
  letter-spacing:-2px;text-transform:uppercase;color:var(--wht);margin:0;
  text-shadow:0 2px 40px rgba(0,0,0,.6);
}
.hero-v2-h1 em{color:var(--red);font-style:italic}
.hero-v2-sub{
  font-family:var(--f1);font-size:clamp(10px,1.1vw,13px);
  letter-spacing:2px;color:var(--silv);text-transform:uppercase;line-height:1.8;
  text-shadow:0 1px 12px rgba(0,0,0,.8);
}

/* ── No longer needed ── */
.hero-v2-right,.hero-car-wrap,.hero-car-img,.hero-car-glow{display:none}

/* ═══════════════════════════════════════
   HOME SPLIT SECTION
═══════════════════════════════════════ */
.home-split{
  position:relative;
  overflow:hidden;
  border-top:1px solid var(--d4);
  /* วาง /images/home-split-bg.jpg เพื่อใช้รูปจริง */
  background:
    linear-gradient(90deg,
      rgba(6,6,12,.96) 0%,
      rgba(6,6,12,.82) 50%,
      rgba(6,6,12,.96) 100%
    ),
    url('/images/home-split-bg.jpg') center/cover no-repeat,
    var(--d1);
}
/* Decorative overlay layers */
.home-split::before{
  content:'';
  position:absolute;inset:0;pointer-events:none;z-index:0;
  background:
    radial-gradient(ellipse 45% 90% at 20% 50%, rgba(232,0,45,.11) 0%, transparent 65%),
    radial-gradient(ellipse 45% 90% at 80% 50%, rgba(0,63,138,.10) 0%, transparent 65%);
}
/* Circuit grid pattern */
.home-split::after{
  content:'';
  position:absolute;inset:0;pointer-events:none;z-index:0;
  background-image:
    linear-gradient(rgba(232,0,45,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(232,0,45,.04) 1px, transparent 1px);
  background-size:52px 52px;
  /* diagonal racing stripe */
  mask-image:linear-gradient(to bottom, transparent 0%, black 15%, black 85%, transparent 100%);
}
.home-split-grid{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1fr 1fr;
  border-bottom:1px solid var(--d4);
}
.ugp-card{
  padding:36px 40px;border-right:1px solid rgba(255,255,255,.07);
  background:rgba(6,6,12,.45);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
}
.ugp-card:last-child{border-right:none}
.ugp-header{
  font-family:var(--f1);font-weight:900;font-size:10px;
  letter-spacing:4px;color:var(--gray);text-transform:uppercase;
  margin-bottom:24px;padding-bottom:14px;border-bottom:1px solid var(--d4);
}

/* ── Upcoming GP inner ── */
.ugp-inner{display:flex;gap:24px;align-items:flex-start}
.ugp-circuit-icon{
  flex:0 0 120px;height:100px;background:var(--d3);
  border:1px solid var(--d4);border-radius:4px;
  display:flex;align-items:center;justify-content:center;
  font-size:48px;line-height:1;
}
.ugp-info{flex:1;min-width:0}
.ugp-round{
  font-family:var(--f1);font-size:9px;letter-spacing:3px;
  color:var(--red);font-weight:700;text-transform:uppercase;margin-bottom:4px;
}
.ugp-name{
  font-family:var(--f1);font-size:clamp(18px,2vw,24px);
  font-weight:900;color:var(--wht);letter-spacing:1px;
  text-transform:uppercase;line-height:1.1;margin-bottom:14px;
}
.ugp-meta{font-size:12px;color:var(--silv);margin-bottom:5px;font-family:var(--thai)}
.ugp-meta span{color:var(--gray);margin-right:4px}
.ugp-cd-label{
  font-family:var(--f1);font-size:8px;letter-spacing:3px;
  color:var(--gray);font-weight:700;text-transform:uppercase;
  margin-top:16px;margin-bottom:8px;
}
.ugp-countdown{display:flex;gap:6px;align-items:flex-end}
.ugp-cd-seg{text-align:center}
.ugp-cd-num{
  font-family:var(--f1);font-size:30px;font-weight:900;
  color:var(--wht);line-height:1;display:block;min-width:40px;
}
.ugp-cd-unit{
  font-family:var(--f1);font-size:7px;color:var(--gray);
  letter-spacing:1px;text-transform:uppercase;margin-top:3px;display:block;
}
.ugp-cd-sep{
  font-family:var(--f1);font-size:22px;font-weight:900;
  color:var(--red);padding-bottom:16px;line-height:1;
}

/* ── Top Drivers Podium ── */
.podium-wrap{
  display:flex;align-items:flex-end;justify-content:center;
  gap:10px;padding-top:8px;min-height:220px;
}
.podium-card{
  display:flex;flex-direction:column;align-items:center;gap:8px;
  flex:1;max-width:130px;cursor:pointer;
  transition:transform .2s;
}
.podium-card:hover{transform:translateY(-4px)}
.podium-av{
  width:60px;height:60px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:24px;border:2px solid var(--d5);
  background:var(--d3);overflow:hidden;flex-shrink:0;
  transition:border-color .2s;
}
.podium-card:hover .podium-av{border-color:var(--red)}
.podium-av img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.podium-name{
  font-family:var(--f1);font-size:11px;font-weight:700;
  color:var(--wht);letter-spacing:1px;text-align:center;
  text-transform:uppercase;line-height:1.3;
  width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.podium-pts{
  font-family:var(--f1);font-size:10px;color:var(--gray);
  font-weight:700;text-align:center;letter-spacing:1px;
}
.podium-block{
  width:100%;display:flex;align-items:center;justify-content:center;
  font-family:var(--f1);font-weight:900;font-size:22px;
  color:var(--wht);border-top:3px solid;
}
.podium-card.p1 .podium-av{border-color:var(--gold);box-shadow:0 0 16px rgba(255,208,64,.3)}
.podium-card.p1 .podium-name{color:var(--gold)}
.podium-card.p1 .podium-block{background:rgba(255,208,64,.12);border-color:var(--gold);color:var(--gold);height:90px}
.podium-card.p2 .podium-block{background:rgba(192,192,192,.08);border-color:#C0C0C0;color:#C0C0C0;height:64px}
.podium-card.p3 .podium-block{background:rgba(205,127,50,.08);border-color:#CD7F32;color:#CD7F32;height:48px}

/* ── Responsive overrides ── */
@media(max-width:1200px){
  /* ซ่อนปุ่ม REGISTER NOW ในนาฟบน tablet/mobile (เปิดผ่านเมนูแทน) */
  .nav-reg-btn{display:none}
  #navPendingMsg{display:none!important}
}
@media(max-width:640px){
  /* Discord login button — icon only บนมือถือ */
  .discord-btn-label{display:none}
  .btn-discord-login{padding:6px 9px}
}
@media(max-width:900px){
  .hero-v2{min-height:380px}
  .hero-v2-inner{padding-top:52px;padding-bottom:52px}
  .hero-v2-h1{font-size:clamp(36px,6vw,64px)}
  .hero-bg-overlay{
    background:linear-gradient(to right,
      rgba(6,6,12,1) 0%,rgba(6,6,12,.98) 40%,
      rgba(6,6,12,.75) 65%,rgba(6,6,12,.3) 100%
    ),linear-gradient(to top,rgba(6,6,12,.7) 0%,transparent 30%);
  }
  .home-split-grid{grid-template-columns:1fr}
  .ugp-card{border-right:none;border-bottom:1px solid var(--d4);padding:28px 20px}
  .ugp-card:last-child{border-bottom:none}
}
@media(max-width:600px){
  .hero-v2{min-height:300px}
  .hero-v2-inner{padding-top:40px;padding-bottom:40px}
  .hero-v2-h1{font-size:clamp(32px,9vw,52px);letter-spacing:-1px}
  .hero-v2-sub{font-size:10px;letter-spacing:1px}
  .hero-badge-pill{font-size:8px;letter-spacing:2px;padding:5px 12px}
  .hero-v2-left{max-width:100%;gap:14px}
}

/* ═══════════════════════════════════════
   STANDINGS V2
═══════════════════════════════════════ */
.stnd-v2-wrap{padding:0}
.stnd-v2-top{padding:48px 0 0}
.stnd-v2-title{font-family:var(--f1);font-weight:900;font-size:clamp(26px,4.5vw,46px);color:var(--wht);letter-spacing:-1px;text-transform:uppercase;margin-bottom:10px}
.stnd-season-badge{display:inline-block;background:var(--red);font-family:var(--f1);font-size:10px;font-weight:700;letter-spacing:3px;color:#fff;padding:5px 18px;text-transform:uppercase;margin-bottom:40px}
/* Podium */
.stnd-podium{display:flex;gap:10px;align-items:flex-end;justify-content:center;margin-bottom:52px;padding:0 20px}
.stnd-pod-card{display:flex;flex-direction:column;align-items:center;gap:10px;flex:1;max-width:200px;cursor:pointer;transition:transform .2s}
.stnd-pod-card:hover{transform:translateY(-5px)}
.stnd-pod-pos{font-family:var(--f1);font-size:11px;font-weight:700;letter-spacing:2px;color:var(--gray);text-transform:uppercase}
.stnd-pod-av{width:80px;height:80px;border-radius:50%;border:3px solid var(--d5);background:var(--d3);overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:28px;transition:border-color .2s}
.stnd-pod-av img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.stnd-pod-name{font-family:var(--thai);font-size:15px;font-weight:700;color:var(--wht);text-align:center;line-height:1.3}
.stnd-pod-tag{font-family:var(--f1);font-size:9px;letter-spacing:2px;color:var(--gray);text-align:center;font-weight:700}
.stnd-pod-pts{font-family:var(--f1);font-size:12px;color:var(--silv);font-weight:700;letter-spacing:1px}
.stnd-pod-block{width:100%;display:flex;align-items:center;justify-content:center;font-family:var(--f1);font-weight:900;font-size:24px;border-top:3px solid}
.stnd-pod-card.p1 .stnd-pod-av{border-color:var(--gold);box-shadow:0 0 24px rgba(255,208,64,.35)}
.stnd-pod-card.p1 .stnd-pod-name{color:var(--gold)}
.stnd-pod-card.p1 .stnd-pod-block{background:rgba(255,208,64,.1);border-color:var(--gold);color:var(--gold);height:108px}
.stnd-pod-card.p2 .stnd-pod-block{background:rgba(192,192,192,.08);border-color:#C0C0C0;color:#C0C0C0;height:76px}
.stnd-pod-card.p3 .stnd-pod-block{background:rgba(205,127,50,.08);border-color:#CD7F32;color:#CD7F32;height:56px}
/* Leaderboard heading */
.stnd-lb-head{font-family:var(--f1);font-size:12px;font-weight:700;letter-spacing:2px;color:var(--wht);text-transform:uppercase;margin-bottom:14px}
/* Updated grid: POS | TREND | DRIVER | WINS | RACES | POINTS */
.f1-sb-head,.f1-sb-row{grid-template-columns:60px 72px 1fr 110px 80px 110px}
/* P1 highlighted row */
.f1-sb-row.p1{
  border:1px solid rgba(232,0,45,.55);
  border-left:3px solid var(--red);
  background:rgba(232,0,45,.05);
}
.f1-sb-row.p1:hover{background:rgba(232,0,45,.09)}
.f1-sb-row.p2,.f1-sb-row.p3{border-left:3px solid transparent}
/* Trend with number */
.f1-trend-wrap{display:inline-flex;align-items:center;gap:4px}
.f1-trend-num{font-family:var(--f1);font-size:10px;font-weight:700;letter-spacing:.5px}
.f1-trend-num.up{color:var(--red)}.f1-trend-num.dn{color:var(--gray)}
/* WINS text style */
.wins-txt{font-family:var(--f1);font-size:12px;font-weight:700;color:var(--red);letter-spacing:.5px}
/* RACES column */
.races-cell{text-align:center;font-family:var(--f1);font-size:16px;font-weight:700;color:var(--silv)}
/* POINTS new style */
.pts-new{display:flex;align-items:baseline;gap:4px}
.pts-new-num{font-family:var(--f1);font-size:22px;font-weight:900;color:var(--wht)}
.pts-new-unit{font-family:var(--f1);font-size:10px;font-weight:700;color:var(--red);letter-spacing:1px}
.f1-sb-row.p1 .pts-new-num{color:var(--gold)}
@media(max-width:768px){
  .stnd-podium{gap:6px;padding:0 8px}
  .stnd-pod-av{width:60px;height:60px;font-size:20px}
  .stnd-pod-name{font-size:12px}
  .stnd-pod-card.p1 .stnd-pod-block{height:80px}
  .stnd-pod-card.p2 .stnd-pod-block{height:56px}
  .stnd-pod-card.p3 .stnd-pod-block{height:42px}
}

/* ═══════════════════════════════════════
   CALENDAR V2 header (kept)
═══════════════════════════════════════ */
.cal-v2-hdr{padding:48px 0 8px}
.cal-v2-title{font-family:var(--f1);font-weight:900;font-size:clamp(20px,3.5vw,36px);color:var(--wht);letter-spacing:-0.5px;text-transform:uppercase;margin-bottom:20px}
.cal-v2-filters{display:flex;gap:12px;margin-bottom:28px;flex-wrap:wrap;align-items:center}
.cal-filter-sel{font-family:var(--f1);font-size:11px;font-weight:700;letter-spacing:1px;background:var(--d2);border:1px solid var(--d5);color:var(--silv);padding:7px 14px;cursor:pointer;appearance:none;outline:none;border-radius:2px}
.cal-v2-list{overflow:hidden}

/* ═══════════════════════════════════════
   CALENDAR V3 ROWS
═══════════════════════════════════════ */
.cv3-row{
  display:grid;
  grid-template-columns:56px 80px 1fr 200px 140px 170px;
  align-items:center;
  min-height:72px;
  background:var(--d2);
  border-bottom:1px solid var(--d4);
  border-left:4px solid transparent;
  transition:background .15s, border-color .15s;
  position:relative;
}
.cv3-item:last-child>.cv3-row{border-bottom:none}
.cv3-row:hover{background:var(--d3)}

/* Done — dimmed */
.cv3-row.cv3-done{opacity:.72}
.cv3-row.cv3-done:hover{opacity:.88;background:var(--d3)}

/* Next race — red accent */
.cv3-row.cv3-next{
  border-left-color:var(--red);
  background:rgba(232,0,45,.06);
}
.cv3-row.cv3-next:hover{background:rgba(232,0,45,.10)}

/* Live */
.cv3-row.cv3-live{border-left-color:var(--danger);background:rgba(255,23,68,.06)}

/* ── Round number ── */
.cv3-num{
  display:flex;align-items:center;justify-content:center;
  font-family:var(--f1);font-size:18px;font-weight:900;color:var(--dkgry);
  padding:0 8px;
}
.cv3-num-next{
  width:36px;height:36px;border-radius:3px;
  background:var(--red);color:#fff;
  font-size:16px;
}
.cv3-num-done{color:var(--d5)}

/* ── Flag column ── */
.cv3-flag-col{
  display:flex;align-items:center;justify-content:center;
  padding:0 8px;border-right:1px solid var(--d4);height:100%;
}
.cv3-flag-img{
  width:52px;height:34px;object-fit:cover;
  border-radius:2px;border:1px solid var(--d5);display:block;
}
.cv3-flag-emoji{font-size:28px;line-height:1}

/* ── Round info ── */
.cv3-info{padding:12px 20px;min-width:0}
.cv3-round-name{
  font-family:var(--f1);font-size:15px;font-weight:700;
  color:var(--wht);letter-spacing:.3px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.cv3-row.cv3-done .cv3-round-name{color:var(--silv)}
.cv3-circuit-name{
  font-family:var(--thai);font-size:12px;color:var(--gray);margin-top:3px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}

/* ── Status column ── */
.cv3-status-col{padding:0 12px}
.cv3-status-done{
  font-family:var(--f1);font-size:10px;font-weight:700;
  letter-spacing:2px;color:var(--gray);text-transform:uppercase;
}
.cv3-status-next{font-family:var(--f1)}
.cv3-next-label{
  font-size:11px;font-weight:700;color:var(--red);
  letter-spacing:1px;margin-bottom:3px;
}
.cv3-next-cd-label{
  font-size:8px;letter-spacing:2px;
  color:var(--gray);text-transform:uppercase;margin-bottom:2px;
}
.cv3-next-cd{
  font-size:13px;font-weight:700;color:var(--wht);letter-spacing:.5px;
}
.cv3-status-live{
  font-family:var(--f1);font-size:12px;font-weight:700;
  color:var(--danger);letter-spacing:1px;
}
.cv3-blink{animation:pulse 1.2s ease-in-out infinite}

/* ── Date/Time column ── */
.cv3-datetime{padding:0 16px;text-align:right}
.cv3-date{
  font-family:var(--f1);font-size:13px;font-weight:700;
  color:var(--silv);letter-spacing:.5px;
}
.cv3-time{font-family:var(--f1);font-size:10px;color:var(--gray);margin-top:3px}

/* ── Action column ── */
.cv3-action-col{padding:0 16px;display:flex;align-items:center;justify-content:flex-end}
.cv3-action-wrap{display:flex;flex-direction:column;gap:5px;align-items:flex-end}
.cv3-btn{
  font-family:var(--f1);font-size:10px;font-weight:700;
  letter-spacing:1.5px;text-transform:uppercase;
  padding:8px 18px;border:none;cursor:pointer;
  white-space:nowrap;border-radius:2px;
  transition:background .15s,color .15s,box-shadow .15s;
}
.cv3-btn-upcoming{
  background:transparent;
  border:1px solid rgba(21,101,192,.55);
  color:#7EC8F5;
}
.cv3-btn-upcoming:hover{background:rgba(21,101,192,.18);box-shadow:0 0 12px rgba(21,101,192,.2)}
.cv3-btn-live{
  background-color:rgb(14,14,26);color:rgb(234,234,234);
  text-decoration:none;display:inline-block;
  transition:all .6s;
  box-shadow:0 0 30px #ff0000;
  border:1px solid #ff0000;
  -webkit-box-reflect:below 2px linear-gradient(to bottom,rgba(0,0,0,0),rgba(0,0,0,.3));
}
.cv3-btn-live:hover{
  background:linear-gradient(270deg,rgba(21, 56, 255, 0.68) 0%,rgba(255, 0, 0, 0.87) 60%);
  color:rgb(4,4,38);
}
.cv3-btn-results{
  background:rgba(255,255,255,.07);
  border:1px solid var(--d5);color:var(--silv);
}
.cv3-btn-results:hover{background:rgba(255,255,255,.14)}
.cv3-add-cal{
  font-family:var(--f1);font-size:9px;color:var(--gray);
  text-decoration:none;letter-spacing:1px;
  transition:color .15s;
}
.cv3-add-cal:hover{color:var(--wht)}

/* ── Responsive ── */
@media(max-width:1024px){
  .cv3-row{grid-template-columns:48px 72px 1fr 130px 110px}
  .cv3-status-col{display:none}
}
@media(max-width:768px){
  .cv3-row{grid-template-columns:40px 1fr 100px}
  .cv3-flag-col,.cv3-datetime{display:none}
  .cv3-info{padding:10px 14px}
  .cv3-round-name{font-size:13px}
}
@media(max-width:480px){
  .cv3-action-col{display:none}
}

/* ── Calendar Results Panel ── */
.cv3-item{display:block}
.cv3-rp{border-bottom:1px solid var(--d4);border-left:4px solid var(--red)}
.cv3-item:last-child>.cv3-rp{border-bottom:none}
.cv3-btn-open{background:rgba(255,255,255,.04)!important;border-color:var(--red)!important;color:var(--wht)!important}
.crp-inner{background:var(--d2)}
.crp-tabs{display:flex;border-bottom:2px solid var(--d4);background:var(--d3)}
.crp-tab{font-family:var(--f1);font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:13px 24px;border:none;background:transparent;color:var(--gray);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s}
.crp-tab:hover{color:var(--silv)}
.crp-tab.crp-active{color:var(--wht);border-bottom-color:var(--red)}
.crp-pane{background:var(--d2)}

/* ═══════════════════════════════════════
   REGISTRATION STEPS
═══════════════════════════════════════ */
.reg-steps{display:flex;align-items:center;justify-content:center;padding:32px 0 0;margin-bottom:32px}
.rs-step{display:flex;flex-direction:column;align-items:center;gap:7px;min-width:70px}
.rs-num{width:34px;height:34px;border-radius:50%;border:2px solid var(--d5);background:var(--d3);display:flex;align-items:center;justify-content:center;font-family:var(--f1);font-size:13px;font-weight:900;color:var(--gray);transition:all .25s}
.rs-lbl{font-family:var(--thai);font-size:9.5px;color:var(--gray);text-align:center;letter-spacing:.3px;transition:color .25s}
.rs-line{flex:1;height:2px;background:var(--d5);margin-bottom:26px;min-width:16px;max-width:48px;transition:background .25s}
.rs-step.active .rs-num{border-color:var(--red);background:var(--red);color:#fff}
.rs-step.active .rs-lbl{color:var(--wht)}
.rs-step.done .rs-num{border-color:var(--grn);background:rgba(0,200,83,.12);color:var(--grn)}
.rs-step.done .rs-lbl{color:var(--grn)}
.rs-line.done{background:var(--grn)}
@media(max-width:560px){.rs-lbl{display:none}.rs-line{min-width:8px}}

/* ═══════════════════════════════════════
   ADMIN PAGE (SIDEBAR LAYOUT)
═══════════════════════════════════════ */
#page-admin{background:var(--blk)}
.adm-layout{display:flex;min-height:calc(100vh - 108px)}
.adm-sidebar{width:220px;flex-shrink:0;background:#090912;border-right:1px solid var(--d4);display:flex;flex-direction:column}
.adm-sidebar-logo{padding:18px 20px 16px;border-bottom:1px solid var(--d4);display:flex;align-items:center}
.adm-logo-img{height:30px;width:auto;object-fit:contain;filter:drop-shadow(0 0 6px rgba(232,0,45,.25))}
.adm-nav{display:flex;flex-direction:column;padding:10px 0;flex:1;overflow-y:auto}
.adm-nav-item{display:flex;align-items:center;gap:10px;padding:11px 20px;font-family:var(--f1);font-size:9.5px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--gray);cursor:pointer;border-left:3px solid transparent;transition:all .15s;user-select:none}
.adm-nav-item:hover{color:var(--wht);background:rgba(255,255,255,.04)}
.adm-nav-item.active{color:var(--wht);border-left-color:var(--red);background:rgba(232,0,45,.06)}
.adm-nav-sub{padding-left:0;display:flex;flex-direction:column}
.adm-nav-sub-item{padding:8px 20px 8px 32px;font-family:var(--f1);font-size:9px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--gray);cursor:pointer;border-left:3px solid transparent;transition:all .15s}
.adm-nav-sub-item:hover{color:var(--wht)}
.adm-nav-sub-item.active{color:var(--red);border-left-color:var(--red)}
.adm-main{flex:1;min-width:0;display:flex;flex-direction:column}
.adm-topbar{background:var(--d1);border-bottom:1px solid var(--d4);padding:18px 28px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-shrink:0}
.adm-page-title{font-family:var(--f1);font-weight:900;font-size:clamp(13px,2vw,20px);color:var(--wht);letter-spacing:1px;text-transform:uppercase}
.adm-topbar-status{display:flex;align-items:center;gap:8px;font-family:var(--f1);font-size:9px;font-weight:700;letter-spacing:2px;color:var(--grn)}
.adm-content{padding:24px 28px;flex:1;overflow-y:auto}
.adm-section{display:none}.adm-section.active{display:block}
.adm-sec-label{font-family:var(--f1);font-size:9px;font-weight:700;letter-spacing:3px;color:var(--red);text-transform:uppercase;margin-bottom:18px;padding-bottom:10px;border-bottom:1px solid var(--d4)}

/* ── ADMIN DASHBOARD ─────────────────────────────────────────────── */
.adm-dash-kpi{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:14px}
.adm-kpi-card{background:var(--d2);border:1px solid var(--d4);padding:20px;position:relative;overflow:hidden;transition:border-color .2s,transform .2s;cursor:default}
.adm-kpi-card:hover{border-color:var(--d5);transform:translateY(-2px)}
.adm-kpi-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:6px}
.adm-kpi-lbl{font-family:var(--f1);font-size:8.5px;font-weight:700;letter-spacing:2.5px;color:var(--gray);text-transform:uppercase}
.adm-kpi-icon{font-size:18px;line-height:1}
.adm-kpi-val{font-family:var(--f1);font-size:44px;font-weight:900;line-height:1;color:var(--wht);letter-spacing:-1px;margin-bottom:10px}
.adm-kpi-sub{font-family:var(--f1);font-size:8.5px;letter-spacing:1.5px;color:var(--gray);text-transform:uppercase}
.adm-kpi-trend{font-family:var(--f1);font-size:8.5px;letter-spacing:1.5px;color:var(--gray);display:flex;align-items:center;gap:5px}

.adm-dash-mid{display:grid;grid-template-columns:2fr 1fr;gap:12px;margin-bottom:14px}
.adm-dash-bot{display:grid;grid-template-columns:2fr 1fr;gap:12px}
.adm-dash-card{background:var(--d2);border:1px solid var(--d4)}
.adm-dash-card-head{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--d4);font-family:var(--f1);font-size:9px;font-weight:700;letter-spacing:2.5px;color:var(--wht);text-transform:uppercase}

.adm-chart-wrap{padding:20px 20px 12px}
.adm-chart-bars{display:flex;align-items:flex-end;gap:8px;height:160px;margin-bottom:8px}
.adm-chart-bar-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:4px;height:100%}
.adm-chart-bar-fill{width:100%;background:rgba(232,0,45,.18);border-top:2px solid var(--red);transition:height .6s ease;min-height:4px}
.adm-chart-bar-pts{font-family:var(--f1);font-size:9px;font-weight:700;color:var(--gray);white-space:nowrap}
.adm-chart-labels{display:flex;gap:8px}
.adm-chart-label{flex:1;text-align:center;font-family:var(--f1);font-size:8px;letter-spacing:1px;color:var(--gray);text-transform:uppercase;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

.adm-ugp-card{display:flex;flex-direction:column;overflow:hidden}
.adm-ugp-top{background:var(--d3);padding:24px 20px;flex:1;display:flex;flex-direction:column;justify-content:center;text-align:center;border-bottom:1px solid var(--d4)}
.adm-ugp-badge{font-family:var(--f1);font-size:8px;font-weight:700;letter-spacing:4px;color:var(--red);text-transform:uppercase;margin-bottom:10px}
.adm-ugp-name{font-family:var(--f1);font-size:17px;font-weight:900;color:var(--wht);text-transform:uppercase;letter-spacing:1px;margin-bottom:4px}
.adm-ugp-circuit{font-family:var(--thai);font-size:12px;color:var(--gray);margin-bottom:14px}
.adm-ugp-cd{font-family:var(--f1);font-size:26px;font-weight:900;color:var(--red);letter-spacing:2px;margin-bottom:4px}
.adm-ugp-date{font-family:var(--f1);font-size:9px;letter-spacing:1.5px;color:var(--gray);text-transform:uppercase}
.adm-ugp-bottom{padding:14px 20px}
.adm-ugp-btn{display:block;width:100%;border:1px solid var(--red);background:transparent;color:var(--red);font-family:var(--f1);font-weight:700;font-size:9px;letter-spacing:2px;text-transform:uppercase;padding:10px;cursor:pointer;transition:all .15s}
.adm-ugp-btn:hover{background:var(--red);color:#fff}

.adm-dash-tbl{width:100%;border-collapse:collapse;font-family:var(--f1)}
.adm-dash-tbl thead th{font-size:8.5px;letter-spacing:2px;color:var(--gray);text-transform:uppercase;padding:10px 20px;text-align:left;border-bottom:1px solid var(--d4);font-weight:700}
.adm-dash-tbl tbody tr{border-bottom:1px solid var(--d3);transition:background .1s}
.adm-dash-tbl tbody tr:hover{background:rgba(255,255,255,.02)}
.adm-dash-tbl td{padding:10px 20px;font-size:12px;vertical-align:middle}
.adm-dash-status{display:inline-flex;align-items:center;padding:3px 8px;font-size:8px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;font-family:var(--f1)}
.adm-dash-status.pending{color:#47d6ff;border:1px solid rgba(71,214,255,.3)}
.adm-dash-status.approved{color:#00e478;border:1px solid rgba(0,228,120,.3)}
.adm-dash-status.rejected{color:var(--danger);border:1px solid rgba(255,23,68,.3)}

.adm-status-row{margin-bottom:14px}
.adm-status-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.adm-status-lbl{font-family:var(--f1);font-size:9px;letter-spacing:2px;color:var(--gray);text-transform:uppercase}
.adm-status-val{font-family:var(--f1);font-size:9px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase}
.adm-status-val.grn{color:#00e478}.adm-status-val.warn{color:#ffd700}
.adm-status-bar{width:100%;background:var(--d4);height:3px;overflow:hidden}
.adm-status-fill{height:100%;background:#00e478}
.adm-status-divider{border-top:1px solid var(--d4);margin:18px 0}
.adm-status-counts{display:grid;grid-template-columns:repeat(3,1fr);text-align:center;gap:8px}
.adm-status-count-val{font-family:var(--f1);font-size:28px;font-weight:900;color:var(--wht);line-height:1;margin-bottom:4px}
.adm-status-count-lbl{font-family:var(--f1);font-size:8px;letter-spacing:2px;color:var(--gray);text-transform:uppercase}

/* Circuit vote chart */
.adm-vote-wrap{padding:16px 20px}
.adm-vote-row{display:grid;grid-template-columns:180px 1fr 40px;align-items:center;gap:10px;margin-bottom:8px}
.adm-vote-label{font-family:var(--f1);font-size:9px;letter-spacing:1px;color:var(--silv);text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.adm-vote-bar-wrap{background:var(--d4);height:8px;border-radius:2px;overflow:hidden}
.adm-vote-bar-fill{height:100%;background:var(--red);border-radius:2px;transition:width .6s ease}
.adm-vote-count{font-family:var(--f1);font-size:10px;font-weight:700;color:var(--gray);text-align:right}

/* Settings card */
.adm-settings-card{background:var(--d2);border:1px solid var(--d4);padding:20px;margin-bottom:14px}
.adm-settings-card-head{display:flex;justify-content:space-between;align-items:center;gap:16px}
.adm-settings-title{font-family:var(--f1);font-size:11px;font-weight:700;letter-spacing:1.5px;color:var(--wht);text-transform:uppercase;margin-bottom:4px}
.adm-settings-desc{font-family:var(--thai);font-size:12px;color:var(--gray)}
.adm-settings-note{font-family:var(--f1);font-size:9px;letter-spacing:1px;color:var(--gray);margin-top:12px;border-top:1px solid var(--d4);padding-top:10px}
.adm-reg-toggle{font-family:var(--f1);font-weight:700;font-size:9px;letter-spacing:2px;text-transform:uppercase;padding:10px 20px;border:none;cursor:pointer;transition:all .2s;white-space:nowrap;flex-shrink:0}
.adm-reg-toggle.open{background:rgba(0,228,120,.12);color:#00e478;border:1px solid rgba(0,228,120,.4)}
.adm-reg-toggle.closed{background:rgba(232,0,45,.12);color:var(--red);border:1px solid rgba(232,0,45,.4)}

@media(max-width:900px){
  .adm-dash-kpi{grid-template-columns:repeat(2,1fr)}
  .adm-dash-mid,.adm-dash-bot{grid-template-columns:1fr}
  .adm-vote-row{grid-template-columns:120px 1fr 30px}
}
@media(max-width:480px){
  .adm-dash-kpi{grid-template-columns:1fr 1fr}
  .adm-kpi-val{font-size:32px}
}
/* Admin Standings table */
.adm-filter-row{display:flex;gap:10px;margin-bottom:18px;flex-wrap:wrap;align-items:flex-end}
.adm-filter-row label{font-family:var(--f1);font-size:9px;color:var(--gray);letter-spacing:2px;text-transform:uppercase;display:flex;flex-direction:column;gap:5px}
.adm-stnd-tbl{width:100%;border-collapse:collapse;font-family:var(--f1)}
.adm-stnd-tbl thead th{font-size:9px;letter-spacing:2px;color:var(--gray);text-transform:uppercase;padding:10px 12px;text-align:left;border-bottom:2px solid var(--d4);font-weight:700;white-space:nowrap}
.adm-stnd-tbl tbody tr{border-bottom:1px solid var(--d3);transition:background .1s}
.adm-stnd-tbl tbody tr:hover{background:rgba(255,255,255,.02)}
.adm-stnd-tbl td{padding:10px 12px;vertical-align:middle}
.adm-drv-cell{display:flex;align-items:center;gap:10px}
.adm-team-bar{width:4px;height:28px;border-radius:2px;flex-shrink:0}
.adm-pts-num{font-size:16px;font-weight:900;color:var(--wht)}
.adm-in{width:70px;background:var(--d3);border:1px solid var(--d4);border-bottom:2px solid var(--d5);color:var(--wht);font-family:var(--f1);font-size:14px;font-weight:700;padding:6px 8px;text-align:center;outline:none}
.adm-in:focus{border-bottom-color:var(--red)}
.adm-delta{display:flex;align-items:center;gap:6px}
.adm-delta-val{font-size:12px;font-weight:700;letter-spacing:1px}
.adm-delta-val.pos{color:var(--grn)}.adm-delta-val.neg{color:var(--danger)}.adm-delta-val.neu{color:var(--gray)}
.adm-action-bar{display:flex;gap:10px;justify-content:flex-end;padding:20px 0 0;border-top:1px solid var(--d4);margin-top:20px;flex-wrap:wrap}
@media(max-width:900px){
  .adm-layout{flex-direction:column}
  .adm-sidebar{width:100%;border-right:none;border-bottom:1px solid var(--d4)}
  .adm-nav{flex-direction:row;overflow-x:auto;padding:6px;scrollbar-width:none}
  .adm-nav-item{padding:8px 14px;border-left:none;border-bottom:2px solid transparent;white-space:nowrap;flex-shrink:0}
  .adm-nav-item.active{border-bottom-color:var(--red);border-left:none;background:rgba(232,0,45,.06)}
  .adm-nav-sub{display:none}
  .adm-content{padding:18px 16px}
}

/* ═══════════════════════════════════════════════
   ANIMATIONS
═══════════════════════════════════════════════ */

/* ── Keyframes ── */
@keyframes fadeUp{
  from{opacity:0;transform:translateY(28px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes fadeIn{
  from{opacity:0}
  to{opacity:1}
}
@keyframes slideRight{
  from{opacity:0;transform:translateX(-24px)}
  to{opacity:1;transform:translateX(0)}
}
@keyframes podiumRise{
  0%{opacity:0;transform:translateY(40px) scale(.94)}
  60%{transform:translateY(-6px) scale(1.02)}
  100%{opacity:1;transform:translateY(0) scale(1)}
}
@keyframes goldPulse{
  0%,100%{box-shadow:0 0 0 0 rgba(255,208,64,.4)}
  50%{box-shadow:0 0 0 12px rgba(255,208,64,0)}
}
@keyframes countUp{
  from{opacity:.3;transform:translateY(4px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes rowSlide{
  from{opacity:0;transform:translateX(-16px)}
  to{opacity:1;transform:translateX(0)}
}

/* ── Scroll-reveal base state ── */
.reveal{
  opacity:0;
  transform:translateY(24px);
  transition:opacity .55s cubic-bezier(.22,.61,.36,1), transform .55s cubic-bezier(.22,.61,.36,1);
}
.reveal.visible{opacity:1;transform:translateY(0)}

/* Stagger delays for reveal children */
.reveal-stagger > *{
  opacity:0;
  transform:translateY(20px);
  transition:opacity .45s cubic-bezier(.22,.61,.36,1),transform .45s cubic-bezier(.22,.61,.36,1);
}
.reveal-stagger.visible > *:nth-child(1){opacity:1;transform:none;transition-delay:.05s}
.reveal-stagger.visible > *:nth-child(2){opacity:1;transform:none;transition-delay:.15s}
.reveal-stagger.visible > *:nth-child(3){opacity:1;transform:none;transition-delay:.25s}
.reveal-stagger.visible > *:nth-child(4){opacity:1;transform:none;transition-delay:.35s}
.reveal-stagger.visible > *:nth-child(5){opacity:1;transform:none;transition-delay:.45s}
.reveal-stagger.visible > *:nth-child(6){opacity:1;transform:none;transition-delay:.55s}

/* ── Podium sequence ── */
.stnd-pod-card{opacity:0;transform:translateY(36px) scale(.95)}
.stnd-pod-card.pod-show{
  animation:podiumRise .55s cubic-bezier(.34,1.4,.64,1) forwards;
}
.stnd-pod-card.p1.pod-show{animation-duration:.65s}
/* P1 gold pulse after rise */
.stnd-pod-card.p1.pod-glow .stnd-pod-av{
  animation:goldPulse 2s ease-in-out 3;
}

/* ── Leaderboard rows slide in ── */
.f1-sb-row{
  opacity:0;
  animation:rowSlide .4s cubic-bezier(.22,.61,.36,1) forwards;
}
/* stagger per row */
.f1-sb-row:nth-child(1){animation-delay:.05s}
.f1-sb-row:nth-child(2){animation-delay:.10s}
.f1-sb-row:nth-child(3){animation-delay:.15s}
.f1-sb-row:nth-child(4){animation-delay:.20s}
.f1-sb-row:nth-child(5){animation-delay:.25s}
.f1-sb-row:nth-child(6){animation-delay:.30s}
.f1-sb-row:nth-child(7){animation-delay:.35s}
.f1-sb-row:nth-child(8){animation-delay:.40s}
.f1-sb-row:nth-child(n+9){animation-delay:.45s}

/* ── Calendar rows ── */
.cal-v2-row{
  opacity:0;
  animation:rowSlide .38s cubic-bezier(.22,.61,.36,1) forwards;
}
.cal-v2-row:nth-child(1){animation-delay:.04s}
.cal-v2-row:nth-child(2){animation-delay:.09s}
.cal-v2-row:nth-child(3){animation-delay:.14s}
.cal-v2-row:nth-child(4){animation-delay:.19s}
.cal-v2-row:nth-child(5){animation-delay:.24s}
.cal-v2-row:nth-child(n+6){animation-delay:.30s}

/* ── Card hover lift+glow ── */
.podium-card,.stnd-pod-card{transition:transform .22s ease,filter .22s ease}
.podium-card:hover,.stnd-pod-card:hover{
  transform:translateY(-6px) scale(1.03);
  filter:brightness(1.1);
}
.f1-sb-row{transition:background .15s,opacity .4s,transform .4s,box-shadow .2s}
.f1-sb-row:hover{box-shadow:inset 0 0 0 1px rgba(232,0,45,.2)}
.nc{transition:background .15s,transform .2s,box-shadow .2s}
.nc:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.35)}
.ugp-card:hover .ugp-name{color:var(--red);transition:color .2s}

/* ── Hero badge pill entrance ── */
.hero-badge-pill{animation:fadeIn .7s ease .2s both}
.hero-v2-h1{animation:fadeUp .7s cubic-bezier(.22,.61,.36,1) .35s both}
.hero-v2-sub{animation:fadeUp .7s cubic-bezier(.22,.61,.36,1) .5s both}
.cta-row{animation:fadeUp .7s cubic-bezier(.22,.61,.36,1) .65s both}

/* ── Live status bar text slide ── */
.live-bar-inner{animation:slideRight .6s cubic-bezier(.22,.61,.36,1) .1s both}

/* ── Count-up flash ── */
.pts-new-num.counting{animation:countUp .25s ease}

/* ── prefers-reduced-motion: ปิด animation ทั้งหมด ── */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:.01ms!important;
  }
  .reveal,.reveal-stagger>*{opacity:1;transform:none}
}

/* ═══════════════════════════════════════
   STANDINGS TAB TOGGLE
═══════════════════════════════════════ */
.stnd-tab-row{display:flex;gap:0;margin-bottom:32px;border-bottom:2px solid var(--d4)}
.stnd-tab{
  background:none;border:none;
  font-family:var(--f1);font-size:11px;font-weight:700;letter-spacing:2px;
  color:var(--gray);text-transform:uppercase;cursor:pointer;
  padding:12px 28px;border-bottom:2px solid transparent;margin-bottom:-2px;
  transition:color .2s,border-color .2s;
}
.stnd-tab:hover{color:var(--wht)}
.stnd-tab.active{color:var(--red);border-bottom-color:var(--red)}

/* ═══════════════════════════════════════
   TEAM LOGO IN DRIVER STANDINGS
═══════════════════════════════════════ */
.f1-team-logo-wrap{width:36px;height:36px;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.f1-team-logo-img{width:36px;height:36px;object-fit:contain;filter:drop-shadow(0 0 4px rgba(255,255,255,.1))}
/* keep backward-compat for color bar fallback */
.f1-team-logo-wrap .f1-team-bar{width:4px;height:36px;border-radius:2px}

/* ═══════════════════════════════════════
   CONSTRUCTOR STANDINGS
═══════════════════════════════════════ */
.constr-sb-head{
  display:grid;grid-template-columns:60px 1fr 100px 120px;
  padding:10px 16px;border-bottom:1px solid var(--d4);
  font-family:var(--f1);font-size:9px;font-weight:700;letter-spacing:2px;color:var(--gray);text-transform:uppercase;
}
.constr-row{
  display:grid;grid-template-columns:60px 1fr 100px 120px;
  align-items:center;padding:14px 16px;
  border-bottom:1px solid var(--d3);transition:background .15s;
}
.constr-row:hover{background:rgba(255,255,255,.04)}
.constr-row.p1{border-left:3px solid var(--red);background:rgba(232,0,45,.05)}
.constr-row.p2{border-left:3px solid #c0c0c0}
.constr-row.p3{border-left:3px solid #cd7f32}
.constr-pos{font-family:var(--f1);font-weight:900;font-size:18px;color:var(--gray);text-align:center}
.constr-row.p1 .constr-pos{color:var(--gold)}
.constr-info{display:flex;align-items:center;gap:14px}
.constr-logo{width:44px;height:44px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.constr-logo-img{width:44px;height:44px;object-fit:contain}
.constr-logo-fallback{width:10px;height:44px;border-radius:3px;flex-shrink:0}
.constr-name{font-family:var(--f1);font-weight:700;font-size:15px;color:var(--wht);letter-spacing:.5px}
.constr-members{font-size:11px;color:var(--gray);margin-top:2px;font-family:var(--thai)}
.constr-driver-count{text-align:center;font-family:var(--f1);font-size:12px;color:var(--silv)}
.constr-pts{text-align:right;padding-right:16px;display:flex;align-items:center;justify-content:flex-end;gap:4px}
@media(max-width:600px){
  .constr-sb-head,.constr-row{grid-template-columns:44px 1fr 90px}
  .constr-driver-count{display:none}
}

/* ═══════════════════════════════════════
   ADMIN — TEAM MANAGEMENT
═══════════════════════════════════════ */
.adm-team-row{
  display:grid;grid-template-columns:56px 1fr auto auto;
  align-items:center;gap:16px;padding:14px 16px;
  border-bottom:1px solid var(--d3);transition:background .15s;
}
.adm-team-row:hover{background:var(--d3)}
.adm-team-logo-cell{width:44px;height:44px;display:flex;align-items:center;justify-content:center}
.adm-team-logo{width:44px;height:44px;object-fit:contain}
.adm-team-color-dot{width:16px;height:44px;border-radius:3px}
.adm-team-name-txt{font-family:var(--f1);font-weight:700;font-size:14px;color:var(--wht)}
.adm-team-short{font-family:var(--f1);font-size:10px;letter-spacing:2px;font-weight:700;margin-top:2px}
.adm-team-pts-cell{font-size:12px;color:var(--gray);white-space:nowrap;font-family:var(--f1)}
.adm-team-actions{display:flex;gap:6px}
/* Preset team buttons */
.adm-team-presets{margin-top:24px;padding:20px;background:var(--d2);border:1px solid var(--d4);border-radius:4px}
.adm-team-preset-grid{display:flex;flex-wrap:wrap;gap:8px}
.adm-preset-btn{
  background:transparent;border:1px solid;cursor:pointer;
  font-family:var(--f1);font-size:10px;font-weight:700;letter-spacing:1px;
  padding:6px 12px;border-radius:2px;transition:background .15s,color .15s;
}
.adm-preset-btn:hover{background:rgba(255,255,255,.08)}


/* ═══════════════════════════════════════
   RULEBOOK
═══════════════════════════════════════ */
.rb-wrap{display:flex;flex-direction:column;gap:0;margin-top:8px}
.rb-section{border:1px solid var(--d4);border-radius:4px;overflow:hidden;margin-bottom:12px}
.rb-sec-head{display:flex;align-items:center;gap:14px;padding:16px 20px;background:var(--d2);font-family:var(--f1);font-size:14px;font-weight:700;color:var(--wht);letter-spacing:.5px;border-bottom:1px solid var(--d4)}
.rb-sec-num{font-family:var(--f1);font-size:11px;font-weight:900;letter-spacing:3px;color:var(--red);flex-shrink:0}
.rb-sec-sub{font-family:var(--f1);font-size:9px;font-weight:400;letter-spacing:2px;color:var(--gray);text-transform:uppercase;margin-left:auto;flex-shrink:0}
.rb-sec-body{padding:16px 20px;display:flex;flex-direction:column;gap:10px}
.rb-rule{display:flex;gap:14px;font-family:var(--thai);font-size:14px;color:var(--silv);line-height:1.7}
.rb-rule strong{color:var(--wht);font-weight:600}
.rb-num{font-family:var(--f1);font-size:10px;font-weight:700;color:var(--gray);flex-shrink:0;width:28px;padding-top:3px;letter-spacing:.5px}
.rb-note{background:rgba(232,0,45,.07);border:1px solid rgba(232,0,45,.2);border-left:3px solid var(--red);padding:10px 14px;font-family:var(--thai);font-size:13px;color:var(--silv);line-height:1.6;border-radius:2px;margin-top:4px}
.rb-table-wrap{margin-top:8px}
.rb-table-label{font-family:var(--f1);font-size:8px;letter-spacing:2px;color:var(--gray);font-weight:700;text-transform:uppercase;margin-bottom:8px}
.rb-table{width:100%;border-collapse:collapse;font-family:var(--f1);font-size:12px}
.rb-table th{padding:8px 12px;background:var(--d3);color:var(--gray);font-size:9px;letter-spacing:2px;font-weight:700;text-align:left;border-bottom:1px solid var(--d4)}
.rb-table td{padding:9px 12px;border-bottom:1px solid var(--d3);color:var(--silv)}
.rb-table tr:last-child td{border-bottom:none}
.rb-table tr:hover td{background:rgba(255,255,255,.02)}
.rb-settings-group{margin-top:12px}
.rb-settings-label{font-family:var(--f1);font-size:8px;letter-spacing:2px;color:var(--gray);font-weight:700;text-transform:uppercase;margin-bottom:6px;padding-left:2px}
.rb-val-on{color:#00c853;font-weight:700;font-family:var(--f1);font-size:11px;letter-spacing:.5px;white-space:nowrap}
.rb-val-off{color:rgba(255,255,255,.3);font-family:var(--f1);font-size:11px;letter-spacing:.5px}
.rb-note-inline{font-family:var(--thai);font-size:11px;color:var(--gray);font-weight:400;letter-spacing:0}
.rb-footer{display:flex;justify-content:space-between;align-items:center;padding:16px 0 4px;font-family:var(--f1);font-size:9px;letter-spacing:1px;color:var(--gray);border-top:1px solid var(--d4);flex-wrap:wrap;gap:8px}
@media(max-width:600px){
  .rb-sec-head{flex-wrap:wrap;gap:6px}
  .rb-sec-sub{margin-left:0;width:100%}
  .rb-rule{font-size:13px}
  .rb-table{font-size:11px}
  .rb-table th,.rb-table td{padding:7px 8px}
  .rb-footer{flex-direction:column;align-items:flex-start}
}

/* ── Super License Card (Driver Profile) ─────────────────────── */
.sl-license-card{position:relative;background:linear-gradient(135deg,#111 0%,#1a1a1a 50%,#0e0e0e 100%);border:1px solid rgba(255,255,255,.08);border-radius:12px;overflow:hidden;margin:20px 0;box-shadow:0 8px 32px rgba(0,0,0,.5),inset 0 1px 0 rgba(255,255,255,.05)}
.sl-license-card::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(255,255,255,.012) 3px,rgba(255,255,255,.012) 4px),repeating-linear-gradient(90deg,transparent,transparent 3px,rgba(255,255,255,.012) 3px,rgba(255,255,255,.012) 4px);pointer-events:none;z-index:0}
.slc-stripe{position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,var(--red),#600);z-index:1}
.sl-lc-ban .slc-stripe{background:linear-gradient(180deg,var(--red),#600)}
.sl-lc-warn .slc-stripe{background:linear-gradient(180deg,#f59e0b,#a06000)}
.sl-lc-ok .slc-stripe{background:linear-gradient(180deg,#00c853,#007030)}
.slc-header{display:flex;justify-content:space-between;align-items:center;padding:10px 20px 10px 28px;border-bottom:1px solid rgba(255,255,255,.06);position:relative;z-index:1}
.slc-league{font-family:var(--f1);font-size:7px;letter-spacing:2px;color:var(--gray);font-weight:700;text-transform:uppercase}
.slc-doc{font-family:var(--f1);font-size:11px;letter-spacing:3px;font-weight:900;color:var(--wht);text-transform:uppercase}
.slc-body{display:flex;align-items:center;gap:0;padding:20px 20px 20px 28px;position:relative;z-index:1}
.slc-left{flex:1;min-width:0}
.slc-divider{width:1px;background:rgba(255,255,255,.08);margin:0 24px;align-self:stretch;flex-shrink:0}
.slc-right{min-width:160px;display:flex;flex-direction:column;align-items:flex-end;gap:4px}
.slc-driver-row{display:flex;align-items:center;gap:16px}
.slc-av{width:60px;height:60px;border-radius:50%;overflow:hidden;background:var(--d4);border:2px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;font-family:var(--f1);font-size:20px;font-weight:900;color:var(--gray);flex-shrink:0}
.slc-av img{width:100%;height:100%;object-fit:cover}
.slc-name{font-family:var(--f1);font-size:20px;font-weight:900;color:var(--wht);letter-spacing:1px}
.slc-tag-sub{font-family:var(--f1);font-size:9px;letter-spacing:2px;color:var(--gray);text-transform:uppercase;margin-top:3px}
.slc-pts-display{display:flex;align-items:baseline;gap:2px}
.slc-pts-num{font-family:var(--f1);font-size:44px;font-weight:900;line-height:1}
.slc-pts-denom{font-family:var(--f1);font-size:18px;color:var(--gray);font-weight:700}
.slc-pts-label{font-family:var(--f1);font-size:8px;letter-spacing:2px;color:var(--gray);text-transform:uppercase}
.slc-bar{width:160px;margin:6px 0 8px}
.slc-expiry{font-family:var(--f1);font-size:9px;color:var(--gray);margin-top:4px;text-align:right;letter-spacing:.5px}
.slc-chip{width:28px;height:20px;margin-top:12px;background:linear-gradient(135deg,#c8a84b,#f0d080 40%,#a07830 70%,#c8a84b);border-radius:3px;opacity:.3}
.slc-chip::after{content:'';display:block;margin:3px;height:calc(100% - 6px);border:1px solid rgba(0,0,0,.25);border-radius:2px}
.slc-history{border-top:1px solid rgba(255,255,255,.06);padding:14px 20px 14px 28px;position:relative;z-index:1}
.slc-history-label{font-family:var(--f1);font-size:8px;letter-spacing:2px;color:var(--gray);font-weight:700;text-transform:uppercase;margin-bottom:10px}
@media(max-width:600px){
  .slc-body{flex-direction:column;gap:20px;padding:16px 16px 16px 22px}
  .slc-divider{display:none}
  .slc-right{align-items:flex-start}
  .slc-bar{width:100%}
  .slc-expiry{text-align:left}
  .slc-chip{display:none}
}
.pen-list-compact{display:flex;flex-direction:column;gap:6px}
.pen-row-compact{display:flex;align-items:center;gap:10px;padding:6px 0;border-bottom:1px solid var(--d3)}
.pen-row-compact:last-child{border-bottom:none}
.pen-pts-badge{font-family:var(--f1);font-size:10px;font-weight:700;padding:2px 7px;border-radius:2px;white-space:nowrap}
.pen-expired{opacity:.5}

/* ═══════════════════════════════════════
   PENALTY ADMIN SECTION
═══════════════════════════════════════ */
.pen-tabs{display:flex;gap:6px;margin-bottom:18px;flex-wrap:wrap}
.pen-tab{font-family:var(--f1);font-size:9px;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:9px 18px;border:1px solid var(--d5);background:var(--d2);color:var(--gray);cursor:pointer;transition:all .15s;border-radius:2px}
.pen-tab:hover{color:var(--wht);border-color:var(--d5)}
.pen-tab.pen-tab-active{color:var(--wht);border-color:var(--red);background:rgba(232,0,45,.08)}
.pen-list-head{display:grid;grid-template-columns:140px 1fr 70px 80px 30px;padding:8px 14px;border-bottom:1px solid var(--d4);font-family:var(--f1);font-size:8.5px;font-weight:700;letter-spacing:2px;color:var(--gray);text-transform:uppercase;background:var(--d3)}
.pen-row{display:grid;grid-template-columns:140px 1fr 70px 80px 30px;align-items:center;padding:12px 14px;border-bottom:1px solid var(--d3);transition:background .15s;gap:8px}
.pen-row:hover{background:var(--d3)}
.pen-row.pen-expired{opacity:.5}
.pen-drv{font-family:var(--f1);font-size:12px;font-weight:700;color:var(--wht)}
.pen-offense{color:var(--silv);font-size:11px;font-family:var(--thai)}
.pen-val{font-family:var(--f1);font-size:13px;font-weight:700;color:var(--red)}

/* Penalty modal type buttons */
.pen-type-btn{font-family:var(--f1);font-size:9px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:9px 16px;border:1px solid var(--d5);background:var(--d2);color:var(--gray);cursor:pointer;transition:all .15s;border-radius:2px;flex:1}
.pen-type-btn:hover{color:var(--wht)}
.pen-type-btn.pen-type-active{color:var(--wht);border-color:var(--red);background:rgba(232,0,45,.08)}

/* Time penalty badge in race results */
.pen-badge-time{display:inline-flex;align-items:center;font-family:var(--f1);font-size:9px;font-weight:700;color:#f59e0b;background:rgba(245,158,11,.12);border:1px solid rgba(245,158,11,.25);padding:1px 5px;border-radius:2px;margin-left:6px;vertical-align:middle;cursor:default}

/* ═══════════════════════════════════════
   MOBILE IMPROVEMENTS
═══════════════════════════════════════ */

/* Calendar: tap hint on mobile for done rows */
@media(max-width:480px){
  .cv3-action-col{display:none}
  .cv3-row.cv3-done::after,.cv3-row.cv3-next::after{
    content:'แตะเพื่อดูรายละเอียด';
    display:block;grid-column:1/-1;
    font-size:9px;letter-spacing:1.5px;color:var(--gray);
    text-align:right;padding:2px 12px 6px;font-family:var(--f1)
  }
}

/* Race results panel mobile scroll */
@media(max-width:600px){
  .crp-inner{overflow-x:auto}
  .f1r-tbl-head,.f1r-row{grid-template-columns:4px 46px 1fr 60px}
  .f1r-team-cell{display:none}
  .crp-tab{padding:11px 14px;font-size:9px}
}

/* Standings: mobile */
@media(max-width:480px){
  .f1-sb-head,.f1-sb-row{grid-template-columns:48px 1fr 90px}
  .f1-sb-col-wins,.f1-sb-col-races{display:none}
}

/* Registration: larger touch targets on mobile */
@media(max-width:600px){
  .f-in{min-height:44px;font-size:15px}
  .f-lbl{font-size:12px}
  .f-grp{margin-bottom:14px}
  .reg-steps{padding:20px 0 0}
  .rs-num{width:30px;height:30px}
  .rs-step{min-width:54px}
}

/* ════════════════════════════════════════
   DISCORD AUTH
════════════════════════════════════════ */
.btn-discord-login{
  display:flex;align-items:center;gap:6px;
  padding:6px 12px;background:#5865F2;color:#fff;
  border:none;border-radius:3px;cursor:pointer;white-space:nowrap;
  font-family:var(--f1);font-size:10px;font-weight:700;letter-spacing:1.5px;
  text-transform:uppercase;transition:background .15s;flex-shrink:0;
}
.btn-discord-login:hover{background:#4752c4}

.nav-discord-user-btn{
  display:flex;align-items:center;gap:6px;
  background:none;border:1px solid var(--d4);border-radius:3px;
  padding:4px 8px;cursor:pointer;color:var(--wht);
  font-family:var(--f1);font-size:10px;font-weight:600;letter-spacing:.5px;
  transition:border-color .15s;white-space:nowrap;
}
.nav-discord-user-btn:hover{border-color:var(--gray)}
.nav-discord-avatar{width:22px;height:22px;border-radius:50%;object-fit:cover;flex-shrink:0}

.nav-user-menu{
  display:none;position:absolute;right:0;top:calc(100% + 8px);
  background:var(--d2);border:1px solid var(--d4);border-radius:4px;
  min-width:160px;z-index:999;overflow:hidden;box-shadow:0 8px 24px rgba(0,0,0,.5);
}
.nav-user-menu.open{display:block}
.nav-user-menu a{
  display:block;padding:11px 16px;font-size:13px;
  color:var(--silv);cursor:pointer;transition:background .1s;white-space:nowrap;
}
.nav-user-menu a:hover{background:var(--d3);color:var(--wht)}

/* ── My Profile page ── */
.my-profile-card{background:var(--d2);border:1px solid var(--d4);border-radius:6px;padding:28px}
.my-profile-top{display:flex;align-items:center;gap:20px;margin-bottom:24px}
.my-profile-avatar-wrap{position:relative;flex-shrink:0}
.my-profile-avatar{width:80px;height:80px;border-radius:50%;object-fit:cover;border:2px solid var(--d4)}
.my-profile-avatar-edit{
  position:absolute;bottom:0;right:0;width:24px;height:24px;
  padding:0 !important;font-size:11px;border-radius:50% !important;
  display:flex;align-items:center;justify-content:center;
}
.my-profile-name{font-size:20px;font-weight:700;margin-bottom:4px}
.my-profile-discord{font-size:13px;color:var(--gray);margin-bottom:8px}
.my-profile-tag{
  display:inline-block;padding:2px 8px;
  background:var(--red);color:#fff;font-size:11px;font-weight:700;
  letter-spacing:2px;border-radius:2px;
}
.my-profile-section{margin-top:20px;padding-top:20px;border-top:1px solid var(--d4)}
.my-profile-section-title{font-size:10px;letter-spacing:2px;color:var(--gray);margin-bottom:10px;font-weight:700}
.my-profile-status{font-size:16px;font-weight:600}
.my-profile-stats{display:flex;gap:32px}
.my-profile-stat{text-align:center;font-size:12px;color:var(--gray);line-height:1.4}
@media(max-width:480px){
  .my-profile-top{flex-direction:column;text-align:center}
  .my-profile-stats{gap:20px}
}

/* Admin panel: mobile adjustments */
@media(max-width:600px){
  .adm-content{padding:16px 14px}
  .adm-topbar{padding:14px 16px}
  .adm-page-title{font-size:12px}
  .adm-dash-kpi{grid-template-columns:1fr 1fr;gap:8px}
  .adm-kpi-val{font-size:32px}
  .adm-kpi-card{padding:14px}
  .modal-box{padding:20px 16px!important;margin:12px}
  .f-grid{grid-template-columns:1fr!important}
  .f-grp[style*="grid-column:1/-1"]{grid-column:1!important}
  .pen-list-head{grid-template-columns:100px 1fr 60px 60px 28px}
  .pen-row{grid-template-columns:100px 1fr 60px 60px 28px}
  .sl-head,.sl-row{grid-template-columns:30px 1fr 50px 60px}
  .sl-col-exp,.sl-col-bar{display:none}
}

/* Tablet: admin sidebar tweak */
@media(max-width:900px){
  .adm-layout{flex-direction:column}
  .adm-sidebar{width:100%;flex-direction:row;align-items:center;border-right:none;border-bottom:1px solid var(--d4)}
  .adm-sidebar-logo{display:none}
  .adm-nav{flex-direction:row;overflow-x:auto;padding:4px 8px;gap:2px;flex:1}
  .adm-nav-item{border-left:none;border-bottom:2px solid transparent;padding:9px 12px;font-size:8.5px;letter-spacing:1.5px;white-space:nowrap}
  .adm-nav-item.active{border-left:none;border-bottom-color:var(--red);background:rgba(232,0,45,.06)}
  .adm-nav-sub{display:none}
}

/* Fix: f1-sb hide columns on mobile — target by data-col or nth-child */
@media(max-width:480px){
  .f1-sb-head > div:nth-child(4),.f1-sb-row > div:nth-child(4),
  .f1-sb-head > div:nth-child(5),.f1-sb-row > div:nth-child(5){display:none}
}

/* ═══════════════════════════════════════
   RACE RESULTS PAGE
═══════════════════════════════════════ */
.rr-card{background:var(--d2);border:1px solid var(--d4);margin-bottom:10px;border-radius:2px;transition:border-color .15s}
.rr-card:hover,.rr-card.rr-card-open{border-color:var(--d5)}
.rr-card-open{border-color:var(--red)!important}
.rr-card-head{display:flex;align-items:center;gap:16px;padding:18px 22px;cursor:pointer;user-select:none;transition:background .15s}
.rr-card-head:hover{background:rgba(255,255,255,.025)}
.rr-card-left{flex:1;min-width:0}
.rr-card-round{font-family:var(--f1);font-size:8.5px;letter-spacing:3px;color:var(--red);font-weight:700;text-transform:uppercase;margin-bottom:3px}
.rr-card-name{font-family:var(--f1);font-size:16px;font-weight:900;color:var(--wht);letter-spacing:.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rr-card-circuit{font-size:12px;color:var(--gray);margin-top:2px;font-family:var(--thai)}
.rr-card-meta{display:flex;flex-direction:column;align-items:flex-end;gap:8px;flex-shrink:0}
.rr-card-date{font-family:var(--f1);font-size:10px;color:var(--gray);letter-spacing:1px}
.rr-podium{display:flex;gap:10px}
.rr-podium-item{display:flex;align-items:center;gap:6px}
.rr-pos{font-size:14px}
.rr-pod-name{font-family:var(--f1);font-size:10px;font-weight:700;color:var(--silv);letter-spacing:.5px;padding-left:7px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:110px}
.rr-card-chevron{font-size:11px;color:var(--gray);flex-shrink:0;transition:transform .2s;margin-left:8px}
.rr-card-open .rr-card-chevron{color:var(--red)}
.rr-panel{border-top:1px solid var(--d4)}
.rr-panel-head{display:grid;grid-template-columns:52px 1fr 80px;padding:8px 22px;font-family:var(--f1);font-size:8.5px;font-weight:700;letter-spacing:2px;color:var(--gray);text-transform:uppercase;background:var(--d3);border-bottom:1px solid var(--d4)}
.rr-row{display:grid;grid-template-columns:52px 1fr 80px;align-items:center;padding:10px 22px;border-bottom:1px solid var(--d3);transition:background .12s}
.rr-row:last-child{border-bottom:none}
.rr-row:hover{background:rgba(232,0,45,.04)}
.rr-row-pos{display:flex;align-items:center}
.rr-row-num{font-family:var(--f1);font-size:15px;font-weight:900;color:var(--silv)}
.rr-row-num.rr-pos-1{color:var(--gold)}
.rr-row-num.rr-pos-2{color:#C0C0C0}
.rr-row-num.rr-pos-3{color:#CD7F32}
.rr-row-name{min-width:0}
.rr-row-dname{font-family:var(--f1);font-size:13px;font-weight:700;color:var(--wht);display:flex;align-items:center;gap:5px;flex-wrap:wrap}
.rr-row-team{font-size:10px;letter-spacing:.5px;margin-top:2px;font-family:var(--f1);font-weight:700;text-transform:uppercase}
.rr-row-pts{text-align:right;padding-right:4px}
.rr-fl-badge{display:inline-flex;align-items:center;font-family:var(--f1);font-size:8px;font-weight:700;color:#a855f7;background:rgba(168,85,247,.12);border:1px solid rgba(168,85,247,.3);padding:1px 5px;border-radius:2px}
.rr-tp-badge{display:inline-flex;align-items:center;font-family:var(--f1);font-size:8px;font-weight:700;color:var(--warn);background:rgba(255,179,0,.1);border:1px solid rgba(255,179,0,.25);padding:1px 5px;border-radius:2px}
@media(max-width:600px){
  .rr-card-head{padding:14px 14px;gap:10px}
  .rr-card-meta{display:none}
  .rr-panel-head{grid-template-columns:44px 1fr 68px;padding:8px 14px}
  .rr-row{grid-template-columns:44px 1fr 68px;padding:9px 14px}
}

/* ═══════════════════════════════════════
   TEAMS PAGE
═══════════════════════════════════════ */
#teamsGrid{display:flex;flex-direction:column;gap:14px}
.tp-card{background:var(--d2);border:1px solid var(--d4);border-radius:2px;overflow:hidden;transition:border-color .2s}
.tp-card:hover{border-color:var(--d5)}
.tp-card-accent{height:4px;width:100%}
.tp-card-inner{padding:22px 26px}
.tp-card-top{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.tp-pos-badge{font-family:var(--f1);font-size:28px;font-weight:900;color:var(--d5);min-width:36px;flex-shrink:0}
.tp-logo{height:52px;width:auto;max-width:90px;object-fit:contain;flex-shrink:0}
.tp-logo-placeholder{width:52px;height:52px;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:22px;color:#fff;border-radius:4px;flex-shrink:0}
.tp-team-info{flex:1;min-width:140px}
.tp-team-name{font-family:var(--f1);font-size:18px;font-weight:900;color:var(--wht);letter-spacing:.5px}
.tp-team-pts{font-family:var(--f1);font-size:13px;font-weight:700;color:var(--gold);margin-top:4px;letter-spacing:1px}
.tp-team-pts span{font-size:9px;color:var(--gray);letter-spacing:3px;font-weight:700}
.tp-team-stats{display:flex;gap:24px;margin-left:auto;flex-shrink:0}
.tp-stat{text-align:center}
.tp-stat-v{font-family:var(--f1);font-size:22px;font-weight:900;color:var(--silv)}
.tp-stat-l{font-family:var(--f1);font-size:8px;letter-spacing:2.5px;color:var(--gray);font-weight:700;text-transform:uppercase;margin-top:2px}
.tp-divider{border-top:1px solid var(--d4);margin:16px 0 14px}
.tp-drivers{display:flex;gap:14px;flex-wrap:wrap}
.tp-driver{display:flex;align-items:center;gap:12px;background:var(--d3);border:1px solid var(--d4);padding:10px 14px;flex:1;min-width:180px;cursor:pointer;transition:border-color .15s,background .15s;border-radius:2px}
.tp-driver:hover{border-color:var(--d5);background:var(--d4)}
.tp-driver-av{width:40px;height:40px;border-radius:50%;background:var(--d4);display:flex;align-items:center;justify-content:center;font-weight:900;font-size:14px;color:var(--silv);overflow:hidden;flex-shrink:0}
.tp-driver-av img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.tp-driver-name{font-family:var(--f1);font-size:13px;font-weight:700;color:var(--wht);letter-spacing:.3px}
.tp-driver-pts{font-family:var(--f1);font-size:10px;color:var(--gray);margin-top:2px}
@media(max-width:600px){
  .tp-card-inner{padding:16px 14px}
  .tp-team-stats{display:none}
  .tp-driver{min-width:140px}
}

/* Profile chart row */
.profile-chart-wrap{background:var(--d2);border:1px solid var(--d4);padding:20px 22px 16px;margin-bottom:24px}
.profile-chart-title{font-family:var(--f1);font-size:8.5px;letter-spacing:3px;color:var(--gray);font-weight:700;text-transform:uppercase;margin-bottom:14px}
.profile-bar-chart{display:flex;align-items:flex-end;gap:5px;height:80px}
.pbc-col{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1;min-width:0}
.pbc-bar-wrap{display:flex;align-items:flex-end;width:100%;height:60px}
.pbc-bar{width:100%;background:var(--red);border-radius:2px 2px 0 0;min-height:3px;transition:height .3s ease}
.pbc-pts{font-family:var(--f1);font-size:9px;font-weight:700;color:var(--silv)}
.pbc-round{font-family:var(--f1);font-size:7.5px;color:var(--gray);letter-spacing:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;text-align:center}
