:root {
  --bg: #0a0a0c;
  --bg-2: #121217;
  --card: #17171c;
  --card-2: #1e1e25;
  --line: #2a2a33;
  --txt: #f5f5f7;
  --txt-dim: #9a9aa8;
  --accent: #e8132b;     /* smesh crimson */
  --accent-2: #ff5a1f;
  --blue: #3b82f6;
  --green: #22c55e;
  --amber: #f59e0b;
  --gold: #f5c518;
  --silver: #cfd2d8;
  --bronze: #cd7f32;
  --radius: 16px;
  --maxw: 520px;
  --font-brand: "Oswald", "Arial Narrow", system-ui, sans-serif;
  /* legacy alias — kept so old rules fall through to system font instead of Oswald */
  --font-head: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --backdrop: #050507;        /* desktop letterbox behind the phone frame */
  --bar: 11,11,15;            /* topbar/bottomnav base (rgb for translucency) */
}

/* light mode — overrides the palette; toggled via <html class="light"> */
html.light {
  --bg: #f4f5f8;
  --bg-2: #ffffff;
  --card: #ffffff;
  --card-2: #eef0f4;
  --line: #e2e3ea;
  --txt: #15161c;
  --txt-dim: #6a6c78;
  --backdrop: #d9dbe2;
  --bar: 255,255,255;
  color-scheme: light;
}
html.light .card { box-shadow: 0 1px 2px rgba(0,0,0,.05); }

* { box-sizing: border-box; -webkit-tap-highlight-color: transparent; }
html, body { margin: 0; padding: 0; background: var(--bg); color: var(--txt);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  height: 100%; }
body { overscroll-behavior: none; }

#app { max-width: var(--maxw); width: 100%; margin: 0 auto; height: 100svh; display: flex;
  flex-direction: column; overflow: hidden; position: relative; background: var(--bg);
  container-type: inline-size; container-name: app; }

/* desktop / wide screens: frame the app as a centered modern phone (9:19.5) */
@media (min-width: 540px) {
  body { display: flex; align-items: center; justify-content: center; min-height: 100svh; background: var(--backdrop); }
  #app { height: min(100svh - 24px, 900px); width: auto; max-width: none; aspect-ratio: 9 / 19.5;
    border-radius: 34px; box-shadow: 0 0 0 1px var(--line), 0 24px 70px rgba(0,0,0,.6); }
}

/* Topbar */
.topbar { flex: none; z-index: 20; display: flex; align-items: center;
  justify-content: space-between; padding: 14px 16px; background: rgba(var(--bar),.85);
  backdrop-filter: blur(12px); border-bottom: 1px solid var(--line); }
.brand { font-weight: 700; letter-spacing: 1px; font-size: 18px; }
.brand-mark { display: none; }  /* wordmark removed — logo alone is the home button */
.brand-mark.accent { color: var(--accent); }
.topbar-actions { display: flex; align-items: center; gap: 8px; }
.icon-btn { background: var(--card); border: 1px solid var(--line); color: var(--txt);
  width: 38px; height: 38px; border-radius: 12px; font-size: 16px; cursor: pointer; }
.icon-btn.on { background: var(--blue); border-color: var(--blue); }
.tg { display: inline-flex; align-items: center; gap: 5px; height: 38px;
  padding: 0 10px; border-radius: 12px; cursor: pointer; background: var(--card);
  border: 1px solid var(--line); color: var(--txt-dim);
  font-weight: 600; font-size: 12px; letter-spacing: .03em; text-transform: uppercase;
  line-height: 1; white-space: nowrap; }
.tg svg { display: block; }
.tg.green { background: rgba(34,197,94,.14); border-color: var(--green); color: var(--green); }
.tg.red { background: rgba(232,19,43,.12); border-color: var(--accent); color: var(--accent); }
.user-select { background: var(--card); color: var(--txt); border: 1px solid var(--line);
  border-radius: 12px; padding: 8px 10px; font-size: 13px; max-width: 120px; }
/* middle dev/beta cluster: user switcher + dev panel, clearly labelled as temporary */
.dev-group { display: flex; flex-direction: column; align-items: center; gap: 3px; }
.dev-beta { font-size: 7px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase;
  color: var(--txt-dim); line-height: 1; opacity: .7; }
.dev-group-row { display: flex; align-items: center; gap: 6px; }

/* narrow app frame (real phones AND the desktop phone-frame): tighten the topbar
   so logo + 2 toggles + user + gear fit on one row */
@container app (max-width: 470px) {
  .topbar { padding: 12px 12px; }
  .topbar-actions { gap: 6px; }
  .user-select { max-width: 84px; padding: 8px; }
  .tg { padding: 0 9px; gap: 4px; }
}

/* Dev panel */
.dev-panel { background: var(--bg-2); border-bottom: 1px solid var(--line); padding: 12px 16px; }
.dev-row { display: flex; gap: 8px; margin-bottom: 8px; }
.dev-btn { flex: 1; background: var(--card-2); color: var(--txt); border: 1px solid var(--line);
  border-radius: 12px; padding: 10px; font-size: 13px; font-weight: 600; cursor: pointer; }
.dev-btn.primary { background: var(--accent); border-color: var(--accent); }
.dev-hint { color: var(--txt-dim); font-size: 11px; margin: 4px 0 0; }

/* View */
.view { flex: 1; overflow-y: auto; -webkit-overflow-scrolling: touch; padding: 16px 16px 24px;
  scrollbar-width: none; -ms-overflow-style: none; }   /* clean look — hide scrollbar, still scrolls */
.view::-webkit-scrollbar { width: 0; height: 0; display: none; }
/* hide scrollbars on horizontal scrollers too */
.league-scroll::-webkit-scrollbar { display: none; }
.league-scroll { scrollbar-width: none; -ms-overflow-style: none; }
.section-title { font-size: 13px; text-transform: uppercase; letter-spacing: 1px;
  color: var(--txt-dim); margin: 18px 4px 10px; font-weight: 700; }
