/* ============================================================
   RACE SEVYN — game styles
   ============================================================ */
.race-wrap{display:flex;gap:30px;justify-content:center;align-items:flex-start;flex-wrap:wrap;}

.race-stage{position:relative;width:100%;max-width:440px;flex:none;}
.race-screen{position:relative;width:100%;}
.race-canvas{width:100%;display:block;border-radius:22px;overflow:hidden;
  box-shadow:0 26px 64px rgba(11,26,58,.32);border:2px solid rgba(11,26,58,.12);background:#256a34;touch-action:none;}
body:not(.theme-sky) .race-canvas{border-color:rgba(255,255,255,.1);}

/* overlays */
.race-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  border-radius:22px;background:rgba(7,15,36,.55);backdrop-filter:blur(3px);padding:20px;text-align:center;z-index:3;}
.ro-card{background:#fff;border-radius:20px;padding:28px 26px;max-width:330px;width:100%;
  box-shadow:0 24px 60px rgba(0,0,0,.4);}
body:not(.theme-sky) .ro-card{background:var(--navy-card);}
.ro-flag{font-size:46px;display:block;margin-bottom:6px;}
.ro-title{font-size:38px;margin:0 0 8px;}
.ro-sub{color:var(--mut);font-size:16px;margin:0 0 20px;}
.ro-diff{display:flex;gap:8px;justify-content:center;margin-bottom:20px;}
.ro-dbtn{flex:1;background:#f1f7fc;border:2px solid var(--line);border-radius:11px;padding:11px 8px;
  font-family:'Saira Condensed',sans-serif;font-weight:800;text-transform:uppercase;letter-spacing:.03em;
  font-size:15px;color:var(--ink);transition:all .14s;}
