/* ===== Mundial HaCongress — Congress Basel World Cup pool ===== */
:root{
  --red:#7a1414; --red2:#a51d1d; --orange:#e8731f; --amber:#f5b301;
  --gold:#ffce4d; --cream:#fff6e6; --ink:#2a1608; --char:#1b1208;
  --green:#1f8a4c; --green2:#27a35a; --grey:#9a8f80; --dead:#6b6055;
  --arg1:#75aadb; --arg2:#ffffff;
  --card:#fffaf0; --line:#e6d8be; --shadow:0 6px 22px rgba(60,20,0,.16);
  --r:16px;
  font-synthesis:none;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Heebo',system-ui,Arial,sans-serif;
  color:var(--ink); background:#2a0d0d;
  background-image:
    radial-gradient(1200px 600px at 80% -10%, rgba(245,179,1,.25), transparent 60%),
    radial-gradient(900px 500px at -10% 10%, rgba(232,115,31,.22), transparent 55%),
    linear-gradient(160deg,#5e0f0f,#3a0a0a 55%,#240707);
  background-attachment:fixed;
  -webkit-text-size-adjust:100%;
}
h1,h2,h3{font-family:'Rubik','Heebo',sans-serif;margin:0}
img{max-width:100%;display:block}

/* ---------- LOGIN GATE ---------- */
.gate{position:fixed;inset:0;z-index:50;display:flex;align-items:center;justify-content:center;padding:20px;
  background:
    radial-gradient(800px 400px at 50% -10%, rgba(117,170,219,.45), transparent 60%),
    linear-gradient(160deg,#0c2a4d,#0a1f3a 60%,#06121f);
}
.gate-card{width:min(420px,100%);background:rgba(255,250,240,.97);border-radius:22px;
  padding:30px 24px 22px;text-align:center;box-shadow:0 20px 60px rgba(0,0,0,.5);
  border:3px solid var(--gold)}
.gate-badge{font-size:58px;line-height:1;filter:drop-shadow(0 4px 8px rgba(0,0,0,.25))}
.gate-title{font-size:30px;color:var(--red);margin-top:6px;letter-spacing:.5px}
.gate-sub{margin:4px 0 0;color:var(--orange);font-weight:700}
.gate-hint{margin:14px 0 16px;color:#6b5a45;font-size:14px}
.gate-input{width:100%;padding:14px 16px;margin-bottom:10px;border:2px solid var(--line);
  border-radius:12px;font-size:16px;font-family:inherit;background:#fff;text-align:right}
.gate-input:focus{outline:none;border-color:var(--arg1);box-shadow:0 0 0 3px rgba(117,170,219,.3)}
.gate-btn{width:100%;padding:14px;border:none;border-radius:12px;cursor:pointer;
  font-size:17px;font-weight:900;font-family:'Rubik',sans-serif;color:#fff;
  background:linear-gradient(135deg,var(--red2),var(--orange));box-shadow:var(--shadow)}
.gate-btn:active{transform:translateY(1px)}
.gate-err{margin-top:12px;color:#c0271b;font-weight:700}
.gate-foot{margin-top:16px;color:#9a8a70;font-weight:700;letter-spacing:3px;font-size:13px}
.shake{animation:shake .4s}
@keyframes shake{0%,100%{transform:translateX(0)}20%,60%{transform:translateX(-9px)}40%,80%{transform:translateX(9px)}}

/* ---------- APP SHELL ---------- */
.app{max-width:1100px;margin:0 auto;padding:0 12px 40px;color:var(--ink)}
.hero{color:#fff;text-align:center;padding:26px 10px 14px}
.hero-logo{width:96px;height:96px;object-fit:cover;border-radius:50%;margin:0 auto 8px;
  border:3px solid var(--gold);box-shadow:0 6px 18px rgba(0,0,0,.4)}
.hero-emojis{font-size:24px;letter-spacing:2px;opacity:.95}
.hero h1{font-size:34px;font-weight:900;margin-top:6px;text-shadow:0 3px 10px rgba(0,0,0,.4)}
.hero .yr{color:var(--gold)}
.hero-sub{margin:6px 0 0;color:#ffe9c9;font-size:15px}
.hero-meta{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:14px}
.pill{background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.3);color:#fff;
  padding:7px 13px;border-radius:999px;font-weight:700;font-size:14px;backdrop-filter:blur(4px)}
.pill.ghost{background:transparent;color:#ffd9a8;font-weight:500}

/* ---------- TABS ---------- */
.tabs{position:sticky;top:0;z-index:20;display:flex;gap:6px;overflow-x:auto;
  padding:10px 4px;margin:8px -4px 0;scrollbar-width:none;-webkit-overflow-scrolling:touch}
.tabs::-webkit-scrollbar{display:none}
.tab{flex:0 0 auto;border:none;cursor:pointer;font-family:'Rubik',sans-serif;font-weight:700;
  font-size:15px;padding:10px 15px;border-radius:999px;color:#fff;white-space:nowrap;
  background:rgba(0,0,0,.28);border:1px solid rgba(255,255,255,.18)}
.tab.is-active{background:var(--gold);color:var(--char);box-shadow:var(--shadow)}

/* ---------- PANELS ---------- */
.panel{display:none;background:var(--cream);border-radius:var(--r);margin-top:12px;
  padding:18px 14px 22px;box-shadow:var(--shadow)}
.panel.is-active{display:block;animation:fade .25s ease}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.sec-title{color:var(--red);font-size:23px}
.sub-title{color:var(--orange);font-size:18px;margin:20px 0 10px}
.sec-note{color:#6b5a45;font-size:14px;line-height:1.6;margin:8px 0 16px}

/* ---------- BETS ---------- */
.bets-grid{display:grid;grid-template-columns:1fr;gap:12px}
.bet{border:1px solid var(--line);border-radius:14px;padding:14px;background:var(--card);
  position:relative;overflow:hidden}
.bet::before{content:"";position:absolute;inset-inline-start:0;top:0;bottom:0;width:6px;background:var(--grey)}
.bet.alive::before{background:linear-gradient(var(--green2),var(--green))}
.bet.dead::before{background:#c2b6a6}
.bet.dead{opacity:.72}
.bet-top{display:flex;align-items:center;justify-content:space-between;gap:8px}
.bet-id{display:inline-flex;align-items:center;gap:9px}
.avatar{width:38px;height:38px;border-radius:50%;object-fit:cover;border:2px solid var(--gold);box-shadow:0 2px 5px rgba(0,0,0,.2)}
.bet-name{font-family:'Rubik',sans-serif;font-weight:900;font-size:18px;color:var(--char)}
.chip{font-size:12px;font-weight:800;padding:4px 9px;border-radius:999px;white-space:nowrap}
.chip.alive{background:#dff5e6;color:#15703c;border:1px solid #aee0bf}
.chip.dead{background:#efe6da;color:#8a6a4a;border:1px solid #d9c7ad}
.chip.win{background:var(--gold);color:#5a3c00;border:1px solid #e0a93a}
.bet-final{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin:12px 0 8px;font-weight:700}
.team{display:inline-flex;align-items:center;gap:6px}
.team img{width:26px;height:auto;border-radius:3px;box-shadow:0 1px 2px rgba(0,0,0,.25)}
.score{font-family:'Rubik';font-weight:900;background:var(--char);color:var(--gold);
  padding:2px 10px;border-radius:8px;font-size:16px}
.bet-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}
.tagm{font-size:12.5px;color:#5b4a36;background:#f3e7d2;border:1px solid var(--line);
  padding:3px 8px;border-radius:8px}
.bet-reason{font-size:13px;color:#7a6a55;margin-top:8px}
.bet-note{font-size:12.5px;color:var(--orange);margin-top:6px;font-weight:700}
.win-team{color:var(--red);font-weight:900}

/* ---------- BRACKET ---------- */
.bracket{display:flex;gap:14px;overflow-x:auto;padding:6px 2px 14px;-webkit-overflow-scrolling:touch}
.round{flex:0 0 auto;display:flex;flex-direction:column;justify-content:space-around;gap:10px;min-width:158px}
.round-h{font-family:'Rubik';font-weight:800;color:var(--red);font-size:13px;text-align:center;
  position:sticky;top:0;padding-bottom:4px}
.match{background:var(--card);border:1px solid var(--line);border-radius:11px;padding:7px;font-size:13px;
  box-shadow:0 2px 6px rgba(60,20,0,.08)}
.match.up{border-color:var(--amber);border-style:dashed}
.match .row{display:flex;align-items:center;gap:6px;padding:3px 2px}
.match .row.win{font-weight:900}
.match .row.lose{opacity:.45;text-decoration:line-through}
.match .row img{width:20px;height:auto;border-radius:2px}
.match .nm{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.match .sc{font-family:'Rubik';font-weight:900;color:var(--char)}
.match .pen{font-size:10px;color:var(--orange)}
.match-meta{display:flex;justify-content:space-between;font-size:10.5px;color:#a08a6c;margin-top:4px}
.odds-mini{display:flex;gap:3px;margin-top:5px}
.odds-mini span{flex:1;text-align:center;font-size:10px;background:#f3e7d2;border-radius:5px;padding:2px 0;font-weight:700}
.odds-mini .hi{background:var(--gold);color:#5a3c00}
.match.pending{opacity:.6}
.tbd{color:var(--grey);font-style:italic}
.half-A{box-shadow:inset 0 0 0 2px rgba(31,138,76,.12)}
.half-B{box-shadow:inset 0 0 0 2px rgba(165,29,29,.10)}

/* clickable sim teams */
.sim .row.pick{cursor:pointer;border-radius:7px}
.sim .row.pick:hover{background:#fbeecd}
.sim .row.chosen{background:#dff5e6;font-weight:900}

/* ---------- ODDS ---------- */
.odds-matches{display:grid;grid-template-columns:1fr;gap:10px}
.oticket{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:12px;
  box-shadow:0 2px 6px rgba(60,20,0,.08)}
.oticket .ot-top{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:#a08a6c}
.oticket .ot-teams{display:flex;align-items:center;justify-content:space-between;gap:6px;margin:8px 0}
.oticket .ot-teams .team{font-weight:800}
.obars{display:flex;gap:6px}
.obar{flex:1;text-align:center;background:#f3e7d2;border-radius:8px;padding:7px 4px;font-weight:800;font-size:13px}
.obar .lab{display:block;font-size:11px;color:#8a755a;font-weight:600}
.obar.hi{background:linear-gradient(135deg,var(--amber),var(--gold));color:#5a3c00}
.no-mkt{font-size:12px;color:#a08a6c;text-align:center;padding:6px}
.odds-bars{display:grid;grid-template-columns:1fr;gap:7px}
.orow{display:flex;align-items:center;gap:9px}
.orow .team{width:120px;flex:0 0 auto;font-weight:700;font-size:14px}
.orow .bar{flex:1;background:#efe2cb;border-radius:999px;height:18px;overflow:hidden}
.orow .bar i{display:block;height:100%;background:linear-gradient(90deg,var(--orange),var(--gold));border-radius:999px}
.orow .pct{width:48px;text-align:left;font-weight:800;font-family:'Rubik';font-size:13px}

/* ---------- SIM ---------- */
.sim-actions{display:flex;gap:8px;margin-bottom:10px;flex-wrap:wrap}
.btn-sec{border:1px solid var(--line);background:#fff;border-radius:10px;padding:9px 14px;
  font-family:'Rubik';font-weight:700;cursor:pointer;color:var(--red)}
.btn-sec:active{transform:translateY(1px)}
.sim-final{margin-top:14px}
.final-card{background:linear-gradient(135deg,#2a0d0d,#5e0f0f);color:#fff;border-radius:16px;
  padding:16px;text-align:center;border:2px solid var(--gold)}
.final-card h3{color:var(--gold);font-size:18px}
.final-teams{display:flex;align-items:center;justify-content:center;gap:14px;margin:12px 0;flex-wrap:wrap}
.final-teams .team{font-size:18px;font-weight:900}
.final-teams img{width:40px}
.stepper{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.12);border-radius:10px;padding:4px}
.stepper button{width:34px;height:34px;border:none;border-radius:8px;background:var(--gold);color:#5a3c00;
  font-size:20px;font-weight:900;cursor:pointer}
.stepper .v{min-width:24px;text-align:center;font-family:'Rubik';font-weight:900;font-size:22px}
.win-pick{display:flex;gap:8px;justify-content:center;margin-top:10px;flex-wrap:wrap}
.win-pick button{border:1px solid rgba(255,255,255,.4);background:rgba(255,255,255,.1);color:#fff;
  border-radius:999px;padding:7px 14px;font-weight:700;cursor:pointer}
.win-pick button.on{background:var(--gold);color:#5a3c00;border-color:var(--gold)}
.sim-verdict{margin-top:14px}
.verdict{border-radius:14px;padding:14px;font-weight:700;text-align:center}
.verdict.win{background:var(--gold);color:#5a3c00;border:2px solid #e0a93a}
.verdict.none{background:#efe6da;color:#7a6a55;border:1px solid var(--line)}
.verdict .big{font-family:'Rubik';font-size:22px;font-weight:900;display:block;margin-top:4px}
.partial{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;margin-top:10px}
.partial .tagm{background:#fff}

/* ---------- RULES / FOOT ---------- */
.rules-list{padding-inline-start:22px;line-height:1.9;color:#4a3a26;font-size:15px}
.rules-list li{margin-bottom:6px}
.foot{color:#ffe9c9;text-align:center;font-size:12.5px;margin-top:20px;line-height:1.7}
.foot-dim{color:#e9b98a;opacity:.8}

/* ---------- RESPONSIVE ---------- */
@media(min-width:680px){
  .bets-grid{grid-template-columns:1fr 1fr}
  .odds-matches{grid-template-columns:1fr 1fr}
  .hero h1{font-size:42px}
  .hero-emojis{font-size:30px}
}
@media(min-width:980px){
  .bets-grid{grid-template-columns:1fr 1fr 1fr}
  .odds-matches{grid-template-columns:1fr 1fr 1fr}
}
@media(max-width:380px){
  .hero h1{font-size:28px}
  .sec-title{font-size:20px}
  .tab{font-size:14px;padding:9px 12px}
}