.section-title:first-child { margin-top: 4px; }

/* Cards */
.card { background: var(--card); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 16px; margin-bottom: 12px; }
.card.tap { cursor: pointer; transition: transform .08s ease, border-color .2s; }
.card.tap:active { transform: scale(.99); }

/* Event list */
.event-card .ev-top { display: flex; justify-content: space-between; align-items: flex-start; }
.event-name { font-size: 17px; font-weight: 700; margin: 0 0 4px; line-height: 1.25; }
.event-meta { color: var(--txt-dim); font-size: 12px; }
.countdown { font-variant-numeric: tabular-nums; font-weight: 700; color: var(--accent-2); font-size: 13px; }
.progress { height: 6px; background: var(--card-2); border-radius: 99px; margin-top: 12px; overflow: hidden; }
.progress > span { display: block; height: 100%; background: linear-gradient(90deg, var(--accent), var(--accent-2)); }

/* Badges */
.badge { font-size: 10px; font-weight: 700; letter-spacing: .5px; padding: 4px 8px;
  border-radius: 99px; text-transform: uppercase; }
.badge.upcoming { background: #2a2a38; color: var(--txt-dim); }
.badge.live { background: rgba(255,59,59,.15); color: var(--accent); }
.badge.live::before { content: "● "; animation: pulse 1s infinite; }
.badge.finished { background: rgba(34,197,94,.15); color: var(--green); }
.badge.locked { background: rgba(245,158,11,.15); color: var(--amber); }
@keyframes pulse { 50% { opacity: .35; } }

/* Fight card */
.fight { padding: 14px; }
.fight-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 10px; }
.fight-wc { font-size: 11px; color: var(--txt-dim); text-transform: uppercase; letter-spacing: .5px; }
.fight-main-tag { color: var(--blue); font-weight: 700; font-size: 11px; }
.fighters { display: grid; grid-template-columns: 1fr auto 1fr; gap: 8px; align-items: stretch; }
.corner { border: 1.5px solid var(--line); border-radius: 12px; padding: 12px 8px; text-align: center;
  background: var(--card-2); cursor: pointer; transition: all .15s; }
.corner .cn { font-weight: 700; font-size: 14px; line-height: 1.2; }
.corner .ctag { font-size: 10px; text-transform: uppercase; letter-spacing: .5px; margin-top: 4px; }
.corner.red .ctag { color: var(--accent); }
.corner.blue .ctag { color: var(--blue); }
/* friends' picks on a fight */
.friends-row { margin-top: 12px; padding-top: 10px; border-top: 1px dashed var(--line); }
.fp-label { font-size: 11px; color: var(--txt-dim); text-transform: uppercase; letter-spacing: .5px; margin-bottom: 7px; }
.fp-chips { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }
.fp-chip { width: 27px; height: 27px; border-radius: 50%; display: flex; align-items: center; justify-content: center;
  font-size: 10px; font-weight: 700; background: var(--card-2); color: var(--txt-dim); border: 2px solid var(--line); }
.fp-chip.fp-red { border-color: var(--accent); color: var(--accent); }
.fp-chip.fp-blue { border-color: var(--blue); color: var(--blue); }
.fp-chip.fp-hidden { filter: blur(0.6px); opacity: .65; }
.fp-note { font-size: 10px; color: var(--txt-dim); margin-left: 4px; }
.odds-chip { display: inline-block; margin-left: 5px; padding: 1px 6px; border-radius: 6px;
  background: var(--card-2); border: 1px solid var(--line); color: var(--gold);
  font-family: var(--font-head); font-weight: 700; font-size: 11px; letter-spacing: .3px;
  text-transform: none; vertical-align: middle; }
/* OneFootball-style odds row */
.odds-row { display: flex; gap: 8px; margin-top: 12px; }
.odds-pick { flex: 1; display: flex; align-items: center; justify-content: space-between; gap: 8px;
  padding: 9px 12px; border-radius: 11px; background: rgba(0,0,0,.35); border: 1px solid var(--line); min-width: 0; }
