/* ============================================================
   ORACLE UI — Design System Component Library
   World Cup 2026 · Apple Vision Pro × Premium Sports × Soft HUD
   Namespaced (oui-*) so it drops into any project without clashes.
   Pair with oracle-ui.js. Single source of truth for all screens.
   ============================================================ */
:root{
  --oui-bg-void:#04060C; --oui-bg-0:#070A12; --oui-bg-1:#0A0F1B; --oui-bg-2:#0E1422;
  --oui-navy-deep:#0B1428; --oui-navy:#13203A;
  --oui-ink:#F3F6FF; --oui-ink-soft:#BAC4DE; --oui-ink-dim:#7E8CAD; --oui-ink-faint:#52607E;
  --oui-orange:#FF8A2B; --oui-orange-hi:#FFA659; --oui-gold:#F4C871; --oui-gold-soft:#FFE6B8;
  --oui-blue:#4E86FF; --oui-blue-hi:#84B0FF; --oui-green:#5FE3A0; --oui-red:#FF6B6B;
  --oui-glass:rgba(255,255,255,.04); --oui-glass-2:rgba(255,255,255,.06); --oui-glass-3:rgba(255,255,255,.09);
  --oui-hair:rgba(255,255,255,.08);
  --oui-glow-s:0 0 28px rgba(255,142,55,.16);
  --oui-glow-m:0 0 80px rgba(255,132,48,.15), 0 0 30px rgba(255,176,96,.10);
  --oui-shadow:0 34px 80px -30px rgba(0,0,0,.72), 0 10px 30px -16px rgba(0,0,0,.46);
  --oui-edge:inset 0 1px 0 rgba(255,255,255,.09);
  --oui-ease:cubic-bezier(.22,.61,.36,1);
  --oui-r-sm:14px; --oui-r-md:18px; --oui-r-lg:24px; --oui-r-xl:32px; --oui-r-pill:999px;
  --oui-font-disp:"Space Grotesk","Noto Sans SC",sans-serif;
  --oui-font-body:"Inter","Noto Sans SC",system-ui,sans-serif;
  --oui-font-mono:"JetBrains Mono","Noto Sans SC",monospace;
}
.oui-scope,.oui-scope *{box-sizing:border-box}
.oui-scope{font-family:var(--oui-font-body);color:var(--oui-ink);line-height:1.55}
.oui-mono{font-family:var(--oui-font-mono)}
.oui-disp{font-family:var(--oui-font-disp)}

/* ---------- 01 GlassCard ---------- */
.oui-card{position:relative;border-radius:var(--oui-r-lg);
  background:linear-gradient(165deg,rgba(24,33,58,.55),rgba(9,13,24,.40));
  backdrop-filter:blur(30px) saturate(150%);-webkit-backdrop-filter:blur(30px) saturate(150%);
  box-shadow:var(--oui-shadow),var(--oui-edge)}
.oui-card--hair::before,.oui-card--warm::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;
  background:linear-gradient(145deg,rgba(255,255,255,.17),rgba(255,255,255,.02) 52%,rgba(130,165,255,.11));
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}
.oui-card--warm::before{background:linear-gradient(145deg,rgba(255,255,255,.22),rgba(255,255,255,.03) 50%,rgba(255,150,70,.24))}
.oui-card--glow{box-shadow:var(--oui-shadow),var(--oui-edge),var(--oui-glow-m)}
.oui-card>*{position:relative;z-index:1}

/* ---------- 03 PremiumButton ---------- */
.oui-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--oui-font-disp);
  font-weight:600;font-size:14.5px;border-radius:var(--oui-r-pill);border:0;cursor:pointer;padding:13px 22px;
  transition:transform .35s var(--oui-ease),box-shadow .35s var(--oui-ease),filter .35s var(--oui-ease);position:relative}
.oui-btn svg{width:16px;height:16px}
.oui-btn:active{transform:scale(.97)}
.oui-btn--block{width:100%}
.oui-btn--sm{padding:11px 18px;font-size:13px}
.oui-btn--primary{color:#160A02;background:linear-gradient(135deg,var(--oui-gold-soft),var(--oui-orange-hi) 45%,var(--oui-orange));
  box-shadow:var(--oui-glow-m),inset 0 1px 0 rgba(255,255,255,.5)}
.oui-btn--primary:hover{transform:translateY(-2px);filter:saturate(1.05)}
.oui-btn--ghost{color:var(--oui-ink);background:var(--oui-glass-2);box-shadow:var(--oui-edge),inset 0 0 0 1px rgba(255,255,255,.06)}
.oui-btn--ghost:hover{transform:translateY(-2px);background:var(--oui-glass-3)}
.oui-btn--muted{color:var(--oui-ink-dim);background:rgba(255,255,255,.05);box-shadow:inset 0 1px 0 rgba(255,255,255,.06)}
.oui-pulse{animation:oui-cta 6s ease-in-out infinite}
@keyframes oui-cta{0%,100%{box-shadow:0 0 40px rgba(255,138,52,.18),inset 0 1px 0 rgba(255,255,255,.42)}50%{box-shadow:0 0 72px rgba(255,138,52,.30),0 0 28px rgba(255,176,96,.18),inset 0 1px 0 rgba(255,255,255,.42)}}

/* ---------- crest (shared by MatchCard/PredictionCard/Ranking) ---------- */
.oui-crest{
  border-radius:12px;display:inline-grid;place-items:center;
  font-family:var(--oui-font-disp);font-weight:700;color:#fff;
  flex-shrink:0;width:44px;height:44px;font-size:12px;
  background-color:#1a2236;background-size:cover;background-position:center;background-repeat:no-repeat;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.3),0 6px 14px -6px rgba(0,0,0,.7);
  position:relative;overflow:hidden;text-indent:-9999px;       /* 隐藏 MEX/RSA 等文字 */
}
.oui-crest::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(155deg,rgba(255,255,255,.18) 0%,rgba(255,255,255,0) 35%,rgba(0,0,0,.10) 100%);
  pointer-events:none;border-radius:inherit;
}

/* ═══ WC 2026 · 48 国真国旗 (flagcdn.com SVG · CDN 全球加速) ═══ */
/* Group A */
.oui-crest--mex{background-image:url(https://flagcdn.com/mx.svg)}
.oui-crest--rsa{background-image:url(https://flagcdn.com/za.svg)}
.oui-crest--kor{background-image:url(https://flagcdn.com/kr.svg)}
.oui-crest--cze{background-image:url(https://flagcdn.com/cz.svg)}
/* Group B */
.oui-crest--can{background-image:url(https://flagcdn.com/ca.svg)}
.oui-crest--bih{background-image:url(https://flagcdn.com/ba.svg)}
.oui-crest--qat{background-image:url(https://flagcdn.com/qa.svg)}
.oui-crest--sui{background-image:url(https://flagcdn.com/ch.svg)}
/* Group C */
.oui-crest--bra{background-image:url(https://flagcdn.com/br.svg)}
.oui-crest--mar{background-image:url(https://flagcdn.com/ma.svg)}
.oui-crest--hai{background-image:url(https://flagcdn.com/ht.svg)}
.oui-crest--sco{background-image:url(https://flagcdn.com/gb-sct.svg)}
/* Group D */
.oui-crest--usa{background-image:url(https://flagcdn.com/us.svg)}
.oui-crest--par{background-image:url(https://flagcdn.com/py.svg)}
.oui-crest--aus{background-image:url(https://flagcdn.com/au.svg)}
.oui-crest--tur{background-image:url(https://flagcdn.com/tr.svg)}
/* Group E */
.oui-crest--ger{background-image:url(https://flagcdn.com/de.svg)}
.oui-crest--cuw{background-image:url(https://flagcdn.com/cw.svg)}
.oui-crest--civ{background-image:url(https://flagcdn.com/ci.svg)}
.oui-crest--ecu{background-image:url(https://flagcdn.com/ec.svg)}
/* Group F */
.oui-crest--ned{background-image:url(https://flagcdn.com/nl.svg)}
.oui-crest--jpn{background-image:url(https://flagcdn.com/jp.svg)}
.oui-crest--swe{background-image:url(https://flagcdn.com/se.svg)}
.oui-crest--tun{background-image:url(https://flagcdn.com/tn.svg)}
/* Group G */
.oui-crest--bel{background-image:url(https://flagcdn.com/be.svg)}
.oui-crest--egy{background-image:url(https://flagcdn.com/eg.svg)}
.oui-crest--irn{background-image:url(https://flagcdn.com/ir.svg)}
.oui-crest--nzl{background-image:url(https://flagcdn.com/nz.svg)}
/* Group H */
.oui-crest--esp{background-image:url(https://flagcdn.com/es.svg)}
.oui-crest--cpv{background-image:url(https://flagcdn.com/cv.svg)}
.oui-crest--ksa{background-image:url(https://flagcdn.com/sa.svg)}
.oui-crest--uru{background-image:url(https://flagcdn.com/uy.svg)}
/* Group I */
.oui-crest--fra{background-image:url(https://flagcdn.com/fr.svg)}
.oui-crest--sen{background-image:url(https://flagcdn.com/sn.svg)}
.oui-crest--irq{background-image:url(https://flagcdn.com/iq.svg)}
.oui-crest--nor{background-image:url(https://flagcdn.com/no.svg)}
/* Group J */
.oui-crest--arg{background-image:url(https://flagcdn.com/ar.svg)}
.oui-crest--alg{background-image:url(https://flagcdn.com/dz.svg)}
.oui-crest--aut{background-image:url(https://flagcdn.com/at.svg)}
.oui-crest--jor{background-image:url(https://flagcdn.com/jo.svg)}
/* Group K */
.oui-crest--por{background-image:url(https://flagcdn.com/pt.svg)}
.oui-crest--cod{background-image:url(https://flagcdn.com/cd.svg)}
.oui-crest--uzb{background-image:url(https://flagcdn.com/uz.svg)}
.oui-crest--col{background-image:url(https://flagcdn.com/co.svg)}
/* Group L */
.oui-crest--eng{background-image:url(https://flagcdn.com/gb-eng.svg)}
.oui-crest--cro{background-image:url(https://flagcdn.com/hr.svg)}
.oui-crest--gha{background-image:url(https://flagcdn.com/gh.svg)}
.oui-crest--pan{background-image:url(https://flagcdn.com/pa.svg)}

/* TBD 占位(1A · 2B · W73 等)· 不上国旗,保留代号文字 + 深灰玻璃 */
.oui-crest--tbd{
  background-image:none;
  background:linear-gradient(150deg,#2A3340,#161D2A);
  color:rgba(255,255,255,.55);
  text-indent:0;
  font-size:10px;
}
.oui-crest--tbd::after{display:none}

/* "没进球" 预测选项 · 橙色玻璃 + ⊘ 符号 · 跟国旗 + TBD 区分 */
.oui-crest--nogoal{
  background-image:none;
  background:linear-gradient(150deg,#3a2620,#2a1612);
  color:rgba(255,138,52,.85);
  text-indent:0;
  font-size:16px;
  font-weight:400;
}
.oui-crest--nogoal::after{display:none}

/* ---------- pills ---------- */
.oui-pill{font-family:var(--oui-font-mono);font-size:9.5px;letter-spacing:.06em;padding:6px 10px;border-radius:var(--oui-r-pill);white-space:nowrap;flex-shrink:0}
.oui-pill--todo{color:var(--oui-orange-hi);background:rgba(255,138,52,.12);box-shadow:inset 0 0 0 1px rgba(255,138,52,.2)}
.oui-pill--done{color:var(--oui-blue-hi);background:rgba(78,124,255,.12);box-shadow:inset 0 0 0 1px rgba(78,124,255,.2)}
.oui-pill--lock{color:var(--oui-ink-dim);background:rgba(255,255,255,.05);white-space:normal;text-align:center;line-height:1.3;max-width:88px}
.oui-pill--end{color:var(--oui-ink-faint);background:rgba(255,255,255,.04)}
.oui-pill--live{color:#ff9a9a;background:rgba(255,107,107,.12);display:inline-flex;align-items:center;gap:6px;box-shadow:inset 0 0 0 1px rgba(255,107,107,.2)}
.oui-dot{width:6px;height:6px;border-radius:50%;background:var(--oui-red);box-shadow:0 0 9px var(--oui-red);animation:oui-pulse 2.4s ease-in-out infinite}
@keyframes oui-pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.55;transform:scale(.84)}}

/* ---------- 02 MatchCard (row) ---------- */
.oui-mrow{display:flex;align-items:center;gap:13px;padding:16px;border-radius:var(--oui-r-md);cursor:pointer;
  background:linear-gradient(165deg,rgba(255,255,255,.05),rgba(255,255,255,.016));box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
  transition:background .35s var(--oui-ease),transform .35s var(--oui-ease)}
.oui-mrow:active{transform:scale(.99)}
.oui-mrow:hover{background:linear-gradient(165deg,rgba(255,150,70,.11),rgba(255,150,70,.03))}
.oui-mrow__time{display:flex;flex-direction:column;gap:3px;width:62px;flex-shrink:0}
.oui-mrow__time .oui-t{font-family:var(--oui-font-disp);font-weight:600;font-size:14px}
.oui-mrow__time .oui-g{font-family:var(--oui-font-mono);font-size:9px;color:var(--oui-ink-dim)}
.oui-mrow__vs{flex:1;display:flex;align-items:center;justify-content:center;gap:10px}
.oui-tm{display:flex;align-items:center;gap:7px;font-size:12.5px;font-weight:500;color:var(--oui-ink-soft)}
.oui-tm .oui-crest{width:26px;height:26px;font-size:10px;border-radius:9px}
.oui-x{font-family:var(--oui-font-mono);font-size:10px;color:var(--oui-ink-faint)}
.oui-x.is-score{font-family:var(--oui-font-disp);font-weight:700;font-size:13px;color:var(--oui-ink);letter-spacing:.02em;white-space:nowrap;flex-shrink:0}

/* ---------- 02b MatchCard (live hero) ---------- */
.oui-live{position:relative;overflow:hidden;border-radius:var(--oui-r-lg);padding:18px;cursor:pointer;
  background:linear-gradient(160deg,rgba(36,26,30,.58),rgba(10,12,22,.44));box-shadow:var(--oui-shadow),var(--oui-edge);
  transition:transform .4s var(--oui-ease)}
.oui-live:active{transform:scale(.99)}
.oui-live::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;
  background:linear-gradient(145deg,rgba(255,255,255,.20),rgba(255,255,255,.02) 50%,rgba(255,107,107,.22));
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}
.oui-live__glow{position:absolute;inset:0;pointer-events:none;background:
  radial-gradient(75% 90% at 50% -8%,rgba(255,107,107,.15),transparent 60%),
  radial-gradient(96% 76% at 50% 0%,rgba(255,138,52,.10),transparent 66%)}
.oui-live>*{position:relative;z-index:1}
.oui-live__top{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.oui-live__comp{font-family:var(--oui-font-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--oui-ink-dim)}
.oui-live__live{display:inline-flex;align-items:center;gap:7px;font-family:var(--oui-font-mono);font-size:10.5px;letter-spacing:.12em;color:#ff9a9a}
.oui-live__score{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:18px}
.oui-live__team{display:flex;flex-direction:column;align-items:center;gap:10px;flex:1}
.oui-live__team .oui-crest{width:54px;height:54px;border-radius:17px;font-size:14px}
.oui-live__nm{font-size:13px;font-weight:600;color:var(--oui-ink-soft)}
.oui-live__num{display:flex;align-items:center;gap:11px;font-family:var(--oui-font-disp);font-weight:700;font-size:40px;letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.oui-live__num .lead{color:var(--oui-gold-soft)} .oui-live__num .dash{color:var(--oui-ink-faint);font-size:24px}
.oui-bartrack{height:6px;border-radius:99px;background:rgba(255,255,255,.08);overflow:hidden}
.oui-barfill{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,var(--oui-orange),var(--oui-gold));box-shadow:var(--oui-glow-s)}
.oui-barlbl{display:flex;align-items:center;justify-content:space-between;margin-top:10px;font-family:var(--oui-font-mono);font-size:10px}
.oui-barlbl .a{color:var(--oui-gold-soft)} .oui-barlbl .b{color:var(--oui-ink-dim)} .oui-barlbl .mid{color:var(--oui-ink-faint);letter-spacing:.12em}

/* ---------- 05 StatsCard ---------- */
.oui-stat{padding:18px 10px;border-radius:var(--oui-r-md);text-align:center;background:linear-gradient(170deg,rgba(255,255,255,.06),rgba(255,255,255,.014));box-shadow:inset 0 1px 0 rgba(255,255,255,.06)}
.oui-stat__ic{width:32px;height:32px;margin:0 auto 11px;border-radius:11px;display:grid;place-items:center}
.oui-stat__ic svg{width:15px;height:15px}
.oui-stat__ic.o{background:rgba(255,138,52,.16);color:var(--oui-orange-hi)} .oui-stat__ic.b{background:rgba(78,124,255,.16);color:var(--oui-blue-hi)}
.oui-stat__v{font-family:var(--oui-font-disp);font-weight:700;font-size:19px;letter-spacing:-.01em}
.oui-stat__l{font-size:9.5px;color:var(--oui-ink-dim);margin-top:5px;letter-spacing:.05em}
/* balance variant */
.oui-bal{position:relative;overflow:hidden;padding:20px 18px 22px}
.oui-bal__bleed{position:absolute;width:180px;height:180px;right:-58px;top:-62px;border-radius:50%;filter:blur(28px)}
.oui-bal.o .oui-bal__bleed{background:radial-gradient(circle,rgba(255,150,70,.34),transparent 70%)}
.oui-bal.b .oui-bal__bleed{background:radial-gradient(circle,rgba(78,124,255,.30),transparent 70%)}
.oui-bal__top{display:flex;align-items:center;gap:9px;font-size:11px;color:var(--oui-ink-soft);margin-bottom:14px;position:relative}
.oui-bal__top .ic{width:28px;height:28px;border-radius:9px;display:grid;place-items:center;position:relative}
.oui-bal.o .oui-bal__top .ic{background:rgba(255,138,52,.18);color:var(--oui-orange-hi)} .oui-bal.b .oui-bal__top .ic{background:rgba(78,124,255,.18);color:var(--oui-blue-hi)}
.oui-bal__top .ic svg{width:14px;height:14px}
.oui-bal__num{font-family:var(--oui-font-disp);font-weight:700;font-size:34px;letter-spacing:-.02em;line-height:1;position:relative}
.oui-bal__delta{font-family:var(--oui-font-mono);font-size:10.5px;margin-top:10px;color:var(--oui-green);position:relative}

/* ---------- 06 SectionHeader ---------- */
.oui-sech{display:flex;align-items:center;justify-content:space-between;margin:30px 2px 15px}
.oui-sech__t{font-family:var(--oui-font-disp);font-weight:600;font-size:16.5px;letter-spacing:-.01em;display:flex;align-items:center;gap:10px}
.oui-sech__t .oui-d{width:6px;height:6px;border-radius:50%;background:var(--oui-orange);box-shadow:var(--oui-glow-s)}
.oui-sech__more{font-size:12px;color:var(--oui-ink-dim);display:flex;align-items:center;gap:4px;cursor:pointer;background:none;border:0;font-family:inherit}
.oui-sech__more svg{width:13px;height:13px}

/* ---------- 07 PredictionCard ---------- */
.oui-pred{position:relative;border-radius:var(--oui-r-lg);padding:18px;
  background:linear-gradient(165deg,rgba(24,33,58,.5),rgba(9,13,24,.36));box-shadow:var(--oui-shadow),var(--oui-edge)}
.oui-pred__h{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.oui-pred__h .t{font-family:var(--oui-font-disp);font-weight:600;font-size:14px;display:flex;align-items:center;gap:8px}
.oui-pred__h .t svg{width:14px;height:14px;color:var(--oui-orange-hi)}
.oui-pred__h .r{font-family:var(--oui-font-mono);font-size:10.5px;color:var(--oui-green)}
.oui-odds{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.oui-odd{padding:13px 8px;border-radius:var(--oui-r-md);text-align:center;cursor:pointer;background:rgba(255,255,255,.035);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.06);transition:all .3s var(--oui-ease)}
.oui-odd .ot{font-size:12.5px;font-weight:600;color:var(--oui-ink-soft)}
.oui-odd .ov{font-family:var(--oui-font-mono);font-size:10px;color:var(--oui-green);margin-top:7px}
.oui-odd.is-sel{background:linear-gradient(165deg,rgba(255,138,52,.22),rgba(255,138,52,.06));box-shadow:inset 0 0 0 1px rgba(255,138,52,.45),var(--oui-glow-s)}
.oui-odd.is-sel .ot{color:var(--oui-gold-soft)}
.oui-pscore{display:flex;align-items:center;justify-content:center;gap:10px;padding:2px 0}
.oui-pscore .tn{font-size:11px;color:var(--oui-ink-dim)}
.oui-pscore .box{width:52px;height:46px;border-radius:13px;display:grid;place-items:center;font-family:var(--oui-font-disp);font-weight:700;font-size:20px;background:rgba(255,255,255,.05);box-shadow:inset 0 0 0 1px rgba(255,255,255,.08);color:var(--oui-ink)}
.oui-pscore .colon{font-family:var(--oui-font-disp);font-weight:700;font-size:18px;color:var(--oui-ink-faint)}
.oui-pscore .oui-crest{width:28px;height:28px;font-size:9px;border-radius:9px}
.oui-scorer{display:flex;gap:10px}
.oui-scorer .opt{flex:1;display:flex;align-items:center;gap:9px;padding:12px;border-radius:var(--oui-r-md);cursor:pointer;font-size:12.5px;
  background:rgba(255,255,255,.035);box-shadow:inset 0 0 0 1px rgba(255,255,255,.06);transition:all .3s var(--oui-ease)}
.oui-scorer .opt .oui-crest{width:28px;height:28px;font-size:10px;border-radius:9px}
.oui-scorer .opt .rw{margin-left:auto;font-family:var(--oui-font-mono);font-size:10px;color:var(--oui-green)}
.oui-scorer .opt.is-sel{background:linear-gradient(165deg,rgba(255,138,52,.18),rgba(255,138,52,.05));box-shadow:inset 0 0 0 1px rgba(255,138,52,.4)}

/* ---------- 08 RankingCard ---------- */
.oui-rank{display:flex;align-items:center;gap:13px;padding:13px 14px;border-radius:var(--oui-r-md);
  background:linear-gradient(165deg,rgba(255,255,255,.05),rgba(255,255,255,.016));box-shadow:inset 0 1px 0 rgba(255,255,255,.06)}
.oui-rank__pos{font-family:var(--oui-font-disp);font-weight:700;font-size:15px;width:22px;text-align:center;color:var(--oui-ink-dim)}
.oui-rank__av{width:38px;height:38px;border-radius:12px;display:grid;place-items:center;font-family:var(--oui-font-disp);font-weight:700;font-size:13px;color:#fff;flex-shrink:0;box-shadow:inset 0 1px 0 rgba(255,255,255,.3)}
.oui-rank__nm{flex:1;font-size:13.5px;font-weight:500}
.oui-rank__pp{font-family:var(--oui-font-mono);font-size:12.5px;color:var(--oui-gold-soft);font-weight:600}
.oui-rank__ch{color:var(--oui-ink-faint)} .oui-rank__ch svg{width:15px;height:15px}
.oui-rank.is-me{background:linear-gradient(165deg,rgba(255,138,52,.14),rgba(255,138,52,.04));box-shadow:inset 0 0 0 1px rgba(255,138,52,.3)}
/* podium */
.oui-pod{display:flex;flex-direction:column;align-items:center;gap:9px;flex:1}
.oui-pod__av{position:relative;border-radius:50%;display:grid;place-items:center;font-family:var(--oui-font-disp);font-weight:700;color:#fff;box-shadow:inset 0 1px 0 rgba(255,255,255,.3),0 10px 22px -8px rgba(0,0,0,.7)}
.oui-pod__nm{font-size:12px;font-weight:600} .oui-pod__pp{font-family:var(--oui-font-mono);font-size:11px;color:var(--oui-gold-soft)} .oui-pod__rk{font-family:var(--oui-font-mono);font-size:10px;color:var(--oui-ink-dim)}
.oui-pod--1 .oui-pod__av{width:78px;height:78px;font-size:22px;background:linear-gradient(150deg,#FFE0A8,#FF9C40);box-shadow:0 0 30px rgba(255,138,52,.5),inset 0 1px 0 rgba(255,255,255,.5);animation:oui-cta 6s ease-in-out infinite}
.oui-pod--2 .oui-pod__av{width:60px;height:60px;font-size:17px;background:linear-gradient(150deg,#AEB8CE,#5A6680)}
.oui-pod--3 .oui-pod__av{width:60px;height:60px;font-size:17px;background:linear-gradient(150deg,#C98A5A,#7A4A28)}
.oui-pod__crown{position:absolute;top:-18px;left:50%;transform:translateX(-50%);color:var(--oui-gold)}
.oui-pod__crown svg{width:22px;height:22px;filter:drop-shadow(0 0 8px rgba(244,200,113,.7))}

/* ---------- 09 InputField ---------- */
.oui-field{margin-bottom:14px}
.oui-field__l{font-family:var(--oui-font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--oui-ink-dim);margin-bottom:9px}
.oui-field__box{display:flex;align-items:center;gap:12px;padding:15px 16px;border-radius:var(--oui-r-md);background:rgba(255,255,255,.04);box-shadow:inset 0 0 0 1px rgba(255,255,255,.08)}
.oui-field__box:focus-within{box-shadow:inset 0 0 0 1.5px rgba(255,138,52,.4)}
.oui-field__cc{font-family:var(--oui-font-disp);font-weight:600;font-size:14.5px;padding-right:12px;border-right:1px solid var(--oui-hair);color:var(--oui-ink-soft)}
.oui-field__box svg{width:18px;height:18px;color:var(--oui-ink-dim)}
.oui-field__in{flex:1;background:none;border:0;outline:none;font-family:var(--oui-font-body);font-size:14px;color:var(--oui-ink)}
.oui-field__in::placeholder{color:var(--oui-ink-faint)}
/* OTP */
.oui-otp{display:flex;gap:9px;justify-content:center}
.oui-otp .cell{width:44px;height:54px;border-radius:14px;display:grid;place-items:center;font-family:var(--oui-font-disp);font-weight:700;font-size:23px;background:rgba(255,255,255,.04);box-shadow:inset 0 0 0 1px rgba(255,255,255,.08)}
.oui-otp .cell.is-fill{box-shadow:inset 0 0 0 1.5px rgba(255,138,52,.5);background:rgba(255,138,52,.08);color:var(--oui-gold-soft)}

/* ---------- 04 FloatingBottomNav ---------- */
.oui-nav{position:absolute;left:18px;right:18px;bottom:18px;z-index:25;display:flex;align-items:center;justify-content:space-between;
  padding:10px 12px;border-radius:34px;background:linear-gradient(180deg,rgba(32,40,66,.5),rgba(9,13,23,.62));
  backdrop-filter:blur(42px) saturate(175%);-webkit-backdrop-filter:blur(42px) saturate(175%);
  box-shadow:0 34px 70px -24px rgba(0,0,0,.86),inset 0 1px 0 rgba(255,255,255,.18),inset 0 -1px 0 rgba(0,0,0,.35),0 0 80px rgba(255,140,55,.05)}
.oui-nav.is-static{position:relative;left:auto;right:auto;bottom:auto}
.oui-nav::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;
  background:linear-gradient(150deg,rgba(255,255,255,.26),rgba(255,255,255,.02) 55%,rgba(255,150,70,.18));
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}
.oui-nav__tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:5px;background:none;border:0;cursor:pointer;
  color:var(--oui-ink-faint);font-family:var(--oui-font-body);font-size:9.5px;letter-spacing:.04em;padding:8px 4px;border-radius:20px;
  transition:color .35s var(--oui-ease),background .35s var(--oui-ease)}
.oui-nav__tab svg{width:22px;height:22px;transition:transform .35s var(--oui-ease)}
.oui-nav__tab.is-active{color:var(--oui-orange-hi);background:radial-gradient(130% 140% at 50% 0%,rgba(255,142,55,.22),rgba(255,142,55,.04));box-shadow:inset 0 1px 0 rgba(255,255,255,.12)}
.oui-nav__tab.is-active svg{filter:drop-shadow(0 0 10px rgba(255,142,55,.5));transform:translateY(-1px)}

/* ---------- 10 ModalSheet ---------- */
.oui-modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:flex-end;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity .4s var(--oui-ease)}
.oui-modal.is-open{opacity:1;pointer-events:auto}
.oui-modal__bd{position:absolute;inset:0;background:rgba(3,5,11,.6);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.oui-modal__sheet{position:relative;width:100%;max-width:440px;margin:0 14px;border-radius:var(--oui-r-xl) var(--oui-r-xl) 0 0;
  padding:14px 22px 28px;background:linear-gradient(180deg,rgba(26,34,56,.9),rgba(9,13,23,.94));
  backdrop-filter:blur(40px) saturate(160%);-webkit-backdrop-filter:blur(40px) saturate(160%);
  box-shadow:0 -30px 80px -20px rgba(0,0,0,.8),inset 0 1px 0 rgba(255,255,255,.14);
  transform:translateY(30px);transition:transform .42s var(--oui-ease)}
.oui-modal.is-open .oui-modal__sheet{transform:translateY(0)}
.oui-modal__sheet::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;
  background:linear-gradient(150deg,rgba(255,255,255,.24),rgba(255,255,255,.02) 55%,rgba(255,150,70,.2));
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}
.oui-modal__handle{width:42px;height:5px;border-radius:99px;background:rgba(255,255,255,.18);margin:0 auto 16px}
.oui-modal__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;position:relative}
.oui-modal__title{font-family:var(--oui-font-disp);font-weight:700;font-size:18px}
.oui-modal__x{width:34px;height:34px;border-radius:11px;display:grid;place-items:center;border:0;cursor:pointer;background:var(--oui-glass-2);box-shadow:var(--oui-edge);color:var(--oui-ink-soft)}
.oui-modal__x svg{width:16px;height:16px}
.oui-modal__body{position:relative}

@media(prefers-reduced-motion:reduce){.oui-scope *{animation:none!important}}
