:root{--bg:#101014;--card:#1b1c22;--card2:#252631;--text:#f5f5f7;--muted:#b8bac7;--red:#e63b3b;--green:#30c56e;--line:#333542;--gold:#f0bb52}*{box-sizing:border-box}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:radial-gradient(circle at top,#262837,#101014 55%);color:var(--text)}a{color:inherit;text-decoration:none}.top{position:sticky;top:0;z-index:10;background:rgba(16,16,20,.94);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);padding:16px 22px;display:flex;gap:16px;align-items:center;justify-content:space-between}.brand{font-weight:900;font-size:20px}.nav{display:flex;gap:8px;flex-wrap:wrap}.nav a,.btn,button{border:1px solid var(--line);background:var(--card2);color:var(--text);padding:10px 13px;border-radius:12px;cursor:pointer;font-weight:700}.nav a.active,.btn.primary,button.primary{background:var(--red);border-color:var(--red)}button.danger{background:#5b1e22;border-color:#7d2b32}button.small{padding:6px 9px;font-size:12px}.wrap{max-width:1280px;margin:0 auto;padding:22px}.hero{display:grid;grid-template-columns:1.1fr .9fr;gap:18px}.card{background:linear-gradient(180deg,var(--card),#171820);border:1px solid var(--line);border-radius:18px;padding:18px;box-shadow:0 12px 40px rgba(0,0,0,.22)}h1{font-size:42px;margin:0 0 10px}h2{margin:0 0 14px}h3{margin:0 0 12px}.muted{color:var(--muted)}.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.input, input, select{background:#0f1015;border:1px solid var(--line);border-radius:10px;color:var(--text);padding:10px;min-width:0}input[type=number]{width:58px;text-align:center}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:14px}.group-title{display:flex;align-items:center;justify-content:space-between;gap:10px}.match{display:grid;grid-template-columns:48px 1fr 58px 12px 58px 1fr;gap:8px;align-items:center;border-top:1px solid var(--line);padding:9px 0}.num{color:var(--muted);font-size:12px;font-weight:800}.team{font-weight:900}.standings{width:100%;border-collapse:collapse;margin-top:12px}.standings th,.standings td{border-bottom:1px solid var(--line);padding:8px;text-align:left}.qualified td{color:var(--green);font-weight:800}.ko{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:12px;align-items:start}.ko-match{border:1px solid var(--line);background:#11131a;border-radius:14px;padding:10px;margin:0 0 10px}.choice{display:block;border:1px solid var(--line);padding:9px;border-radius:10px;margin:6px 0;background:#181a22}.choice.winner{border-color:var(--green);color:var(--green);font-weight:900}.notice{border-left:4px solid var(--gold);padding:12px;background:rgba(240,187,82,.08);border-radius:12px}pre{white-space:pre-wrap;word-break:break-word;background:#0d0e13;border:1px solid var(--line);border-radius:14px;padding:14px}.pill{display:inline-block;padding:4px 8px;border-radius:999px;background:#252631;color:var(--muted);font-size:12px}.footer{padding:30px;text-align:center;color:var(--muted)}@media(max-width:760px){.hero{grid-template-columns:1fr}.top{align-items:flex-start;flex-direction:column}.match{grid-template-columns:38px 1fr 44px 8px 44px 1fr;font-size:13px}h1{font-size:30px}.wrap{padding:14px}}

.ko-score-line{display:grid;grid-template-columns:1fr 58px 14px 58px 1fr;gap:8px;align-items:center;margin:8px 0}
.ko-score-line input{width:58px;text-align:center}
.ko-match{gap:8px}


/* ===== V17 TABLEAU FINAL PROPRE ===== */

#koBox{
  width:100% !important;
}

.ko-title{
  text-align:center !important;
  margin:34px auto 22px !important;
}

.ko-title h2{
  font-size:34px !important;
  font-weight:900 !important;
  margin:0 0 8px !important;
}

.ko-scroll{
  width:100% !important;
  overflow-x:auto !important;
  padding:8px 0 70px !important;
}

.ko{
  width:max-content !important;
  margin-left:auto !important;
  margin-right:auto !important;
  display:flex !important;
  justify-content:center !important;
  align-items:flex-start !important;
  gap:22px !important;
}

