/* ============================================================
   SuperCars Syria — "Project Drift" design system
   OLED black · glass · spring motion · RTL · red/black/white
   ============================================================ */
:root {
  --red: #e11d2e; --red-dark: #b81424;
  --red-soft: rgba(225,29,46,.12); --red-glow: rgba(225,29,46,.35);
  --spring: cubic-bezier(.34,1.56,.64,1);
  --ease: cubic-bezier(.22,.9,.3,1);
  --r-sm: 12px; --r-md: 16px; --r-lg: 22px; --r-xl: 30px;
  --tap: 50px;
  --font: "IBM Plex Sans Arabic", -apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", sans-serif;
}
[data-theme="dark"] {
  --bg: #000000; --bg2: #101014; --bg3: #1a1a20; --bg4: #24242c;
  --line: rgba(255,255,255,.08); --hairline: rgba(255,255,255,.06);
  --text: #f5f5f7; --text2: #8e8e99;
  --glass: rgba(16,16,20,.72); --card-shadow: 0 8px 32px rgba(0,0,0,.55);
  --input-bg: #16161c;
}
[data-theme="light"] {
  --bg: #f2f2f7; --bg2: #ffffff; --bg3: #ececf1; --bg4: #e2e2e8;
  --line: rgba(0,0,0,.08); --hairline: rgba(0,0,0,.06);
  --text: #0a0a0c; --text2: #6e6e78;
  --glass: rgba(255,255,255,.72); --card-shadow: 0 8px 26px rgba(0,0,0,.08);
  --input-bg: #ececf1;
}
* { margin:0; padding:0; box-sizing:border-box; -webkit-tap-highlight-color:transparent; }
html, body { height:100%; }
body {
  font-family: var(--font); background: var(--bg); color: var(--text);
  font-size: 15px; line-height: 1.5; overscroll-behavior: none;
  transition: background .4s var(--ease), color .4s var(--ease);
}
button { font-family:inherit; cursor:pointer; border:none; }
input, select, textarea {
  font-family:inherit; font-size:16px; width:100%;
  background:var(--input-bg); color:var(--text);
  border:1.5px solid transparent; border-radius:var(--r-md);
  padding:13px 15px; outline:none; min-height:var(--tap); appearance:none;
  transition: border-color .2s, box-shadow .2s, background .4s;
}
input:focus, select:focus, textarea:focus { border-color:var(--red); box-shadow:0 0 0 4px var(--red-soft); }
label { display:block; font-size:12px; font-weight:600; color:var(--text2); margin:13px 0 5px; letter-spacing:.2px; }
@media (prefers-reduced-motion: reduce) { *, *::before, *::after { animation-duration:.01ms !important; transition-duration:.01ms !important; } }

/* ================= LOGIN — cinematic ================= */
#loginScreen { position:fixed; inset:0; display:flex; align-items:center; justify-content:center;
  background:#000; z-index:100; padding:24px; overflow:hidden; }
.aurora {
  position:absolute; width:130vmax; height:130vmax; border-radius:50%;
  background: radial-gradient(closest-side, rgba(225,29,46,.28), transparent 65%);
  top:-70vmax; left:-30vmax; animation: aur 14s ease-in-out infinite alternate; pointer-events:none;
}
.aurora.a2 { top:auto; bottom:-90vmax; left:auto; right:-40vmax;
  background: radial-gradient(closest-side, rgba(225,29,46,.14), transparent 60%);
  animation-duration: 19s; animation-delay:-6s; }
