/* ===========================================================================
   Futboin - "stadium night x digital mosaic"
   True-black base, WC2026 tile palette as vivid accents, Saira/Sora type.
   =========================================================================== */


:root{
  --bg:#06070a; --bg-2:#0b0d12; --surface:#111419; --surface-2:#181c23; --surface-3:#20252e;
  --border:#2a303a; --border-2:#3a414d; --text:#f3f6f9; --muted:#9aa4b1; --faint:#6c7682;
  --green:#18c172; --green-2:#34e08a; --blue:#1ec8e6; --purple:#b15cff;
  --red:#ff5360; --orange:#ff8a3d; --yellow:#ffd23f; --on-accent:#04130c;
  --display:"Saira","Sora",system-ui,-apple-system,sans-serif;
  --body:"Sora",system-ui,-apple-system,sans-serif;
  --radius:14px; --radius-lg:20px; --shadow:0 18px 48px rgba(0,0,0,.55); --shadow-sm:0 8px 22px rgba(0,0,0,.4);
  --m1:var(--green); --m2:var(--blue); --m3:var(--purple); --m4:var(--red); --m5:var(--orange); --m6:var(--yellow);
  color-scheme:dark;
}
*{ box-sizing:border-box; }
html{ font-size:17px; -webkit-text-size-adjust:100%; }
body{ margin:0; min-height:100vh; display:flex; flex-direction:column; font-family:var(--body); color:var(--text);
  line-height:1.6; letter-spacing:.1px;
  background:
    radial-gradient(820px 460px at 8% -6%, rgba(24,193,114,.14), transparent 60%),
    radial-gradient(760px 420px at 96% 4%, rgba(30,200,230,.12), transparent 60%),
    radial-gradient(900px 520px at 70% 108%, rgba(177,92,255,.12), transparent 62%),
    var(--bg);
  background-attachment:fixed; }
::selection{ background:var(--green); color:var(--on-accent); }
:focus-visible{ outline:3px solid var(--green); outline-offset:2px; border-radius:8px; }
.skip{ position:absolute; left:-9999px; top:8px; background:var(--green); color:var(--on-accent);
  padding:10px 16px; border-radius:10px; font-weight:700; z-index:100; }
.skip:focus{ left:16px; }

.mosaic-bar{ height:10px; opacity:.28; background:repeating-linear-gradient(90deg,
    var(--m1) 0 44px, var(--m2) 44px 88px, var(--m3) 88px 132px,
    var(--m5) 132px 176px, var(--m6) 176px 220px, var(--m2) 220px 264px); background-size:264px 100%; }

.topbar{ position:sticky; top:0; z-index:30; background:rgba(6,7,10,.82);
  backdrop-filter:blur(12px) saturate(120%); border-bottom:1px solid var(--border); }
.bar{ max-width:1180px; margin:0 auto; padding:0 22px; min-height:70px; display:flex; align-items:center; gap:18px; flex-wrap:wrap; }
.brand{ display:flex; align-items:center; gap:12px; text-decoration:none; }
.brand-logo{ width:38px; height:38px; flex:0 0 auto; background:url("/static/logo.png") left center / contain no-repeat; }
.brand-name{ font-family:var(--display); font-weight:800; font-size:1.7rem; letter-spacing:2px; color:var(--text); line-height:1; }
.brand-name b{ color:var(--green); font-weight:800; }
.menu{ margin-left:auto; display:flex; align-items:center; gap:3px; }
.menu a{ display:inline-flex; align-items:center; gap:8px; min-height:42px; padding:9px 15px; text-decoration:none;
  color:var(--muted); font-weight:600; font-size:.98rem; border-radius:11px; position:relative; transition:color .15s, background .15s; }
