/* ── Variables ───────────────────────────────────────────────────── */
:root {
  --bg:        #060b10;
  --surface:   #0c1219;
  --card:      #111820;
  --card2:     #161f2a;
  --border:    #172030;
  --border2:   #1e2d3e;
  --accent:    #03E2E2;
  --accent-g:  rgba(3,226,226,0.10);
  --accent-b:  rgba(3,226,226,0.25);
  --amber:     #f0a500;
  --red:       #ff4d6d;
  --green:     #00c97a;
  --blue:      #4d9fff;
  --text:      #e4ecf4;
  --muted:     #486070;
  --muted2:    #6a8499;
  --dim:       #0a1520;
  --safe-top:  env(safe-area-inset-top, 0px);
  --safe-bot:  env(safe-area-inset-bottom, 0px);
}

* { margin:0; padding:0; box-sizing:border-box; -webkit-tap-highlight-color:transparent; }
html { scroll-behavior:smooth; }
body {
  background:var(--bg);
  color:var(--text);
  font-family:'DM Sans',sans-serif;
  min-height:100dvh;
  overflow-x:hidden;
  overscroll-behavior:none;
}

/* ── Grid background ─────────────────────────────────────────────── */
body::before {
  content:'';position:fixed;inset:0;
  background-image:
    linear-gradient(rgba(3,226,226,.012) 1px,transparent 1px),
    linear-gradient(90deg,rgba(3,226,226,.012) 1px,transparent 1px);
  background-size:40px 40px;
  pointer-events:none;z-index:0;
}

/* ── Splash ──────────────────────────────────────────────────────── */
#splash {
  position:fixed;inset:0;z-index:100;
  background:var(--bg);
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:8px;
  animation:splashOut 0.4s ease 1.8s forwards;
}
.splash-logo {
  font-family:'DM Sans',sans-serif;
  font-size:48px;font-weight:700;letter-spacing:-.02em;color:var(--text);
}
.splash-logo span { color:var(--accent); }
.splash-sub {
  font-family:'DM Mono',monospace;
  font-size:11px;letter-spacing:.2em;color:var(--muted);
}
.splash-dot {
  width:6px;height:6px;border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 12px var(--accent);
  margin-top:20px;
  animation:pulseDot 1s infinite;
}
@keyframes pulseDot{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.5);opacity:.6}}
@keyframes splashOut{to{opacity:0;pointer-events:none}}

/* ── Auth ────────────────────────────────────────────────────────── */
#auth-screen {
  position:fixed;
  inset:0;
  z-index:50;
  background:var(--bg);
  overflow-y:auto;
  overflow-x:hidden;
}
.auth-wrap {
  width:100%;
  max-width:440px;
  margin:0 auto;
  padding:40px 20px 60px;
  box-sizing:border-box;
  display:block;
}
.auth-logo {
  font-family:'DM Sans',sans-serif;
  font-size:34px;font-weight:700;letter-spacing:-.02em;
  color:var(--text);margin-bottom:4px;
}
.auth-logo span { color:var(--accent); }
.auth-tagline { font-size:14px;color:var(--muted2);margin-bottom:32px;line-height:1.5; }
.auth-tabs {
  display:flex;gap:2px;
  background:var(--dim);border-radius:10px;padding:3px;
  margin-bottom:24px;
}
.auth-tab {
  flex:1;padding:9px;border:none;border-radius:8px;
  font-family:'DM Mono',monospace;font-size:12px;letter-spacing:.06em;
  background:transparent;color:var(--muted);cursor:pointer;transition:all .2s;
}
.auth-tab.active { background:var(--card2);color:var(--accent); }
.field { margin-bottom:16px; }
.field label {
  display:block;font-family:'DM Mono',monospace;
  font-size:10px;letter-spacing:.14em;color:var(--muted);
  margin-bottom:6px;text-transform:uppercase;
}
.field input {
  width:100%;background:var(--dim);
  border:1px solid var(--border2);border-radius:10px;
  padding:13px 14px;color:var(--text);font-size:15px;
  font-family:'DM Sans',sans-serif;outline:none;
  transition:border-color .2s;
}
.field input:focus { border-color:var(--accent); }
.btn-primary {
  width:100%;background:var(--accent);color:var(--bg);
  border:none;border-radius:10px;padding:15px;
  font-family:'Bebas Neue',sans-serif;font-size:18px;letter-spacing:.08em;
  cursor:pointer;transition:opacity .2s;margin-top:4px;
}
.btn-primary:hover { opacity:.9; }
.btn-primary:active { opacity:.8;transform:scale(.99); }
.btn-primary:disabled { opacity:.4;cursor:not-allowed; }
.auth-error {
  margin-top:10px;font-size:13px;color:var(--red);
  min-height:20px;text-align:center;
}
.auth-guest {
  text-align:center;margin-top:20px;
  font-size:13px;color:var(--muted);cursor:pointer;
  transition:color .2s;
}
.auth-guest:hover { color:var(--accent); }

/* ── App shell ───────────────────────────────────────────────────── */
#app {
  position:fixed;inset:0;
  display:flex;flex-direction:column;
  padding-top:calc(var(--safe-top) + 56px);
  padding-bottom:calc(var(--safe-bot) + 78px);
}

/* ── Top bar ─────────────────────────────────────────────────────── */
.topbar {
  position:fixed;top:0;left:0;right:0;z-index:40;
  height:calc(var(--safe-top) + 56px);
  padding-top:var(--safe-top);
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;
  padding-left:16px;padding-right:16px;
  background:rgba(6,11,16,.92);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);
}
.topbar-title {
  font-family:'Pacifico',cursive;
  font-size:18px;letter-spacing:.02em;color:var(--accent);
  text-align:center;line-height:1;
}
.topbar-logo {
  font-family:'DM Sans',sans-serif;
  font-size:20px;font-weight:700;letter-spacing:-.02em;color:var(--text);
}
.topbar-logo span { color:var(--accent); }
.topbar-right { display:flex;align-items:center;gap:10px;justify-content:flex-end; }
.live-badge {
  font-family:'DM Mono',monospace;font-size:10px;letter-spacing:.1em;
  color:var(--red);border:1px solid var(--red);
  border-radius:20px;padding:3px 8px;
  animation:pulse 1.5s infinite;
}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}
.avatar-btn { background:none;border:none;cursor:pointer;padding:0; }
.avatar {
  width:32px;height:32px;border-radius:50%;
  background:var(--accent-g);border:1px solid var(--accent-b);
  display:flex;align-items:center;justify-content:center;
  font-family:'Bebas Neue',sans-serif;font-size:14px;color:var(--accent);
}

/* ── Pages ───────────────────────────────────────────────────────── */
#pages { flex:1;overflow:hidden;position:relative; }
.page {
  position:absolute;inset:0;
  opacity:0;pointer-events:none;
  transition:opacity .2s;
}
.page.active { opacity:1;pointer-events:all; }
.page-scroll {
  height:100%;overflow-y:auto;
  padding:16px 16px 8px;
  overscroll-behavior:contain;
}

/* ── Date strip ──────────────────────────────────────────────────── */
.date-strip {
  display:flex;gap:8px;overflow-x:auto;
  padding-bottom:12px;margin-bottom:4px;
  scrollbar-width:none;
}
.date-strip::-webkit-scrollbar { display:none; }
.date-chip {
  flex-shrink:0;
  display:flex;flex-direction:column;align-items:center;
  padding:8px 14px;border-radius:10px;
  background:var(--card);border:1px solid var(--border);
  cursor:pointer;transition:all .15s;min-width:52px;
}
.date-chip.active {
  background:var(--accent-g);border-color:var(--accent-b);
}
.date-chip-day {
  font-family:'DM Mono',monospace;font-size:9px;
  letter-spacing:.1em;color:var(--muted);text-transform:uppercase;
}
.date-chip-num {
  font-family:'Bebas Neue',sans-serif;font-size:20px;
  color:var(--text);line-height:1;margin:2px 0;
}
.date-chip.active .date-chip-num { color:var(--accent); }
.date-chip-count {
  font-family:'DM Mono',monospace;font-size:9px;
  color:var(--muted);
}