body:not(.theme-sky) .ro-dbtn{background:#0d1937;}
.ro-dbtn:hover{transform:translateY(-2px);}
.ro-dbtn.on{border-color:var(--cyan);background:rgba(0,174,239,.12);color:var(--cyan-d);}
body:not(.theme-sky) .ro-dbtn.on{color:var(--cyan-l);}
.ro-start{width:100%;justify-content:center;}
.ro-how{margin-top:14px;color:var(--mut-d);font-size:13px;font-family:ui-monospace,monospace;}
.ro-best{margin-top:14px;background:rgba(255,212,0,.16);border:1px solid rgba(255,212,0,.5);color:#b58a00;
  font-family:'Saira Condensed',sans-serif;font-weight:800;text-transform:uppercase;letter-spacing:.04em;
  font-size:15px;padding:9px 14px;border-radius:11px;}
body:not(.theme-sky) .ro-best{color:#ffd84d;}
.ro-actions{display:flex;flex-direction:column;gap:10px;}
.ro-actions .btn{justify-content:center;}

/* countdown */
.race-count{background:rgba(7,15,36,.4);}
.rc-num{font-family:'Saira Condensed',sans-serif;font-style:italic;font-weight:900;font-size:140px;
  color:#fff;text-shadow:0 8px 30px rgba(0,0,0,.5);animation:rcpop .5s ease;}
.rc-num.go{color:var(--cyan-l);font-size:96px;}
@keyframes rcpop{from{transform:scale(.4);opacity:0}to{transform:scale(1);opacity:1}}

/* touch controls — docked deck below the screen */
.race-controls{display:flex;align-items:center;justify-content:space-between;gap:12px;
  margin-top:14px;padding:14px 16px;border-radius:18px;background:var(--navy-card);
  border:1px solid var(--line);box-shadow:0 8px 26px rgba(11,26,58,.08);transition:opacity .2s;}
.rc-steer{display:flex;gap:12px;}
.rc-hint{flex:1;text-align:center;font-family:'Saira Condensed',sans-serif;font-style:italic;font-weight:700;
  text-transform:uppercase;letter-spacing:.04em;font-size:14px;color:var(--mut);}
.rc-btn{width:64px;height:64px;border-radius:18px;border:0;background:#0d1937;color:#fff;
  font-size:24px;display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 16px rgba(0,0,0,.22);transition:transform .1s, background .15s;touch-action:none;user-select:none;}
body.theme-sky .rc-btn{background:#16285a;}
.rc-btn:active{transform:scale(.92);background:var(--cyan);color:#04263a;}
.rc-boost{height:64px;padding:0 24px;border:0;border-radius:18px;background:var(--magenta);color:#fff;
  font-family:'Saira Condensed',sans-serif;font-style:italic;font-weight:900;text-transform:uppercase;
  letter-spacing:.04em;font-size:18px;box-shadow:0 8px 22px rgba(236,28,148,.45);transition:transform .1s, filter .15s;touch-action:none;user-select:none;white-space:nowrap;}
.rc-boost:active{transform:scale(.94);filter:brightness(1.12);}

/* side panel */
.race-side{flex:1;min-width:260px;max-width:360px;}
.rs-score{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:18px;}
.rsc-box{background:var(--navy-card);border:1px solid var(--line);border-radius:14px;padding:14px 10px;text-align:center;
  box-shadow:0 4px 14px rgba(11,26,58,.05);}
.rsc-num{display:block;font-family:'Saira Condensed',sans-serif;font-style:italic;font-weight:900;
  font-size:34px;line-height:1;color:var(--cyan-d);}
body:not(.theme-sky) .rsc-num{color:var(--cyan-l);}
.rsc-hearts{color:var(--magenta);letter-spacing:1px;font-size:24px;}
.rsc-lab{display:block;margin-top:4px;font-family:'Saira Condensed',sans-serif;font-weight:700;
  text-transform:uppercase;letter-spacing:.06em;font-size:12px;color:var(--mut);}
.rs-h3{font-size:30px;margin:0 0 16px;}
.rs-grid{list-style:none;padding:0;margin:0 0 26px;display:flex;flex-direction:column;gap:10px;}
.rs-grid li{display:flex;align-items:center;gap:12px;background:var(--navy-card);border:1px solid var(--line);
  border-radius:13px;padding:11px 16px;box-shadow:0 4px 14px rgba(11,26,58,.05);}
.rs-num{width:38px;height:38px;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center;
  color:#fff;font-family:'Saira Condensed',sans-serif;font-style:italic;font-weight:900;font-size:17px;
  box-shadow:inset 0 -2px 6px rgba(0,0,0,.2);}
.rs-grid b{font-family:'Saira Condensed',sans-serif;font-weight:800;text-transform:uppercase;font-size:18px;letter-spacing:.02em;}
.rs-tag{margin-left:auto;color:var(--mut);font-size:13px;text-transform:uppercase;letter-spacing:.05em;font-family:'Saira Condensed',sans-serif;font-weight:600;}
.rs-how{background:var(--navy-card);border:1px solid var(--line);border-radius:16px;padding:20px 22px;}
.rs-how h4{font-family:'Saira Condensed',sans-serif;font-weight:800;text-transform:uppercase;letter-spacing:.05em;
  font-size:15px;color:var(--mut);margin:0 0 12px;}
.rs-how p{font-size:15px;color:var(--ink);margin:0 0 9px;}
.rs-how p b{color:var(--cyan-d);}
body:not(.theme-sky) .rs-how p b{color:var(--cyan-l);}
.rs-how .btn{margin-top:8px;}

@media(max-width:920px){
  .race-wrap{flex-direction:column;align-items:center;}
  .race-side{max-width:440px;width:100%;}
}


/* ============================================================
   RACE UPGRADES — build chip, cups, rivals
   ============================================================ */
.ro-mycar{display:flex;align-items:center;gap:12px;margin:0 0 16px;padding:10px 12px;
  border-radius:14px;background:rgba(11,26,58,.06);border:1px solid var(--line);}
body:not(.theme-sky) .ro-mycar{background:rgba(255,255,255,.05);}
.rom-dot{flex:none;width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  color:#fff;font-family:'Saira Condensed',sans-serif;font-style:italic;font-weight:900;font-size:18px;
  border:3px solid #fff;box-shadow:0 4px 12px rgba(0,0,0,.25);}
.rom-stats{flex:1;display:flex;flex-direction:column;gap:3px;min-width:0;}
.rom-stat{display:flex;align-items:center;gap:8px;}
.rom-stat > span{flex:none;width:42px;text-align:left;font-family:'Saira Condensed',sans-serif;
  font-weight:800;text-transform:uppercase;font-size:11px;color:var(--mut);letter-spacing:.04em;}
.rom-pips{display:flex;gap:3px;}
.rom-pip{width:14px;height:6px;border-radius:3px;background:rgba(120,140,170,.28);}
.rom-pip.lit{background:var(--cyan);}
.rom-stat:nth-child(2) .rom-pip.lit{background:var(--magenta);}
.rom-stat:nth-child(3) .rom-pip.lit{background:#f6b800;}
.rom-tune{flex:none;border:0;background:var(--cyan);color:#04263a;border-radius:10px;padding:8px 12px;
  font-family:'Saira Condensed',sans-serif;font-weight:900;font-style:italic;text-transform:uppercase;
  font-size:13px;letter-spacing:.03em;cursor:pointer;transition:transform .12s;}
.rom-tune:hover{transform:translateY(-2px);}

.ro-dbtn small{display:block;font-size:10.5px;font-weight:700;letter-spacing:.05em;color:var(--mut);margin-top:2px;}
.ro-dbtn.on small{color:inherit;opacity:.75;}

.ro-cups{display:flex;gap:8px;justify-content:center;margin:0 0 18px;}
.roc{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 4px;
  border-radius:11px;border:1px dashed var(--line);font-size:22px;filter:grayscale(1);opacity:.45;}
.roc small{font-family:'Saira Condensed',sans-serif;font-weight:800;text-transform:uppercase;
  font-size:9.5px;letter-spacing:.05em;color:var(--mut);line-height:1.15;}
.roc.got{filter:none;opacity:1;border-style:solid;border-color:rgba(246,184,0,.5);background:rgba(255,212,0,.08);}

.ro-cupwin{margin:0 0 14px;background:rgba(255,212,0,.16);border:1px solid rgba(255,212,0,.5);color:#b58a00;
  font-family:'Saira Condensed',sans-serif;font-weight:800;text-transform:uppercase;letter-spacing:.04em;
  font-size:15px;padding:9px 14px;border-radius:11px;}
body:not(.theme-sky) .ro-cupwin{color:#ffd84d;}
.ro-cupwin.new{animation:cupPop .5s cubic-bezier(.2,1.6,.4,1);}
@keyframes cupPop{from{transform:scale(.6);opacity:0}to{transform:scale(1);opacity:1}}

.ro-rivals{display:flex;flex-wrap:wrap;gap:6px;align-items:center;justify-content:center;margin:0 0 14px;}
.ror-label{font-family:'Saira Condensed',sans-serif;font-weight:800;text-transform:uppercase;
  font-size:12px;letter-spacing:.05em;color:var(--mut);}
.ror-chip{background:rgba(0,174,239,.10);border:1px solid rgba(0,174,239,.35);border-radius:99px;
  padding:4px 11px;font-family:'Saira Condensed',sans-serif;font-weight:800;font-size:13px;letter-spacing:.03em;}
.rs-buildnote{border-top:1px dashed var(--line);padding-top:10px;}
