*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --green:#006633;--green2:#008844;--green3:#e8f5ed;--green4:#c8ecd6;
  --gold:#cc9900;--gold2:#ffcc00;--gold3:#fff8dc;--gold4:#fff3a0;
  --red:#cc2200;--blue:#003399;
  --bg:#f4f7f0;--white:#ffffff;
  --text:#1a2e1a;--text2:#4a6741;--text3:#7a9e72;
  --border:#c8dcc0;--border2:#e0eedd;
  --shadow:0 2px 8px rgba(0,100,50,.10);
  --shadow2:0 4px 16px rgba(0,100,50,.14);
}
html{font-size:15px}
body{
  font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif;
  background:var(--bg);color:var(--text);line-height:1.5;min-height:100vh;
}
a{color:inherit;text-decoration:none}
input,select,button{font-family:inherit;font-size:14px}
input,select{
  border:1.5px solid var(--border);border-radius:8px;padding:7px 11px;
  background:var(--white);color:var(--text);outline:none;transition:border-color .15s,box-shadow .15s;
}
input:focus,select:focus{border-color:var(--green2);box-shadow:0 0 0 3px rgba(0,136,68,.12)}
input[type=number]{width:54px;text-align:center;font-weight:600}

/* ── Layout ── */
.container{max-width:860px;margin:0 auto;padding:0 14px 60px}

