:root{
  /* maroon / sand palette (restored) */
  --bg:#F4F1EA; --panel:#ffffff; --panel-2:#FAF8F3; --line:#E5E1D8;
  --ink:#1A1A2E; --muted:#6B6B80;
  --accent:#8A1538; --accent-2:#A52048; --accent-soft:rgba(138,21,56,.08);
  --navy:#1B2A4A; --navy-soft:rgba(27,42,74,.10);
  --gold:#B38A4C; --gold-soft:rgba(179,138,76,.16);
  --red:#C0392B; --green:#1E7A46;
  --chip:#F1ECE2; --radius:14px; --shadow:0 2px 12px rgba(26,26,46,.07);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);
  font-family:"Readex Pro",system-ui,-apple-system,"Segoe UI",Tahoma,sans-serif;
  max-width:100%;overflow-x:hidden;}
body{min-height:100vh}
[dir="rtl"]{font-family:"Readex Pro","Segoe UI",Tahoma,sans-serif}
a{color:var(--accent)}
button{font-family:inherit}

/* layout */
.wrap{max-width:1100px;margin:0 auto;padding:16px}
header.top{position:sticky;top:0;z-index:20;background:#fff;border-bottom:2px solid var(--accent)}
.top .wrap{display:flex;align-items:center;gap:12px;padding-block:10px}
.brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:19px;color:var(--ink);cursor:pointer}
.brandlogo{height:36px;width:auto;display:block}
.spacer{flex:1}
.langbtn,.ghost{background:var(--chip);color:var(--ink);border:1px solid var(--line);
  padding:8px 12px;border-radius:10px;cursor:pointer;font-size:14px}
.langbtn:hover,.ghost:hover{border-color:var(--accent);color:var(--accent)}

/* cards */
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:18px;box-shadow:var(--shadow);margin-bottom:16px}
.card h2{margin:0 0 4px;font-size:20px;color:var(--ink)}
.card .sub{color:var(--muted);font-size:14px;margin-bottom:14px}
.grid{display:grid;gap:12px}
.row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}

/* forms */
label{display:block;font-size:13px;color:var(--muted);margin-bottom:5px}
input[type=text],input[type=email],input[type=password],input[type=datetime-local]{
  width:100%;background:#fff;border:1px solid var(--line);color:var(--ink);
  padding:11px 12px;border-radius:10px;font-size:15px}
input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.btn{background:var(--accent);color:#fff;border:none;font-weight:700;
  padding:11px 18px;border-radius:10px;cursor:pointer;font-size:15px}
.btn:hover{background:var(--accent-2)}
.btn[disabled]{opacity:.45;cursor:not-allowed}
.btn.outline{background:transparent;border:1px solid var(--accent);color:var(--accent)}
.btn.outline:hover{background:var(--accent);color:#fff}
.btn.danger{background:transparent;border:1px solid var(--red);color:var(--red)}
.linkbtn{background:none;border:none;color:var(--accent);cursor:pointer;font-size:14px;padding:4px 0;text-decoration:underline}
.err{color:var(--red);font-size:13px;margin-top:8px;min-height:16px}
.ok{color:var(--green)}

/* tabs */
.tabs{display:flex;gap:6px;margin-bottom:14px;flex-wrap:wrap}
.tabs button{background:var(--chip);border:1px solid var(--line);color:var(--muted);
  padding:8px 16px;border-radius:999px;cursor:pointer;font-size:14px}
.tabs button.active{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:700}

/* game list */
.game-item{display:flex;align-items:center;gap:12px;justify-content:space-between;
  background:var(--panel-2);border:1px solid var(--line);border-radius:12px;padding:14px}
.game-item .gi-main{min-width:0}
.game-item .meta{color:var(--muted);font-size:13px;display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-top:4px}
.code-pill{font-family:ui-monospace,monospace;letter-spacing:2px;background:#fff;
  border:1px dashed var(--accent);color:var(--accent);padding:3px 10px;border-radius:8px;
  font-weight:700;direction:ltr;unicode-bidi:isolate;display:inline-block}
.badge{background:var(--chip);border:1px solid var(--line);color:var(--muted);
  font-size:12px;padding:2px 8px;border-radius:999px}
.badge.host{color:var(--accent);border-color:var(--accent);background:var(--accent-soft)}

/* stepper */
.steps{display:flex;gap:6px;margin-bottom:16px;flex-wrap:wrap}
.steps .s{flex:1;min-width:90px;text-align:center;font-size:12px;color:var(--muted);
  padding:8px 4px;border-bottom:3px solid var(--line)}
.steps .s.active{color:var(--ink);border-color:var(--accent)}
.steps .s.done{color:var(--accent);border-color:var(--accent-2)}

/* group picker + groups display */
.groups-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}
.group-card{background:var(--panel-2);border:1px solid var(--line);border-radius:12px;padding:12px}
.group-card h4{margin:0 0 8px;font-size:14px;color:var(--accent);display:flex;justify-content:space-between}
.team{display:flex;align-items:center;gap:8px;justify-content:space-between;
  background:#fff;border:1px solid var(--line);border-radius:9px;padding:9px 11px;
  margin-bottom:6px;cursor:pointer;font-size:14px;user-select:none}
.team:hover{border-color:var(--accent)}
.team.r1{border-color:var(--accent);background:var(--accent-soft)}
.team.r2{border-color:var(--navy);background:var(--navy-soft)}
.team.r3{border-color:var(--gold);background:var(--gold-soft)}
.team.disabled{opacity:.4;cursor:not-allowed}
.team.static{cursor:default}
.team.static:hover{border-color:var(--line)}
.team .ar{color:var(--muted);font-size:13px}
.rankbadge{min-width:22px;height:22px;border-radius:50%;display:inline-flex;
  align-items:center;justify-content:center;font-size:12px;font-weight:700;background:var(--chip);color:var(--ink)}