.menu a:hover{ color:var(--text); background:rgba(255,255,255,.06); }
.menu a.active{ color:var(--text); background:rgba(24,193,114,.14); }
.menu a.active::after{ content:""; position:absolute; left:14px; right:14px; bottom:4px; height:2px; border-radius:2px; background:var(--green); }
.menu a.logout:hover{ color:var(--red); background:rgba(255,83,96,.12); }
.profile-link span{ line-height:1; }
.navtoggle{ display:none; margin-left:auto; width:48px; height:48px; padding:0; border-radius:11px; background:var(--surface-2); border:1px solid var(--border); cursor:pointer; }
.navtoggle .hb, .navtoggle .hb::before, .navtoggle .hb::after{ display:block; width:22px; height:2.5px; background:var(--text); border-radius:2px; margin:0 auto; content:""; }
.navtoggle .hb{ position:relative; }
.navtoggle .hb::before{ position:absolute; top:-7px; left:0; }
.navtoggle .hb::after{ position:absolute; top:7px; left:0; }

.wrap{ flex:1; display:flex; justify-content:center; align-items:flex-start; padding:42px 18px 90px; }
body.auth .wrap{ align-items:center; }
.container{ width:100%; max-width:1080px; background:linear-gradient(180deg, var(--surface), var(--bg-2));
  border:1px solid var(--border); border-radius:var(--radius-lg); padding:38px 42px; box-shadow:var(--shadow);
  position:relative; overflow:hidden; animation:rise .34s cubic-bezier(.2,.7,.3,1) both; }
body.auth .container{ max-width:440px; text-align:center; }
body.wide .container{ max-width:1640px; }
@keyframes rise{ from{ opacity:0; transform:translateY(12px); } to{ opacity:1; transform:none; } }