/* ── Navbar ── */
.navbar{
  background:var(--green);
  box-shadow:0 2px 12px rgba(0,80,30,.25);
  position:sticky;top:0;z-index:100;
}
.navbar__inner{
  max-width:860px;margin:0 auto;padding:0 14px;
  display:flex;align-items:center;gap:6px;height:54px;flex-wrap:wrap;
}
.navbar__logo{
  font-weight:800;font-size:17px;color:var(--gold2);
  letter-spacing:-.3px;margin-right:6px;text-shadow:0 1px 2px rgba(0,0,0,.3);
  display:flex;align-items:center;gap:6px;
}
.navbar__right{margin-left:auto;display:flex;align-items:center;gap:8px}
.navbar__user{font-size:13px;color:rgba(255,255,255,.85)}
.navbar__rank{
  font-size:12px;background:var(--gold2);color:var(--green);
  padding:3px 10px;border-radius:99px;font-weight:700;
}
.nav-btn{
  padding:6px 13px;border:1.5px solid rgba(255,255,255,.25);border-radius:8px;
  background:transparent;cursor:pointer;color:rgba(255,255,255,.85);font-size:13px;
  transition:all .15s;display:inline-flex;align-items:center;gap:4px;font-weight:500;
}
.nav-btn:hover{background:rgba(255,255,255,.15);color:#fff;border-color:rgba(255,255,255,.4)}
.nav-btn.active{background:var(--gold2);color:var(--green);border-color:var(--gold2);font-weight:700}
.nav-btn--sm{font-size:12px;padding:4px 9px}

/* ── Hero banner ── */
.hero{
  background:linear-gradient(135deg,var(--green) 0%,var(--green2) 100%);
  border-radius:16px;margin:18px 0 20px;padding:24px 28px;
  display:flex;align-items:center;gap:20px;flex-wrap:wrap;
  box-shadow:var(--shadow2);position:relative;overflow:hidden;
}
.hero::before{
  content:'⚽';font-size:120px;position:absolute;right:-10px;top:-20px;
  opacity:.08;transform:rotate(-15deg);pointer-events:none;
}
.hero__rank{font-size:48px;line-height:1}
.hero__info h2{font-size:20px;font-weight:700;color:#fff}
.hero__info p{font-size:13px;color:rgba(255,255,255,.75);margin-top:2px}
.hero__pts{margin-left:auto;text-align:right}
.hero__pts strong{font-size:36px;font-weight:800;color:var(--gold2);display:block;line-height:1}
.hero__pts span{font-size:12px;color:rgba(255,255,255,.7)}

/* ── Toast ── */
.toast{
  position:fixed;top:16px;left:50%;transform:translateX(-50%);
  padding:10px 20px;border-radius:99px;font-size:13px;font-weight:600;
  z-index:9999;white-space:nowrap;box-shadow:var(--shadow2);
  animation:fadeout 3.5s forwards;border:2px solid;
}
.toast--success{background:#e8f5ed;color:var(--green);border-color:var(--green4)}
.toast--error{background:#ffeee8;color:var(--red);border-color:#ffc8b8}
@keyframes fadeout{0%,70%{opacity:1}100%{opacity:0;pointer-events:none}}

/* ── Section title ── */
.section-title{
  font-size:17px;font-weight:700;color:var(--green);margin:24px 0 12px;
  display:flex;align-items:center;gap:8px;
}
.section-title::after{
  content:'';flex:1;height:2px;background:linear-gradient(90deg,var(--green4),transparent);
  border-radius:2px;margin-left:4px;
}

/* ── Tabs ── */
.tabs{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:14px}
.tab{
  padding:7px 15px;border:1.5px solid var(--border);border-radius:99px;
  background:var(--white);cursor:pointer;font-size:13px;color:var(--text2);
  transition:all .15s;font-weight:500;
}
.tab:hover{border-color:var(--green2);color:var(--green);background:var(--green3)}
.tab.active{background:var(--green);color:#fff;border-color:var(--green);box-shadow:0 2px 8px rgba(0,100,50,.2)}
.tabs--sm .tab{padding:4px 10px;font-size:12px}

/* ── Alert ── */
.alert{padding:10px 14px;border-radius:10px;font-size:13px;margin-bottom:12px;display:flex;align-items:center;gap:8px;font-weight:500}
.alert--warning{background:#fff8e0;border:1.5px solid #f0c040;color:#8a6200}
.alert--info{background:var(--green3);border:1.5px solid var(--green4);color:var(--green)}

/* ── Date header ── */
.date-header{
  font-size:12px;font-weight:700;color:var(--text3);text-transform:uppercase;
  letter-spacing:.6px;margin:18px 0 8px;padding:6px 10px;
  background:var(--green3);border-radius:6px;border-left:3px solid var(--green2);
}

/* ── Match card ── */
.match-card{
  background:var(--white);border:1.5px solid var(--border2);border-radius:12px;
  padding:12px 16px;margin-bottom:7px;box-shadow:var(--shadow);
  transition:border-color .15s,box-shadow .15s;
}
.match-card:hover{border-color:var(--border);box-shadow:var(--shadow2)}
.match-card--locked{opacity:.8;background:#fafafa}
.match-card__meta{display:flex;align-items:center;gap:7px;margin-bottom:9px;flex-wrap:wrap}
.phase-badge{
  background:var(--green3);color:var(--green2);border:1px solid var(--green4);
  padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;
}
.result-badge{
  background:#e8f5ed;color:var(--green);border:1px solid var(--green4);
  padding:2px 8px;border-radius:4px;font-size:11px;font-weight:700;
}
.pts-badge{
  margin-left:auto;background:var(--gold3);color:var(--gold);border:1.5px solid var(--gold4);
  padding:2px 10px;border-radius:99px;font-size:12px;font-weight:800;
}
.pts-badge--zero{background:#f5f5f5;color:#999;border-color:#ddd}
.lock-badge{margin-left:auto;font-size:11px;color:#999;display:flex;align-items:center;gap:3px}
.match-card__row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.team{font-size:13px;font-weight:600;flex:1 1 110px;color:var(--text)}
.team--right{text-align:right}
.team-flag{font-size:18px;vertical-align:middle;margin:0 2px}
.score-display{
  font-size:15px;color:var(--text3);padding:0 10px;min-width:60px;
  text-align:center;font-weight:600;
}
.score-inputs{display:flex;align-items:center;gap:6px}
.score-inputs input{width:46px;font-size:15px;font-weight:700;padding:6px 4px}
.score-sep{color:var(--text3);font-weight:300;font-size:18px}
.save-btn{
  padding:6px 14px;border:1.5px solid var(--border);border-radius:8px;
  cursor:pointer;background:var(--white);font-size:12px;color:var(--text2);
  margin-left:auto;transition:all .15s;font-weight:600;
}
.save-btn:hover{background:var(--green);border-color:var(--green);color:#fff}
.save-btn.saved{background:var(--green3);border-color:var(--green4);color:var(--green)}
.empty-msg{color:var(--text3);font-size:14px;padding:28px 0;text-align:center}

/* ── Group qualifier bet ── */
.group-qualifier-bets{
  background:var(--white);border:2px solid var(--gold2);border-radius:14px;
  padding:16px 18px;margin-bottom:10px;box-shadow:0 2px 12px rgba(204,153,0,.12);
}
.gqb-header{
  display:flex;align-items:center;gap:10px;margin-bottom:14px;
  font-size:14px;font-weight:700;color:var(--gold);
}
.gqb-header span{background:var(--gold3);border:1.5px solid var(--gold4);padding:3px 10px;border-radius:99px;font-size:12px;color:var(--gold)}
.gqb-row{display:flex;align-items:center;gap:10px;margin-bottom:10px;flex-wrap:wrap}
.gqb-label{font-size:13px;font-weight:600;color:var(--text2);min-width:70px}
.gqb-select{flex:1;min-width:150px}
.gqb-suggestion{
  font-size:11px;color:var(--green2);background:var(--green3);border:1px solid var(--green4);
  padding:2px 8px;border-radius:99px;cursor:pointer;transition:all .15s;font-weight:500;
}
.gqb-suggestion:hover{background:var(--green);color:#fff;border-color:var(--green)}
.gqb-pts-info{
  font-size:11px;color:var(--text3);background:#f8f8f8;border-radius:6px;
  padding:6px 10px;margin-top:4px;
}
.gqb-result{padding:8px 0;font-size:13px}
.gqb-result--ok{color:var(--green);font-weight:600}
.gqb-result--partial{color:var(--gold);font-weight:600}
.gqb-result--miss{color:#999}

/* ── Special bets ── */
.special-section{margin-top:28px}
.special-cards{display:flex;flex-direction:column;gap:10px}
.special-card{
  background:var(--white);border:1.5px solid var(--border2);border-radius:12px;
  padding:14px 16px;box-shadow:var(--shadow);
}
.special-card__head{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.special-card__icon{font-size:22px}
.special-card__title{font-size:14px;font-weight:700;color:var(--text)}
.special-card__pts{
  margin-left:auto;font-size:11px;font-weight:800;
  background:var(--gold3);border:1.5px solid var(--gold4);color:var(--gold);
  padding:3px 10px;border-radius:99px;
}
.special-input-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.special-input-row input,.special-input-row select{flex:1;min-width:140px}
.current-bet{font-size:12px;color:var(--text3);margin-top:6px}
.locked-msg{font-size:13px;color:#e0a000;display:flex;align-items:center;gap:5px}
.result-ok{font-size:13px;color:var(--green);display:flex;align-items:center;gap:5px;font-weight:600}
.result-miss{font-size:13px;color:#999}

/* ── Ranking ── */
.ranking-list{display:flex;flex-direction:column;gap:5px;margin-bottom:20px}
.ranking-row{
  display:flex;align-items:center;gap:12px;
  background:var(--white);border:1.5px solid var(--border2);border-radius:10px;
  padding:10px 16px;box-shadow:var(--shadow);transition:all .15s;
}
.ranking-row:hover{border-color:var(--border);box-shadow:var(--shadow2)}
.ranking-row--me{background:linear-gradient(135deg,#e8f5ed,#d0eedd);border-color:var(--green2)}
.ranking-row--top1{border-left:4px solid var(--gold2)}
.ranking-row--top2{border-left:4px solid #c0c0c0}
.ranking-row--top3{border-left:4px solid #cd7f32}
.ranking-pos{font-size:16px;min-width:28px;text-align:center}
.ranking-pseudo{flex:1;font-size:14px;font-weight:600}
.ranking-pts{font-size:16px;font-weight:800;color:var(--gold)}
.pts-label{font-size:11px;font-weight:400;color:var(--text3)}
.ranking-detail{font-size:11px;color:var(--text3)}

.scoring-legend{
  display:flex;flex-wrap:wrap;gap:6px;margin-bottom:20px;
}
.scoring-legend span{
  font-size:12px;color:var(--text2);background:var(--white);
  padding:4px 12px;border-radius:99px;border:1.5px solid var(--border);font-weight:500;
}

/* ── Standings ── */
.standings-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:12px}
.standings-table{
  background:var(--white);border:1.5px solid var(--border2);border-radius:12px;
  overflow:hidden;box-shadow:var(--shadow);
}
.standings-table__header{
  background:var(--green);padding:9px 14px;font-size:13px;font-weight:700;
  color:#fff;display:flex;justify-content:space-between;align-items:center;
}
.standings-table__header em{font-style:normal;color:rgba(255,255,255,.7);font-size:11px;font-weight:400}
table.st{width:100%;border-collapse:collapse}
table.st th{
  padding:6px 8px;text-align:right;font-size:11px;font-weight:600;
  color:var(--text3);background:#fafafa;border-bottom:1.5px solid var(--border2);
}
table.st th:nth-child(2){text-align:left;padding-left:0}
table.st td{padding:8px 8px;text-align:right;font-size:13px;border-bottom:1px solid var(--border2)}
table.st td:first-child{width:6px;padding:0}
table.st td:nth-child(2){text-align:left;padding-left:8px;font-weight:600}
table.st tr:last-child td{border-bottom:none}
table.st tr:hover td{background:var(--green3)}
.st-pts{font-weight:800;color:var(--green)}
.st-q{background:var(--green2)!important}
.st-q2{background:#388bfd!important}

/* ── Admin ── */
.admin-add-match{
  background:var(--white);border:1.5px solid var(--border);border-radius:12px;
  padding:14px 16px;margin-bottom:14px;box-shadow:var(--shadow);
}
.admin-add-match h4{font-size:13px;font-weight:700;margin-bottom:10px;color:var(--text2)}
.admin-add-match__row{display:flex;gap:8px;align-items:flex-end;flex-wrap:wrap}
.admin-add-match__row input,.admin-add-match__row select{flex:1;min-width:90px}
.admin-matches{display:flex;flex-direction:column;gap:5px;margin-bottom:20px}
.admin-match-row{
  background:var(--white);border:1.5px solid var(--border2);border-radius:10px;
  padding:9px 14px;display:flex;align-items:center;gap:8px;flex-wrap:wrap;
  box-shadow:var(--shadow);
}
.admin-match-row--locked{border-left:4px solid #f0c040}
.admin-match-row--done{border-left:4px solid var(--green2)}
.admin-match-meta{font-size:11px;color:var(--text3);min-width:100px}
.team--sm{font-size:12px;font-weight:600;flex:1 1 90px;color:var(--text)}
.special-results-admin{
  background:var(--white);border:1.5px solid var(--border);border-radius:12px;
  padding:14px 16px;margin-bottom:20px;box-shadow:var(--shadow);
}
.special-results-admin h4{font-size:13px;font-weight:700;margin-bottom:12px;color:var(--text2)}
.sra-row{
  display:flex;align-items:center;gap:8px;flex-wrap:wrap;
  padding:9px 0;border-bottom:1px solid var(--border2);font-size:13px;
}
.sra-row:last-child{border-bottom:none;padding-bottom:0}
.sra-row>span:first-child{min-width:185px;font-weight:600}
.sra-row select,.sra-row input{flex:1;min-width:140px}
.done{color:var(--green);font-size:13px;font-weight:600}
.admin-rank-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:7px 0;border-bottom:1px solid var(--border2);font-size:13px;
}
.admin-rank-row:last-child{border-bottom:none}

/* ── Auth ── */
.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(135deg,var(--green) 0%,var(--green2) 100%)}
.auth-card{
  width:100%;max-width:380px;
  background:var(--white);border-radius:20px;
  padding:36px 30px;box-shadow:0 8px 40px rgba(0,80,30,.25);
}
.auth-logo{font-size:48px;text-align:center;margin-bottom:8px}
.auth-title{font-size:24px;font-weight:800;text-align:center;color:var(--green);margin-bottom:4px}
.auth-sub{font-size:14px;color:var(--text3);text-align:center;margin-bottom:26px}
.auth-hint{font-size:11px;color:var(--text3);text-align:center;margin-top:14px}
.label{font-size:13px;color:var(--text2);font-weight:600;display:block;margin:12px 0 5px}
.input{width:100%;padding:9px 12px}
.error-text{
  color:var(--red);font-size:13px;background:#fff0ee;border:1.5px solid #ffb8a8;
  padding:9px 12px;border-radius:9px;margin-bottom:12px;font-weight:500;
}
.mt-8{margin-top:8px;display:block}

/* ── Buttons ── */
.btn{
  padding:10px 18px;border-radius:10px;cursor:pointer;font-size:14px;font-weight:700;
  border:2px solid transparent;transition:all .15s;display:inline-block;text-align:center;
  width:100%;margin-top:8px;
}
.btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,.15)}
.btn:active{transform:translateY(0)}
.btn--primary{background:var(--green);color:#fff;border-color:var(--green2)}
.btn--success{background:var(--green);color:#fff;border-color:var(--green2)}
.btn--info{background:var(--green3);color:var(--green);border-color:var(--green4)}
.btn--secondary{background:#f5f5f5;color:var(--text2);border-color:var(--border)}
.btn--sm{padding:6px 14px;font-size:12px;border-radius:8px;width:auto;margin-top:0}
.btn--danger{background:#fff0ee;color:var(--red);border-color:#ffb8a8}
.btn--gold{background:var(--gold2);color:var(--green);border-color:var(--gold)}

@media(max-width:600px){
  .standings-grid{grid-template-columns:1fr}
  .team{font-size:12px}
  .score-inputs input{width:40px}
  .hero{padding:16px 14px}
  .hero__rank{font-size:36px}
  .hero__pts strong{font-size:28px}
}