.team.r1 .rankbadge{background:var(--accent);color:#fff}
.team.r2 .rankbadge{background:var(--navy);color:#fff}
.team.r3 .rankbadge{background:var(--gold);color:#fff}
.counter{font-weight:700}
.counter.full{color:var(--green)}

/* ---- bracket: equal-share alignment + horizontal containment ---- */
.bracketwrap{overflow-x:auto;max-width:100%;-webkit-overflow-scrolling:touch}
.bracket{display:flex;gap:16px;align-items:stretch;min-width:min-content;padding:6px 2px 16px}
.bcol{display:flex;flex-direction:column;min-width:152px;flex:0 0 auto}
.bcol h5{margin:0 0 6px;text-align:center;color:var(--muted);font-size:12px}
.bcol h5 .pts{color:var(--accent);font-weight:600}
.seeds{display:flex;flex-direction:column;flex:1 1 auto}
.seed{display:flex;flex-direction:column;justify-content:center;flex:1 1 0;min-height:104px;position:relative;padding:0 4px}
.match{background:#fff;border:1px solid var(--line);border-radius:10px;overflow:hidden;position:relative;margin:6px 0}
.bcol.left .match::after,.bcol.right .match::before{content:"";position:absolute;top:50%;width:16px;height:2px;background:var(--line)}
.bcol.left .match::after{right:-16px}
.bcol.right .match::before{left:-16px}
.match .slot{display:flex;align-items:center;justify-content:space-between;gap:6px;
  padding:9px 10px;font-size:13px;cursor:pointer;border-bottom:1px solid var(--line)}
.match .slot:last-of-type{border-bottom:none}
.match .slot:hover{background:var(--panel-2)}
.match .slot.empty{color:var(--muted);cursor:default;font-style:italic}
.match .slot.empty:hover{background:transparent}
.match .slot.win{background:var(--accent-soft);font-weight:700;color:var(--accent)}
.match .slot.correct{background:rgba(30,122,70,.16);font-weight:700;color:var(--green)}
.match .slot.wrong{background:rgba(192,57,43,.12);color:var(--red)}
.match .mno{display:flex;justify-content:space-between;align-items:center;font-size:10px;color:var(--muted);padding:3px 8px;background:var(--panel-2)}
.match .mno .mdate{color:var(--accent);font-weight:600}

/* Final (M104): a bit bigger, gold-framed, and nudged above the two semis */
.bcol.center{min-width:178px}
.bcol.center .match{border:2px solid var(--gold);box-shadow:0 2px 10px rgba(179,138,76,.25)}
.bcol.center .match .slot{padding:13px 12px;font-size:15px}
.bcol.center .match .mno{font-size:11px}
.champrow{text-align:center;margin-top:10px}
.champrow .trophy{height:68px;width:auto;display:block;margin:0 auto 4px}
.champrow .who{font-size:20px;font-weight:800;color:var(--gold)}
.champrow .who.correct{color:var(--green)}
.champrow .who.wrong{color:var(--red);opacity:.7}
.champrow .pts{display:block;font-size:12px;color:var(--accent);font-weight:600;margin-top:2px}

/* team name + flag */
.tn{display:flex;align-items:center;gap:8px;min-width:0}
.flag{width:24px;height:auto;border-radius:2px;box-shadow:0 0 0 1px var(--line);flex:0 0 auto}

/* leaderboard */
table.lb{width:100%;border-collapse:collapse;font-size:14px;table-layout:fixed}
table.lb th,table.lb td{padding:10px;border-bottom:1px solid var(--line);text-align:start;overflow:hidden}
table.lb th{color:var(--muted);font-weight:600;font-size:12px}
table.lb tr.me{background:var(--accent-soft)}
table.lb td.sc{font-weight:800;color:var(--accent);text-align:end}
.rankcell{font-weight:700;color:var(--muted)}
.barwrap{background:var(--chip);border-radius:6px;height:8px;overflow:hidden;min-width:60px}
.bar{height:100%;background:var(--accent)}   /* flat, simple */
.rowbracket{max-width:100%}
.rowbracket .bcol{min-width:138px}

.center{text-align:center}
.muted{color:var(--muted)}
.small{font-size:13px}
.notice{background:var(--gold-soft);border:1px solid var(--gold);color:#7a5a23;
  padding:10px 14px;border-radius:10px;font-size:14px;margin-bottom:14px}
.notice.closed{background:rgba(192,57,43,.10);border-color:var(--red);color:#8a2a20}
.notice.cutoff{background:var(--accent-soft);border-color:var(--accent);color:var(--accent);text-align:center;font-weight:600}
.card.compact{padding:14px}
.card.compact h2{font-size:17px}
.card.compact .sub{margin-bottom:10px}
.appfoot{text-align:end;color:var(--muted);font-size:11px;padding:20px 16px 28px}
.toast{position:fixed;inset-inline:0;bottom:22px;margin-inline:auto;width:max-content;
  max-width:90%;background:#fff;border:1px solid var(--green);color:var(--ink);
  padding:10px 18px;border-radius:10px;box-shadow:var(--shadow);z-index:50}
.toast.err{border-color:var(--red)}
.hidden{display:none}
@media(max-width:600px){.top .wrap{flex-wrap:wrap}.bcol{min-width:140px}}