/* ── Section labels ──────────────────────────────────────────────── */
.section-label {
  font-family:'DM Sans',sans-serif;font-size:11px;font-weight:700;
  letter-spacing:.14em;color:#fff;
  margin-bottom:10px;text-transform:uppercase;
}

/* ── Top picks grid ──────────────────────────────────────────────── */
.picks-grid { display:flex;flex-direction:column;gap:8px; }
.pick-card {
  background:var(--card);border:1px solid var(--border);
  border-radius:12px;padding:14px;
  display:flex;align-items:center;gap:12px;
  cursor:pointer;transition:border-color .15s;
  position:relative;overflow:hidden;
}
.pick-card::before {
  content:'';position:absolute;left:0;top:0;bottom:0;
  width:3px;border-radius:3px 0 0 3px;
}
.pick-card.high::before { background:var(--accent); }
.pick-card.medium::before { background:var(--amber); }
.pick-card.low::before { background:var(--muted); }
.pick-card:hover { border-color:var(--accent-b); }
.pick-teams {
  flex:1;min-width:0;
}
.pick-match {
  font-size:13px;font-weight:600;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.pick-league {
  font-family:'DM Mono',monospace;font-size:9px;
  color:var(--muted);margin-top:2px;letter-spacing:.06em;
}
.pick-market {
  display:flex;flex-direction:column;align-items:flex-end;
  flex-shrink:0;gap:3px;min-width:72px;
}
.pick-market-name {
  font-family:'DM Mono',monospace;font-size:9px;
  color:var(--muted);letter-spacing:.08em;
}
.pick-market-val {
  font-family:'Bebas Neue',sans-serif;font-size:22px;
  color:var(--accent);line-height:1;
}
.pick-conf {
  font-family:'DM Mono',monospace;font-size:8px;
  letter-spacing:.08em;padding:2px 7px;border-radius:8px;
  margin-top:3px;display:inline-block;
}
.pick-conf.high { background:rgba(3,226,226,.12);color:var(--accent); }
.pick-conf.medium { background:rgba(240,165,0,.12);color:var(--amber); }
.bnc-pct-col .fc-bookmark { margin-top:4px; }

/* ── Fixtures header + sort toggle ──────────────────────────────── */
.fixtures-header {
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:10px;
}
.sort-toggle {
  display:flex;gap:4px;
}
.sort-btn {
  padding:4px 10px;border-radius:20px;
  border:1px solid var(--border2);background:transparent;
  color:#fff;font-family:'DM Sans',sans-serif;font-weight:700;
  font-size:9px;letter-spacing:.08em;cursor:pointer;
  transition:all .15s;white-space:nowrap;
}
.sort-btn.active {
  background:var(--accent-g);border-color:var(--accent-b);color:var(--accent);
}

/* ── League filter chips ─────────────────────────────────────────── */
.league-filter {
  display:flex;gap:6px;overflow-x:auto;
  padding-bottom:10px;margin-bottom:10px;
  scrollbar-width:none;
}
.league-filter::-webkit-scrollbar { display:none; }
.lf-chip {
  flex-shrink:0;padding:5px 12px;
  border-radius:20px;border:1px solid var(--border2);
  background:transparent;color:#fff;
  font-family:'DM Sans',sans-serif;font-size:10px;font-weight:700;
  cursor:pointer;transition:all .15s;white-space:nowrap;
}
.lf-chip.active {
  background:var(--accent-g);border-color:var(--accent-b);
  color:var(--accent);
}
.lf-chip--icon { display:inline-flex;align-items:center;gap:5px; }
.chip-icon { font-size:13px;line-height:1; }

/* ── Fixture cards ───────────────────────────────────────────────── */
.fixture-card {
  background:var(--card);border:1px solid var(--border);
  border-radius:12px;margin-bottom:8px;overflow:hidden;
  cursor:pointer;transition:border-color .15s;position:relative;
}
.fixture-card:hover { border-color:var(--accent-b); }
.fixture-card:active { transform:scale(.99); }
.fc-league {
  display:flex;align-items:center;justify-content:space-between;
  padding:6px 12px;background:var(--card2);
  border-bottom:1px solid var(--border);
}
.fc-league-name {
  font-family:'DM Mono',monospace;font-size:9px;
  letter-spacing:.08em;color:var(--muted);text-transform:uppercase;
}
.fc-league-right { display:flex;align-items:center;gap:8px; }
.fc-time {
  font-family:'DM Mono',monospace;font-size:9px;color:var(--muted);
}
.fc-bookmark {
  background:none;border:none;cursor:pointer;
  color:var(--muted);padding:2px;display:flex;align-items:center;
  transition:color .15s;flex-shrink:0;
}
.fc-bookmark.bookmarked { color:var(--accent); }
.fc-bookmark:hover { color:var(--accent); }
.fc-body {
  padding:12px;
  display:grid;grid-template-columns:1fr auto 1fr;
  align-items:center;gap:8px;
}
.fc-team {
  font-size:13px;font-weight:600;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.fc-team.away { text-align:right; }
.fc-vs {
  font-family:'Bebas Neue',sans-serif;font-size:14px;
  color:var(--muted);text-align:center;
}
.fc-markets {
  display:flex;gap:4px;padding:0 12px 10px;flex-wrap:wrap;
}
.fc-market-pill {
  display:flex;align-items:center;gap:4px;
  padding:3px 8px;border-radius:20px;
  background:var(--dim);border:1px solid var(--border);
}
.fc-market-label {
  font-family:'DM Mono',monospace;font-size:8px;
  letter-spacing:.06em;color:var(--muted);
}
.fc-market-val {
  font-family:'DM Mono',monospace;font-size:10px;
  font-weight:700;
}
.fc-market-val.btts-y { color:var(--accent); }
.fc-market-val.btts-n { color:var(--red); }
.fc-market-val.ou { color:var(--amber); }
.fc-market-val.res { color:var(--blue); }

/* ── Match drawer ────────────────────────────────────────────────── */
.drawer {
  position:fixed;left:0;right:0;bottom:0;z-index:60;
  background:var(--surface);
  border-radius:20px 20px 0 0;
  border:1px solid var(--border);
  border-bottom:none;
  max-height:92dvh;
  transform:translateY(100%);
  transition:transform .3s cubic-bezier(.16,1,.3,1);
  padding-bottom:var(--safe-bot);
}
.drawer.open { transform:translateY(0); }
.drawer-handle {
  width:36px;height:4px;border-radius:2px;
  background:var(--border2);margin:12px auto 0;
}
.drawer-scroll {
  overflow-y:auto;
  max-height:calc(92dvh - 28px);
  padding:16px;
}
.drawer-backdrop {
  position:fixed;inset:0;z-index:59;
  background:rgba(0,0,0,.6);
  opacity:0;pointer-events:none;
  transition:opacity .3s;
}
.drawer-backdrop.open { opacity:1;pointer-events:all; }

/* Match drawer content */
.md-header {
  margin-bottom:20px;
}
.md-league {
  font-family:'DM Mono',monospace;font-size:10px;
  letter-spacing:.1em;color:var(--accent);margin-bottom:6px;
}
.md-teams {
  display:grid;grid-template-columns:1fr auto 1fr;
  align-items:center;gap:8px;margin-bottom:6px;
}
.md-team { font-size:16px;font-weight:700; }
.md-team.away { text-align:right; }
.md-vs {
  font-family:'Bebas Neue',sans-serif;font-size:18px;
  color:var(--muted);text-align:center;
}
.md-meta {
  font-family:'DM Mono',monospace;font-size:10px;
  color:var(--muted);
}

/* Market sections */
.market-section {
  background:var(--card);border:1px solid var(--border);
  border-radius:12px;margin-bottom:10px;overflow:hidden;
}
.market-title {
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 14px;background:var(--card2);
  border-bottom:1px solid var(--border);
}
.market-name {
  font-family:'DM Mono',monospace;font-size:10px;
  letter-spacing:.12em;color:var(--muted);text-transform:uppercase;
}
.market-premium {
  font-family:'DM Mono',monospace;font-size:9px;
  color:var(--amber);border:1px solid rgba(240,165,0,.3);
  padding:2px 7px;border-radius:8px;
}
.market-body { padding:14px; }

/* Result market */
.result-grid {
  display:grid;grid-template-columns:1fr 1fr 1fr;
  gap:8px;
}
.result-box {
  text-align:center;padding:12px 8px;
  background:var(--dim);border-radius:8px;
  border:1px solid var(--border);
}
.result-label {
  font-family:'DM Mono',monospace;font-size:9px;
  color:var(--muted);letter-spacing:.08em;margin-bottom:4px;
}
.result-pct {
  font-family:'Bebas Neue',sans-serif;font-size:28px;
  line-height:1;
}
.result-pct.home { color:var(--accent); }
.result-pct.draw { color:var(--muted2); }
.result-pct.away { color:var(--blue); }
.result-bar {
  display:flex;height:4px;border-radius:2px;
  overflow:hidden;margin-top:12px;gap:2px;
}
.rb-h { background:var(--accent); }
.rb-d { background:var(--muted); }
.rb-a { background:var(--blue); }

/* BTTS market */
.btts-grid { display:grid;grid-template-columns:1fr 1fr;gap:8px; }
.btts-box {
  text-align:center;padding:12px;
  border-radius:8px;border:1px solid var(--border);
}
.btts-box.yes { background:rgba(3,226,226,.06);border-color:var(--accent-b); }
.btts-box.no  { background:rgba(240,64,96,.06);border-color:rgba(240,64,96,.25); }
.btts-label {
  font-family:'DM Mono',monospace;font-size:9px;
  letter-spacing:.1em;margin-bottom:6px;
}
.btts-pct {
  font-family:'Bebas Neue',sans-serif;font-size:36px;line-height:1;
}
.btts-box.yes .btts-pct { color:var(--accent); }
.btts-box.no  .btts-pct { color:var(--red); }

/* O/U market */
.ou-row {
  display:flex;align-items:center;justify-content:space-between;
  padding:8px 0;border-bottom:1px solid var(--border);
}
.ou-row:last-child { border-bottom:none; }
.ou-label {
  font-family:'DM Mono',monospace;font-size:11px;color:var(--muted);
}
.ou-vals { display:flex;gap:16px; }
.ou-val { text-align:center; }
.ou-val-label {
  font-family:'DM Mono',monospace;font-size:8px;color:var(--muted);
}
.ou-val-pct {
  font-family:'Bebas Neue',sans-serif;font-size:18px;
}
.ou-val-pct.over { color:var(--green); }
.ou-val-pct.under { color:var(--red); }
.ou-bar {
  height:3px;background:var(--border);border-radius:2px;
  margin-top:8px;overflow:hidden;
}
.ou-bar-fill { height:100%;border-radius:2px;background:var(--green); }

/* Correct score */
.cs-grid { display:grid;grid-template-columns:1fr 1fr;gap:6px; }
.cs-item {
  display:flex;align-items:center;justify-content:space-between;
  padding:7px 10px;background:var(--dim);border-radius:7px;
}
.cs-score {
  font-family:'Bebas Neue',sans-serif;font-size:16px;color:var(--text);
}
.cs-pct {
  font-family:'DM Mono',monospace;font-size:11px;color:var(--accent);
}

/* HT/FT */
.htft-grid { display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px; }
.htft-item {
  text-align:center;padding:8px;
  background:var(--dim);border-radius:7px;
}
.htft-combo {
  font-family:'DM Mono',monospace;font-size:9px;
  color:var(--muted);margin-bottom:4px;
}
.htft-pct {
  font-family:'Bebas Neue',sans-serif;font-size:18px;color:var(--text);
}

/* Asian Handicap */
.ah-row {
  display:flex;align-items:center;justify-content:space-between;
  padding:8px 0;border-bottom:1px solid var(--border);
}
.ah-row:last-child { border-bottom:none; }
.ah-line {
  font-family:'DM Mono',monospace;font-size:11px;color:var(--muted);
}
.ah-vals { display:flex;gap:20px; }
.ah-val { text-align:center; }
.ah-val-label {
  font-family:'DM Mono',monospace;font-size:8px;color:var(--muted);
}
.ah-val-pct {
  font-family:'Bebas Neue',sans-serif;font-size:18px;color:var(--text);
}

/* Save tip button */
.save-tip-row {
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 0;border-top:1px solid var(--border);
  margin-top:4px;
}
.save-tip-select {
  background:var(--dim);border:1px solid var(--border2);
  color:var(--text);border-radius:8px;padding:8px 10px;
  font-family:'DM Sans',sans-serif;font-size:13px;
  flex:1;margin-right:10px;outline:none;
}
.save-tip-btn {
  background:var(--accent);color:var(--bg);
  border:none;border-radius:8px;padding:8px 16px;
  font-family:'DM Mono',monospace;font-size:11px;
  letter-spacing:.08em;cursor:pointer;white-space:nowrap;
  transition:opacity .15s;
}
.save-tip-btn:hover { opacity:.9; }
.save-tip-btn.saved {
  background:var(--card2);color:var(--accent);
  border:1px solid var(--accent-b);
}

/* ── Tips page ───────────────────────────────────────────────────── */
.tips-header {
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:16px;
}
.tips-title {
  font-family:'Bebas Neue',sans-serif;font-size:22px;letter-spacing:.06em;
}
.record-card {
  background:var(--card);border:1px solid var(--border);
  border-radius:12px;padding:16px;margin-bottom:16px;
}
.record-grid {
  display:grid;grid-template-columns:repeat(4,1fr);gap:8px;
}
.record-stat { text-align:center; }
.record-val {
  font-family:'Bebas Neue',sans-serif;font-size:24px;line-height:1;
}
.record-val.green { color:var(--green); }
.record-val.red   { color:var(--red); }
.record-val.amber { color:var(--amber); }
.record-label {
  font-family:'DM Mono',monospace;font-size:8px;
  color:var(--muted);letter-spacing:.08em;margin-top:3px;
}

/* Saved tip item */
.tip-item {
  background:var(--card);border:1px solid var(--border);
  border-radius:12px;padding:14px;margin-bottom:8px;
  position:relative;
}
.tip-item-header {
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:8px;
}
.tip-match { font-size:14px;font-weight:600; }
.tip-result-badge {
  font-family:'DM Mono',monospace;font-size:9px;
  letter-spacing:.08em;padding:3px 8px;border-radius:8px;
}
.tip-result-badge.won     { background:rgba(0,201,122,.12);color:var(--green); }
.tip-result-badge.lost    { background:rgba(240,64,96,.12);color:var(--red); }
.tip-result-badge.pending { background:rgba(240,165,0,.12);color:var(--amber); }
.tip-result-badge.settling { background:rgba(3,226,226,.08);color:var(--accent);animation:pulse 1.4s ease-in-out infinite; }
.tip-market {
  font-family:'DM Mono',monospace;font-size:10px;
  color:var(--accent);letter-spacing:.06em;
}
.tip-meta {
  font-family:'DM Mono',monospace;font-size:9px;
  color:var(--muted);margin-top:4px;
}
.tip-delete {
  position:absolute;right:12px;bottom:12px;
  background:none;border:none;cursor:pointer;
  color:var(--muted);font-size:12px;transition:color .15s;
}
.tip-delete:hover { color:var(--red); }

/* ── Leagues page ────────────────────────────────────────────────── */
.leagues-country-heading {
  font-family:'Bebas Neue',sans-serif;font-size:18px;
  letter-spacing:.06em;color:var(--text);
  margin:20px 0 8px;padding-bottom:6px;
  border-bottom:1px solid var(--border);
}
.leagues-country-heading:first-child { margin-top:4px; }
.league-item {
  display:flex;align-items:center;justify-content:space-between;
  background:var(--card);border:1px solid var(--border);
  border-radius:10px;padding:12px 14px;margin-bottom:6px;
  cursor:pointer;transition:border-color .15s;
}
.league-item:hover { border-color:var(--accent-b); }
.league-item-name { font-size:14px;font-weight:500; }
.league-item-meta {
  font-family:'DM Mono',monospace;font-size:10px;
  color:var(--muted);margin-top:2px;
}
.league-item-count {
  font-family:'DM Mono',monospace;font-size:11px;
  color:var(--muted2);
}

/* ── Profile page ────────────────────────────────────────────────── */
.profile-header {
  background:var(--card);border:1px solid var(--border);
  border-radius:12px;padding:20px;margin-bottom:16px;
  text-align:center;
}
.profile-avatar-lg {
  width:64px;height:64px;border-radius:50%;
  background:var(--accent-g);border:2px solid var(--accent-b);
  display:flex;align-items:center;justify-content:center;
  font-family:'Bebas Neue',sans-serif;font-size:28px;color:var(--accent);
  margin:0 auto 12px;
}
.profile-name { font-size:18px;font-weight:700;margin-bottom:2px; }
.profile-email {
  font-family:'DM Mono',monospace;font-size:11px;color:var(--muted);
}
.premium-badge {
  display:inline-block;margin-top:8px;
  font-family:'DM Mono',monospace;font-size:10px;letter-spacing:.1em;
  padding:4px 12px;border-radius:20px;
  background:rgba(240,165,0,.12);color:var(--amber);
  border:1px solid rgba(240,165,0,.3);
}
.free-badge {
  display:inline-block;margin-top:8px;
  font-family:'DM Mono',monospace;font-size:10px;letter-spacing:.1em;
  padding:4px 12px;border-radius:20px;
  background:var(--dim);color:var(--muted);
  border:1px solid var(--border2);
}
.settings-item {
  display:flex;align-items:center;justify-content:space-between;
  background:var(--card);border:1px solid var(--border);
  border-radius:10px;padding:14px;margin-bottom:6px;
  cursor:pointer;transition:border-color .15s;
}
.settings-item:hover { border-color:var(--accent-b); }
.settings-item-left { display:flex;align-items:center;gap:10px; }
.settings-icon {
  width:32px;height:32px;border-radius:8px;
  background:var(--dim);display:flex;align-items:center;justify-content:center;
  font-size:15px;
}
.settings-label { font-size:14px; }
.settings-sub {
  font-family:'DM Mono',monospace;font-size:10px;
  color:var(--muted);margin-top:1px;
}
.settings-chevron { color:var(--muted);font-size:16px; }

/* Upgrade card */
.upgrade-card {
  background:linear-gradient(135deg,rgba(3,226,226,.08),rgba(77,159,255,.06));
  border:1px solid var(--accent-b);border-radius:12px;
  padding:16px;margin-bottom:16px;
}
.upgrade-title {
  font-family:'Bebas Neue',sans-serif;font-size:18px;
  color:var(--accent);margin-bottom:4px;
}
.upgrade-sub { font-size:13px;color:var(--muted2);margin-bottom:12px; }
.upgrade-features { margin-bottom:14px; }
.upgrade-feature {
  display:flex;align-items:center;gap:8px;
  font-size:13px;margin-bottom:6px;
}
.upgrade-feature::before { content:'✓';color:var(--accent);font-size:11px; }
.upgrade-btn {
  width:100%;background:var(--accent);color:var(--bg);
  border:none;border-radius:8px;padding:12px;
  font-family:'Bebas Neue',sans-serif;font-size:16px;letter-spacing:.06em;
  cursor:pointer;transition:opacity .2s;
}
.upgrade-btn:hover { opacity:.9; }

/* ── Premium lock overlay ────────────────────────────────────────── */
.premium-lock {
  position:relative;overflow:hidden;border-radius:8px;
}
.premium-lock::after {
  content:'🔒 PREMIUM';
  position:absolute;inset:0;
  background:rgba(6,11,16,.85);
  display:flex;align-items:center;justify-content:center;
  font-family:'DM Mono',monospace;font-size:11px;
  letter-spacing:.12em;color:var(--amber);
  backdrop-filter:blur(2px);
  cursor:pointer;
}

/* ── Loading states ──────────────────────────────────────────────── */
.skeleton {
  background:linear-gradient(90deg,var(--card) 25%,var(--card2) 50%,var(--card) 75%);
  background-size:200% 100%;
  animation:shimmer 1.4s infinite;
  border-radius:8px;
}
@keyframes shimmer { 0%{background-position:200% 0} 100%{background-position:-200% 0} }

.loading-row {
  height:72px;margin-bottom:8px;border-radius:12px;
}

/* ── Empty state ─────────────────────────────────────────────────── */
.empty-state {
  text-align:center;padding:40px 20px;
  color:var(--muted);font-size:14px;
}
.empty-icon { font-size:36px;margin-bottom:12px; }
.empty-sub { font-size:12px;margin-top:6px;color:var(--muted); }

/* ── Bottom nav ──────────────────────────────────────────────────── */
.bottom-nav {
  position: fixed;
  left: 50%;
  bottom: calc(10px + env(safe-area-inset-bottom));
  transform: translateX(-50%) translateZ(0);
  width: calc(100% - 28px);
  max-width: 430px;
  height: 50px;
  padding: 0 4px;
  box-sizing: border-box;
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: space-around;
  z-index: 999;
  background: rgba(6,11,16,.97);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  will-change: transform;
  transition: opacity .25s ease;
}
.nav-btn {
  flex: 1;
  height: 36px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1px;
  background: none;
  border: none;
  cursor: pointer;
  color: #fff;
  transition: color .15s;
}

.nav-btn svg {
  width: 18px;
  height: 18px;
  stroke-width: 2.2;
  stroke-linecap: round;
  stroke-linejoin: round;

}

.nav-btn span {
  font-family: 'DM Mono', monospace;
  font-size: 8.5px;
  line-height: 1;
  letter-spacing: .03em;
  font-weight: 700;

}

.nav-btn.active {
  color: var(--accent);
}

/* ── Toast ───────────────────────────────────────────────────────── */
.toast {
  position:fixed;bottom:calc(14px + env(safe-area-inset-bottom) + 72px);
  left:50%;transform:translateX(-50%) translateY(20px);
  background:var(--card2);border:1px solid var(--border2);
  border-radius:20px;padding:10px 18px;
  font-family:'DM Mono',monospace;font-size:12px;
  color:var(--text);white-space:nowrap;z-index:80;
  opacity:0;transition:all .3s;pointer-events:none;
}
.toast.show { opacity:1;transform:translateX(-50%) translateY(0); }

/* ── Scrollbar ───────────────────────────────────────────────────── */
::-webkit-scrollbar { width:3px;height:3px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:var(--border2);border-radius:3px; }

/* ── Auth feature icons ──────────────────────────────────────────── */
.af-icon {
  width:42px;height:42px;border-radius:10px;
  background:rgba(3,226,226,0.08);border:1px solid rgba(3,226,226,0.2);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.af-title { font-size:14px;font-weight:600;color:var(--text);margin-bottom:2px; }
.af-sub   { font-size:12px;color:var(--muted2); }
.auth-feature { display:flex;align-items:center;gap:14px;margin-bottom:16px; }

/* ── Social buttons full width ──────────────────────────────────── */
.social-btn-full {
  width:100%;display:flex;align-items:center;justify-content:center;gap:12px;
  background:var(--bg);border:1px solid var(--border2);
  border-radius:14px;padding:15px;color:var(--text);
  font-size:15px;font-family:'DM Sans',sans-serif;font-weight:500;
  cursor:pointer;transition:border-color .2s,background .2s;margin-bottom:10px;
}
.social-btn-full:hover { border-color:var(--muted);background:var(--dim); }

/* ── Field with icon ────────────────────────────────────────────── */
.field-icon { position:relative;display:flex;align-items:center; }
.field-ico  { position:absolute;left:14px;pointer-events:none;flex-shrink:0; }
.field-icon input {
  width:100%;padding-left:46px !important;
  background:var(--dim);border:1px solid var(--border2);
  border-radius:10px;padding:13px 14px;color:var(--text);
  font-size:15px;font-family:'DM Sans',sans-serif;outline:none;
  transition:border-color .2s;
}
.field-icon input:focus { border-color:var(--accent); }
.pwd-toggle {
  position:absolute;right:14px;background:none;border:none;
  cursor:pointer;color:var(--muted2);padding:0;
  display:flex;align-items:center;
}

/* ── Secondary button ───────────────────────────────────────────── */
.btn-secondary {
  width:100%;background:transparent;color:var(--text);
  border:1px solid var(--border2);border-radius:10px;padding:14px;
  font-family:'DM Sans',sans-serif;font-size:15px;font-weight:600;
  cursor:pointer;transition:border-color .2s;margin-top:10px;
}
.btn-secondary:hover { border-color:var(--accent-b); }

/* ── Forgot password ────────────────────────────────────────────── */
.forgot-pw {
  font-size:13px;font-weight:600;color:var(--accent);
  cursor:pointer;text-align:right;
}

/* ── Auth lined divider ──────────────────────────────────────────── */
.auth-divider {
  display:flex;align-items:center;gap:10px;
  font-size:12px;color:var(--muted);
  margin:8px 0 14px;font-family:'DM Mono',monospace;letter-spacing:.08em;
}
.auth-divider::before,.auth-divider::after {
  content:"";flex:1;height:1px;background:var(--border2);
}

/* ── Social buttons (Google + Apple) ────────────────────────────── */
.google-btn, .apple-btn {
  width:100%;
  height:52px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,0.10);
  background:rgba(10,15,20,0.95);
  display:flex;
  align-items:center;
  justify-content:center;
  gap:12px;
  color:#ffffff;
  font-size:14px;
  font-weight:500;
  font-family:'DM Sans',sans-serif;
  cursor:pointer;
  transition:all 0.25s ease;
}
.google-btn:hover, .apple-btn:hover {
  border-color:rgba(3,226,226,0.35);
  box-shadow:0 0 18px rgba(3,226,226,0.10), inset 0 0 12px rgba(255,255,255,0.02);
  transform:translateY(-1px);
}
.social-icon { width:22px;height:22px; }
.apple-icon  { width:20px;height:20px; }

/* ── Access error states ─────────────────────────────────────────── */
.access-error {
  text-align:center;
  padding:40px 20px;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:14px;
  margin:16px 0;
}
.ae-icon  { font-size:40px;margin-bottom:14px; }
.ae-title { font-size:17px;font-weight:700;color:var(--text);margin-bottom:8px; }
.ae-msg   { font-size:13px;color:var(--muted2);line-height:1.6;margin-bottom:20px; }
.ae-btn   {
  background:var(--accent);color:var(--bg);
  border:none;border-radius:10px;padding:12px 24px;
  font-family:'DM Sans',sans-serif;font-size:14px;font-weight:600;
  cursor:pointer;transition:opacity .2s;
}
.ae-btn:hover { opacity:.9; }
.ae-btn-ghost { background:transparent;color:var(--muted);border:1px solid var(--border);margin-top:8px; }

/* ── Calibration Rankings (Pro Feature) ──────────────────────────── */
#calibration-table {
  padding: 20px;
  animation: fadeIn 0.3s ease;
}

.calibration-header {
  margin-bottom: 24px;
  text-align: center;
}

.calibration-header h2 {
  font-size: 24px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 6px;
}

.calibration-subtitle {
  font-size: 13px;
  color: var(--muted2);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.calibration-rankings-table {
  width: 100%;
  border-collapse: collapse;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 12px;
  overflow: hidden;
  font-size: 13px;
}

.calibration-rankings-table thead {
  background: var(--dim);
  border-bottom: 1px solid var(--border2);
}

.calibration-rankings-table th {
  padding: 14px 12px;
  text-align: left;
  font-weight: 600;
  color: var(--muted2);
  text-transform: uppercase;
  font-size: 11px;
  letter-spacing: 0.4px;
}

.calibration-rankings-table tbody tr {
  border-bottom: 1px solid var(--border2);
  transition: background 0.15s ease;
}

.calibration-rankings-table tbody tr:hover {
  background: rgba(3, 226, 226, 0.04);
}

.calibration-rankings-table td {
  padding: 14px 12px;
  color: var(--text);
}

.calibration-row.green {
  border-left: 4px solid #10b981;
}

.calibration-row.amber {
  border-left: 4px solid #f59e0b;
}

.calibration-row.red {
  border-left: 4px solid #ef4444;
}

.rank {
  font-weight: 700;
  color: var(--accent);
}

.league {
  font-weight: 600;
  color: var(--text);
}

.country {
  color: var(--muted2);
  font-size: 12px;
}

.tier {
  background: var(--dim);
  padding: 4px 8px;
  border-radius: 6px;
  font-size: 11px;
  font-weight: 500;
  display: inline-block;
  color: var(--muted2);
}

.btts {
  text-align: center;
}

.badge {
  background: var(--accent);
  color: var(--bg);
  padding: 4px 10px;
  border-radius: 12px;
  font-weight: 600;
  font-size: 12px;
}

.consistency {
  letter-spacing: 2px;
  color: var(--text);
  font-weight: 500;
}

.colour-badge {
  display: inline-block;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  border: 2px solid transparent;
}

.colour-badge.green { background: #10b981; }
.colour-badge.amber { background: #f59e0b; }
.colour-badge.red { background: #ef4444; }

.reason {
  color: var(--muted2);
  font-size: 12px;
  line-height: 1.4;
  max-width: 300px;
}

@media (max-width: 768px) {
  .calibration-rankings-table {
    font-size: 12px;
  }
  
  .calibration-rankings-table th,
  .calibration-rankings-table td {
    padding: 10px 8px;
  }
  
  .reason {
    display: none;
  }
}

/* ── Subscription Management ─────────────────────────────────────── */
#subscriptions-page {
  padding: 20px;
  animation: fadeIn 0.3s ease;
}

.subscriptions-header {
  margin-bottom: 24px;
  text-align: center;
}

.subscriptions-header h2 {
  font-size: 24px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 6px;
}

.subscriptions-subtitle {
  font-size: 13px;
  color: var(--muted2);
  line-height: 1.6;
}

.current-status {
  margin-bottom: 32px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.current-plan-badge {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 16px;
  text-align: center;
}

.current-plan-badge.regular {
  border-left: 4px solid var(--accent);
}

.current-plan-badge.regular {
  border-left: 4px solid var(--accent);
  background: rgba(3, 226, 226, 0.05);
}

.current-plan-badge.free {
  border-left: 4px solid var(--muted2);
  opacity: 0.7;
}

.badge-label {
  font-size: 14px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 4px;
}

.badge-days {
  font-size: 12px;
  color: var(--accent);
}

.badge-end {
  font-size: 11px;
  color: var(--muted2);
  margin-top: 4px;
}

.cancel-btn {
  background: var(--dim);
  color: var(--text);
  border: 1px solid var(--border2);
  border-radius: 10px;
  padding: 12px 20px;
  font-family: 'DM Sans', sans-serif;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
}

.cancel-btn:hover {
  background: rgba(239, 68, 68, 0.1);
  border-color: #ef4444;
  color: #ef4444;
}

.plans-container {
  display: flex;
  flex-direction: column;
  gap: 32px;
}

.plan-group {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.group-title {
  font-size: 16px;
  font-weight: 700;
  color: var(--text);
  margin: 0;
}

.plans-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}

@media (min-width: 640px) {
  .plans-grid {
    grid-template-columns: 1fr 1fr;
  }
}

.plan-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 20px;
  position: relative;
  transition: all 0.25s ease;
  display: flex;
  flex-direction: column;
}

.plan-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(3, 226, 226, 0.1);
  border-color: var(--accent);
}

.plan-card.active {
  border-color: var(--accent);
  background: rgba(3, 226, 226, 0.05);
}

.plan-card.featured {
  border-color: #f59e0b;
}

.plan-badge {
  position: absolute;
  top: 12px;
  right: 12px;
  background: #f59e0b;
  color: white;
  font-size: 11px;
  font-weight: 700;
  padding: 4px 10px;
  border-radius: 20px;
  text-transform: uppercase;
}

.saving-badge {
  position: absolute;
  top: 12px;
  left: 12px;
  background: var(--accent);
  color: var(--bg);
  font-size: 11px;
  font-weight: 700;
  padding: 4px 10px;
  border-radius: 20px;
}

.plan-header {
  margin-bottom: 20px;
  padding-top: 8px;
}

.plan-name {
  font-size: 16px;
  font-weight: 700;
  color: var(--text);
  margin: 0 0 8px 0;
}

.plan-price {
  font-size: 14px;
  color: var(--muted2);
  display: flex;
  align-items: baseline;
  gap: 2px;
}

.currency {
  font-size: 12px;
}

.amount {
  font-size: 28px;
  font-weight: 700;
  color: var(--accent);
}

.period {
  font-size: 12px;
  color: var(--muted2);
}

.plan-features {
  flex: 1;
  margin-bottom: 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.feature {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 13px;
  color: var(--text);
  line-height: 1.4;
}

.feature svg {
  color: var(--accent);
  flex-shrink: 0;
  margin-top: 2px;
}

.plan-btn {
  width: 100%;
  padding: 12px 16px;
  border: none;
  border-radius: 10px;
  font-family: 'DM Sans', sans-serif;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
}

.plan-btn.upgrade {
  background: var(--accent);
  color: var(--bg);
}

.plan-btn.upgrade:hover {
  opacity: 0.9;
  transform: scale(1.02);
}

.plan-btn.current {
  background: var(--dim);
  color: var(--text);
  cursor: default;
  opacity: 0.6;
}

.error-state {
  text-align: center;
  padding: 40px 20px;
  color: var(--muted2);
  font-size: 14px;
}

/* ── Subscription action buttons ─────────────────────────────── */
.sub-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.sub-action-btn {
  flex: 1;
  min-width: 130px;
  border-radius: 10px;
  padding: 11px 16px;
  font-family: 'DM Sans', sans-serif;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
  border: 1px solid var(--border2);
  background: var(--dim);
  color: var(--text);
}

.sub-action-btn.cancel-btn:hover {
  background: rgba(239, 68, 68, 0.1);
  border-color: #ef4444;
  color: #ef4444;
}

.sub-action-btn.portal-btn:hover {
  border-color: var(--accent);
  color: var(--accent);
}

/* ── Plan price display ───────────────────────────────────────── */
.price-main {
  font-size: 20px;
  font-weight: 700;
  color: var(--accent);
  display: block;
}

.price-sub {
  font-size: 11px;
  color: var(--muted2);
  display: block;
  margin-top: 2px;
}

/* ── Recommended tag ─────────────────────────────────────────── */
.recommended-tag {
  font-size: 11px;
  font-weight: 600;
  color: #f59e0b;
  background: rgba(245, 158, 11, 0.12);
  border-radius: 20px;
  padding: 2px 8px;
  margin-left: 8px;
  vertical-align: middle;
}

/* ── Stripe disclaimer ───────────────────────────────────────── */
.payment-note {
  text-align: center;
  font-size: 11px;
  color: var(--muted2);
  margin-top: 24px;
  padding-bottom: 8px;
  opacity: 0.7;
}

/* ── Skeleton Loaders ────────────────────────────────────────────────── */
@keyframes shimmer {
  0% { background-position: -1000px 0; }
  100% { background-position: 1000px 0; }
}

.skeleton {
  background: linear-gradient(90deg, var(--dim) 0%, var(--card) 50%, var(--dim) 100%);
  background-size: 1000px 100%;
  animation: shimmer 2s infinite;
  border-radius: 10px;
}

.skeleton-fixture {
  height: 140px;
  margin: 12px 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 16px;
}

.skeleton-fixture-header {
  display: flex;
  justify-content: space-between;
  gap: 10px;
}

.skeleton-fixture-header .skeleton {
  height: 20px;
  flex: 1;
}

.skeleton-fixture-teams {
  display: flex;
  justify-content: space-between;
  gap: 12px;
}

.skeleton-fixture-team {
  flex: 1;
  height: 24px;
  border-radius: 10px;
}

.skeleton-fixture-bar {
  height: 4px;
  margin: 8px 0;
  border-radius: 2px;
}

.skeleton-fixture-stats {
  display: flex;
  justify-content: space-between;
  gap: 8px;
}

.skeleton-fixture-stats .skeleton {
  flex: 1;
  height: 20px;
}

.skeleton-tips {
  height: 100px;
  margin: 12px 0;
  padding: 12px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.skeleton-tips .skeleton {
  height: 16px;
  width: 100%;
}

.skeleton-tips .skeleton:last-child {
  width: 80%;
}

.skeleton-calibration-row {
  display: grid;
  grid-template-columns: 60px 1fr 80px 80px 100px 80px;
  gap: 12px;
  padding: 12px;
  align-items: center;
  height: 50px;
  margin: 8px 0;
}

.skeleton-calibration-row .skeleton {
  height: 20px;
}

.skeleton-plan-card {
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.skeleton-plan-header {
  display: flex;
  gap: 12px;
  align-items: center;
}

.skeleton-plan-header .skeleton {
  height: 24px;
  flex: 1;
}

.skeleton-plan-price {
  height: 40px;
}

.skeleton-plan-features {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.skeleton-plan-features .skeleton {
  height: 16px;
  width: 90%;
}

.skeleton-plan-button {
  height: 44px;
  margin-top: 8px;
}

/* Hide skeleton when content is loaded */
.skeleton-container.loaded .skeleton {
  display: none;
}

/* ── Empty States ────────────────────────────────────────────────────── */
.empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 60px 20px;
  text-align: center;
  color: var(--muted);
}

.empty-state-icon {
  font-size: 64px;
  margin-bottom: 16px;
  opacity: 0.6;
}

.empty-state-title {
  font-size: 18px;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 8px;
  font-family: 'DM Sans', sans-serif;
}

.empty-state-message {
  font-size: 14px;
  color: var(--muted);
  margin-bottom: 24px;
  max-width: 300px;
  line-height: 1.5;
}

.empty-state-action {
  background: var(--accent);
  color: var(--bg);
  border: none;
  border-radius: 10px;
  padding: 12px 24px;
  font-family: 'DM Sans', sans-serif;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
}

.empty-state-action:hover {
  opacity: 0.9;
  transform: scale(1.02);
}

.empty-state-action:active {
  transform: scale(0.98);
}

@media (max-width: 640px) {
  .plans-grid {
    grid-template-columns: 1fr;
  }

  .plan-card {
    padding: 16px;
  }

  .plan-name {
    font-size: 14px;
  }

  .amount {
    font-size: 24px;
  }
}

/* ── Home hero ───────────────────────────────────────────────────── */
.home-hero {
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:14px;padding:0 2px;
}
.home-hero-left { display:flex;flex-direction:column; }
.home-hero-title {
  font-family:'Bebas Neue',sans-serif;font-size:20px;
  letter-spacing:.06em;color:var(--text);line-height:1;
}
.home-hero-date {
  font-family:'DM Mono',monospace;font-size:10px;font-weight:500;
  letter-spacing:.1em;color:#fff;margin-top:3px;
}
.home-hero-badge {
  font-family:'DM Mono',monospace;font-size:10px;
  letter-spacing:.08em;padding:5px 12px;border-radius:20px;flex-shrink:0;
}
.home-hero-badge.regular {
  background:var(--accent-g);color:var(--accent);
  border:1px solid var(--accent-b);
}
.home-hero-badge.free {
  background:var(--dim);color:var(--muted2);
  border:1px solid var(--border2);
}

/* ── Enhanced fixture card ───────────────────────────────────────── */
.fixture-card.btts-high { border-left:3px solid var(--green); }
.fixture-card.btts-mid  { border-left:3px solid var(--amber); }
.fixture-card.btts-low  { border-left:3px solid var(--red); }
.fc-btts-bar {
  height:3px;margin:0 12px 10px;
  background:var(--border);border-radius:2px;overflow:hidden;
}
.fc-btts-bar-fill {
  height:100%;border-radius:2px;transition:width .4s ease;
}
.fc-btts-bar-fill.high  { background:var(--green); }
.fc-btts-bar-fill.mid   { background:var(--amber); }
.fc-btts-bar-fill.low   { background:var(--red); }

/* ── Top pick card enhancement ───────────────────────────────────── */
.pick-confidence-bar {
  height:3px;margin-top:8px;
  background:var(--border);border-radius:2px;overflow:hidden;
}
.pick-confidence-fill {
  height:100%;border-radius:2px;
}
.pick-confidence-fill.high   { background:var(--accent); }
.pick-confidence-fill.medium { background:var(--amber); }
.pick-confidence-fill.low    { background:var(--muted); }

/* ── BTTS ring (match drawer) ────────────────────────────────────── */
.btts-rings-wrap {
  display:flex;align-items:center;justify-content:center;gap:20px;padding:8px 0;
}
.btts-ring {
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  position:relative;width:96px;height:96px;
}
.btts-ring-svg {
  position:absolute;inset:0;transform:rotate(-90deg);
}
.btts-ring-inner {
  position:relative;z-index:1;text-align:center;
}
.btts-ring-pct {
  font-family:'Bebas Neue',sans-serif;font-size:28px;line-height:1;
}
.btts-ring-lbl {
  font-family:'DM Mono',monospace;font-size:9px;letter-spacing:.1em;margin-top:2px;
}
.btts-ring.yes .btts-ring-pct { color:var(--accent); }
.btts-ring.yes .btts-ring-lbl { color:var(--accent); }
.btts-ring.no  .btts-ring-pct { color:var(--red); }
.btts-ring.no  .btts-ring-lbl { color:var(--red); }

/* ── App entry fade ──────────────────────────────────────────────── */
#app.entering { animation:appFadeIn .3s ease forwards; }
@keyframes appFadeIn {
  from { opacity:0; }
  to   { opacity:1; }
}

/* ── Auth screen fade out ────────────────────────────────────────── */
#auth-screen.fading { animation:fadeOut .25s ease forwards; }
@keyframes fadeOut { to { opacity:0;pointer-events:none; } }

/* ── Subscription lock banner ────────────────────────────────────── */
.sub-lock-banner {
  display:flex;align-items:center;gap:10px;
  background:rgba(3,226,226,.06);border:1px solid var(--accent-b);
  border-radius:12px;padding:14px;margin-bottom:12px;cursor:pointer;
  transition:background .2s;
}
.sub-lock-banner:hover { background:rgba(3,226,226,.10); }
.sub-lock-icon { font-size:20px;flex-shrink:0; }
.sub-lock-text { flex:1; }
.sub-lock-title { font-size:13px;font-weight:600;color:var(--accent); }
.sub-lock-sub   { font-family:'DM Mono',monospace;font-size:10px;color:var(--muted);margin-top:2px; }
.sub-lock-arrow { color:var(--accent);font-size:16px; }

/* ── Date chip today indicator ───────────────────────────────────── */
.date-chip.today .date-chip-day { color:var(--accent);font-weight:600; }

/* ── Past date chip (yesterday) — dimmed but selectable ─────────── */
.date-chip.past { opacity:.55; }
.date-chip.past.active { opacity:1; }
.date-chip.locked { opacity:.4; filter:blur(.5px); cursor:default; }
.date-chip.locked.active { opacity:1; filter:none; }

/* ── Fixture card hover tap feedback ─────────────────────────────── */
.fixture-card { transition:border-color .15s,transform .1s; }
.fixture-card:active { transform:scale(.985); }

/* ── Pick card BTTS emphasis ─────────────────────────────────────── */
.pick-card { transition:border-color .15s,transform .1s; }
.pick-card:active { transform:scale(.985); }

/* ── Calibration cards (new) ─────────────────────────────────────── */
.calibration-title {
  font-family:'Bebas Neue',sans-serif;font-size:24px;
  letter-spacing:.06em;color:var(--text);margin-bottom:4px;
}
.calibration-subtitle {
  font-family:'DM Mono',monospace;font-size:10px;
  letter-spacing:.1em;color:var(--muted);
}
.calibration-header { margin-bottom:16px; }

.cal-legend {
  display:flex;gap:16px;margin-bottom:4px;flex-wrap:wrap;
}
.cal-leg-item {
  display:flex;align-items:center;gap:6px;
  font-family:'DM Mono',monospace;font-size:10px;letter-spacing:.06em;
}
.cal-leg-item.green { color:var(--green); }
.cal-leg-item.amber { color:var(--amber); }
.cal-leg-item.red   { color:var(--red); }
.cal-leg-dot {
  width:8px;height:8px;border-radius:50%;flex-shrink:0;
}
.cal-leg-dot.green { background:var(--green); }
.cal-leg-dot.amber { background:var(--amber); }
.cal-leg-dot.red   { background:var(--red); }

.cal-card {
  background:var(--card);border:1px solid var(--border);
  border-radius:12px;padding:14px;margin-bottom:8px;
  transition:border-color .15s;
}
.cal-card:hover { border-color:var(--border2); }
.cal-card-top {
  display:flex;align-items:center;gap:12px;
}
.cal-rank {
  font-family:'Bebas Neue',sans-serif;font-size:22px;
  color:var(--muted);min-width:32px;line-height:1;
}
.cal-league-info { flex:1;min-width:0; }
.cal-league-name {
  font-size:14px;font-weight:600;color:var(--text);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.cal-league-meta {
  font-family:'DM Mono',monospace;font-size:10px;
  color:var(--muted);margin-top:2px;
}
.cal-btts-block {
  display:flex;flex-direction:column;align-items:flex-end;flex-shrink:0;gap:2px;
}
.cal-btts-pct {
  font-family:'Bebas Neue',sans-serif;font-size:26px;
  line-height:1;
}
.cal-btts-lbl {
  font-family:'DM Mono',monospace;font-size:9px;letter-spacing:.08em;
  color:var(--muted);text-align:right;
}
.cal-stars {
  font-size:12px;color:var(--amber);margin-top:8px;letter-spacing:2px;
}
.cal-reason {
  font-family:'DM Mono',monospace;font-size:10px;
  color:var(--muted2);margin-top:6px;line-height:1.5;
}

/* ── BTTS No picks ──────────────────────────────────────────────────── */
.btts-no-card {
  position:relative;
  display:flex;align-items:stretch;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:14px;
  margin:0 16px 10px;
  overflow:hidden;
  cursor:pointer;
  transition:border-color .15s, transform .1s;
  border-left-width:3px;
}
.btts-no-card:active { transform:scale(.985); }
.btts-no-card.bnc-high     { border-left-color:var(--red); }
.btts-no-card.bnc-moderate { border-left-color:var(--amber); }

.bnc-conf-tag {
  font-family:'DM Mono',monospace;font-size:9px;
  letter-spacing:.08em;padding:3px 7px;border-radius:6px;font-weight:600;
  margin-bottom:6px;text-align:center;
}
.bnc-tag-high     { background:rgba(255,77,109,.20);color:var(--accent); }
.bnc-tag-moderate { background:rgba(240,165,0,.20);color:var(--accent); }

.bnc-body {
  flex:1;padding:14px 14px 12px 16px;min-width:0;
}
.bnc-teams {
  font-size:14px;font-weight:600;color:var(--text);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  padding-right:70px;
}
.bnc-vs { color:var(--muted2);font-weight:400;margin:0 4px;font-size:12px; }
.bnc-meta {
  font-family:'DM Mono',monospace;font-size:10px;
  color:var(--muted);margin-top:4px;letter-spacing:.04em;
}
.bnc-bar-wrap {
  height:3px;background:var(--border2);border-radius:2px;
  margin-top:10px;overflow:hidden;
}
.bnc-bar-fill {
  height:100%;border-radius:2px;transition:width .4s ease;
}
.bnc-fill-high     { background:var(--red); }
.bnc-fill-moderate { background:var(--amber); }

.bnc-pct-col {
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:10px 10px 10px 8px;flex-shrink:0;gap:2px;width:68px;
}
.bnc-no-pct {
  font-family:'Bebas Neue',sans-serif;font-size:28px;line-height:1;color:var(--red);
}
.bnc-no-lbl {
  font-family:'DM Mono',monospace;font-size:9px;letter-spacing:.1em;
  color:var(--muted);margin-bottom:4px;
}
.bnc-yes-pct {
  font-size:11px;font-weight:600;color:var(--muted2);
}
.bnc-yes-lbl {
  font-size:9px;color:var(--muted);font-weight:400;
}

/* ── Drawer market subtitle + lambda display ────────────────────────── */
.market-subtitle {
  font-family:'DM Mono',monospace;font-size:9px;letter-spacing:.06em;
  color:var(--muted);margin-top:2px;
}
.btts-lambdas {
  display:flex;justify-content:space-between;
  font-family:'DM Mono',monospace;font-size:10px;color:var(--muted2);
  margin-top:10px;padding:0 4px;
}

/* ── Notifications page ───────────────────────────────────────────── */
.notif-wrap {
  padding: 24px 20px 40px;
  max-width: 480px;
  margin: 0 auto;
}
.notif-header {
  margin-bottom: 28px;
}
.notif-title {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 28px;
  letter-spacing: .06em;
  color: var(--text);
}
.notif-sub {
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  color: var(--muted2);
  margin-top: 4px;
  letter-spacing: .04em;
}
.notif-loading,
.notif-status-msg {
  font-family: 'DM Mono', monospace;
  font-size: 12px;
  color: var(--muted2);
  text-align: center;
  padding: 48px 0;
}
.notif-unsupported {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 32px 20px;
  text-align: center;
}
.notif-unsup-icon { font-size: 36px; margin-bottom: 12px; }
.notif-unsup-msg {
  font-family: 'DM Sans', sans-serif;
  font-size: 13px;
  color: var(--muted2);
  line-height: 1.5;
}
.notif-denied-banner {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  background: rgba(255,77,109,.10);
  border: 1px solid rgba(255,77,109,.25);
  border-radius: 12px;
  padding: 14px 16px;
  margin-bottom: 20px;
}
.notif-denied-icon { font-size: 20px; }
.notif-denied-title {
  font-family: 'DM Sans', sans-serif;
  font-size: 13px;
  font-weight: 600;
  color: var(--red);
  margin-bottom: 2px;
}
.notif-denied-msg {
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  color: var(--muted2);
}
.notif-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 18px 18px;
  margin-bottom: 12px;
}
.notif-item-label {
  font-family: 'DM Sans', sans-serif;
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
}
.notif-item-desc {
  font-family: 'DM Mono', monospace;
  font-size: 10px;
  color: var(--muted2);
  margin-top: 3px;
  letter-spacing: .03em;
}
/* Toggle switch */
.notif-toggle-wrap {
  position: relative;
  display: inline-block;
  width: 46px;
  height: 26px;
  flex-shrink: 0;
}
.notif-toggle-wrap input { opacity: 0; width: 0; height: 0; }
.notif-slider {
  position: absolute;
  inset: 0;
  background: var(--border2);
  border-radius: 26px;
  cursor: pointer;
  transition: background .2s;
}
.notif-slider::before {
  content: '';
  position: absolute;
  width: 20px;
  height: 20px;
  left: 3px;
  bottom: 3px;
  background: #fff;
  border-radius: 50%;
  transition: transform .2s;
}
.notif-toggle-wrap input:checked + .notif-slider { background: var(--accent); }
.notif-toggle-wrap input:checked + .notif-slider::before { transform: translateX(20px); }
.notif-toggle-wrap.disabled { opacity: .4; pointer-events: none; }
.notif-footer {
  font-family: 'DM Mono', monospace;
  font-size: 10px;
  color: var(--muted);
  line-height: 1.6;
  margin-top: 20px;
  letter-spacing: .03em;
}

/* ── World Cup model badge ────────────────────────────────────────── */
.wc-model-badge {
  color: var(--amber) !important;
  letter-spacing: .04em;
}

/* ── World Cup fixture card accent ───────────────────────────────── */
.fixture-card[data-league="world-cup-2026"] {
  border-color: var(--amber);
  background: linear-gradient(135deg, var(--card) 85%, rgba(240,165,0,.06));
}
.fixture-card[data-league="world-cup-2026"] .fc-league {
  color: var(--amber);
  font-weight: 600;
}
