*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{width:100%;height:100%;overflow:hidden;overscroll-behavior:none}
body{font-family:Arial,Helvetica,sans-serif;color:#fff;background:#050814}
button{border:0;cursor:pointer;border-radius:999px;padding:12px 20px;font-weight:900;color:#041017;background:linear-gradient(135deg,#25e7ff,#ff59f7);box-shadow:0 0 16px rgba(37,231,255,.45),0 0 26px rgba(255,89,247,.25)}
button:hover{filter:brightness(1.12)}button:active{transform:scale(.96)}button:disabled{opacity:.45;cursor:not-allowed;filter:grayscale(.3)}
.app,.screen{width:100%;height:100%}.screen{display:none}.screen.active{display:block}
.menu-bg{min-height:100vh;display:grid;place-items:center;text-align:center;padding:24px;background:radial-gradient(circle at 18% 20%,rgba(255,179,92,.28),transparent 26%),radial-gradient(circle at 70% 25%,rgba(120,72,255,.22),transparent 30%),radial-gradient(circle at 75% 75%,rgba(255,79,253,.16),transparent 34%),linear-gradient(180deg,#2a315b 0%,#5d3269 36%,#201b37 64%,#070a18 100%)}
.menu-card,.garage-card{width:min(980px,94vw);padding:clamp(22px,5vw,52px);border-radius:34px;background:rgba(0,0,0,.44);border:1px solid rgba(255,255,255,.14);box-shadow:0 18px 70px rgba(0,0,0,.32),0 0 55px rgba(0,247,255,.20),inset 0 0 32px rgba(255,255,255,.05);backdrop-filter:blur(8px)}
.wide-card{width:min(1180px,96vw)}
.badge-row{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-bottom:18px}
.badge-row span{border:1px solid rgba(84,255,116,.35);color:#54ff74;background:rgba(84,255,116,.08);border-radius:999px;padding:8px 12px;font-size:12px;letter-spacing:2px;font-weight:900}
.badge-row span:first-child{color:#fff36b;border-color:rgba(255,243,107,.38);background:rgba(255,243,107,.09)}
.menu-card h1{font-size:clamp(42px,8vw,92px);color:#00f7ff;text-shadow:0 0 12px #00f7ff,0 0 34px rgba(255,79,253,.8);margin-bottom:14px;letter-spacing:-2px}
.garage-card h2{font-size:clamp(38px,7vw,74px);color:#00f7ff;text-shadow:0 0 12px #00f7ff,0 0 34px rgba(255,79,253,.8);margin-bottom:14px}
.menu-card p,.garage-card p{max-width:820px;font-size:18px;line-height:1.55;color:rgba(255,255,255,.88);margin:0 auto 22px}
.menu-actions,.button-row{display:flex;flex-wrap:wrap;justify-content:center;gap:12px}.menu-actions button{min-width:118px}.primary-button{padding:16px 34px;font-size:18px}
.status-row,.campaign-top{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:18px}
.best-card,.campaign-top div{display:inline-flex;gap:8px;padding:12px 16px;border:1px solid rgba(0,247,255,.35);border-radius:999px;background:rgba(0,0,0,.20)}
.best-card span,.campaign-top span{color:#fff36b;font-weight:900}
.league-tabs{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin:18px 0 6px}.league-tabs button{padding:9px 13px;font-size:12px;background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.12)}.league-tabs .active{background:linear-gradient(135deg,#fff36b,#25e7ff);color:#050514}
.campaign-list{display:grid;gap:12px;margin:18px 0;max-height:48vh;overflow:auto;padding-right:6px}
.campaign-list::-webkit-scrollbar{width:8px}.campaign-list::-webkit-scrollbar-thumb{background:rgba(0,247,255,.35);border-radius:999px}
.campaign-race{display:grid;grid-template-columns:1fr auto auto;gap:12px;align-items:center;text-align:left;padding:16px;border-radius:22px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);transition:.15s ease}
.campaign-race.available{border-color:rgba(84,255,116,.5);box-shadow:0 0 18px rgba(84,255,116,.12)}.campaign-race.available:hover{transform:translateY(-2px);box-shadow:0 0 26px rgba(84,255,116,.16)}
.campaign-race.locked{opacity:.52}.campaign-race.completed{border-color:rgba(0,247,255,.35)}
.campaign-race h3{color:#fff36b;margin-bottom:5px}.campaign-race p{font-size:14px;margin:0;color:rgba(255,255,255,.78)}
.campaign-race .tag{font-size:12px;font-weight:900;color:#050514;background:#54ff74;border-radius:999px;padding:7px 10px;white-space:nowrap}.campaign-race button{pointer-events:auto;padding:10px 17px}
.danger-button{background:linear-gradient(135deg,#ff315c,#ffb347);color:#170409}
.garage-grid{display:grid;grid-template-columns:repeat(3,minmax(240px,1fr));gap:14px;margin:22px 0;align-items:stretch}
.garage-item{position:relative;overflow:hidden;text-align:left;padding:18px;border-radius:22px;background:rgba(255,255,255,.08);border:1px solid rgba(0,247,255,.24);display:flex;flex-direction:column;min-height:390px;transition:.15s ease}
.garage-item:hover{transform:translateY(-2px);box-shadow:0 0 26px rgba(0,247,255,.16)}.garage-item.selected{border-color:rgba(255,243,107,.72)!important}.garage-item.owned{border-color:rgba(84,255,116,.5)}.garage-item.locked{opacity:.72}
.garage-item h3,.how-grid h3,.upgrade-item h3{color:#fff36b;margin-bottom:8px}.garage-item p{font-size:15px;margin:0 0 10px;color:rgba(255,255,255,.82)}.car-price{color:#fff36b;font-size:18px;font-weight:900;margin:8px 0}
.stat{display:flex;justify-content:space-between;gap:10px;margin-top:7px;font-size:14px;color:rgba(255,255,255,.8)}.stat b{color:#00f7ff}.garage-item button{margin-top:auto;width:100%;pointer-events:auto}
.car-preview-wrap{height:145px;width:100%;border-radius:18px;margin-bottom:14px;overflow:hidden;border:1px solid rgba(0,247,255,.22);background:radial-gradient(circle at 50% 68%,rgba(0,247,255,.18),transparent 42%),linear-gradient(180deg,rgba(255,255,255,.07),rgba(0,0,0,.22));position:relative}
.car-preview-wrap:after{content:"";position:absolute;left:18%;right:18%;bottom:22px;height:10px;border-radius:50%;background:rgba(0,0,0,.42);filter:blur(8px)}
.preview-car{position:absolute;left:50%;top:50%;width:172px;height:74px;transform:translate(-50%,-50%);animation:carFloat 1.9s ease-in-out infinite}
.preview-car .body{position:absolute;left:18px;right:18px;bottom:18px;height:34px;border-radius:18px 22px 10px 10px;background:linear-gradient(180deg,var(--car-main),var(--car-dark));box-shadow:0 0 18px var(--car-glow)}
.preview-car .hood{position:absolute;left:8px;width:48px;bottom:24px;height:18px;border-radius:14px 6px 6px 10px;background:var(--car-main);transform:skewX(-18deg)}
.preview-car .cabin{position:absolute;left:72px;width:48px;bottom:42px;height:28px;border-radius:12px 12px 4px 4px;background:#050715;border:3px solid var(--car-main)}
.preview-car .spoiler{position:absolute;right:18px;bottom:55px;width:46px;height:7px;border-radius:999px;background:var(--car-accent);box-shadow:0 0 12px var(--car-accent)}
.preview-car .skirt{position:absolute;left:24px;right:24px;bottom:15px;height:7px;border-radius:999px;background:var(--car-accent);box-shadow:0 0 12px var(--car-accent)}
.preview-car .wheel{position:absolute;bottom:2px;width:32px;height:32px;border-radius:50%;background:#050509;border:6px solid var(--car-accent);box-shadow:0 0 14px var(--car-accent);animation:wheelSpin .75s linear infinite}.preview-car .wheel.left{left:34px}.preview-car .wheel.right{right:34px}
@keyframes carFloat{0%,100%{transform:translate(-50%,-50%) rotateY(-12deg) translateY(0)}50%{transform:translate(-50%,-50%) rotateY(12deg) translateY(-5px)}}@keyframes wheelSpin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
.upgrade-grid{display:grid;grid-template-columns:repeat(2,minmax(260px,1fr));gap:14px;margin:22px 0}.upgrade-item{padding:18px;border-radius:22px;text-align:left;background:rgba(255,255,255,.08);border:1px solid rgba(0,247,255,.24)}.upgrade-item button{margin-top:12px;width:100%}
.level-bar{height:12px;border-radius:999px;overflow:hidden;background:rgba(255,255,255,.12);margin:12px 0}.level-fill{height:100%;background:linear-gradient(90deg,#25e7ff,#fff36b,#54ff74)}
.daily-card{margin:22px auto;padding:22px;border-radius:24px;max-width:520px;border:1px solid rgba(255,243,107,.32);background:rgba(255,243,107,.08)}.daily-card h3{color:#fff36b;margin-bottom:10px}
.achievements-list{display:grid;grid-template-columns:repeat(2,minmax(260px,1fr));gap:14px;margin:22px 0;max-height:52vh;overflow:auto}.achievement{padding:16px;border-radius:20px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);text-align:left}.achievement.claimed{border-color:rgba(84,255,116,.42);opacity:.75}.achievement.ready{border-color:rgba(255,243,107,.52);box-shadow:0 0 18px rgba(255,243,107,.12)}.achievement h3{color:#fff36b;margin-bottom:7px}.achievement p{font-size:14px;margin:0 0 10px;color:rgba(255,255,255,.78)}.achievement button{width:100%}
.how-grid{display:grid;grid-template-columns:repeat(2,minmax(240px,1fr));gap:14px;margin:22px 0}.how-grid div{text-align:left;padding:18px;border-radius:22px;background:rgba(255,255,255,.08);border:1px solid rgba(0,247,255,.24)}
#gameScreen{position:relative;overflow:hidden;background:#050814}#gameContainer{position:absolute;inset:0}#gameContainer canvas{display:block;width:100%;height:100%;filter:saturate(1.08) contrast(1.03)}
.race-ui{position:absolute;inset:0;z-index:4;pointer-events:none}.top-strip{position:absolute;left:8px;top:8px;right:210px;display:grid;grid-template-columns:1.1fr .75fr repeat(5,minmax(70px,1fr));gap:6px;max-width:calc(100vw - 230px)}
.top-strip div{padding:6px 9px;border:1px solid rgba(0,247,255,.25);border-radius:12px;background:rgba(16,14,32,.34);backdrop-filter:blur(5px)}.top-strip span{display:block;color:rgba(255,255,255,.6);font-size:10px;text-transform:uppercase;letter-spacing:1px}.top-strip strong{color:#fff36b;font-size:15px}.top-strip small{color:#fff36b;font-weight:900}
.quick-buttons{position:absolute;top:8px;right:12px;display:flex;gap:8px;pointer-events:auto}.quick-buttons button{padding:8px 13px;font-size:12px}
.race-rule-badge{position:absolute;left:50%;top:58px;transform:translateX(-50%);padding:8px 14px;border-radius:999px;background:rgba(0,0,0,.28);border:1px solid rgba(255,243,107,.26);color:#fff36b;font-weight:900;font-size:13px;opacity:.88}
.bottom-cluster{position:absolute;left:12px;right:12px;bottom:16px;display:grid;grid-template-columns:minmax(260px,420px) 58px 190px;gap:14px;align-items:end}.rpm-panel,.nitro-panel{padding:11px;border:1px solid rgba(0,247,255,.28);border-radius:18px;background:rgba(14,12,30,.42);backdrop-filter:blur(5px)}
.rpm-labels{display:flex;justify-content:space-between;margin-bottom:8px;font-weight:900;color:rgba(255,255,255,.84)}#shiftHint{color:#fff36b}.rpm-bar,.nitro-bar{position:relative;height:20px;overflow:hidden;border-radius:999px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.14)}
.rpm-fill{height:100%;width:0%;background:linear-gradient(90deg,#00f7ff,#fff36b,#ff315c);box-shadow:0 0 14px rgba(255,243,107,.8);transition:width .08s linear}.perfect-zone{position:absolute;left:72%;width:13%;top:0;bottom:0;background:rgba(84,255,116,.42);box-shadow:0 0 14px rgba(84,255,116,.55);z-index:2}
.gear-stack{display:grid;gap:5px}.gear-item{width:56px;height:27px;display:grid;place-items:center;border-radius:10px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);color:rgba(255,255,255,.7);font-weight:900;font-size:14px;transition:.15s ease}.gear-item.active{color:#050514;background:linear-gradient(135deg,#fff36b,#00f7ff);box-shadow:0 0 14px rgba(255,243,107,.6),0 0 24px rgba(0,247,255,.3)}
.nitro-panel span{display:block;margin-bottom:8px;color:#ff4ffd;font-weight:900}.nitro-fill{height:100%;width:100%;background:linear-gradient(90deg,#ff4ffd,#00f7ff);box-shadow:0 0 14px rgba(255,79,253,.75);transition:width .1s linear}
.countdown-overlay{position:absolute;inset:0;display:grid;place-items:center;pointer-events:none;z-index:5}.drag-tree{position:absolute;top:74px;display:grid;gap:6px;padding:10px;border-radius:999px;background:rgba(12,10,26,.62);border:1px solid rgba(255,255,255,.16);transform:scale(.92)}
.tree-light{width:21px;height:21px;border-radius:50%;background:#171a22;box-shadow:inset 0 0 8px rgba(0,0,0,.8)}.tree-light.active{background:#fff36b;box-shadow:0 0 16px #fff36b,0 0 28px rgba(255,243,107,.7)}.tree-light.go-light.active{background:#54ff74;box-shadow:0 0 16px #54ff74,0 0 28px rgba(84,255,116,.7)}
#countdownText{font-size:clamp(50px,10vw,118px);font-weight:900;color:#fff36b;text-shadow:0 0 18px #fff36b,0 0 44px rgba(255,49,92,.75)}
.overlay{position:absolute;inset:0;z-index:8;display:grid;place-items:center;padding:20px;text-align:center;background:rgba(0,0,0,.72);backdrop-filter:blur(5px)}.overlay.hidden{display:none}.overlay-card{width:min(760px,94vw);padding:26px;border-radius:28px;border:1px solid rgba(255,243,107,.25);background:radial-gradient(circle at top left,rgba(0,247,255,.18),transparent 40%),rgba(8,12,28,.95);box-shadow:0 0 34px rgba(0,247,255,.25)}
.overlay-card h2{color:#fff36b;font-size:clamp(34px,7vw,68px);margin-bottom:10px;text-shadow:0 0 20px rgba(255,243,107,.8)}.overlay-card p{color:rgba(255,255,255,.88);font-size:18px;line-height:1.45;margin-bottom:18px}
.race-summary-box{margin:12px auto 0;padding:10px 13px;max-width:540px;border:1px solid rgba(255,243,107,.30);border-radius:16px;background:rgba(255,243,107,.08);color:rgba(255,255,255,.92);font-weight:800;line-height:1.45}.reward-box{margin:10px auto;padding:12px 14px;max-width:520px;border:1px solid rgba(84,255,116,.32);border-radius:18px;background:rgba(84,255,116,.08);color:#fff36b;font-weight:900;line-height:1.5}
.result-grid{display:grid;grid-template-columns:repeat(2,minmax(120px,1fr));gap:12px;margin:14px 0}.result-grid div{padding:14px;border-radius:18px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.13)}.result-grid span{display:block;color:rgba(255,255,255,.66);font-size:12px;text-transform:uppercase;letter-spacing:1px}.result-grid strong{display:block;margin-top:5px;color:#00f7ff;font-size:24px}.hidden-result{display:none!important}
.mobile-controls{display:none;position:absolute;left:50%;bottom:114px;transform:translateX(-50%);z-index:6;gap:10px}.mobile-controls button{min-width:94px;height:58px;font-size:15px}.gas-button{background:linear-gradient(135deg,#54ff74,#00f7ff)}
@media(max-width:980px){.top-strip{right:16px;max-width:none;grid-template-columns:repeat(2,minmax(90px,1fr))}.quick-buttons{top:auto;bottom:264px;right:14px;flex-direction:column}.mobile-controls{display:flex}.bottom-cluster{grid-template-columns:1fr 58px}.nitro-panel{grid-column:1/2;width:210px}.garage-grid,.upgrade-grid,.achievements-list,.how-grid{grid-template-columns:1fr}.campaign-race{grid-template-columns:1fr}.race-rule-badge{top:160px}}
@media(max-width:620px){.menu-bg{padding:12px}.top-strip{left:10px;right:10px;top:10px;gap:6px}.top-strip div{padding:7px}.top-strip strong{font-size:13px}.quick-buttons{bottom:245px;right:10px}.bottom-cluster{left:10px;right:10px;bottom:80px;gap:8px;grid-template-columns:1fr}.mobile-controls{width:100%;justify-content:center;bottom:14px}.mobile-controls button{min-width:88px;padding:12px 14px}.gear-stack{display:none}.nitro-panel{width:180px}.menu-actions button{min-width:100px}.campaign-list{max-height:43vh}}


/* V8.1 bug-fix build */
.nitro-panel.disabled{
  opacity:.58;
  border-color:rgba(255,255,255,.14);
  background:rgba(30,30,36,.45);
}
.nitro-panel.disabled span{
  color:#bdbdbd !important;
}
.nitro-panel.disabled .nitro-fill{
  background:linear-gradient(90deg,#8a8a8a,#5a5a5a);
  box-shadow:none;
}
#mobileNitro.disabled{
  background:linear-gradient(135deg,#8a8a8a,#5a5a5a);
  color:#efefef;
  opacity:.78;
}
.small-note{
  opacity:.72;
  font-size:14px;
}
.distance-board{
  position: absolute;
}


/* V8.2 balance + purchase confirmation */
.buy-confirm-card{
  max-width: 620px;
}
.recommend-tag{
  display:inline-flex;
  margin-top:7px;
  padding:5px 9px;
  border-radius:999px;
  font-size:12px;
  font-weight:900;
  color:#050514;
  background:linear-gradient(135deg,#fff36b,#25e7ff);
}
.balance-note{
  color:#54ff74;
}


/* V8.3 test build polish */
.main-menu-actions{
  display:grid;
  gap:12px;
  justify-items:center;
}
.main-menu-actions .menu-row{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:12px;
}
.career-main-button{
  min-width:280px!important;
  font-size:22px!important;
  padding:18px 44px!important;
  background:linear-gradient(135deg,#fff36b,#25e7ff,#ff59f7);
  box-shadow:0 0 22px rgba(255,243,107,.42),0 0 36px rgba(0,247,255,.35);
}
.small-row button{
  min-width:130px;
  opacity:.92;
}
.menu-hint{
  margin:16px auto 0;
  max-width:760px;
  color:rgba(255,255,255,.78);
  font-weight:800;
  font-size:14px;
}
.notify-button.ready{
  position:relative;
  animation:notifyPulse 1.25s ease-in-out infinite;
}
.notify-button.ready::after{
  content:attr(data-badge);
  position:absolute;
  right:-8px;
  top:-8px;
  min-width:24px;
  height:24px;
  padding:0 6px;
  display:grid;
  place-items:center;
  border-radius:999px;
  color:#050514;
  background:#fff36b;
  box-shadow:0 0 14px rgba(255,243,107,.9);
  font-size:12px;
  font-weight:900;
}
@keyframes notifyPulse{
  0%,100%{filter:brightness(1); box-shadow:0 0 16px rgba(37,231,255,.45),0 0 26px rgba(255,89,247,.25)}
  50%{filter:brightness(1.18); box-shadow:0 0 24px rgba(255,243,107,.65),0 0 38px rgba(84,255,116,.35)}
}
.achievement-toast{
  position:fixed;
  top:86px;
  left:50%;
  transform:translateX(-50%);
  z-index:50;
  width:min(460px,92vw);
  padding:14px 18px;
  border-radius:18px;
  border:1px solid rgba(255,243,107,.42);
  background:rgba(8,12,28,.94);
  box-shadow:0 0 28px rgba(255,243,107,.28),0 0 40px rgba(0,247,255,.16);
  text-align:center;
  pointer-events:none;
}
.achievement-toast.hidden{display:none}
.achievement-toast strong{
  display:block;
  color:#fff36b;
  font-size:18px;
  margin-bottom:4px;
}
.achievement-toast span{
  color:#fff;
  font-weight:800;
}
.buy-confirm-card{
  max-width:620px;
}
.recommend-tag{
  display:inline-flex;
  margin-top:7px;
  padding:5px 9px;
  border-radius:999px;
  font-size:12px;
  font-weight:900;
  color:#050514;
  background:linear-gradient(135deg,#fff36b,#25e7ff);
}
.player-power-tag{
  display:inline-flex;
  margin-left:8px;
  margin-top:7px;
  padding:5px 9px;
  border-radius:999px;
  font-size:12px;
  font-weight:900;
  color:#050514;
  background:linear-gradient(135deg,#54ff74,#25e7ff);
}
.player-power-tag.under{
  background:linear-gradient(135deg,#ff315c,#ffb347);
}
.advice-box{
  margin:10px auto;
  padding:12px 14px;
  max-width:560px;
  border:1px solid rgba(0,247,255,.28);
  border-radius:16px;
  background:rgba(0,247,255,.07);
  color:rgba(255,255,255,.92);
  font-weight:800;
  line-height:1.45;
}
.nitro-panel.disabled{
  opacity:.58;
  border-color:rgba(255,255,255,.14);
  background:rgba(30,30,36,.45);
}
.nitro-panel.disabled span{
  color:#bdbdbd!important;
}
.nitro-panel.disabled .nitro-fill{
  background:linear-gradient(90deg,#8a8a8a,#5a5a5a);
  box-shadow:none;
}
#mobileNitro.disabled{
  background:linear-gradient(135deg,#8a8a8a,#5a5a5a);
  color:#efefef;
  opacity:.78;
}

/* League theme overlays */
body.theme-street #gameContainer canvas{filter:saturate(1.08) contrast(1.03)}
body.theme-industrial #gameContainer canvas{filter:saturate(1.02) contrast(1.08) sepia(.08)}
body.theme-harbor #gameContainer canvas{filter:saturate(1.18) hue-rotate(8deg) contrast(1.05)}
body.theme-skyline #gameContainer canvas{filter:saturate(1.15) brightness(1.04) contrast(1.06)}
body.theme-masters #gameContainer canvas{filter:saturate(1.25) contrast(1.12) brightness(1.04)}
@media(max-width:620px){
  .career-main-button{min-width:240px!important;font-size:18px!important}
}


/* V8.4 big fix test build */
.top-strip{
  grid-template-columns: 1.25fr .85fr repeat(5,minmax(70px,1fr));
  right: 190px;
}
.race-progress-hud{
  position:absolute;
  left:50%;
  top:48px;
  transform:translateX(-50%);
  width:min(520px,42vw);
  padding:8px 12px;
  border-radius:18px;
  border:1px solid rgba(0,247,255,.25);
  background:rgba(8,12,28,.36);
  backdrop-filter:blur(6px);
  pointer-events:none;
}
.progress-labels{
  display:flex;
  justify-content:space-between;
  font-size:11px;
  font-weight:900;
  color:rgba(255,255,255,.72);
  margin-bottom:6px;
}
.progress-track{
  position:relative;
  height:8px;
  border-radius:999px;
  background:rgba(255,255,255,.12);
  overflow:visible;
}
.progress-dot{
  position:absolute;
  top:50%;
  width:15px;
  height:15px;
  border-radius:50%;
  transform:translate(-50%,-50%);
  left:0%;
  box-shadow:0 0 16px currentColor;
}
.player-dot{background:#00f7ff;color:#00f7ff}
.rival-dot{background:#fff36b;color:#fff36b;top:calc(50% + 12px)}
.progress-finish{
  position:absolute;
  right:10px;
  bottom:-16px;
  font-size:10px;
  font-weight:900;
  color:#fff36b;
}
.shift-feedback{
  position:absolute;
  left:50%;
  top:56%;
  transform:translate(-50%,-50%);
  z-index:6;
  padding:12px 22px;
  border-radius:999px;
  font-size:clamp(20px,3vw,42px);
  font-weight:900;
  color:#fff36b;
  background:rgba(8,12,28,.58);
  border:1px solid rgba(255,243,107,.36);
  text-shadow:0 0 16px rgba(255,243,107,.9);
  box-shadow:0 0 28px rgba(255,243,107,.22);
  pointer-events:none;
  animation:shiftPop .8s ease-out forwards;
}
.shift-feedback.hidden{display:none}
@keyframes shiftPop{
  0%{opacity:0; transform:translate(-50%,-45%) scale(.82)}
  15%{opacity:1; transform:translate(-50%,-50%) scale(1.04)}
  100%{opacity:0; transform:translate(-50%,-66%) scale(.98)}
}
.pre-race-tip{
  position:absolute;
  left:50%;
  top:88px;
  transform:translateX(-50%);
  width:min(560px,72vw);
  z-index:6;
  padding:12px 18px;
  border-radius:20px;
  text-align:center;
  border:1px solid rgba(255,243,107,.35);
  background:rgba(8,12,28,.64);
  backdrop-filter:blur(6px);
  box-shadow:0 0 26px rgba(0,247,255,.16);
  pointer-events:none;
}
.pre-race-tip strong{
  display:block;
  color:#fff36b;
  font-size:17px;
  margin-bottom:3px;
}
.pre-race-tip span{
  color:rgba(255,255,255,.92);
  font-weight:800;
  line-height:1.35;
}
.pre-race-tip.hidden{display:none}
.achievement-modal-card{max-width:600px}
.notify-button.ready::after{
  z-index:3;
}
.campaign-race .tag{
  pointer-events:none;
}
.cta-upgrade-button{
  background:linear-gradient(135deg,#fff36b,#54ff74)!important;
  color:#050514!important;
}
.lock-note{
  margin-top:6px;
  font-size:13px;
  color:#ffcf6b;
  font-weight:900;
}
.garage-item.locked button{
  opacity:.65;
}
.environment-note{
  position:absolute;
  left:12px;
  bottom:130px;
  padding:8px 12px;
  border-radius:999px;
  color:#fff36b;
  border:1px solid rgba(255,243,107,.2);
  background:rgba(8,12,28,.36);
  pointer-events:none;
  font-weight:900;
  font-size:12px;
}
body.theme-street .pre-race-tip{border-color:rgba(0,247,255,.35)}
body.theme-industrial .pre-race-tip{border-color:rgba(255,122,50,.45)}
body.theme-harbor .pre-race-tip{border-color:rgba(0,180,255,.45)}
body.theme-skyline .pre-race-tip{border-color:rgba(255,255,255,.35)}
body.theme-masters .pre-race-tip{border-color:rgba(255,243,107,.6)}
@media(max-width:980px){
  .race-progress-hud{
    top:166px;
    width:min(420px,76vw);
  }
  .pre-race-tip{
    top:218px;
    width:86vw;
  }
}
@media(max-width:620px){
  .race-progress-hud{display:none}
  .pre-race-tip{
    top:150px;
    width:90vw;
    padding:10px 12px;
  }
  .top-strip{
    right:10px!important;
  }
  .menu-card h1{
    font-size:clamp(36px,12vw,64px);
  }
}


/* FINAL BUILD PATCHES */
.race-progress-hud{
  display:none!important;
}

.side-progress-rail{
  position:absolute;
  right:18px;
  top:118px;
  bottom:170px;
  width:70px;
  z-index:5;
  pointer-events:none;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:8px;
}
.rail-label{
  font-size:10px;
  font-weight:900;
  color:#fff36b;
  text-shadow:0 0 8px rgba(255,243,107,.8);
}
.rail-line{
  position:relative;
  flex:1;
  width:10px;
  border-radius:999px;
  background:linear-gradient(180deg,#fff36b,#00f7ff,#ff4ffd);
  box-shadow:0 0 18px rgba(0,247,255,.35);
  border:1px solid rgba(255,255,255,.22);
}
.side-dot{
  position:absolute;
  left:50%;
  transform:translate(-50%,50%);
  width:28px;
  height:28px;
  border-radius:50%;
  display:grid;
  place-items:center;
  font-size:9px;
  font-weight:900;
  color:#050514;
  border:2px solid rgba(255,255,255,.55);
}
.side-dot span{
  transform:scale(.85);
}
.side-player-dot{
  bottom:0%;
  background:#00f7ff;
  box-shadow:0 0 16px #00f7ff;
}
.side-rival-dot{
  bottom:0%;
  background:#fff36b;
  box-shadow:0 0 16px #fff36b;
}

.top-strip{
  right:220px!important;
  grid-template-columns:1.15fr .8fr .85fr .55fr 1fr .8fr .8fr!important;
}
.pre-race-tip{
  top:72px!important;
}
.shift-feedback{
  z-index:12;
}

.campaign-race .tag{
  border-radius:999px;
  min-width:86px;
  text-align:center;
  pointer-events:none!important;
}
.campaign-race .tag.upgrade-status{
  background:linear-gradient(135deg,#ffb347,#ff315c);
  color:#050514;
}
.race-card-actions{
  display:flex;
  justify-content:flex-end;
  align-items:center;
  flex-wrap:wrap;
  gap:10px;
}
.race-card-actions button{
  min-width:105px;
}
.cta-upgrade-button{
  background:linear-gradient(135deg,#fff36b,#54ff74)!important;
  color:#050514!important;
}
.race-anyway-button{
  background:linear-gradient(135deg,#6dd8ff,#d95cff)!important;
}

.garage-item .lock-note{
  margin:8px 0;
  padding:7px 10px;
  border-radius:12px;
  background:rgba(255,179,71,.12);
  border:1px solid rgba(255,179,71,.24);
  color:#ffcf6b;
  font-weight:900;
  font-size:13px;
}

.menu-hint{
  color:rgba(255,255,255,.86)!important;
}

body.theme-industrial #gameContainer canvas{
  filter:saturate(1.08) contrast(1.1) sepia(.12)!important;
}
body.theme-harbor #gameContainer canvas{
  filter:saturate(1.2) hue-rotate(12deg) contrast(1.06) brightness(.98)!important;
}
body.theme-skyline #gameContainer canvas{
  filter:saturate(1.18) brightness(1.08) contrast(1.08)!important;
}
body.theme-masters #gameContainer canvas{
  filter:saturate(1.32) brightness(1.06) contrast(1.14)!important;
}

.speed-focus{
  position:absolute;
  right:105px;
  bottom:34px;
  width:158px;
  padding:12px 14px;
  border-radius:20px;
  background:rgba(8,12,28,.48);
  border:1px solid rgba(0,247,255,.28);
  box-shadow:0 0 26px rgba(0,247,255,.18);
  pointer-events:none;
  text-align:center;
}
.speed-focus span{
  display:block;
  font-size:11px;
  letter-spacing:1px;
  text-transform:uppercase;
  color:rgba(255,255,255,.65);
  font-weight:900;
}
.speed-focus strong{
  display:block;
  font-size:38px;
  line-height:1;
  color:#00f7ff;
  text-shadow:0 0 12px rgba(0,247,255,.7);
}
.speed-focus small{
  color:#fff36b;
  font-weight:900;
}
@media(max-width:980px){
  .side-progress-rail{
    right:8px;
    top:220px;
    bottom:220px;
    transform:scale(.85);
    transform-origin:right center;
  }
  .speed-focus{
    display:none;
  }
}
@media(max-width:620px){
  .side-progress-rail{
    display:none;
  }
  .top-strip{
    right:10px!important;
  }
}


/* FINAL POLISHED BUILD */
.race-tracker-hud,.race-progress-hud,.side-progress-rail,.speed-focus{display:none!important;}
.countdown-overlay{display:block!important;inset:auto!important;left:18px!important;top:86px!important;width:128px!important;height:auto!important;z-index:14!important;pointer-events:none!important;}
.drag-tree{position:relative!important;top:auto!important;left:auto!important;display:grid!important;gap:10px!important;padding:14px!important;border-radius:999px!important;background:rgba(7,9,22,.76)!important;border:1px solid rgba(255,243,107,.32)!important;box-shadow:0 0 24px rgba(255,243,107,.18),0 0 30px rgba(0,247,255,.16)!important;transform:none!important;width:max-content!important;}
.tree-light{width:30px!important;height:30px!important;border-radius:50%!important;background:#10131c!important;box-shadow:inset 0 0 9px rgba(0,0,0,.9)!important;}
.tree-light.active{background:#fff36b!important;box-shadow:0 0 18px #fff36b,0 0 34px rgba(255,243,107,.75)!important;}
.tree-light.go-light.active{background:#54ff74!important;box-shadow:0 0 18px #54ff74,0 0 34px rgba(84,255,116,.75)!important;}
#countdownText{position:fixed!important;left:50%!important;top:50%!important;transform:translate(-50%,-50%)!important;font-size:clamp(54px,9vw,118px)!important;font-weight:900!important;color:#fff36b!important;text-shadow:0 0 18px #fff36b,0 0 44px rgba(255,49,92,.75)!important;}
.top-strip{right:18px!important;grid-template-columns:1.05fr .75fr .75fr .5fr .95fr .65fr .75fr!important;gap:8px!important;}
.top-strip div{min-height:38px!important;padding:6px 10px!important;background:rgba(8,12,28,.58)!important;backdrop-filter:blur(6px)!important;}
.pre-race-tip{top:86px!important;left:50%!important;max-width:520px!important;opacity:.92!important;}
.top-back-button{position:sticky;top:12px;z-index:20;width:max-content;min-width:120px;margin:0 0 12px 0;padding:12px 22px;border-radius:999px;border:1px solid rgba(0,247,255,.38);background:linear-gradient(135deg,#36d8ff,#d95cff);color:#050514;font-weight:900;box-shadow:0 0 22px rgba(0,247,255,.22);}
.garage-card.wide-card,.panel-card{max-height:calc(100vh - 56px);overflow:auto;padding-bottom:42px!important;scrollbar-color:#00f7ff rgba(255,255,255,.08);}
.car-preview-wrap{min-height:110px!important}.garage-item p{min-height:38px}.garage-item .stat{margin:4px 0!important;}
.campaign-race .tag{pointer-events:none!important;cursor:default!important}.campaign-race .tag.upgrade-status{background:linear-gradient(135deg,#ffb347,#ff315c)!important;color:#050514!important}.race-card-actions{display:flex;justify-content:flex-end;align-items:center;gap:10px;flex-wrap:wrap}.cta-upgrade-button{background:linear-gradient(135deg,#fff36b,#54ff74)!important;color:#050514!important}.race-anyway-button{background:linear-gradient(135deg,#6dd8ff,#d95cff)!important;}
@media(max-width:920px){.top-strip{grid-template-columns:repeat(3,1fr)!important;left:8px!important;right:8px!important}.countdown-overlay{top:180px!important;left:12px!important;transform:scale(.8);transform-origin:left top}.pre-race-tip{top:170px!important;width:78vw!important}.garage-card.wide-card,.panel-card{max-height:calc(100vh - 24px);width:96vw!important}}
@media(max-width:620px){.countdown-overlay{display:none!important}.top-strip div{padding:5px 7px!important}.top-back-button{top:6px}}


/* GO + ENGINE PATCH */
.countdown-overlay.force-hidden,
#countdownOverlay.force-hidden,
#countdownText.force-hidden{display:none!important;opacity:0!important;visibility:hidden!important;}
.countdown-overlay{left:22px!important;top:96px!important;width:150px!important;z-index:18!important;transform:scale(1.12)!important;transform-origin:top left!important;}
.drag-tree{transform:scale(1.18)!important;transform-origin:top left!important;}
#countdownText{z-index:17!important;}
@media(max-width:800px){.countdown-overlay{top:145px!important;left:12px!important;transform:scale(.82)!important;}}


/* FINAL UPLOAD PATCH: keep start tree upper-left, keep READY/3/2/1/GO centered */
.countdown-overlay{
  position:fixed!important;
  left:22px!important;
  top:96px!important;
  width:150px!important;
  height:auto!important;
  inset:auto!important;
  z-index:18!important;
  pointer-events:none!important;
  display:grid!important;
  place-items:start!important;
  transform:none!important;
}
.countdown-overlay.hidden,
.countdown-overlay.force-hidden,
#countdownOverlay.force-hidden{
  display:none!important;
  opacity:0!important;
  visibility:hidden!important;
}
.drag-tree{
  position:relative!important;
  transform:scale(1.18)!important;
  transform-origin:top left!important;
}
#countdownText{
  position:fixed!important;
  left:50vw!important;
  top:50vh!important;
  transform:translate(-50%,-50%)!important;
  z-index:19!important;
  width:auto!important;
  height:auto!important;
  display:block!important;
  text-align:center!important;
  font-size:clamp(58px,10vw,128px)!important;
  line-height:1!important;
  font-weight:900!important;
  color:#fff36b!important;
  text-shadow:0 0 18px #fff36b,0 0 44px rgba(255,49,92,.75)!important;
  pointer-events:none!important;
}
#countdownText.force-hidden{
  display:none!important;
  opacity:0!important;
  visibility:hidden!important;
}
@media(max-width:800px){
  .countdown-overlay{top:145px!important;left:12px!important;width:120px!important;}
  .drag-tree{transform:scale(.86)!important;}
  #countdownText{font-size:clamp(48px,18vw,92px)!important;}
}
