:root{
  --gold:#bd9527; --gold-dark:#9a7a1f; --gold-soft:#f3ead0;
  --ink:#1b1b1b; --muted:#777; --line:#e6e1d4; --bg:#faf8f3; --card:#ffffff;
  --ok:#1f7a3d; --okbg:#e7f4ec; --err:#a32525; --errbg:#fbe9e9;
  --radius:14px; --shadow:0 1px 3px rgba(0,0,0,.06),0 8px 24px rgba(0,0,0,.04);
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;background:var(--bg);color:var(--ink);
  font:16px/1.5 system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
.wrap{width:100%;max-width:780px;margin:0 auto;padding:0 16px}

/* Topbar */
.topbar{background:#fff;border-bottom:3px solid var(--gold)}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;gap:12px;min-height:60px}
.brand{font-weight:800;font-size:1.15rem;color:var(--ink);text-decoration:none;letter-spacing:.2px}
.userbox{display:flex;align-items:center;gap:12px;font-size:.9rem}
.hello{color:var(--muted)}

/* Nav */
.mainnav{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:10}
.mainnav .wrap{display:flex;gap:4px;overflow-x:auto;-webkit-overflow-scrolling:touch}
.mainnav a{
  white-space:nowrap;padding:13px 12px;color:var(--muted);text-decoration:none;font-weight:600;font-size:.92rem;
  border-bottom:3px solid transparent;margin-bottom:-1px;
}
.mainnav a:hover{color:var(--ink)}
.mainnav a.active{color:var(--gold-dark);border-bottom-color:var(--gold)}

/* Content */
.content{padding:20px 16px 60px}
.page-title{font-size:1.5rem;margin:.2em 0 .7em;font-weight:800}
h2{font-size:1.15rem;margin:.2em 0 .6em}
.muted{color:var(--muted)}
.small{font-size:.85rem}
.nowrap{white-space:nowrap}

/* Cards */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:18px;margin:0 0 16px;box-shadow:var(--shadow)}
.card-narrow{max-width:380px;margin-left:auto;margin-right:auto}
.login-card{margin-top:24px}

/* Buttons */
.btn{display:inline-block;background:var(--gold);color:#fff;border:0;border-radius:10px;padding:12px 18px;font-weight:700;font-size:1rem;cursor:pointer;text-decoration:none}
.btn:hover{background:var(--gold-dark)}
.btn-2{background:#fff;color:var(--gold-dark);border:1.5px solid var(--gold)}
.btn-2:hover{background:var(--gold-soft)}
.btn-ghost{background:transparent;border:1px solid var(--line);color:var(--ink);border-radius:8px;padding:7px 12px;text-decoration:none;cursor:pointer;font-weight:600}
.btn-ghost:hover{border-color:var(--gold)}
.btn-ghost.small,.small.btn-ghost{padding:5px 9px;font-size:.8rem}

/* Forms */
label{display:block;margin:0 0 14px;font-weight:600}
input[type=text],input[type=number],input[type=datetime-local],select{
  display:block;width:100%;margin-top:5px;padding:11px 12px;border:1.5px solid var(--line);border-radius:9px;
  font-size:1rem;background:#fff;color:var(--ink);font-weight:500
}
input:focus,select:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-soft)}

/* Flash */
.flash{padding:11px 14px;border-radius:10px;margin:0 0 14px;font-weight:600}
.flash-ok{background:var(--okbg);color:var(--ok)}
.flash-err{background:var(--errbg);color:var(--err)}

/* Stats */
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.stat{text-align:center}
.stat-num{font-size:2rem;font-weight:800;color:var(--gold-dark);line-height:1.1}
.stat-lbl{color:var(--muted);font-size:.85rem;margin-top:4px}

/* Match cards (tipping) */
.dayhead{font-size:.95rem;color:var(--gold-dark);font-weight:800;text-transform:uppercase;letter-spacing:.5px;margin:22px 0 8px;padding-bottom:5px;border-bottom:2px solid var(--gold-soft)}
.match{background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px 14px;margin-bottom:10px}
.match.is-locked{background:#fbfaf6;opacity:.92}
.match-meta{font-size:.78rem;color:var(--muted);margin-bottom:6px}
.match-row{display:flex;align-items:center;gap:8px}
.team{flex:1;font-weight:700;font-size:.98rem}
.team-l{text-align:right}
.team-r{text-align:left}
.team-tbd{flex:1;text-align:center;color:var(--muted);font-style:italic}
.score{display:flex;align-items:center;gap:6px;flex:0 0 auto}
.score input{width:48px;margin-top:0;text-align:center;padding:9px 4px;font-weight:800;font-size:1.1rem;-moz-appearance:textfield}
.score input::-webkit-outer-spin-button,.score input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.colon{font-weight:800;color:var(--muted)}
.match-status{margin-top:7px;text-align:center;font-size:.82rem;min-height:1.1em}
.lock{color:var(--muted)}
.saved{color:var(--ok);font-weight:700}
.late{color:var(--gold-dark);font-weight:700}
.result{color:var(--ink);font-weight:700;margin-right:8px}

/* Points badge */
.pts{display:inline-block;min-width:1.7em;text-align:center;padding:2px 7px;border-radius:20px;font-weight:800;font-size:.8rem;color:#fff;background:#bbb}
.pts-0{background:#c2c2c2}
.pts-1{background:#9fb7c9}
.pts-2{background:#5b9bd5}
.pts-3{background:#3f8f5b}
.pts-4{background:var(--gold);color:#fff}

/* Save bar */
.savebar{position:sticky;bottom:0;background:linear-gradient(to top,var(--bg) 70%,transparent);padding:12px 0;text-align:center;z-index:5}
.savebar .btn{width:100%;max-width:360px}

/* Tables */
.tbl{width:100%;border-collapse:collapse;font-size:.95rem}
.tbl th,.tbl td{padding:10px 8px;border-bottom:1px solid var(--line);text-align:left;vertical-align:middle}
.tbl th{font-size:.78rem;text-transform:uppercase;letter-spacing:.4px;color:var(--muted);font-weight:700}
.tbl .num{text-align:right;white-space:nowrap}
.tbl .total{font-weight:800;color:var(--gold-dark)}
.tbl tr:last-child td{border-bottom:0}
.rank .rankcell{font-weight:800;width:2.4em;text-align:center;color:var(--muted)}
.rank .rank-1{color:#b8860b}.rank .rank-2{color:#888}.rank .rank-3{color:#a8743a}
.rank tr.mine{background:var(--gold-soft)}
.badge{display:inline-block;background:var(--gold-soft);color:var(--gold-dark);border-radius:20px;padding:1px 9px;font-size:.72rem;font-weight:800;vertical-align:middle}
.grouprow td{background:#fbfaf6;font-weight:800;color:var(--gold-dark);font-size:.82rem;text-transform:uppercase;letter-spacing:.4px}
.games td:first-child{font-weight:600}
.scroll-x{overflow-x:auto}

/* Bonus + rules */
.bonus-q{font-weight:700;margin-bottom:10px}
.bonuslist{margin:.3em 0;padding-left:1.2em}
.bonuslist li{margin:.25em 0}
.rules td:first-child{width:2.6em}
.steps{margin:.3em 0;padding-left:1.3em}
.steps li{margin:.35em 0}

/* Admin */
.admin-actions{display:flex;flex-wrap:wrap;gap:10px}
.admin-actions .btn{flex:1 1 auto;text-align:center}
.tabs{display:flex;gap:8px;margin-bottom:14px}
.tab{flex:1;text-align:center;padding:11px;border:1.5px solid var(--line);border-radius:10px;text-decoration:none;color:var(--muted);font-weight:700;background:#fff}
.tab.active{border-color:var(--gold);color:var(--gold-dark);background:var(--gold-soft)}
.admin-res input{width:60px;margin:0 auto}
.admin-res td.num{width:70px}
.ko-edit .ko-slot{font-weight:800;color:var(--gold-dark);margin-bottom:8px}
.pin{font-size:1.1rem;font-weight:800;letter-spacing:2px;background:var(--gold-soft);padding:3px 10px;border-radius:7px;color:var(--ink)}

/* Footer */
.foot{border-top:1px solid var(--line);background:#fff;color:var(--muted);font-size:.82rem;padding:18px 0;text-align:center;margin-top:30px}

@media (max-width:480px){
  .page-title{font-size:1.3rem}
  .stat-num{font-size:1.6rem}
  .team{font-size:.9rem}
  .score input{width:42px}
  .admin-actions .btn{flex-basis:100%}
}