h1{ font-family:var(--display); font-weight:800; letter-spacing:.4px; font-size:2.3rem; margin:6px 0 22px; line-height:1.08; }
h2{ font-family:var(--display); font-weight:700; font-size:1.25rem; margin:34px 0 14px; display:flex; align-items:center; gap:11px; letter-spacing:.3px; }
h2::before{ content:""; width:14px; height:14px; border-radius:4px; background:conic-gradient(var(--m1), var(--m2), var(--m3), var(--m5), var(--m6), var(--m1)); }
p{ margin:12px 0; }
a{ color:var(--blue); text-decoration:none; }
a:hover{ text-decoration:underline; text-underline-offset:3px; }
.muted{ color:var(--muted); }
code{ background:#000; border:1px solid var(--border); padding:2px 7px; border-radius:6px; font-size:.86em; color:var(--green-2); }

form.stack{ display:flex; flex-direction:column; gap:18px; max-width:380px; margin:8px auto 0; text-align:left; }
form.stack label{ display:flex; flex-direction:column; gap:8px; font-size:.76rem; letter-spacing:.8px; text-transform:uppercase; color:var(--muted); font-weight:600; }
input[type=text],input[type=password],input[type=email],input[type=file],input[type=datetime-local],select{
  width:100%; padding:14px 15px; background:#05060a; color:var(--text); border:1px solid var(--border-2); border-radius:12px;
  font-size:1.02rem; font-family:inherit; outline:none; min-height:50px; transition:border-color .15s, box-shadow .15s; }
input:focus,select:focus{ border-color:var(--green); box-shadow:0 0 0 3px rgba(24,193,114,.25); }
input::file-selector-button{ background:var(--surface-3); color:var(--text); border:1px solid var(--border-2); border-radius:9px; padding:9px 13px; margin-right:12px; cursor:pointer; font-family:inherit; font-size:.95rem; }
label.inline{ display:inline-flex; align-items:center; gap:9px; font-size:.78rem; text-transform:uppercase; letter-spacing:.6px; color:var(--muted); font-weight:600; }
label.inline input[type=checkbox]{ width:18px; height:18px; accent-color:var(--green); }
select{ max-width:300px; }

.btn,button{ display:inline-flex; align-items:center; justify-content:center; min-height:48px; cursor:pointer; font-family:inherit;
  font-size:1rem; font-weight:700; padding:12px 22px; border-radius:12px; letter-spacing:.2px; border:1px solid var(--border-2);
  background:var(--surface-2); color:var(--text); text-decoration:none; transition:transform .08s ease, background .15s, border-color .15s, box-shadow .15s; }
.btn:hover,button:hover{ background:var(--surface-3); text-decoration:none; }
.btn:active,button:active{ transform:translateY(1px); }
.btn.primary,button.primary{ background:linear-gradient(180deg, var(--green-2), var(--green)); border-color:var(--green); color:var(--on-accent); box-shadow:0 8px 22px rgba(24,193,114,.28); }
.btn.primary:hover,button.primary:hover{ filter:brightness(1.06); }
button.danger{ background:transparent; color:var(--red); border-color:rgba(255,83,96,.5); font-weight:600; }
button.danger:hover{ background:rgba(255,83,96,.14); }
button.warn{ background:transparent; color:var(--orange); border-color:rgba(255,138,61,.5); }
button.warn:hover{ background:rgba(255,138,61,.14); }
.actions{ display:flex; flex-direction:column; gap:14px; max-width:300px; margin:12px auto 0; }
.actions .btn{ width:100%; padding:16px; font-size:1.08rem; }
.upload{ display:flex; gap:14px; align-items:center; flex-wrap:wrap; }
.upload input[type=text]{ max-width:240px; }

.hero{ display:flex; flex-direction:column; align-items:center; }
.hero-logo{ width:120px; height:90px; margin:0 auto; background:url("/static/logo.png") center / contain no-repeat; }
.hero-name{ font-family:var(--display); font-weight:800; font-size:3.4rem; letter-spacing:2px; margin:18px 0 22px; }
.hero .actions{ flex-direction:row; justify-content:center; max-width:none; gap:14px; }
.hero .actions .btn{ width:auto; padding:14px 30px; }
.hero-name b{ color:var(--green); }
.hero-tag{ color:var(--muted); margin:0 0 26px; letter-spacing:.4px; }

.avatar-sm{ width:30px; height:30px; border-radius:50%; object-fit:cover; border:1px solid var(--border-2); }
.avatar-sm.initials{ display:inline-flex; align-items:center; justify-content:center; background:var(--surface-3); color:var(--text); font-weight:800; font-size:.95rem; }
.avatar-lg{ width:104px; height:104px; border-radius:50%; object-fit:cover; border:2px solid transparent;
  background:linear-gradient(var(--surface), var(--surface)) padding-box, conic-gradient(var(--m1), var(--m2), var(--m3), var(--m5), var(--m6), var(--m1)) border-box; }
.avatar-lg.initials{ display:inline-flex; align-items:center; justify-content:center; font-family:var(--display); font-size:2.6rem; font-weight:800; }
.profile-top{ display:flex; align-items:center; gap:22px; margin-bottom:8px; }
.profile-name{ font-size:1.5rem; font-weight:800; font-family:var(--display); letter-spacing:.5px; }

.cards{ display:grid; grid-template-columns:repeat(auto-fit, minmax(220px, 1fr)); gap:16px; margin-top:8px; }
.card{ display:flex; align-items:center; justify-content:space-between; gap:12px; padding:26px; border:1px solid var(--border);
  border-radius:var(--radius); text-decoration:none; background:var(--surface-2); color:var(--text); font-weight:700; font-size:1.18rem;
  transition:border-color .15s, transform .12s, background .15s, box-shadow .15s; }
.card:hover{ border-color:var(--green); transform:translateY(-3px); box-shadow:var(--shadow-sm); color:var(--text); }
.card .arrow{ color:var(--green); font-size:1.4rem; }

table{ width:100%; border-collapse:collapse; margin-top:12px; font-size:1rem; }
th,td{ padding:13px 14px; text-align:left; border-bottom:1px solid var(--border); }
th{ font-size:.74rem; letter-spacing:.8px; text-transform:uppercase; color:var(--muted); font-weight:700; }
table tr:hover{ background:rgba(255,255,255,.035); }
td form{ display:inline; }
td button{ min-height:38px; padding:8px 13px; font-size:.85rem; margin-right:5px; }

.flashes{ list-style:none; padding:0; margin:0 0 24px; text-align:left; }
.flashes li{ background:var(--surface-2); border:1px solid var(--border); border-left:5px solid var(--green); padding:13px 17px; border-radius:11px; margin-bottom:10px; font-size:.98rem; word-break:break-word; }

.badge{ font-size:.68rem; letter-spacing:.7px; text-transform:uppercase; font-weight:800; padding:4px 10px; border-radius:999px;
  background:rgba(255,255,255,.08); color:var(--text); border:1px solid var(--border-2); line-height:1.6; white-space:nowrap; }
.badge.closed{ background:rgba(255,83,96,.15); color:var(--red); border-color:rgba(255,83,96,.45); }
.badge.open{ background:rgba(24,193,114,.15); color:var(--green-2); border-color:rgba(24,193,114,.45); }
.badge.pending{ background:rgba(255,138,61,.15); color:var(--orange); border-color:rgba(255,138,61,.45); }
.badge.info{ background:rgba(30,200,230,.14); color:var(--blue); border-color:rgba(30,200,230,.45); }
.won{ color:var(--green-2); font-weight:800; }
.lost{ color:var(--red); font-weight:700; }

.set{ border:1px solid var(--border); border-radius:var(--radius); padding:22px; margin-bottom:18px; background:rgba(255,255,255,.02); }
.set-head{ display:flex; align-items:center; flex-wrap:wrap; gap:10px; margin-bottom:12px; }
.set-head strong{ font-size:1.2rem; font-weight:800; }
.set-controls{ display:flex; flex-wrap:wrap; gap:14px; align-items:center; margin-bottom:12px; }
.set-controls form{ display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.setlist{ list-style:none; padding:0; margin:0; }
.set-item{ display:flex; align-items:center; gap:16px; padding:18px 22px; margin-bottom:14px; border:1px solid var(--border); border-radius:var(--radius); background:var(--surface-2); transition:border-color .15s, transform .12s; flex-wrap:wrap; }
.set-item:hover{ border-color:var(--green); transform:translateY(-2px); }
.set-item .set-link{ font-size:1.2rem; font-weight:800; text-decoration:none; color:var(--text); }
.set-item a.set-link:hover{ color:var(--green-2); }
.set-count{ font-size:.9rem; }
.countdown{ margin-left:auto; font-variant-numeric:tabular-nums; font-weight:700; color:var(--text); background:rgba(255,255,255,.08); padding:6px 13px; border-radius:10px; font-size:1rem; }
.set-item.closed{ opacity:.6; }
.set-item.closed .countdown{ color:var(--red); background:rgba(255,83,96,.1); }
a.blink{ margin-left:auto; font-size:.92rem; font-weight:700; text-decoration:none; color:var(--blue); background:rgba(30,200,230,.12); padding:6px 12px; border-radius:10px; }
.set-item a.blink:hover{ background:rgba(30,200,230,.2); text-decoration:none; }

input[type=radio]{ accent-color:var(--green); width:20px; height:20px; vertical-align:middle; margin-right:6px; }
label.pick{ position:relative; display:inline-flex; align-items:center; gap:4px; cursor:pointer; min-height:44px; padding:9px 14px; border:1px solid var(--border-2); border-radius:12px; font-weight:700; font-size:1.05rem; transition:border-color .12s, background .12s; }
label.pick:hover{ border-color:var(--green); }
label.pick:has(input:checked){ background:rgba(24,193,114,.16); border-color:var(--green); }
label.pick[data-tip]:hover:not(.tip-hide)::after{ content:attr(data-tip); position:absolute; bottom:118%; left:50%; transform:translateX(-50%); white-space:nowrap; background:#000; color:var(--text); border:1px solid var(--green); padding:6px 11px; border-radius:8px; font-size:.82rem; font-weight:600; z-index:5; box-shadow:var(--shadow-sm); }

.champion-bar{ margin:14px 0; padding:14px 18px; border-radius:var(--radius); background:linear-gradient(180deg, rgba(255,210,63,.16), rgba(255,210,63,.06)); border:1px solid rgba(255,210,63,.5); font-size:1.05rem; display:flex; align-items:center; gap:10px; }
.champion-bar strong{ font-family:var(--display); font-weight:800; letter-spacing:.5px; font-size:1.2rem; color:var(--yellow); }
.champion-bar::before{ content:"\1F3C6"; font-size:1.2rem; }
.bracket-status{ font-size:.92rem; font-weight:700; margin:6px 0 14px; padding:10px 15px; border-radius:11px; background:var(--surface-2); border:1px solid var(--border-2); display:inline-block; }
.bracket-status.warn{ color:var(--orange); border-color:rgba(255,138,61,.5); background:rgba(255,138,61,.08); }
.bracket-status.ok{ color:var(--green-2); border-color:var(--green); background:rgba(24,193,114,.1); }
.bracket-scroll{ overflow:auto; max-height:80vh; border:1px solid var(--border); border-radius:var(--radius); background:radial-gradient(700px 360px at 50% 0%, rgba(255,255,255,.03), transparent 60%), #04050a; }
.bracket-canvas{ position:relative; }
.bracket-svg{ position:absolute; top:0; left:0; pointer-events:none; }
.bconn{ fill:none; stroke:var(--border-2); stroke-width:2; }
.bconn.active{ stroke:var(--green); stroke-width:3; filter:drop-shadow(0 0 4px rgba(24,193,114,.45)); }
.barrow{ fill:var(--green); }
.bcol-h{ position:absolute; font-family:var(--display); font-size:.8rem; letter-spacing:1px; text-transform:uppercase; color:var(--muted); font-weight:800; text-align:center; padding-bottom:4px; }
.bcol-h.r-r32{ color:var(--green-2); }
.bcol-h.r-r16{ color:var(--blue); }
.bcol-h.r-qf{ color:var(--purple); }
.bcol-h.r-sf{ color:var(--orange); }
.bcol-h.r-final{ color:var(--yellow); }
.bnode{ position:absolute; display:flex; flex-direction:column; gap:3px; border:1px solid var(--border); border-radius:11px; padding:4px; background:var(--surface); box-sizing:border-box; box-shadow:var(--shadow-sm); }
.bteam{ position:relative; display:flex; align-items:center; justify-content:space-between; gap:8px; width:100%; text-align:left; min-height:26px; padding:7px 11px; font-size:.98rem; font-weight:600; border:1px solid transparent; border-radius:7px; background:var(--surface-2); color:var(--text); cursor:pointer; transition:background .12s, border-color .12s; }
.bt-name{ flex:1; min-width:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.bt-odd{ flex:0 0 auto; color:var(--muted); font-weight:700; font-variant-numeric:tabular-nums; }
.bteam.sel .bt-odd, .bteam.sel.champ .bt-odd{ color:inherit; opacity:.8; }
.bteam[data-tip]:hover:not(.tip-hide)::after{ content:attr(data-tip); position:absolute; bottom:116%; left:50%; transform:translateX(-50%); white-space:nowrap; background:#000; color:var(--text); border:1px solid var(--green); padding:5px 10px; border-radius:8px; font-size:.78rem; font-weight:700; z-index:6; box-shadow:var(--shadow-sm); pointer-events:none; }
.bteam:hover{ background:var(--surface-3); }
.bteam.sel{ background:linear-gradient(180deg, var(--green-2), var(--green)); color:var(--on-accent); border-color:var(--green); font-weight:800; }
.bteam.sel.champ{ background:linear-gradient(180deg, #ffe07a, var(--yellow)); border-color:var(--yellow); color:#1a1400; box-shadow:0 0 0 2px rgba(255,210,63,.35), 0 0 18px rgba(255,210,63,.4); }
.bteam.empty{ color:var(--faint); cursor:default; background:transparent; }
.bteam.empty:hover{ background:transparent; }
.bteam.dim{ opacity:.4; }
.bteam:disabled{ cursor:default; }
.bracket-actions{ display:flex; gap:12px; align-items:center; margin-top:16px; }
#save:disabled{ opacity:.45; cursor:not-allowed; }

.set-collapse{ border:1px solid var(--border); border-radius:var(--radius); margin-bottom:14px; background:rgba(255,255,255,.02); overflow:hidden; }
.set-collapse > summary{ list-style:none; cursor:pointer; display:flex; align-items:center; gap:12px; padding:16px 20px; font-weight:700; }
.set-collapse > summary::-webkit-details-marker{ display:none; }
.set-collapse > summary::after{ content:"\25BC"; margin-left:auto; color:var(--muted); font-size:.78rem; transition:transform .15s; }
.set-collapse[open] > summary::after{ transform:rotate(180deg); }
.set-collapse > summary:hover{ background:rgba(255,255,255,.05); }
.set-collapse .sum-name{ font-size:1.15rem; font-weight:800; }
.set-collapse .sum-pts{ margin-left:6px; }
.set-collapse table, .set-collapse .champion-bar{ margin-left:20px; margin-right:20px; margin-bottom:18px; }
.set-collapse table{ width:calc(100% - 40px); }

.error h1{ font-size:3.4rem; color:var(--green-2); }

@media (max-width: 820px){
  .navtoggle{ display:inline-flex; align-items:center; justify-content:center; }
  .menu{ display:none; flex-direction:column; align-items:stretch; gap:6px; flex-basis:100%; width:100%; margin:8px 0 12px; }
  .menu.open{ display:flex; }
  .menu a{ width:100%; font-size:1.05rem; padding:14px 16px; }
  .menu a.active::after{ display:none; }
  .container{ padding:26px 22px; }
  h1{ font-size:1.9rem; }
  .hero-name{ font-size:2.6rem; }
}

/* remember-me row (login) */
.remember{ display:flex; align-items:center; gap:10px; font-size:.95rem; color:var(--text);
  text-transform:none; letter-spacing:normal; font-weight:500; }
.remember input[type=checkbox]{ width:18px; height:18px; accent-color:var(--green); flex:0 0 auto; margin:0; }

/* danger zone (admin wipe) */
h2.danger-h{ color:var(--red); }
h2.danger-h::before{ background:var(--red); }
.danger-zone{ border:1px solid rgba(255,83,96,.4); background:rgba(255,83,96,.05);
  border-radius:var(--radius); padding:18px 20px; display:flex; flex-direction:column; gap:16px; }
.danger-zone form{ display:flex; align-items:center; gap:12px; flex-wrap:wrap; }

/* avatar + name inline (standings, queues, lists) */
.uname{ display:inline-flex; align-items:center; gap:9px; }
.uname a{ color:var(--text); }
.uname a:hover{ color:var(--green-2); }

/* flashy "Make a Bet" notification when there are unbetted open sets */
.card.flashy{ border-color:var(--green); box-shadow:0 0 0 1px var(--green), 0 0 22px rgba(24,193,114,.35);
  animation:pulse 1.6s ease-in-out infinite; position:relative; }
@keyframes pulse{ 0%,100%{ box-shadow:0 0 0 1px var(--green), 0 0 14px rgba(24,193,114,.25); }
  50%{ box-shadow:0 0 0 1px var(--green), 0 0 26px rgba(24,193,114,.55); } }
.notif{ display:inline-flex; align-items:center; justify-content:center; min-width:24px; height:24px;
  padding:0 7px; border-radius:999px; background:var(--green); color:var(--on-accent);
  font-size:.82rem; font-weight:800; margin-left:8px; }
.menu a.flashy{ color:var(--green-2); }
.menu a .notif{ margin-left:6px; }

/* bracket: clearer frame on the Round-of-32 matchup boxes */
.bnode.first-round{ border-color:rgba(52,224,138,.55); box-shadow:0 0 0 1px rgba(52,224,138,.25), var(--shadow-sm); }

/* "waiting for results" — flashy, attention-drawing */
.await-h{ color:var(--orange); }
.await-h::before{ background:var(--orange); }
.await-list .await-item{ border-color:rgba(255,138,61,.5);
  box-shadow:0 0 0 1px rgba(255,138,61,.4), 0 0 16px rgba(255,138,61,.18);
  animation:pulseO 1.7s ease-in-out infinite; }
.await-item .notif{ background:var(--orange); color:#1a0d00; }
@keyframes pulseO{ 0%,100%{ box-shadow:0 0 0 1px rgba(255,138,61,.35), 0 0 12px rgba(255,138,61,.15); }
  50%{ box-shadow:0 0 0 1px rgba(255,138,61,.6), 0 0 24px rgba(255,138,61,.4); } }

/* extra (single-choice stat bets) */
.extra-options{ display:flex; flex-direction:column; gap:10px; max-width:520px; margin-top:8px; }
.extra-opt{ justify-content:flex-start; width:100%; gap:12px; }
.extra-opt .opt-name{ flex:1; }
.extra-opt .opt-odd{ color:var(--muted); font-weight:800; font-variant-numeric:tabular-nums; }
.extra-opt:has(input:checked) .opt-odd{ color:var(--green-2); }

/* ---- server clock (navbar) ---- */
.server-clock{ font-family:ui-monospace,"Cascadia Code",Consolas,monospace; font-size:.82rem;
  color:var(--muted); background:rgba(255,255,255,.04); border:1px solid var(--line);
  padding:5px 10px; border-radius:9px; margin-left:14px; white-space:nowrap; letter-spacing:.3px; }
.server-clock.near{ color:var(--orange); border-color:rgba(255,138,61,.6);
  animation:clkNear 1.6s ease-in-out infinite; }
.server-clock.urgent{ color:var(--red); border-color:rgba(255,83,96,.7);
  animation:clkUrgent .8s ease-in-out infinite; }
@keyframes clkNear{ 0%,100%{ box-shadow:0 0 0 0 rgba(255,138,61,.0);} 50%{ box-shadow:0 0 12px 1px rgba(255,138,61,.45);} }
@keyframes clkUrgent{ 0%,100%{ box-shadow:0 0 0 0 rgba(255,83,96,.0); } 50%{ box-shadow:0 0 16px 2px rgba(255,83,96,.6); } }
@media (max-width:640px){ .server-clock{ display:none; } }

/* ---- flashy unbetted badge (same green pulse as the make-a-bet card) ---- */
.flashy-badge{ display:inline-flex; align-items:center; justify-content:center; min-width:20px;
  height:20px; padding:0 6px; border-radius:999px; background:var(--green); color:#04130c;
  font-weight:800; font-size:.74rem; line-height:1; animation:badgePulse 1.5s ease-in-out infinite; }
@keyframes badgePulse{ 0%,100%{ box-shadow:0 0 0 0 rgba(24,193,114,.0); transform:scale(1);} 50%{ box-shadow:0 0 12px 2px rgba(24,193,114,.6); transform:scale(1.08);} }
.navtoggle{ position:relative; }
.hb-badge{ position:absolute; top:-7px; right:-7px; }

/* ---- whole-row clickable ---- */
[data-href]{ cursor:pointer; }
.set-item[data-href]:hover{ border-color:var(--green); background:rgba(24,193,114,.06); }
tr[data-href]:hover{ background:rgba(24,193,114,.06); }

/* ---- bracket pick result colours (player's bracket view) ---- */
.bteam.sel.res-pending{ background:rgba(154,164,177,.18); border-color:var(--muted); color:var(--text); }
.bteam.sel.res-correct{ background:rgba(24,193,114,.20); border-color:var(--green); color:var(--green-2); }
.bteam.sel.res-wrong{ background:rgba(255,83,96,.18); border-color:var(--red); color:var(--red); }

/* ---- bracket points form (admin draft) ---- */
.bpoints{ margin:8px 0 12px; }
.bpoints-label{ font-size:.85rem; color:var(--muted); margin-bottom:6px; }
.bpoints-grid{ display:flex; flex-wrap:wrap; gap:10px; margin-bottom:10px; }
.bpoint{ display:flex; flex-direction:column; gap:3px; font-size:.78rem; color:var(--muted); }
.bpoint input{ width:90px; }

/* ---- Rules page (Nasıl Oynanır?) ---- */
.rules{ max-width:780px; margin:0 auto; }
.rules-title{ font-family:var(--display); font-size:1.7rem; letter-spacing:.4px; margin:0 0 6px; }
.rules-intro{ color:var(--muted); margin:0 0 22px; }
.rules-sec{ background:var(--surface); border:1px solid var(--line); border-left:3px solid var(--green);
  border-radius:12px; padding:16px 20px; margin:0 0 16px; }
.rules-sec h2{ font-family:var(--display); font-size:1.12rem; margin:0 0 8px; }
.rules-sec p{ margin:0 0 10px; }
.rules-sec ul{ margin:0; padding-left:20px; }
.rules-sec li{ margin:6px 0; }
.rules-sec li b{ color:var(--green2); }

/* ---- Home: large symmetrical "Nasıl Oynanır?" button under Log In / Sign Up ---- */
.hero .actions{ flex-direction:row; justify-content:center; gap:14px; max-width:360px; margin:0 auto; }
.hero .actions .btn{ flex:1; width:auto; padding:14px 0; }
.rules-cta{ display:block; width:360px; max-width:90vw; margin:14px auto 0; padding:18px; font-size:1.12rem;
  font-weight:700; text-align:center; color:var(--green2); border:1px solid rgba(24,193,114,.45);
  background:rgba(24,193,114,.07); }
.rules-cta:hover{ border-color:var(--green); background:rgba(24,193,114,.14); }

/* ---- Nav "Nasıl Oynanır?" — first, subtly distinct ---- */
.menu a.rules-link{ color:var(--green2); border:1px solid rgba(24,193,114,.4); border-radius:8px; }
.menu a.rules-link:hover, .menu a.rules-link.active{ color:#04130c; background:var(--green); border-color:var(--green); }

/* ---- Signup: accept-rules checkbox ---- */
.accept-rules{ display:flex; align-items:flex-start; gap:10px; font-size:.92rem; }
.accept-rules input{ width:18px; height:18px; margin-top:2px; flex:0 0 auto; }
.accept-rules a{ color:var(--green2); font-weight:600; }

/* ---- Admin users: name link + see-email toggle ---- */
a.uname{ display:inline-flex; align-items:center; gap:8px; color:var(--text); text-decoration:none; }
a.uname:hover{ color:var(--green2); }
.see-email{ font-size:.82rem; padding:5px 10px; }
.email-cell{ min-width:140px; }
.email-box{ display:inline-flex; align-items:center; gap:8px; margin-left:8px; }
.email-box[hidden], .email-view[hidden], .email-form[hidden]{ display:none; }
.email-view{ display:inline-flex; align-items:center; gap:8px; }
.email-text{ white-space:nowrap; font-family:ui-monospace,Consolas,monospace; font-size:.86rem; }
.email-form{ display:inline-flex; align-items:center; gap:6px; }
.email-input{ width:260px; max-width:60vw; }
.email-edit{ font-size:.78rem; padding:4px 10px; }

/* ---- Bracket: fit-to-screen + corner controls ---- */
.bracket.has-controls{ position:relative; }
.bracket-controls{ position:absolute; right:10px; bottom:10px; display:flex; gap:8px; z-index:6; }
.bctl{ width:40px; height:40px; display:inline-flex; align-items:center; justify-content:center;
  background:var(--surface2); border:1px solid var(--line); border-radius:10px; color:var(--text);
  cursor:pointer; box-shadow:var(--shadow-sm); padding:0; }
.bctl:hover{ border-color:var(--green); color:var(--green2); }
.bctl svg{ width:21px; height:21px; fill:none; stroke:currentColor; stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }
