/* ============================================================
   components.css — BWorldCupPredictor component layer
   ============================================================ */

/* ---------------- Buttons ---------------- */
.btn {
  font-family: var(--font-ui); font-weight: 700; font-size: var(--fs-sm);
  display: inline-flex; align-items: center; justify-content: center; gap: var(--sp-3);
  padding: var(--sp-4) var(--sp-6); border-radius: var(--r-sm);
  border: 1px solid transparent; cursor: pointer; white-space: nowrap;
  transition: background var(--dur) var(--ease), transform var(--dur-fast) var(--ease),
              box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease), color var(--dur);
  -webkit-tap-highlight-color: transparent; user-select: none;
}
.btn:active { transform: translateY(1px); }
.btn--gold { background: var(--gold); color: var(--on-gold); box-shadow: 0 1px 0 oklch(1 0 0 /.25) inset, 0 6px 20px -8px var(--gold-glow); }
.btn--gold:hover { background: var(--gold-bright); box-shadow: 0 1px 0 oklch(1 0 0 /.3) inset, 0 8px 26px -8px var(--gold-glow); }
.btn--ghost { background: transparent; color: var(--ink); border-color: var(--navy-600); }
.btn--ghost:hover { background: var(--navy-800); border-color: var(--navy-500); }
.btn--quiet { background: var(--navy-800); color: var(--ink-soft); }
.btn--quiet:hover { background: var(--navy-750); color: var(--ink); }
.btn--lg { font-size: var(--fs-md); padding: var(--sp-5) var(--sp-9); border-radius: var(--r-md); }
.btn--sm { font-size: var(--fs-xs); padding: var(--sp-2) var(--sp-4); }
.btn--block { width: 100%; }
.btn:disabled { opacity: .45; cursor: not-allowed; }

/* ---------------- Pills / badges ---------------- */
.pill {
  display: inline-flex; align-items: center; gap: var(--sp-2);
  font-size: var(--fs-2xs); font-weight: 700; letter-spacing: .04em; text-transform: uppercase;
  padding: var(--sp-2) var(--sp-4); border-radius: var(--r-full);
  background: var(--navy-800); color: var(--ink-mut); border: 1px solid var(--navy-700);
}
.pill--gold { background: var(--gold-dim); color: var(--gold-bright); border-color: transparent; }
.pill--green { background: var(--pitch-dim); color: var(--pitch); border-color: transparent; }
.pill--live { background: var(--loss-dim); color: oklch(.78 .19 24); border-color: transparent; }
.pill--live::before { content:''; width:6px; height:6px; border-radius:50%; background: var(--loss); box-shadow:0 0 0 0 var(--loss); animation: livepulse 1.6s infinite; }
@keyframes livepulse { 0%{box-shadow:0 0 0 0 oklch(.64 .215 24 /.6);} 70%{box-shadow:0 0 0 6px transparent;} 100%{box-shadow:0 0 0 0 transparent;} }

/* accuracy badge with color scale */
.acc-badge {
  display: inline-flex; align-items: baseline; gap: var(--sp-2);
  font-family: var(--font-display); padding: var(--sp-2) var(--sp-4); border-radius: var(--r-full);
  line-height: 1;
}
.acc-badge[data-level="low"]  { background: var(--loss-dim);  color: oklch(.78 .2 24); }
.acc-badge[data-level="mid"]  { background: oklch(.8 .15 65 /.16); color: var(--amber); }
.acc-badge[data-level="high"] { background: var(--pitch-dim); color: var(--pitch); }
.acc-badge b { font-size: 1.15em; }

/* ---------------- Verdict tokens ---------------- */
.verdict { display: inline-flex; align-items: center; justify-content: center; border-radius: 50%; flex: none; }
.verdict[data-ok="true"]  { background: var(--win);  color: var(--navy-950); }
.verdict[data-ok="false"] { background: var(--loss); color: oklch(.98 .02 24); }

/* ---------------- Flag + team ---------------- */
.flag { display: inline-block; filter: drop-shadow(0 1px 1px oklch(0 0 0 /.4)); }
.flag--tbd { color: var(--ink-faint); filter: none; }
.team { display: inline-flex; align-items: center; gap: var(--sp-3); min-width: 0; }
.team__name { font-weight: 600; font-size: var(--fs-sm); color: var(--ink); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.team[data-strong="1"] .team__name { font-weight: 800; }

/* ============================================================
   Match tile
   ============================================================ */
.tile {
  background: var(--navy-800); border-radius: var(--r-md); box-shadow: var(--elev-card);
  padding: var(--sp-4); display: flex; flex-direction: column; gap: var(--sp-3);
  border: 1px solid transparent; transition: border-color var(--dur), background var(--dur);
}
.tile__head { display: flex; align-items: center; justify-content: space-between; font-size: var(--fs-2xs); color: var(--ink-mut); letter-spacing: .03em; }
.tile__row { display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: var(--sp-3); }
.tile__side { display: flex; align-items: center; gap: var(--sp-3); min-width: 0; }
.tile__side--away { justify-content: flex-end; flex-direction: row-reverse; text-align: right; }
.tile__nm { font-weight: 700; font-size: var(--fs-sm); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.tile__vs { font-family: var(--font-mono); font-size: var(--fs-2xs); color: var(--ink-faint); }

/* segmented result picker */
.seg { display: grid; grid-template-columns: 1fr 0.7fr 1fr; gap: var(--sp-2); }
.seg__btn {
  font-family: var(--font-ui); font-weight: 800; font-size: var(--fs-xs); letter-spacing: .03em;
  padding: var(--sp-3) var(--sp-2); border-radius: var(--r-sm); cursor: pointer;
  background: var(--navy-850); color: var(--ink-mut); border: 1px solid var(--navy-700);
  display: flex; align-items: center; justify-content: center; gap: 4px;
  transition: all var(--dur-fast) var(--ease); text-transform: uppercase;
}
.seg__btn:hover { background: var(--navy-750); color: var(--ink-soft); }
.seg__btn[data-on="1"][data-kind="home"] { background: var(--pitch); color: var(--navy-950); border-color: transparent; box-shadow: 0 0 16px -4px var(--pitch); }
.seg__btn[data-on="1"][data-kind="draw"] { background: var(--gold); color: var(--on-gold); border-color: transparent; box-shadow: 0 0 16px -4px var(--gold-glow); }
.seg__btn[data-on="1"][data-kind="away"] { background: var(--pitch); color: var(--navy-950); border-color: transparent; box-shadow: 0 0 16px -4px var(--pitch); }

/* score steppers (appear when a result is chosen) */
.score { display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: var(--sp-3);
  overflow: hidden; max-height: 0; opacity: 0; transition: max-height var(--dur-slow) var(--ease), opacity var(--dur) var(--ease), margin var(--dur); }
.score[data-show="1"] { max-height: 60px; opacity: 1; }
.stepper { display: flex; align-items: center; gap: var(--sp-2); justify-content: center; }
.stepper button { width: 26px; height: 26px; border-radius: var(--r-sm); border: 1px solid var(--navy-600); background: var(--navy-850); color: var(--ink-soft); font-size: 16px; cursor: pointer; display: flex; align-items: center; justify-content: center; line-height: 1; }
.stepper button:hover { background: var(--navy-700); color: var(--ink); }
.stepper input { width: 34px; height: 30px; text-align: center; background: var(--navy-950); border: 1px solid var(--navy-700); border-radius: var(--r-sm); color: var(--ink); font-family: var(--font-mono); font-weight: 700; font-size: var(--fs-md); }
.score__dash { color: var(--ink-faint); font-family: var(--font-mono); }

/* locked / played tile */
.tile[data-locked="1"] { background: var(--navy-850); border-color: var(--navy-750); }
.tile[data-locked="1"] .tile__head { color: var(--ink-faint); }
.tile__final { font-family: var(--font-display); font-size: var(--fs-2xl); letter-spacing: .02em; display: flex; align-items: center; gap: var(--sp-3); color: var(--ink); }
.tile__final small { font-family: var(--font-mono); font-size: var(--fs-2xs); color: var(--ink-mut); font-weight: 400; }
.tile__verline { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-3); padding-top: var(--sp-3); border-top: 1px dashed var(--navy-700); font-size: var(--fs-2xs); color: var(--ink-mut); }
.tile__pick { display: inline-flex; align-items: center; gap: var(--sp-2); }

/* ============================================================
   Group table
   ============================================================ */
.gtable { width: 100%; border-collapse: collapse; font-size: var(--fs-xs); }
.gtable th { font-weight: 700; font-size: var(--fs-2xs); letter-spacing: .05em; text-transform: uppercase; color: var(--ink-faint); text-align: right; padding: var(--sp-3) var(--sp-2); }
.gtable th:first-child, .gtable td:first-child { text-align: left; }
.gtable td { padding: var(--sp-3) var(--sp-2); border-top: 1px solid var(--navy-800); }
.gtable .col-team { width: 100%; }
.gtable .pos { color: var(--ink-faint); font-family: var(--font-mono); width: 18px; }
.gtable tr[data-qual="1"] td { background: var(--gold-dim); }
.gtable tr[data-qual="1"] .pos { color: var(--gold); font-weight: 700; }
.gtable tr[data-qual="2"] td { background: oklch(0.72 0.15 152 / 0.10); }
.gtable tr[data-qual="2"] .pos { color: var(--pitch); }
.gtable tr[data-me="1"] td { background: var(--gold-dim); }
.gtable tr[data-me="1"] .pos { color: var(--gold); font-weight: 700; }
.gtable .pts { font-family: var(--font-display); font-size: var(--fs-md); color: var(--ink); }
.gtable .teamcell { display: flex; align-items: center; gap: var(--sp-3); }
.gtable .teamcell b { font-weight: 700; font-size: var(--fs-sm); }
.gtable .num { font-family: var(--font-mono); color: var(--ink-soft); }

/* ============================================================
   Group card
   ============================================================ */
.gcard { background: var(--navy-850); border-radius: var(--r-md); overflow: hidden; border: 1px solid var(--navy-800); }
.gcard__head { display: flex; align-items: center; justify-content: space-between; padding: var(--sp-5) var(--sp-5) var(--sp-4); }
.gcard__title { display: flex; align-items: baseline; gap: var(--sp-3); }
.gcard__letter { font-family: var(--font-display); font-size: var(--fs-2xl); color: var(--gold); line-height: .8; }
.gcard__sub { font-size: var(--fs-2xs); color: var(--ink-mut); }
.gcard__body { padding: 0 var(--sp-4) var(--sp-4); display: flex; flex-direction: column; gap: var(--sp-3); }
.gcard__tablewrap { background: var(--navy-900); border-radius: var(--r-sm); padding: var(--sp-2) var(--sp-4) var(--sp-3); margin: 0 var(--sp-1); }
.gcard__tabletitle { font-size: var(--fs-2xs); text-transform: uppercase; letter-spacing: .06em; color: var(--ink-faint); padding: var(--sp-3) var(--sp-2) 0; display:flex; justify-content:space-between; align-items:center; }

/* ============================================================
   Section scaffolding
   ============================================================ */
.section-h { font-family: var(--font-display); font-size: var(--fs-3xl); line-height: .95; text-transform: uppercase; }
.eyebrow { font-size: var(--fs-2xs); font-weight: 800; letter-spacing: .18em; text-transform: uppercase; color: var(--gold); }
.muted { color: var(--ink-mut); }
.divider { height: 1px; background: var(--navy-800); border: 0; margin: var(--sp-8) 0; }

/* ============================================================
   Bracket node
   ============================================================ */
.bnode { background: var(--navy-800); border-radius: var(--r-sm); border: 1px solid var(--navy-700); overflow: hidden; width: 184px; box-shadow: var(--elev-card); }
.bnode__slot { display: flex; align-items: center; gap: var(--sp-3); padding: var(--sp-3) var(--sp-4); cursor: pointer; transition: background var(--dur-fast); position: relative; }
.bnode__slot + .bnode__slot { border-top: 1px solid var(--navy-700); }
.bnode__slot:hover { background: var(--navy-750); }
.bnode__slot .team__name, .bnode__slot .tbd { font-size: var(--fs-xs); font-weight: 700; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.bnode__slot .tbd { color: var(--ink-faint); font-weight: 600; }
.bnode__slot[data-win="1"] { background: var(--gold-dim); }
.bnode__slot[data-win="1"] .team__name { color: var(--gold-bright); }
.bnode__slot[data-win="1"]::after { content:''; position:absolute; right:0; top:0; bottom:0; width:3px; background: var(--gold); }
.bnode__slot[data-correct="1"] { background: var(--win-dim); }
.bnode__slot[data-correct="0"] { background: var(--loss-dim); }
.bnode__seed { font-family: var(--font-mono); font-size: 10px; color: var(--ink-faint); margin-left: auto; }
.bnode__hd { font-size: 10px; letter-spacing: .08em; text-transform: uppercase; color: var(--ink-faint); padding: 2px var(--sp-4); background: var(--navy-850); display:flex; justify-content:space-between; }

/* ============================================================
   Top nav
   ============================================================ */
.nav { position: sticky; top: 0; z-index: 40; display: flex; align-items: center; gap: var(--sp-6);
  padding: var(--sp-4) var(--sp-7); background: oklch(0.18 0.046 264 / 0.82); backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--navy-800); }
.nav__brand { display: flex; align-items: center; gap: var(--sp-3); font-family: var(--font-display); font-size: var(--fs-lg); letter-spacing: .02em; text-transform: uppercase; }
.nav__brand .dot { width: 10px; height: 10px; border-radius: 50%; background: var(--gold); box-shadow: 0 0 12px var(--gold); }
.nav__links { display: flex; gap: var(--sp-2); margin-left: var(--sp-5); overflow-x: auto; }
.nav__link { display: inline-flex; align-items: center; gap: var(--sp-2); padding: var(--sp-3) var(--sp-4); border-radius: var(--r-sm); font-size: var(--fs-sm); font-weight: 600; color: var(--ink-mut); cursor: pointer; white-space: nowrap; transition: all var(--dur-fast); border: 1px solid transparent; }
.nav__link:hover { color: var(--ink); background: var(--navy-800); }
.nav__link[data-active="1"] { color: var(--gold-bright); background: var(--gold-dim); }
.nav__spacer { flex: 1; }

/* progress meter under nav */
.savebar { display:flex; align-items:center; gap: var(--sp-4); font-size: var(--fs-xs); color: var(--ink-mut); }
.meter { width: 120px; height: 6px; border-radius: 999px; background: var(--navy-800); overflow: hidden; }
.meter > i { display:block; height:100%; background: linear-gradient(90deg, var(--pitch), var(--gold)); transition: width var(--dur-slow) var(--ease); }

/* page shell */
.page { max-width: 1280px; margin: 0 auto; padding: var(--sp-9) var(--sp-7) var(--sp-14); }
.stack { display: flex; flex-direction: column; }
.row { display: flex; align-items: center; }

/* modal */
.scrim { position: fixed; inset: 0; z-index: 80; background: oklch(0.1 0.03 264 / 0.7); backdrop-filter: blur(6px); display: flex; align-items: center; justify-content: center; padding: var(--sp-7); animation: fade var(--dur) var(--ease); }
.modal { background: var(--navy-850); border: 1px solid var(--navy-700); border-radius: var(--r-lg); box-shadow: var(--elev-modal); width: min(560px, 100%); overflow: hidden; animation: pop var(--dur-slow) var(--ease); }
@keyframes fade { from{opacity:0;} } @keyframes pop { from{opacity:0; transform: translateY(12px) scale(.98);} }

@media (max-width: 720px) {
  .page { padding: var(--sp-7) var(--sp-5) var(--sp-13); }
  .section-h { font-size: var(--fs-2xl); }
  .nav { padding: var(--sp-4) var(--sp-5); }
}

/* rank #1 confetti celebration */
.confetti { position: fixed; inset: 0; z-index: 95; overflow: hidden; pointer-events: none; }
.confetti__piece {
  position: absolute; top: -12px; border-radius: 2px;
  animation-name: confettiFall; animation-timing-function: ease-in; animation-fill-mode: forwards;
}
@keyframes confettiFall {
  0% { transform: translate3d(0, 0, 0) rotate(0deg); opacity: 1; }
  90% { opacity: 1; }
  100% { transform: translate3d(var(--drift), 105vh, 0) rotate(var(--rot)); opacity: 0; }
}