.odds-pick .op-name { font-size: 12px; font-weight: 600; color: var(--txt-dim);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.odds-pick .op-val { font-family: var(--font-head); font-weight: 700; font-size: 15px; color: var(--gold); }
.odds-pick.red { border-left: 3px solid var(--accent); }
.odds-pick.blue { border-left: 3px solid var(--blue); }
/* ad placeholder slot */
.ad-slot { position: relative; margin: 16px 0; min-height: 90px; border: 1px dashed var(--line);
  border-radius: 14px; background: var(--card); display: flex; align-items: center; justify-content: center; }
.ad-tag { position: absolute; top: 7px; left: 9px; font-size: 9px; letter-spacing: .1em;
  text-transform: uppercase; color: var(--txt-dim); }
.ad-body { color: var(--txt-dim); font-size: 13px; letter-spacing: .03em; }
/* watch (broadcaster) affiliate card */
.watch-card { position: relative; display: flex; align-items: center; justify-content: space-between;
  gap: 12px; flex-wrap: wrap; padding-top: 22px; }
.wc-label { font-size: 11px; text-transform: uppercase; letter-spacing: .06em; color: var(--txt-dim); }
.wc-when { font-weight: 700; font-size: 14px; margin-top: 2px; }
.wc-btn { display: inline-flex; align-items: center; gap: 6px; padding: 10px 14px; border-radius: 12px;
  background: var(--accent); color: #fff; font-weight: 700; font-size: 13px; text-decoration: none; white-space: nowrap; }
/* betting affiliate banner */
.bet-ad { position: relative; display: flex; align-items: center; justify-content: center;
  margin: 12px 0; min-height: 56px; padding: 14px; border-radius: 14px; text-decoration: none;
  background: linear-gradient(135deg, rgba(232,19,43,.18), rgba(245,197,24,.12));
  border: 1px solid var(--line); }
.bet-ad-body { color: var(--txt); font-weight: 700; font-size: 14px; }
.bet-gate { flex-wrap: wrap; gap: 10px; }
.age-btn { background: var(--txt); color: var(--bg); border: none; border-radius: 8px;
  padding: 7px 14px; font-weight: 700; font-size: 12px; cursor: pointer; }
/* promo / raffle banner */
.promo-banner { display: flex; align-items: center; gap: 12px; margin-bottom: 16px; padding: 14px 16px;
  border-radius: 14px; background: linear-gradient(135deg, rgba(245,197,24,.16), rgba(232,19,43,.10));
  border: 1px solid rgba(245,197,24,.4); }
.pb-icon { font-size: 26px; }
.pb-title { font-weight: 700; font-size: 14px; }
.pb-sub { color: var(--txt-dim); font-size: 12px; margin-top: 2px; }
.corner.picked.red { border-color: var(--accent); background: rgba(255,59,59,.12); box-shadow: 0 0 0 1px var(--accent) inset; }
.corner.picked.blue { border-color: var(--blue); background: rgba(59,130,246,.12); box-shadow: 0 0 0 1px var(--blue) inset; }
.corner.win { box-shadow: 0 0 0 2px var(--green) inset; border-color: var(--green); }
.corner.lose { opacity: .45; }
.corner.disabled { cursor: default; opacity: .9; }
.corner { position: relative; }
.corner-tick { position: absolute; top: 6px; right: 6px; width: 22px; height: 22px; border-radius: 50%;
  background: var(--accent); color: #fff; display: flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 700; }
.corner-win { margin-top: 6px; display: inline-block; background: rgba(34,197,94,.18); color: var(--green);
  font-family: var(--font-head); font-size: 10px; font-weight: 700; letter-spacing: .5px; padding: 3px 8px; border-radius: 99px; }
.live-seg { display: flex; border-radius: 12px; overflow: hidden; border: 1px solid var(--line); margin-bottom: 14px; }
.live-seg > div { flex: 1; padding: 11px; text-align: center; font-family: var(--font-head); font-weight: 600; font-size: 13px; }
.live-seg .ls-a { background: var(--accent); color: #fff; }
.live-seg .ls-b { background: var(--card); color: var(--txt-dim); }
.vs { display: flex; align-items: center; justify-content: center; color: var(--txt-dim);
  font-weight: 700; font-size: 12px; }

.rounds { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 12px; }
.round-chip { border: 1px solid var(--line); background: var(--card-2); color: var(--txt-dim);
  border-radius: 99px; padding: 6px 12px; font-size: 12px; font-weight: 700; cursor: pointer; }
.round-chip.on { background: var(--blue); border-color: var(--blue); color: #fff; }
.rounds-label { font-size: 11px; color: var(--txt-dim); margin: 12px 0 6px; }

.result-line { margin-top: 12px; font-size: 13px; display: flex; justify-content: space-between; align-items: center; }
.pts { font-weight: 700; border-radius: 99px; padding: 4px 10px; font-size: 12px; }
.pts.p3 { background: rgba(34,197,94,.18); color: var(--green); }
.pts.p1 { background: rgba(245,158,11,.18); color: var(--amber); }
.pts.p0 { background: #2a2a38; color: var(--txt-dim); }
.result-hidden { color: var(--txt-dim); font-style: italic; }

/* Rankings */
.tabs { display: flex; gap: 8px; margin-bottom: 14px; }
.tab { flex: 1; text-align: center; padding: 10px; border-radius: 12px; background: var(--card);
  border: 1px solid var(--line); color: var(--txt-dim); font-weight: 700; font-size: 13px; cursor: pointer; }
.tab.on { background: var(--txt); border-color: var(--txt); color: var(--bg); }
.rank-row { display: flex; align-items: center; gap: 12px; padding: 12px 14px; }
.rank-row.me { border-color: var(--blue); box-shadow: 0 0 0 1px var(--blue) inset; }
.rank-no { font-weight: 700; width: 28px; text-align: center; font-size: 16px; color: var(--txt-dim); }
.rank-no.top { color: var(--accent-2); }
.rank-name { flex: 1; font-weight: 700; }
.rank-acc { font-size: 11px; color: var(--txt-dim); }
.rank-pts { font-weight: 700; font-size: 18px; }
.rank-pts small { font-size: 11px; color: var(--txt-dim); font-weight: 600; }

/* Stats */
.stat-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.stat { background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); padding: 16px; }
.stat .v { font-size: 26px; font-weight: 700; }
.stat .v.accent { color: var(--txt); }
.stat .l { font-size: 11px; color: var(--txt-dim); text-transform: uppercase; letter-spacing: .5px; margin-top: 4px; }

/* Forms */
.field { width: 100%; background: var(--card-2); border: 1px solid var(--line); color: var(--txt);
  border-radius: 12px; padding: 12px; font-size: 14px; margin-bottom: 10px; }
.btn { width: 100%; background: var(--accent); color: #fff; border: none; border-radius: 12px;
  padding: 13px; font-size: 15px; font-weight: 700; cursor: pointer; }
.btn.ghost { background: var(--card); border: 1px solid var(--line); color: var(--txt); }
/* login screen */
.login { min-height: 100svh; display: flex; flex-direction: column; align-items: center; justify-content: flex-start;
  text-align: center; gap: 10px; padding: 56px 24px 24px; }
.login-logo { width: 110px; height: 128px; background-color: var(--accent);
  -webkit-mask: url('logo-mark.png') no-repeat center / contain;
  mask: url('logo-mark.png') no-repeat center / contain; }
.login-title { font-family: var(--font-brand); font-style: italic; font-weight: 700; font-size: 34px;
  letter-spacing: 2px; margin-top: 6px; }
.login-sub { color: var(--txt-dim); font-size: 14px; margin-bottom: 18px; }
.login-msg { color: var(--accent); font-size: 13px; margin-bottom: 6px; }
.auth-btn { display: flex; align-items: center; justify-content: center; gap: 10px; width: 100%; max-width: 300px;
  padding: 12px 16px; border-radius: 12px; font-size: 15px; font-weight: 700; cursor: pointer;
  border: 1px solid transparent; }
.auth-btn svg { flex: none; }
.auth-google { background: #fff; color: #1f1f1f; border-color: #dadce0; }
.auth-apple { background: #000; color: #fff; margin-top: 10px; }
.auth-apple.auth-disabled { opacity: .45; cursor: default; }
.auth-soon { font-size: 11px; font-weight: 400; opacity: .7; margin-left: 2px; }
.auth-divider { display: flex; align-items: center; gap: 10px; width: 100%; max-width: 300px;
  margin: 16px 0 4px; color: var(--txt-dim); font-size: 12px; }
.auth-divider::before,.auth-divider::after { content:""; flex:1; height:1px; background:var(--line); }
.auth-input { width: 100%; max-width: 300px; padding: 12px 14px; border-radius: 12px;
  border: 1px solid var(--line); background: var(--card); color: var(--txt);
  font-size: 15px; margin-top: 8px; box-sizing: border-box; outline: none; }
.auth-input:focus { border-color: var(--blue); }
.auth-email-btn { margin-top: 10px; background: var(--accent); color: #fff; border-color: transparent; }
.auth-email-btn:disabled { opacity: .5; cursor: default; }
.auth-email-links { display: flex; justify-content: space-between; width: 100%; max-width: 300px;
  margin-top: 10px; font-size: 12px; }
.auth-email-links a { color: var(--txt-dim); text-decoration: underline; cursor: pointer; }
.login-demo { background: none; border: none; color: var(--txt-dim); font-size: 13px;
  text-decoration: underline; cursor: pointer; margin-top: 16px; }

/* Bottom nav */
.bottomnav { flex: none; display: flex; background: rgba(var(--bar),.92);
  backdrop-filter: blur(12px); border-top: 1px solid var(--line); z-index: 20;
  padding-bottom: env(safe-area-inset-bottom, 0px); }
.nav-btn { flex: 1; background: none; border: none; color: var(--txt-dim); padding: 10px 0 14px;
  font-size: 10px; font-weight: 700; display: flex; flex-direction: column; align-items: center;
  gap: 3px; cursor: pointer; }
.nav-btn span { font-size: 20px; }
.nav-btn.active { color: var(--accent); }

/* Misc */
.back { color: var(--txt-dim); background: none; border: none; font-size: 14px; cursor: pointer;
  margin-bottom: 8px; padding: 4px 0; }
.muted { color: var(--txt-dim); font-size: 13px; }
.center { text-align: center; padding: 40px 0; color: var(--txt-dim); }
.hidden { display: none !important; }
.toast { position: fixed; bottom: 84px; left: 50%; transform: translateX(-50%);
  background: var(--card-2); border: 1px solid var(--line); color: var(--txt); padding: 10px 18px;
  border-radius: 99px; font-size: 13px; font-weight: 600; z-index: 50; box-shadow: 0 8px 24px rgba(0,0,0,.4); }
.invite-code { font-family: ui-monospace, monospace; background: var(--card-2); padding: 4px 10px;
  border-radius: 8px; border: 1px solid var(--line); letter-spacing: 2px; }
.row-between { display: flex; justify-content: space-between; align-items: center; }

/* Logo */
.brand { display: flex; align-items: center; }
.logo { width: 26px; height: 30px; margin-right: 0; background-color: var(--accent);
  -webkit-mask: url('logo-mark.png') no-repeat center / contain;
  mask: url('logo-mark.png') no-repeat center / contain; }

/* Avatars */
.ava { position: relative; border-radius: 50%; flex: none;
  background: linear-gradient(135deg, #2a2a38, #14141c);
  display: flex; align-items: center; justify-content: center; }
.ava-fallback { font-weight: 700; color: var(--txt-dim); }
.ava-img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover;
  border-radius: 50%; background: #14141c; }
.ava-flag { position: absolute; bottom: -2px; right: -2px; width: 42%; height: 42%;
  border-radius: 50%; object-fit: cover; border: 2px solid var(--card); background: var(--card); }
.ava-md { width: 60px; height: 60px; margin: 0 auto 8px; }
.ava-md .ava-fallback { font-size: 20px; }
.ava-sm { width: 38px; height: 38px; }
.ava-sm .ava-fallback { font-size: 14px; }
.ava-lg { width: 84px; height: 84px; }
.ava-lg .ava-fallback { font-size: 30px; }
.corner.red .ava { box-shadow: 0 0 0 2px rgba(255, 59, 59, .55); }
.corner.blue .ava { box-shadow: 0 0 0 2px rgba(59, 130, 246, .55); }
.corner.win .ava { box-shadow: 0 0 0 2px var(--green); }

/* Hero banner */
.hero { position: relative; border-radius: var(--radius); overflow: hidden;
  margin-bottom: 14px; border: 1px solid var(--line); }
.hero-bg { position: absolute; inset: 0; background:
  radial-gradient(130% 100% at 100% 0%, rgba(255, 59, 59, .38), transparent 55%),
  linear-gradient(135deg, #2a1016, #0b0b0f 72%); }
.hero-octagon { position: absolute; right: -28px; top: -22px; width: 175px; height: 175px; opacity: .12; }
.hero-content { position: relative; padding: 18px 16px; color: #fff; }  /* hero bg is always dark → light text */
.hero-title { font-size: 22px; font-weight: 700; margin: 10px 0 4px; line-height: 1.15; color: #fff; }
.hero-meta { color: rgba(255,255,255,.78); font-size: 12px; margin-bottom: 12px; }
.hero .cd-label { color: rgba(255,255,255,.7); }

/* Event card accent */
.event-card { position: relative; overflow: hidden; }
.event-card.dimmed { opacity: .5; filter: grayscale(.5); }
.event-card.dimmed:active { opacity: .8; }
/* pulsing red LIVE chip next to the Spotlight title */
.live-dot { color: var(--accent); font-size: 11px; font-weight: 700; letter-spacing: .05em; margin-left: 8px; animation: livepulse 1.5s ease-in-out infinite; }
@keyframes livepulse { 0%,100% { opacity: 1; } 50% { opacity: .35; } }
/* app footer (legal links) */
.app-footer { margin: 22px 0 8px; text-align: center; }
.foot-links { display: flex; justify-content: center; gap: 8px; flex-wrap: wrap; }
.foot-links a { color: var(--txt-dim); font-size: 12px; cursor: pointer; text-decoration: underline; }
.foot-links span { color: var(--line); font-size: 12px; }
.foot-meta { color: var(--txt-dim); font-size: 11px; margin-top: 8px; opacity: .7; }
/* simple modal (legal pages) */
.modal-ov { position: fixed; inset: 0; background: rgba(0,0,0,.6); z-index: 100; display: flex;
  align-items: center; justify-content: center; padding: 20px; }
.modal { background: var(--card); border: 1px solid var(--line); border-radius: 16px; max-width: 460px;
  width: 100%; max-height: 80svh; display: flex; flex-direction: column; overflow: hidden; }
.modal-head { display: flex; align-items: center; justify-content: space-between; padding: 14px 16px;
  border-bottom: 1px solid var(--line); }
.modal-x { background: none; border: none; color: var(--txt-dim); font-size: 16px; cursor: pointer; }
.modal-body { padding: 16px; overflow-y: auto; color: var(--txt-dim); font-size: 13px; line-height: 1.6; }

/* Fighter avatar picker */
.fpick-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 8px; }
.fpick { aspect-ratio: 1/1; border-radius: 50%; cursor: pointer; padding: 0;
  background: #fff;
  border: 3px solid transparent; transition: border-color .15s, transform .1s; overflow: hidden; }
.fpick:hover { transform: scale(1.05); }
.fpick.selected { border-color: var(--accent); transform: scale(1.05); }
.fpick svg, .fpick img { width: 100%; height: 100%; display: block; object-fit: cover; }
@container app (max-width:380px) { .fpick-grid { grid-template-columns: repeat(4, 1fr); } }

/* Profile setup modal */
.ps-label { color: var(--txt); font-size: 13px; font-weight: 600; margin-bottom: 4px; }
.ps-input { margin-top: 0 !important; }
.ps-gender { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 6px; }
.ps-gender .seg-btn { padding: 9px 6px; font-size: 12px; }
.ps-gender .seg-btn.sel { background: var(--accent); color: #fff; border-color: var(--accent); }

/* DOB three-select row */
.dob-row { display: grid; grid-template-columns: 1fr 1.4fr 1fr; gap: 6px; }
.dob-sel { width: 100%; padding: 11px 10px; border-radius: 10px; border: 1px solid var(--line);
  background: var(--card); color: var(--txt); font-size: 14px; outline: none; appearance: none;
  -webkit-appearance: none; background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path fill='%239aa' d='M0 0l5 6 5-6z'/></svg>");
  background-repeat: no-repeat; background-position: right 10px center; padding-right: 28px; }
.dob-sel:focus { border-color: var(--blue); }

/* "oder Avatar wählen" divider */
.ps-or { display: flex; align-items: center; gap: 10px; margin: 14px 0 10px; color: var(--txt-dim); font-size: 12px; }
.ps-or::before, .ps-or::after { content: ""; flex: 1; height: 1px; background: var(--line); }

/* Skeleton loading placeholders */
.skeleton { background: linear-gradient(90deg, rgba(0,0,0,.06) 25%, rgba(0,0,0,.12) 50%, rgba(0,0,0,.06) 75%);
  background-size: 200% 100%; animation: skel 1.2s infinite; border-radius: 8px; }
html:not(.light) .skeleton { background: linear-gradient(90deg, rgba(255,255,255,.05) 25%, rgba(255,255,255,.12) 50%, rgba(255,255,255,.05) 75%);
  background-size: 200% 100%; }
@keyframes skel { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }
.skel-line { height: 12px; margin: 8px 0; }
.skel-stat { height: 64px; }
.del-title { font-weight: 700; font-size: 13px; color: var(--txt); margin: 14px 0 4px; }
.del-reason { display: flex; align-items: center; gap: 8px; padding: 7px 0; font-size: 13px; color: var(--txt); cursor: pointer; }
.del-reason input { accent-color: var(--accent); }
.del-btn { background: var(--accent); }
.event-card::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 4px;
  background: linear-gradient(180deg, var(--accent), var(--accent-2)); }
.ev-thumbs { display: flex; flex: none; }
.ev-thumbs .ava { margin: 0; }
.ev-thumbs .ava:last-child { margin-left: -12px; border-radius: 50%; }
.event-card .event-name { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* Home hero (featured event) */
.home-hero { position: relative; border-radius: 18px; overflow: hidden; border: 1px solid var(--line);
  min-height: 270px; margin-bottom: 14px; cursor: pointer; }
.hh-photos { position: absolute; inset: 0; display: grid; grid-template-columns: 1fr 1fr; }
.hh-photo { position: relative; overflow: hidden; }
.hh-photo img { width: 100%; height: 100%; object-fit: cover; object-position: top center; }
.hh-photo.red { background: radial-gradient(110% 100% at 0 0, rgba(232,19,43,.30), #121217); }
.hh-photo.blue { background: radial-gradient(110% 100% at 100% 0, rgba(59,130,246,.28), #121217); }
.hh-grad { position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(10,10,12,.2) 0, transparent 28%, rgba(10,10,12,.94) 86%); }
.hh-top { position: absolute; top: 12px; left: 12px; display: flex; gap: 6px; }
.hh-badge { font-family: var(--font-head); font-size: 11px; font-weight: 700; letter-spacing: .5px;
  padding: 4px 9px; border-radius: 6px; background: rgba(0,0,0,.5); color: #fff; border: 1px solid rgba(255,255,255,.15); }
.hh-badge.live { background: var(--accent); border-color: var(--accent); }
.hh-badge.ppv { background: var(--accent-2); border-color: var(--accent-2); color: #1a1a1a; }
.hh-body { position: absolute; left: 0; right: 0; bottom: 0; padding: 16px; }
.hh-event { font-family: var(--font-brand); font-style: italic; text-transform: uppercase; font-weight: 700;
  font-size: 23px; line-height: 1.05; color: #fff; }
.hh-matchup { font-size: 13px; color: #e8e8ee; margin-top: 4px; font-weight: 600; }
.hh-matchup span { color: var(--accent); }
.hh-meta { font-size: 11px; color: rgba(255,255,255,.72); margin: 3px 0 2px; }
.hh-watch { font-size: 11px; color: #e8e8ee; font-weight: 600; margin: 0 0 12px; }
/* dark outline so white hero text stays readable over bright photo areas (both themes) */
.hh-event, .hh-matchup, .hh-meta, .hh-watch { text-shadow: 0 1px 3px rgba(0,0,0,.8), 0 0 2px rgba(0,0,0,.6); }
.hh-cta { background: linear-gradient(135deg, var(--accent), var(--accent-2)); }

/* Profile head */
.set-title { font-weight: 700; font-size: 14px; margin: 0 0 8px; }
.profile-head { display: flex; flex-direction: row; align-items: center; text-align: left; gap: 14px; padding: 14px 16px; }
.profile-head .ava-lg { width: 58px; height: 58px; }
.profile-head .ava-lg .ava-fallback { font-size: 21px; }
.profile-head .avatar-edit { width: 22px; height: 22px; font-size: 11px; border-width: 2px; }
.ph-info { min-width: 0; display: flex; flex-direction: column; gap: 4px; align-items: flex-start; }
.profile-name { font-size: 19px; font-weight: 700; }
.profile-head .streak-badge { margin-top: 2px; }

/* === Visual refresh (Stitch-inspired) === */
.brand, .brand-mark { font-family: var(--font-brand); font-style: italic; letter-spacing: 1px; }
.hero-title, .profile-name { font-family: var(--font-brand); font-style: italic;
  text-transform: uppercase; letter-spacing: .5px; }
.event-name { font-family: var(--font-head); text-transform: uppercase; letter-spacing: .3px; }
.corner .cn { font-family: var(--font-head); text-transform: uppercase; letter-spacing: .3px; font-weight: 600; }
.rank-pts, .rank-no, .stat .v { font-family: var(--font-head); }

/* Countdown boxes */
.cd-label { font-size: 10px; letter-spacing: 1.5px; color: var(--txt-dim); text-transform: uppercase;
  margin: 4px 0 6px; font-weight: 700; }
.countdown-box { display: flex; gap: 6px; }
.cd-cell { background: var(--card-2); border: 1px solid var(--line); border-radius: 10px;
  padding: 7px 0; min-width: 48px; text-align: center; }
.cd-num { font-family: var(--font-head); font-size: 22px; font-weight: 700; color: var(--txt); line-height: 1; }
.cd-unit { font-size: 9px; color: var(--txt-dim); letter-spacing: 1px; margin-top: 4px; }
.cd-mini .cd-cell { min-width: 34px; padding: 4px 0; }
.cd-mini .cd-num { font-size: 15px; }
.cd-mini .cd-unit { font-size: 8px; margin-top: 2px; }

/* Community pick bar */
.community { margin-top: 12px; }
.cbar { display: flex; height: 8px; border-radius: 99px; overflow: hidden; background: var(--card-2); }
.cbar .cb-red { background: var(--accent); }
.cbar .cb-blue { background: var(--blue); }
.community-hint { font-size: 10px; color: var(--txt-dim); margin-top: 6px; text-align: center; }

/* Podium */
.podium { display: flex; align-items: flex-end; gap: 8px; margin-bottom: 16px; }
.pod { flex: 1; background: var(--card); border: 1px solid var(--line); border-radius: 14px;
  padding: 16px 8px 12px; text-align: center; position: relative; }
.pod.first { padding-top: 22px; background: linear-gradient(180deg, rgba(245,197,24,.18), var(--card));
  border-color: var(--gold); }
.pod.second { background: linear-gradient(180deg, rgba(207,210,216,.14), var(--card)); border-color: rgba(207,210,216,.5); }
.pod.second .pod-rank { color: var(--silver); }
.pod.second .ava { box-shadow: 0 0 0 2px var(--silver); }
.pod.third { background: linear-gradient(180deg, rgba(205,127,50,.16), var(--card)); border-color: rgba(205,127,50,.5); }
.pod.third .pod-rank { color: var(--bronze); }
.pod.third .ava { box-shadow: 0 0 0 2px var(--bronze); }
.pod-crown { position: absolute; top: -22px; left: 50%; transform: translateX(-50%); width: 56px; height: 34px; }
.pod-rank { font-family: var(--font-head); font-weight: 700; font-size: 13px; color: var(--txt-dim); }
.pod.first .pod-rank { color: var(--gold); }
.pod-name { font-weight: 700; font-size: 13px; margin-top: 4px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.pod-pts { font-family: var(--font-head); font-weight: 700; font-size: 18px; color: var(--txt); margin-top: 2px; }
.pod.first .pod-pts { color: #c8900a; }   /* gold */
.pod.second .pod-pts { color: #9aa0a8; }  /* silber */
.pod.third .pod-pts { color: #c17d3c; }   /* bronze */
.pod-pts small { font-size: 10px; color: var(--txt-dim); }
.pod .ava { margin: 0 auto 6px; }
.pod.first .ava { box-shadow: 0 0 0 2px var(--gold); }

/* Quick Pick screen */
.ava-xl { width: 110px; height: 110px; margin: 0 auto 10px; }
.ava-xl .ava-fallback { font-size: 40px; }
.pick-btn { margin-top: 12px; }
.qp { }
.qp-meta { font-size: 11px; color: var(--txt-dim); text-transform: uppercase; letter-spacing: .5px; text-align: center; }
.qp-prompt { font-family: var(--font-head); text-transform: uppercase; letter-spacing: 1px;
  text-align: center; color: var(--txt-dim); font-size: 13px; margin: 6px 0 16px; }
.qp-fighters { display: grid; grid-template-columns: 1fr auto 1fr; gap: 8px; align-items: stretch; }
.qp-card { position: relative; min-height: 210px; border-radius: 16px; overflow: hidden;
  border: 2px solid var(--line); background: var(--card); cursor: pointer; transition: all .15s; }
.qpf-fallback { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
  font-family: var(--font-head); font-size: 54px; font-weight: 700; color: #3a3a46;
  background: radial-gradient(120% 80% at 50% 18%, #20202a, #121217); }
.qp-card.red .qpf-fallback { background: radial-gradient(120% 80% at 50% 18%, rgba(232,19,43,.20), #121217); }
.qp-card.blue .qpf-fallback { background: radial-gradient(120% 80% at 50% 18%, rgba(59,130,246,.20), #121217); }
.qpf-photo { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: top center; }
.qpf-grad { position: absolute; inset: 0; background: linear-gradient(180deg, transparent 38%, rgba(0,0,0,.88)); }
.qpf-corner { position: absolute; top: 10px; left: 10px; font-family: var(--font-head); font-size: 11px;
  font-weight: 700; letter-spacing: .5px; padding: 3px 8px; border-radius: 6px; }
.qpf-corner.red { background: var(--accent); color: #fff; }
.qpf-corner.blue { background: var(--blue); color: #fff; }
.qpf-check { position: absolute; top: 8px; right: 8px; width: 26px; height: 26px; border-radius: 50%;
  background: var(--green); color: #fff; display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 14px; }
.qpf-odds { position: absolute; top: 9px; right: 10px; padding: 2px 7px; border-radius: 7px;
  background: rgba(0,0,0,.55); border: 1px solid var(--line); color: var(--gold);
  font-family: var(--font-head); font-weight: 700; font-size: 12px; backdrop-filter: blur(2px); }
.qp-card.sel .qpf-odds { right: 42px; }
.qpf-info { position: absolute; left: 0; right: 0; bottom: 0; padding: 12px; text-align: left; }
.qpf-rec { display: flex; align-items: center; gap: 6px; font-size: 12px; color: var(--txt-dim); margin-top: 3px; }
.qpf-flag { width: 18px; height: 18px; border-radius: 50%; object-fit: cover; }
.qp-card.red.sel { border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent) inset, 0 0 20px rgba(232,19,43,.35); }
.qp-card.blue.sel { border-color: var(--blue); box-shadow: 0 0 0 1px var(--blue) inset, 0 0 20px rgba(59,130,246,.35); }
.qp-vs { align-self: center; font-family: var(--font-brand); font-weight: 700; color: var(--txt-dim); font-size: 14px; }
.qp-name { font-family: var(--font-head); text-transform: uppercase; font-weight: 600; font-size: 17px; line-height: 1.1; color: #fff; }
.qp-section { font-size: 11px; color: var(--txt-dim); text-transform: uppercase; letter-spacing: 1px;
  font-weight: 700; margin: 20px 0 8px; }
.seg { display: flex; gap: 8px; background: var(--card); border: 1px solid var(--line);
  border-radius: 12px; padding: 6px; }
.seg-btn { flex: 1; background: transparent; border: none; color: var(--txt-dim); border-radius: 9px;
  padding: 11px 6px; font-weight: 700; font-size: 13px; cursor: pointer; font-family: var(--font-head);
  letter-spacing: .5px; }
.seg-btn.sel { background: var(--blue); color: #fff; }
.seg-disabled { opacity: .4; pointer-events: none; }
.lock-btn { margin-top: 22px; }
.lock-btn[disabled] { opacity: .45; cursor: default; }

/* Profile stat extras */
.stat-top { display: flex; align-items: baseline; gap: 8px; }
.stat-delta { font-size: 12px; font-weight: 700; }
.stat-delta.up { color: var(--green); }
.stat-delta.down { color: var(--txt); }
.acc-bar { height: 6px; background: var(--card-2); border-radius: 99px; overflow: hidden; margin: 8px 0 6px; }
.acc-bar > span { display: block; height: 100%; background: linear-gradient(90deg, var(--accent), var(--blue)); }
.stat .v.blue { color: var(--txt); }
.perfect-dots { display: flex; gap: 5px; margin: 8px 0 6px; }
.perfect-dots i { width: 9px; height: 9px; border-radius: 50%; background: var(--blue); display: inline-block; }
.invite-btn { margin-bottom: 14px; }
.trend-tag { font-family: var(--font-head); font-size: 10px; font-weight: 700; letter-spacing: .5px; padding: 3px 8px; border-radius: 6px; }
.trend-tag.up { background: rgba(34,197,94,.18); color: var(--green); }
.trend-tag.down { background: rgba(232,19,43,.18); color: var(--accent); }

/* Reminder bar */
.rem-bar { display: flex; gap: 8px; margin-bottom: 14px; }
.rem-btn { flex: 1; background: var(--card); border: 1px solid var(--line); color: var(--txt);
  border-radius: 12px; padding: 11px; font-size: 13px; font-weight: 700; cursor: pointer; }
.rem-btn.on { background: var(--blue); border-color: var(--blue); color: #fff; }

/* Streak badge */
.streak-badge { display: inline-flex; align-items: center; gap: 4px; background: var(--accent); color: #fff;
  font-family: var(--font-head); font-weight: 700; font-size: 12px; letter-spacing: .5px; padding: 4px 12px;
  border-radius: 99px; text-transform: uppercase; margin-top: -14px; position: relative; z-index: 2; }

/* Creator-league tiles (horizontal scroll) */
.league-scroll { display: flex; gap: 12px; overflow-x: auto; padding: 2px 2px 10px; scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch; }
.league-scroll::-webkit-scrollbar { display: none; }
.league-tile { flex: 0 0 80%; scroll-snap-align: start; position: relative; height: 150px; border-radius: 16px;
  overflow: hidden; border: 1px solid var(--line); cursor: pointer; }
.lt-img { position: absolute; inset: 0; background: linear-gradient(135deg, #2a1016, #121217); }
.lt-img img { width: 100%; height: 100%; object-fit: cover; }
.lt-grad { position: absolute; inset: 0; background: linear-gradient(180deg, transparent 35%, rgba(0,0,0,.9)); }
.lt-badge { position: absolute; top: 10px; left: 10px; font-family: var(--font-head); font-size: 10px; font-weight: 700;
  letter-spacing: .5px; padding: 3px 8px; border-radius: 6px; background: var(--blue); color: #fff; }
.lt-badge.verified { background: var(--blue); }
.lt-body { position: absolute; left: 0; right: 0; bottom: 0; padding: 12px; }
.lt-name { font-family: var(--font-head); text-transform: uppercase; font-weight: 600; font-size: 16px; color: #fff; }
.lt-meta { font-size: 11px; color: var(--txt-dim); margin: 3px 0 8px; }
.lt-join { background: var(--accent); color: #fff; border: none; border-radius: 8px; padding: 7px 14px;
  font-weight: 700; font-size: 12px; cursor: pointer; }
.lt-join.joined { background: var(--card-2); color: var(--txt-dim); border: 1px solid var(--line); }

/* My groups row */
.group-row { display: flex; align-items: center; justify-content: space-between; padding: 14px; }
.group-row .gr-rank { font-family: var(--font-head); font-weight: 700; color: var(--blue); }
.live-dot { color: var(--accent); font-size: 10px; }

/* Trend chart */
.trend-card .trend-top { display: flex; align-items: baseline; gap: 8px; }
.trend-val { font-family: var(--font-head); font-size: 26px; font-weight: 700; }
.trend-delta { font-size: 12px; font-weight: 700; }
.trend-delta.up { color: var(--green); } .trend-delta.down { color: var(--accent); }
.trend-svg { width: 100%; height: 90px; margin-top: 8px; display: block; }
.trend-x { display: flex; justify-content: space-between; font-size: 9px; color: var(--txt-dim); margin-top: 4px; }

/* Latest picks */
.pick-row { display: flex; align-items: center; gap: 12px; padding: 12px 14px; }
.pick-ic { width: 26px; height: 26px; border-radius: 50%; display: flex; align-items: center; justify-content: center;
  font-size: 14px; font-weight: 700; flex: none; }
.pick-ic.ok { background: rgba(34,197,94,.18); color: var(--green); }
.pick-ic.miss { background: rgba(232,19,43,.18); color: var(--accent); }
.pick-ic.open { background: var(--card-2); color: var(--txt-dim); }
.pick-main { flex: 1; }
.pick-title { font-weight: 700; font-size: 13px; }
.pick-sub { font-size: 11px; color: var(--txt-dim); margin-top: 2px; }
.pick-res { font-family: var(--font-head); font-weight: 700; font-size: 12px; }
.pick-res.ok { color: var(--green); } .pick-res.miss { color: var(--txt-dim); }

/* Avatar upload (profile) */
.avatar-upload { position: relative; cursor: pointer; display: inline-block; }
.avatar-edit { position: absolute; bottom: 0; right: 0; width: 28px; height: 28px;
  border-radius: 50%; background: var(--blue); color: #fff; display: flex;
  align-items: center; justify-content: center; font-size: 13px; border: 2px solid var(--bg); z-index: 2; }
.avatar-upload:hover .avatar-edit { background: var(--accent-2); }

/* Avatar color swatches (account creation) */
.avatar-color-grid { display: flex; gap: 10px; flex-wrap: wrap; justify-content: center; }
.color-swatch { width: 36px; height: 36px; border-radius: 50%; border: 3px solid transparent;
  cursor: pointer; transition: transform .1s; }
.color-swatch:active { transform: scale(.9); }
.color-swatch.sel { border-color: #fff; box-shadow: 0 0 0 2px rgba(255,255,255,.5); }

/* Private/Public toggle */
.toggle-row { display: flex; align-items: center; gap: 10px; color: var(--txt-dim);
  font-size: 13px; padding: 10px 4px; cursor: pointer; }
.toggle-row input[type=checkbox] { width: 18px; height: 18px; cursor: pointer; accent-color: var(--blue); }

/* Rank movement */
.rank-move { font-size: 10px; font-weight: 700; margin-top: 2px; }
.rank-move.up { color: var(--green); } .rank-move.down { color: var(--accent); } .rank-move.flat { color: var(--txt-dim); }

/* Bottom-nav center FAB (Quick Pick) — keep .bottomnav position:fixed (from base) */
.nav-fab-slot { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: flex-end;
  padding-bottom: 14px; }
.nav-fab { width: 50px; height: 50px; border-radius: 50%; margin-top: -26px;
  background: linear-gradient(135deg, var(--accent), var(--accent-2)); color: #fff; border: 4px solid var(--bg);
  font-size: 22px; line-height: 1; cursor: pointer; box-shadow: 0 6px 18px rgba(232,19,43,.45);
  display: flex; align-items: center; justify-content: center; z-index: 22; }
.nav-fab:active { transform: scale(.94); }
.nav-fab-label { font-size: 10px; font-weight: 700; color: var(--accent); margin-top: 4px; }