@keyframes aur { from { transform:translate(0,0) scale(1); } to { transform:translate(8vmax,6vmax) scale(1.15); } }
.login-card { width:100%; max-width:380px; position:relative;
  background:rgba(16,16,20,.66); backdrop-filter:blur(28px); -webkit-backdrop-filter:blur(28px);
  border-radius:var(--r-xl); padding:36px 28px; border:1px solid rgba(255,255,255,.09);
  box-shadow:0 30px 80px rgba(0,0,0,.6); animation: cardIn .7s var(--spring) both .15s; color:#f5f5f7; }
.login-card input { background:rgba(255,255,255,.07); color:#fff; }
.login-card label { color:#8e8e99; }
@keyframes cardIn { from { transform:translateY(46px) scale(.95); opacity:0; } }
.login-logo { text-align:center; margin-bottom:26px; }
.logo-img { width:92px; height:92px; border-radius:26px; object-fit:cover; margin:0 auto 14px;
  display:block; box-shadow:0 14px 40px rgba(225,29,46,.35); animation: logoDrop .8s var(--spring) both; }
@keyframes logoDrop { from { transform:translateY(-70px) scale(.6); opacity:0; } }
.login-logo .mark { font-size:34px; font-weight:700; letter-spacing:-1px; }
.login-logo .mark span { color:var(--red); }
.login-logo .sub { color:#8e8e99; font-size:12px; letter-spacing:3px; text-transform:uppercase; margin-top:2px; }

/* ================= SHELL ================= */
#appShell { display:none; min-height:100dvh; }
#topbar {
  position:sticky; top:0; z-index:40; display:flex; align-items:center; gap:10px;
  padding:12px 16px; padding-top:max(12px, env(safe-area-inset-top));
  background:var(--glass); backdrop-filter:blur(22px) saturate(1.6); -webkit-backdrop-filter:blur(22px) saturate(1.6);
  border-bottom:.5px solid var(--hairline);
}
#topbar .brand { font-weight:700; font-size:17px; letter-spacing:-.3px; }
#topbar .brand span { color:var(--red); }
#topbar .spacer { flex:1; }
.icon-btn { width:40px; height:40px; border-radius:50%; background:var(--bg3); color:var(--text);
  display:inline-flex; align-items:center; justify-content:center; font-size:17px; position:relative; flex:none;
  transition:transform .25s var(--spring), background .4s; }
.icon-btn:active { transform:scale(.86); }
.icon-btn .dot { position:absolute; top:4px; inset-inline-end:4px; width:9px; height:9px;
  background:var(--red); border-radius:50%; border:2px solid var(--bg); animation:pulse 1.4s infinite; }

#pageMain { padding:18px 16px calc(118px + env(safe-area-inset-bottom)); max-width:1080px; margin:0 auto; }
#pageMain.slide-in { animation: pageIn .42s var(--ease) both; }
@keyframes pageIn { from { transform:translateX(calc(var(--dir,1) * -26px)); opacity:0; } }
[dir="ltr"] #pageMain.slide-in { --dir:-1; }
@media (min-width:900px) { #pageMain { padding:26px 32px 60px; } }

.page-title { font-size:31px; font-weight:700; letter-spacing:-1px; margin-bottom:4px; }
.page-sub { color:var(--text2); font-size:13.5px; margin-bottom:18px; }

/* ================= FLOATING GLASS DOCK ================= */
#tabbar { position:fixed; bottom:calc(14px + env(safe-area-inset-bottom)); inset-inline:0; z-index:40;
  display:flex; justify-content:center; pointer-events:none; }
#dock { pointer-events:auto; display:flex; gap:2px; padding:7px;
  background:var(--glass); backdrop-filter:blur(24px) saturate(1.7); -webkit-backdrop-filter:blur(24px) saturate(1.7);
  border:.5px solid var(--hairline); border-radius:32px; box-shadow:0 14px 44px rgba(0,0,0,.4); }
.tab { position:relative; background:none; color:var(--text2); display:flex; flex-direction:column; align-items:center;
  gap:2px; font-size:10px; font-weight:600; padding:7px 15px 6px; border-radius:24px;
  transition:color .25s, transform .3s var(--spring); }
.tab .ti { font-size:22px; line-height:1.15; transition:transform .35s var(--spring); }
.tab.active { color:#fff; background:var(--red); box-shadow:0 6px 20px var(--red-glow); }
.tab.active .ti { transform:translateY(-2px) scale(1.12); }
.tab:active { transform:scale(.9); }
@media (min-width:900px) {
  #tabbar { top:50%; bottom:auto; inset-inline-start:14px; inset-inline-end:auto; transform:translateY(-50%); }
  #dock { flex-direction:column; border-radius:28px; }
  #pageMain { margin-inline-start:110px; }
}

/* ================= CARDS / STATS ================= */
.card { background:var(--bg2); border:.5px solid var(--hairline); border-radius:var(--r-lg);
  padding:16px; box-shadow:var(--card-shadow); margin-bottom:14px; transition:background .4s; }
.card h3 { font-size:13px; margin-bottom:10px; color:var(--text2); font-weight:600; letter-spacing:.3px; }
.stat-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:10px; margin-bottom:14px; }
@media (min-width:700px){ .stat-grid { grid-template-columns:repeat(4,1fr);} }
.stat { position:relative; overflow:hidden; background:var(--bg2); border:.5px solid var(--hairline);
  border-radius:var(--r-lg); padding:15px; box-shadow:var(--card-shadow); }
.stat::before { content:""; position:absolute; inset-inline-start:0; top:14px; bottom:14px; width:3.5px;
  border-radius:3px; background:var(--accent, var(--bg4)); }
.stat .v { font-size:23px; font-weight:700; letter-spacing:-.6px; font-variant-numeric:tabular-nums; }
.stat .l { font-size:11px; color:var(--text2); font-weight:600; margin-top:1px; }
.stat.red { --accent: var(--red); } .stat.red .v { color:var(--red); }
.stat.green { --accent:#27b87a; } .stat.purple { --accent:#9b59b6; } .stat.blue { --accent:#4a90d9; }

/* hero greeting */
.hero { margin-bottom:18px; }
.hero .hi { font-size:26px; font-weight:700; letter-spacing:-.8px; }
.hero .date { color:var(--text2); font-size:13px; }

/* wallet credit card */
.wallet-card { position:relative; overflow:hidden; border-radius:26px; padding:24px 22px; color:#fff;
  background:linear-gradient(135deg,#17171c 0%, #26262e 55%, #3a0e14 100%); border:.5px solid rgba(255,255,255,.1);
  box-shadow:0 20px 50px rgba(0,0,0,.5); margin-bottom:16px; }
.wallet-card::after { content:""; position:absolute; width:340px; height:340px; border-radius:50%;
  background:radial-gradient(closest-side, rgba(225,29,46,.4), transparent 70%); top:-160px; inset-inline-end:-120px; }
.wallet-card .chip { width:38px; height:28px; border-radius:7px;
  background:linear-gradient(135deg,#e8c56a,#b98f3e); margin-bottom:16px; }
.wallet-card .amt { font-size:30px; font-weight:700; letter-spacing:-1px; font-variant-numeric:tabular-nums; }
.wallet-card .ccy { font-size:12px; color:rgba(255,255,255,.55); letter-spacing:2px; }

/* ================= BUTTONS ================= */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:8px;
  min-height:var(--tap); padding:0 20px; border-radius:var(--r-md);
  font-size:15px; font-weight:700; transition:transform .3s var(--spring), opacity .2s, box-shadow .3s; }
.btn:active { transform:scale(.955); }
.btn-primary { background:var(--red); color:#fff; box-shadow:0 8px 22px var(--red-glow); }
.btn-primary:hover { background:var(--red-dark); }
.btn-primary.glow { animation:glowPulse 2.4s ease-in-out infinite; }
@keyframes glowPulse { 0%,100% { box-shadow:0 8px 22px var(--red-glow);} 50% { box-shadow:0 8px 34px rgba(225,29,46,.55);} }
.btn-ghost { background:var(--bg3); color:var(--text); }
.btn-danger { background:transparent; color:var(--red); border:1.5px solid var(--red); }
.btn-sm { min-height:38px; padding:0 14px; font-size:13px; border-radius:12px; }
.btn-block { width:100%; }
.fab { position:fixed; bottom:calc(96px + env(safe-area-inset-bottom)); inset-inline-end:18px; z-index:39;
  width:60px; height:60px; border-radius:50%; background:var(--red); color:#fff; font-size:28px;
  box-shadow:0 12px 32px var(--red-glow); display:flex; align-items:center; justify-content:center;
  transition:transform .35s var(--spring); animation:fabIn .5s var(--spring) both .2s; }
.fab:active { transform:scale(.86) rotate(90deg); }
@keyframes fabIn { from { transform:scale(0) rotate(-90deg);} }
@media (min-width:900px){ .fab { bottom:28px; } }

/* slide-to-confirm */
.slide-confirm { position:relative; height:56px; border-radius:28px; background:var(--bg3);
  overflow:hidden; margin-top:12px; user-select:none; }
.slide-confirm .sc-text { position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  font-weight:700; font-size:14px; color:var(--text2); animation:pulse 1.6s infinite; }
.slide-confirm .sc-knob { position:absolute; top:4px; inset-inline-start:4px; width:48px; height:48px;
  border-radius:50%; background:var(--red); color:#fff; display:flex; align-items:center; justify-content:center;
  font-size:20px; box-shadow:0 6px 16px var(--red-glow); touch-action:none; z-index:2; }
.slide-confirm.done { background:rgba(39,184,122,.16); }
.slide-confirm.done .sc-text { color:#27b87a; animation:none; }

/* ================= LISTS / ROWS ================= */
.row { display:flex; align-items:center; gap:12px; padding:14px;
  background:var(--bg2); border:.5px solid var(--hairline); border-radius:var(--r-lg);
  margin-bottom:10px; cursor:pointer; box-shadow:var(--card-shadow);
  transition:transform .3s var(--spring), background .4s; }
.row:active { transform:scale(.985); }
.row .grow { flex:1; min-width:0; }
.row .t { font-weight:700; font-size:14.5px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.row .s { font-size:12.5px; color:var(--text2); }
.row .end { text-align:end; flex:none; }
.avatar { width:44px; height:44px; border-radius:15px; background:var(--red-soft); color:var(--red);
  display:flex; align-items:center; justify-content:center; font-size:19px; font-weight:700; flex:none; }
.avatar.init { background:linear-gradient(135deg,var(--bg3),var(--bg4)); color:var(--text); font-size:15px; }

/* staggered entrance */
.anim-list > * { animation:rise .5s var(--ease) both; }
.anim-list > *:nth-child(1){animation-delay:.02s} .anim-list > *:nth-child(2){animation-delay:.06s}
.anim-list > *:nth-child(3){animation-delay:.1s}  .anim-list > *:nth-child(4){animation-delay:.14s}
.anim-list > *:nth-child(5){animation-delay:.18s} .anim-list > *:nth-child(6){animation-delay:.22s}
.anim-list > *:nth-child(7){animation-delay:.26s} .anim-list > *:nth-child(8){animation-delay:.3s}
.anim-list > *:nth-child(9){animation-delay:.34s} .anim-list > *:nth-child(n+10){animation-delay:.38s}
@keyframes rise { from { transform:translateY(16px); opacity:0; } }

/* swipe actions (orders) */
.swipe { display:flex; overflow-x:auto; scroll-snap-type:x mandatory; scrollbar-width:none;
  margin-bottom:10px; border-radius:var(--r-lg); }
.swipe::-webkit-scrollbar { display:none; }
.swipe > .row { flex:0 0 100%; scroll-snap-align:start; margin-bottom:0; }
.swipe > .swipe-acts { flex:0 0 auto; display:flex; gap:8px; padding-inline:8px; align-items:center; scroll-snap-align:end; }
.swipe-acts a { width:52px; height:52px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-size:22px; text-decoration:none; background:var(--bg3); }

/* pipeline dots on order cards */
.pipe { display:flex; gap:5px; margin-top:6px; }
.pipe i { width:16px; height:5px; border-radius:3px; background:var(--bg4); transition:background .3s; }
.pipe i.on { background:var(--red); box-shadow:0 0 8px var(--red-glow); }
.pipe i.done { background:#27b87a; }

/* order wizard step indicator */
.wiz { display:flex; gap:8px; justify-content:center; margin:2px 0 16px; }
.wiz i { width:38px; height:6px; border-radius:3px; background:var(--bg4); transition:background .3s; }
.wiz i.on { background:var(--red); box-shadow:0 0 8px var(--red-glow); }
.wiz i.done { background:#27b87a; }
.fld-label { display:flex; align-items:center; font-weight:600; font-size:13px; color:var(--text);
  padding:0 12px; min-height:var(--tap); background:var(--bg3); border-radius:var(--r-md); }
textarea { resize:vertical; line-height:1.5; }

/* timeline (order detail) */
.timeline { margin:6px 0 4px; }
.tl-step { display:flex; gap:13px; position:relative; padding-bottom:20px; }
.tl-step::before { content:""; position:absolute; inset-inline-start:11px; top:26px; bottom:0; width:2px; background:var(--bg4); }
.tl-step:last-child::before { display:none; }
.tl-dot { width:24px; height:24px; border-radius:50%; flex:none; display:flex; align-items:center; justify-content:center;
  font-size:11px; background:var(--bg4); color:var(--text2); z-index:1; transition:all .3s; }
.tl-step.done .tl-dot { background:#27b87a; color:#fff; }
.tl-step.now .tl-dot { background:var(--red); color:#fff; box-shadow:0 0 0 5px var(--red-soft); animation:pulse 1.6s infinite; }
.tl-step .tl-t { font-weight:700; font-size:13.5px; }
.tl-step .tl-s { font-size:11.5px; color:var(--text2); }
.tl-step.now .tl-t { color:var(--red); }

/* ================= BADGES / SEG ================= */
.badge { display:inline-block; padding:3px 10px; border-radius:999px; font-size:11px; font-weight:700; }
.b-red{background:var(--red-soft);color:var(--red)} .b-gray{background:var(--bg3);color:var(--text2)}
.b-green{background:rgba(39,184,122,.14);color:#27b87a} .b-blue{background:rgba(74,144,217,.14);color:#4a90d9}
.b-yellow{background:rgba(245,185,66,.14);color:#d99b16} .b-purple{background:rgba(155,89,182,.14);color:#9b59b6}
.ribbon { position:absolute; top:10px; inset-inline-end:-26px; transform:rotate(35deg); background:var(--red);
  color:#fff; font-size:9px; font-weight:700; padding:2px 28px; letter-spacing:1px; }
[dir="ltr"] .ribbon { transform:rotate(-35deg); }

.seg { display:flex; background:var(--bg3); border-radius:16px; padding:4px; gap:4px;
  overflow-x:auto; margin-bottom:16px; scrollbar-width:none; }
.seg::-webkit-scrollbar{display:none}
.seg button { flex:1; white-space:nowrap; background:none; color:var(--text2); font-weight:700;
  font-size:13px; padding:9px 15px; border-radius:12px; transition:all .3s var(--spring); }
.seg button.active { background:var(--bg2); color:var(--text); box-shadow:0 3px 10px rgba(0,0,0,.2); transform:scale(1.02); }

/* ================= SHEET (draggable) ================= */
#sheetWrap { position:fixed; inset:0; z-index:60; display:none; }
#sheetWrap.open { display:block; }
#sheetWrap .backdrop { position:absolute; inset:0; background:rgba(0,0,0,.55);
  backdrop-filter:blur(4px); -webkit-backdrop-filter:blur(4px); animation:fade .25s both; }
@keyframes fade { from { opacity:0; } }
#sheet { position:absolute; bottom:0; inset-inline:0; max-height:92dvh; overflow-y:auto;
  background:var(--bg2); border-radius:var(--r-xl) var(--r-xl) 0 0;
  padding:8px 20px calc(26px + env(safe-area-inset-bottom));
  border-top:.5px solid var(--hairline); box-shadow:0 -20px 60px rgba(0,0,0,.5);
  animation:up .42s var(--spring); touch-action:pan-y; will-change:transform; }
@keyframes up { from { transform:translateY(80px); opacity:0; } }
@media (min-width:900px) {
  #sheet { inset-inline:auto; left:50%; transform:translateX(-50%); width:560px;
    bottom:auto; top:7dvh; border-radius:var(--r-xl); max-height:86dvh; animation:pop .3s var(--spring); }
  @keyframes pop { from { transform:translateX(-50%) scale(.94); opacity:0; } }
}
.sheet-handle { width:42px; height:5px; border-radius:3px; background:var(--bg4); margin:8px auto 14px; cursor:grab; }
.sheet-title { font-size:21px; font-weight:700; letter-spacing:-.5px; margin-bottom:6px; }

/* ================= DYNAMIC ISLAND TOAST ================= */
#island { position:fixed; top:calc(12px + env(safe-area-inset-top)); left:50%; z-index:80;
  display:flex; align-items:center; gap:9px; max-width:88vw;
  background:#000; color:#fff; border:1px solid rgba(255,255,255,.14);
  font-weight:600; font-size:13.5px; padding:11px 20px; border-radius:999px;
  box-shadow:0 14px 40px rgba(0,0,0,.55);
  transform:translateX(-50%) translateY(-90px) scale(.6);
  transition:transform .5s var(--spring); }
#island.show { transform:translateX(-50%) translateY(0) scale(1); }
#island.err { background:var(--red); border-color:rgba(255,255,255,.25); }
#islandIcon { font-size:16px; }

/* ================= CONFETTI ================= */
.cf { position:fixed; top:-14px; z-index:99; width:9px; height:15px; border-radius:2px;
  pointer-events:none; animation:cfall linear both; }
@keyframes cfall { to { transform:translateY(110vh) rotate(720deg); opacity:.9; } }

/* check animation */
.checkpop { animation:checkpop .5s var(--spring); }
@keyframes checkpop { 30% { transform:scale(1.25); } }

/* pull-to-refresh hint */
#pullHint { position:fixed; top:calc(64px + env(safe-area-inset-top)); left:50%;
  transform:translateX(-50%) scale(0); font-size:26px; z-index:35; transition:transform .3s var(--spring); }
#pullHint.show { transform:translateX(-50%) scale(1); animation:spin 1s linear infinite; }
@keyframes spin { to { transform:translateX(-50%) scale(1) rotate(360deg); } }

/* ================= UTILITIES ================= */
.grid2 { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.mt{margin-top:14px} .mb{margin-bottom:14px}
.muted { color:var(--text2); font-size:12.5px; }
.right { text-align:end; }
.empty { text-align:center; color:var(--text2); padding:52px 16px; }
.empty .big { font-size:52px; margin-bottom:10px; display:inline-block; animation:float 3s ease-in-out infinite; }
@keyframes float { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-9px)} }
@keyframes pulse { 0%,100%{opacity:.45} 50%{opacity:1} }
.money { font-variant-numeric:tabular-nums; font-weight:700; }
.money-in { font-size:22px !important; font-weight:700; text-align:center; letter-spacing:.5px; }
.pos{color:#27b87a} .neg{color:var(--red)}
.hide{display:none !important}
canvas{max-width:100%}
.skel { background:linear-gradient(90deg,var(--bg3),var(--bg2),var(--bg3)); background-size:200%;
  animation:sk 1.2s infinite; border-radius:var(--r-lg); height:70px; margin-bottom:10px; }
@keyframes sk { from{background-position:200% 0} to{background-position:-200% 0} }
.squircle { width:32px; height:32px; border-radius:9px; display:inline-flex; align-items:center;
  justify-content:center; font-size:16px; color:#fff; flex:none; }

/* ================= DESKTOP / PC — command center ================= */
@media (hover:hover) {
  .row:hover { transform:translateY(-2px); box-shadow:0 14px 34px rgba(0,0,0,.3); }
  .card:hover { box-shadow:0 14px 38px rgba(0,0,0,.28); }
  .stat:hover { transform:translateY(-3px); box-shadow:0 16px 36px rgba(0,0,0,.3); }
  .stat, .row, .card { transition:transform .25s var(--ease), box-shadow .25s var(--ease), background .4s; }
  .btn-ghost:hover { background:var(--bg4); }
  .tab:hover { color:var(--text); }
  .icon-btn:hover { background:var(--bg4); }
}
@media (min-width:900px) {
  body { font-size:15.5px; }
  .page-title { font-size:38px; }
  .stat .v { font-size:27px; }
  /* two-column zones driven by page markup */
  .cols { display:grid; grid-template-columns:1.6fr 1fr; gap:16px; align-items:start; }
  .cards-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:12px; }
  .cards-grid .row, .cards-grid .swipe { margin-bottom:0; }
}
@media (min-width:1400px) {
  #pageMain { max-width:1280px; }
  .stat-grid { grid-template-columns:repeat(4,1fr); gap:14px; }
  .cards-grid { grid-template-columns:repeat(3,1fr); }
}
@media (max-width:899px) {
  .cols { display:block; }
  .cards-grid { display:block; }
}

/* ================= DRIFT LOADER ================= */
#loader { position:fixed; inset:0; z-index:95; display:flex; flex-direction:column;
  align-items:center; justify-content:center; gap:18px;
  background:color-mix(in srgb, var(--bg) 78%, transparent);
  backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px); }
.drift { position:relative; width:120px; height:120px; }
.track { position:absolute; inset:10px; border-radius:50%; border:2.5px dashed var(--line); }
.skid { position:absolute; inset:10px; border-radius:50%; border:3px solid transparent;
  border-top-color:var(--red); border-right-color:rgba(225,29,46,.35);
  animation:orbit .9s linear infinite; filter:drop-shadow(0 0 6px var(--red-glow)); }
.orbit { position:absolute; inset:0; animation:orbit .9s linear infinite; }
.car { position:absolute; top:-6px; left:50%; font-size:30px; line-height:1;
  transform:translateX(-50%) scaleX(-1) rotate(18deg);
  animation:wobble .45s ease-in-out infinite alternate;
  filter:drop-shadow(0 4px 6px rgba(0,0,0,.45)); }
@keyframes orbit { to { transform:rotate(360deg); } }
@keyframes wobble { from { transform:translateX(-50%) scaleX(-1) rotate(12deg);} to { transform:translateX(-50%) scaleX(-1) rotate(26deg);} }
.load-text { font-weight:700; font-size:12px; letter-spacing:4px; text-transform:uppercase;
  color:var(--text2); animation:pulse 1.2s ease-in-out infinite; }