.ko-round{
  width:252px !important;
  min-width:252px !important;
  max-width:252px !important;
  background:linear-gradient(180deg,#1b1d27,#12141b) !important;
  border:1px solid #333542 !important;
  border-radius:18px !important;
  padding:14px !important;
  box-shadow:0 16px 45px rgba(0,0,0,.28) !important;
}

.ko-round h3{
  text-align:center !important;
  font-size:23px !important;
  font-weight:900 !important;
  margin:0 0 16px !important;
  padding-bottom:10px !important;
  border-bottom:1px solid rgba(230,59,67,.45) !important;
}

.ko-match{
  width:100% !important;
  overflow:hidden !important;
  background:#10121a !important;
  border:1px solid #333542 !important;
  border-radius:15px !important;
  padding:11px !important;
  margin:0 0 14px !important;
}

.ko-match-head{
  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
  gap:8px !important;
  margin-bottom:9px !important;
}

.ko-match-head .pill{
  flex:0 0 auto !important;
}

.reset-match-btn{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  width:auto !important;
  min-width:64px !important;
  height:30px !important;
  padding:0 10px !important;
  margin:0 !important;
  border-radius:999px !important;
  border:1px solid rgba(230,59,67,.75) !important;
  background:#e63b3b !important;
  color:#fff !important;
  font-size:12px !important;
  font-weight:900 !important;
  cursor:pointer !important;
}

.reset-match-btn:hover{
  filter:brightness(1.08) !important;
}

.ko-score-line{
  display:grid !important;
  grid-template-columns:minmax(0,1fr) 42px 10px 42px minmax(0,1fr) !important;
  align-items:center !important;
  gap:6px !important;
  width:100% !important;
  margin:8px 0 12px !important;
}

.ko-score-line .team{
  display:block !important;
  min-width:0 !important;
  width:100% !important;
  overflow:hidden !important;
  text-overflow:ellipsis !important;
  white-space:nowrap !important;
  font-size:15px !important;
  font-weight:900 !important;
}

.team-left{
  text-align:left !important;
}

.team-right{
  text-align:right !important;
}

.ko-score-line input{
  width:42px !important;
  min-width:42px !important;
  max-width:42px !important;
  height:36px !important;
  padding:4px !important;
  text-align:center !important;
  font-size:16px !important;
  border-radius:10px !important;
}

.ko-score-line .dash{
  text-align:center !important;
  color:#fff !important;
  font-weight:900 !important;
}

.choice{
  display:block !important;
  width:100% !important;
  overflow:hidden !important;
  text-overflow:ellipsis !important;
  white-space:nowrap !important;
  border:1px solid #333542 !important;
  padding:9px !important;
  border-radius:11px !important;
  margin:7px 0 !important;
  background:#171a23 !important;
  font-size:14px !important;
}

.choice.winner{
  border-color:#30c56e !important;
  color:#30c56e !important;
  font-weight:900 !important;
}

@media(max-width:1450px){
  .ko{
    margin-left:0 !important;
    margin-right:0 !important;
  }
}


/* ===== V18 boutons valider ===== */

.validate-btn{
  width:100%;
  border:1px solid #333542;
  background:#171a23;
  color:#fff;
  border-radius:12px;
  padding:12px;
  margin-top:8px;
  font-size:15px;
  font-weight:800;
  cursor:pointer;
  transition:.2s ease;
}

.validate-btn:hover{
  border-color:#e63b3b;
}

.validate-btn.winner{
  background:#1f3b2a;
  border-color:#30c56e;
  color:#30c56e;
}


/* ===== V19 tirs au but ===== */

.penalty-note{
  display:block;
  margin:6px 0 10px;
  padding:8px 10px;
  border-radius:10px;
  background:rgba(255,255,255,.045);
  color:#cfd2dc;
  font-size:12px;
  line-height:1.25;
  text-align:center;
}

.validate-btn.winner::after{
  content:"";
}

.ko-match:has(.validate-btn.winner) .penalty-note{
  border:1px solid rgba(255,190,80,.35);
  background:rgba(255,190,80,.08);
}


/* ===== V20 champs tirs au but ===== */

.penalty-box{
  margin:8px 0 10px;
  padding:9px;
  border-radius:12px;
  background:rgba(255,190,80,.07);
  border:1px solid rgba(255,190,80,.25);
}

.penalty-title{
  text-align:center;
  color:#f5c66b;
  font-size:12px;
  font-weight:900;
  margin-bottom:7px;
}

.penalty-score-line{
  display:grid;
  grid-template-columns:minmax(0,1fr) 38px 10px 38px minmax(0,1fr);
  align-items:center;
  gap:5px;
}

.penalty-score-line .team{
  display:block;
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  font-size:12px;
  font-weight:800;
}

.penalty-score-line input{
  width:38px !important;
  min-width:38px !important;
  height:32px !important;
  padding:3px !important;
  text-align:center !important;
  font-size:14px !important;
  border-radius:9px !important;
}

.penalty-score-line .dash{
  text-align:center;
  font-weight:900;
}
