@font-face{font-family:"Plus Jakarta Sans";src:url("../fonts/plus-jakarta-sans-400.ttf") format("truetype");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Plus Jakarta Sans";src:url("../fonts/plus-jakarta-sans-500.ttf") format("truetype");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Plus Jakarta Sans";src:url("../fonts/plus-jakarta-sans-600.ttf") format("truetype");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"Plus Jakarta Sans";src:url("../fonts/plus-jakarta-sans-700.ttf") format("truetype");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:"Plus Jakarta Sans";src:url("../fonts/plus-jakarta-sans-800.ttf") format("truetype");font-weight:800;font-style:normal;font-display:swap}

:root {
  --red: #d9232e;
  --red-dark: #a8121d;
  --green: #17704b;
  --green-dark: #0e4b34;
  --ink: #17201c;
  --muted: #65716a;
  --cream: #f8f1e4;
  --paper: #fffdf8;
  --line: #dedfd9;
  --gold: #f4c85b;
  --white: #fff;
  --shadow: 0 20px 60px rgba(24, 45, 35, .13);
  --shadow-soft: 0 10px 30px rgba(24, 45, 35, .08);
  --radius: 24px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  min-height: 100vh;
  color: var(--ink);
  background:
    radial-gradient(circle at 8% 0%, rgba(244, 200, 91, .22), transparent 28rem),
    linear-gradient(180deg, #fbf7ef 0%, #f5f7f3 100%);
  font-family: "Plus Jakarta Sans", ui-sans-serif, system-ui, sans-serif;
  line-height: 1.5;
}

button, input, select, textarea { font: inherit; }
a { color: inherit; }
.page { min-height: 100vh; }
.container { width: min(1120px, calc(100% - 32px)); margin: auto; padding: 24px 0 40px; }

.brandbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin: 4px 0 20px;
}
.brand { display: flex; align-items: center; gap: 12px; color: var(--ink); font-size: 18px; font-weight: 900; line-height: 1.05; text-decoration: none; }
.brand small { display: block; margin-top: 5px; color: var(--muted); font-size: 12px; font-weight: 750; letter-spacing: .05em; text-transform: uppercase; }
.brand-badge {
  width: 48px;
  height: 48px;
  display: grid;
  place-items: center;
  flex: 0 0 auto;
  border-radius: 15px;
  color: var(--white);
  background: linear-gradient(145deg, var(--red), var(--red-dark));
  box-shadow: 0 10px 24px rgba(217, 35, 46, .25);
  font-family: Georgia, serif;
  font-size: 26px;
  font-style: italic;
}
.season-chip, .code-chip {
  padding: 9px 14px;
  border: 1px solid #d7d9d4;
  border-radius: 999px;
  background: rgba(255, 255, 255, .72);
  color: var(--green-dark);
  font-size: 13px;
  font-weight: 800;
}

.hero {
  position: relative;
  display: flex;
  min-height: 430px;
  overflow: hidden;
  isolation: isolate;
  border-radius: 32px;
  color: var(--white);
  background: #153c2c url("../img/football-hero.svg") center / cover no-repeat;
  box-shadow: var(--shadow);
}
.hero::after {
  position: absolute;
  z-index: -1;
  inset: 0;
  content: "";
  background: linear-gradient(90deg, rgba(10, 28, 21, .96) 0%, rgba(10, 28, 21, .82) 48%, rgba(10, 28, 21, .18) 100%);
}
.hero-content { align-self: center; width: min(650px, 100%); padding: 52px; }
.eyebrow, .section-kicker {
  display: inline-block;
  color: var(--red);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.eyebrow {
  padding: 8px 13px;
  border: 1px solid rgba(255, 255, 255, .3);
  border-radius: 999px;
  color: var(--white);
  background: rgba(255, 255, 255, .12);
}
.hero h1 { margin: 18px 0 16px; font-size: clamp(42px, 6.5vw, 76px); letter-spacing: -.055em; line-height: .95; }
.hero p { max-width: 590px; margin: 0 0 26px; color: #eef4ef; font-size: clamp(17px, 2vw, 21px); }
.highlight { color: var(--gold); }
.hero-actions { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.pill {
  display: inline-flex;
  align-items: center;
  min-height: 48px;
  padding: 10px 14px;
  border: 1px solid rgba(255, 255, 255, .28);
  border-radius: 14px;
  background: rgba(255, 255, 255, .12);
  font-size: 14px;
  font-weight: 800;
  backdrop-filter: blur(8px);
}

button, .btn {
  min-height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 13px 19px;
  border: 0;
  border-radius: 14px;
  color: var(--white);
  background: linear-gradient(135deg, var(--red), var(--red-dark));
  box-shadow: 0 10px 24px rgba(217, 35, 46, .22);
  cursor: pointer;
  font-weight: 850;
  text-align: center;
  text-decoration: none;
  transition: transform .18s, box-shadow .18s, opacity .18s;
}
button:hover, .btn:hover { transform: translateY(-1px); box-shadow: 0 13px 28px rgba(217, 35, 46, .28); }
button:focus-visible, .btn:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible {
  outline: 3px solid rgba(23, 112, 75, .25);
  outline-offset: 2px;
}
button:disabled { opacity: .48; cursor: not-allowed; transform: none; box-shadow: none; }
.btn-secondary { background: linear-gradient(135deg, #24322b, #111915); box-shadow: var(--shadow-soft); }
.btn-green { background: linear-gradient(135deg, var(--green), var(--green-dark)); box-shadow: 0 10px 24px rgba(23, 112, 75, .22); }

.code-panel {
  position: relative;
  z-index: 2;
  width: calc(100% - 64px);
  display: grid;
  grid-template-columns: .75fr 1.25fr;
  gap: 40px;
  align-items: center;
  margin: -34px auto 0;
  padding: 28px 32px;
  border: 1px solid rgba(255, 255, 255, .9);
  border-radius: var(--radius);
  background: rgba(255, 253, 248, .96);
  box-shadow: var(--shadow);
}
.code-panel h2, .section-heading h2, .page-intro h1 { margin: 4px 0 6px; font-size: clamp(28px, 4vw, 42px); letter-spacing: -.04em; line-height: 1.05; }
.code-panel p, .section-copy { margin: 0; color: var(--muted); }
.code-form label, label { display: block; margin: 0 0 7px; font-size: 14px; font-weight: 800; }
.code-entry { display: grid; grid-template-columns: 1fr auto; gap: 10px; }
input, select, textarea {
  width: 100%;
  min-height: 48px;
  padding: 12px 14px;
  border: 1px solid #cfd3cd;
  border-radius: 13px;
  color: var(--ink);
  background: var(--white);
  outline: none;
  transition: border-color .18s, box-shadow .18s;
}
input:focus, select:focus, textarea:focus { border-color: var(--green); box-shadow: 0 0 0 4px rgba(23, 112, 75, .1); }
.ticket-input { text-transform: uppercase; letter-spacing: .1em; font-size: 19px; font-weight: 900; }
.field-hint { display: block; margin-top: 7px; color: var(--muted); font-size: 12px; }

.how-it-works { padding: 76px 0 16px; }
.section-heading { margin-bottom: 22px; text-align: center; }
.steps { counter-reset: steps; display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.step {
  min-height: 190px;
  padding: 24px;
  border: 1px solid var(--line);
  border-radius: 20px;
  background: rgba(255, 255, 255, .74);
  box-shadow: var(--shadow-soft);
}
.step::before {
  counter-increment: steps;
  content: "0" counter(steps);
  display: block;
  margin-bottom: 28px;
  color: var(--red);
  font-size: 13px;
  font-weight: 900;
  letter-spacing: .08em;
}
.step b { display: block; margin-bottom: 6px; font-size: 19px; }
.step p { margin: 0; color: var(--muted); }
.footer { display: flex; justify-content: space-between; gap: 20px; padding: 34px 0 8px; color: var(--muted); font-size: 13px; }
.footer a { font-weight: 750; }

.page-intro {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 24px;
  padding: 26px 0 18px;
}
.page-intro p { margin: 0; color: var(--muted); }
.selection-counter { display: flex; align-items: baseline; gap: 5px; min-width: 130px; color: var(--muted); }
.selection-counter strong { color: var(--green); font-size: 48px; letter-spacing: -.05em; line-height: 1; }
.selection-counter span { font-weight: 800; }
.card {
  margin: 16px 0;
  padding: 24px;
  border: 1px solid rgba(255, 255, 255, .9);
  border-radius: var(--radius);
  background: rgba(255, 253, 248, .9);
  box-shadow: var(--shadow-soft);
}
.card h1, .card h2, .card h3 { margin-top: 0; }
.form-section { display: grid; grid-template-columns: 48px 1fr; gap: 20px; }
.section-number {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 14px;
  color: var(--white);
  background: var(--green);
  font-size: 18px;
  font-weight: 900;
}
.section-body { min-width: 0; }
.section-body h2 { margin-bottom: 3px; font-size: 27px; letter-spacing: -.025em; }
.form-row { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 15px; margin-top: 22px; }
.consent {
  display: flex;
  align-items: flex-start;
  gap: 11px;
  margin-top: 18px;
  padding: 14px;
  border-radius: 14px;
  background: #f0f3ef;
  font-weight: 650;
}
.consent input, .match-selector input { width: 18px; min-height: 18px; flex: 0 0 auto; accent-color: var(--green); }
.matches-heading { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; margin-bottom: 20px; }
.selection-status { padding: 7px 11px; border-radius: 999px; color: var(--green-dark); background: #e4f1e9; font-size: 12px; font-weight: 850; white-space: nowrap; }
.choice-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.match {
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: var(--white);
  transition: border-color .18s, box-shadow .18s, opacity .18s;
}
.match:has(.match-selector input:disabled) { opacity: .55; }
.match.is-selected { border-color: var(--green); box-shadow: 0 0 0 3px rgba(23, 112, 75, .1); }
.match-selector { position: relative; display: block; min-height: 130px; margin: 0; padding: 18px; cursor: pointer; }
.match-selector input { position: absolute; opacity: 0; pointer-events: none; }
.match-check {
  position: absolute;
  top: 15px;
  right: 15px;
  width: 27px;
  height: 27px;
  display: grid;
  place-items: center;
  border: 1px solid #ccd1cb;
  border-radius: 9px;
  color: transparent;
  background: var(--white);
}
.is-selected .match-check { border-color: var(--green); color: var(--white); background: var(--green); }
.match-meta { display: flex; justify-content: space-between; gap: 42px; color: var(--muted); font-size: 12px; font-weight: 750; }
.match-stage { color: var(--red); text-transform: uppercase; }
.match-title { display: flex; align-items: center; justify-content: center; gap: 12px; margin-top: 25px; font-size: 18px; text-align: center; }
.match-title span { color: var(--muted); font-size: 11px; font-weight: 800; text-transform: uppercase; }
.score-entry { display: none; align-items: flex-end; justify-content: center; gap: 10px; padding: 16px 18px 18px; border-top: 1px solid var(--line); background: #f3f6f2; }
.is-selected .score-entry { display: flex; }
.score-entry label { width: 100px; margin: 0; text-align: center; }
.score-entry label span { display: block; overflow: hidden; margin-bottom: 5px; color: var(--muted); font-size: 11px; text-overflow: ellipsis; white-space: nowrap; }
.score-entry input { min-height: 52px; padding: 8px; font-size: 22px; font-weight: 900; text-align: center; }
.score-separator { padding-bottom: 13px; font-size: 20px; font-weight: 900; }
.submit-bar {
  position: sticky;
  z-index: 5;
  bottom: 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  margin-top: 18px;
  padding: 15px 16px 15px 20px;
  border: 1px solid rgba(255, 255, 255, .9);
  border-radius: 18px;
  color: var(--white);
  background: rgba(20, 34, 27, .95);
  box-shadow: 0 15px 40px rgba(18, 35, 27, .25);
  backdrop-filter: blur(10px);
}
.submit-bar strong, .submit-bar span { display: block; }
.submit-bar span { color: #bec8c1; font-size: 12px; }
.submit-bar button { flex: 0 0 auto; }

.alert { margin: 14px 0; padding: 13px 15px; border: 1px solid transparent; border-radius: 13px; font-weight: 750; }
.alert-error { border-color: #f2b8bc; color: #8b1620; background: #fff0f1; }
.alert-ok { border-color: #abd5bd; color: #145d3f; background: #e8f6ee; }
.confirmation-page { min-height: 100vh; display: grid; place-items: center; }
.confirmation-card { max-width: 690px; padding: clamp(32px, 7vw, 72px); border-radius: 32px; background: var(--paper); box-shadow: var(--shadow); text-align: center; }
.confirmation-mark { width: 70px; height: 70px; display: grid; place-items: center; margin: 0 auto 24px; border-radius: 50%; color: var(--white); background: var(--green); font-size: 34px; font-weight: 900; }
.confirmation-card h1 { margin: 10px 0 16px; font-size: clamp(36px, 6vw, 60px); letter-spacing: -.05em; line-height: 1; }
.confirmation-card p { margin: 0 auto 28px; color: var(--muted); font-size: 17px; }

.grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(210px, 1fr)); gap: 14px; }
.stat { padding: 22px; border: 1px solid var(--line); border-radius: 18px; background: var(--white); box-shadow: var(--shadow-soft); }
.stat strong { display: block; font-size: 34px; }
.stat span, .small { color: var(--muted); font-size: 13px; font-weight: 750; }
.topbar, .admin-title { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; }
.table-wrap { overflow: auto; border: 1px solid var(--line); border-radius: 18px; background: var(--white); }
.table { width: 100%; min-width: 720px; border-collapse: collapse; }
.table th { color: var(--white); background: #18241e; text-align: left; }
.table th, .table td { padding: 12px; border-bottom: 1px solid var(--line); }
.table tr:hover td { background: #f7f8f6; }
.admin-menu { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; margin: 0 0 16px; padding: 12px; }
.admin-menu .btn { min-height: 42px; padding: 10px 14px; font-size: 13px; }
.admin-shell .container { padding-top: 14px; }
code { padding: 2px 5px; border-radius: 5px; background: #e9ece8; }

@media (max-width: 780px) {
  .container { width: min(100% - 20px, 1120px); padding-top: 14px; }
  .season-chip { display: none; }
  .hero { min-height: 500px; border-radius: 24px; background-position: 62% center; }
  .hero::after { background: linear-gradient(90deg, rgba(10, 28, 21, .96), rgba(10, 28, 21, .72)); }
  .hero-content { align-self: flex-end; padding: 30px 24px 38px; }
  .hero h1 { font-size: clamp(42px, 14vw, 62px); }
  .hero-actions .btn { width: 100%; }
  .pill { width: 100%; justify-content: center; }
  .code-panel { width: calc(100% - 16px); grid-template-columns: 1fr; gap: 20px; margin-top: -22px; padding: 22px; }
  .code-entry { grid-template-columns: 1fr; }
  .steps { grid-template-columns: 1fr; }
  .step { min-height: 0; }
  .step::before { margin-bottom: 18px; }
  .footer { flex-direction: column; gap: 8px; }
  .page-intro { align-items: center; }
  .page-intro p { max-width: 250px; }
  .selection-counter { min-width: auto; flex-direction: column; align-items: center; line-height: 1; }
  .selection-counter strong { font-size: 40px; }
  .selection-counter span { font-size: 11px; }
  .card { padding: 18px; }
  .form-section { grid-template-columns: 1fr; gap: 12px; }
  .form-row, .choice-grid { grid-template-columns: 1fr; }
  .matches-heading { align-items: flex-start; }
  .submit-bar { bottom: 8px; align-items: stretch; flex-direction: column; gap: 12px; }
  .submit-bar button { width: 100%; }
  .admin-menu .btn { flex: 1 1 135px; }
  .table { font-size: 13px; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { transition: none !important; }
}

/* Accueil Prono Mondial */
.home-dark {
  color: #f7f9fc;
  background: #031228;
  font-family: "Plus Jakarta Sans", Arial, sans-serif;
}
.home-wrap { width: min(1450px, calc(100% - 64px)); margin: 0 auto; }
.site-header {
  position: relative;
  z-index: 20;
  border-bottom: 1px solid rgba(255,255,255,.06);
  background: #031126;
  box-shadow: 0 5px 25px rgba(0,0,0,.28);
}
.nav-wrap { min-height: 96px; display: flex; align-items: center; gap: 48px; }
.prono-logo { display: flex; align-items: center; gap: 12px; color: #fff; text-decoration: none; line-height: .82; }
.logo-ball { font-size: 59px; filter: grayscale(1) brightness(2.3); }
.prono-logo strong, .prono-logo b { display: block; font-size: 29px; font-weight: 950; letter-spacing: -.03em; }
.prono-logo b { color: #ffbd0b; }
.prono-logo small { display: block; margin-top: 8px; font-size: 10px; font-weight: 800; letter-spacing: .32em; }
.main-nav { display: flex; align-items: center; justify-content: center; gap: clamp(20px, 2.5vw, 44px); flex: 1; }
.main-nav a, .home-footer a { color: #f3f6fb; font-size: 14px; font-weight: 900; text-decoration: none; text-transform: uppercase; }
.main-nav a:hover { color: #ffc21c; }
.login-button { min-width: 164px; padding: 14px 20px; border: 2px solid #f2b900; border-radius: 12px; color: #fff; font-size: 14px; font-weight: 900; text-align: center; text-decoration: none; text-transform: uppercase; }
.login-button span { margin-right: 8px; color: #ffe8aa; }
.mobile-nav { position: relative; display: none; }
.mobile-nav summary { padding: 10px 12px; border: 1px solid #395572; border-radius: 8px; color: #fff; cursor: pointer; font-size: 12px; font-weight: 800; list-style: none; text-transform: uppercase; }
.mobile-nav summary::-webkit-details-marker { display: none; }
.mobile-nav nav { position: absolute; z-index: 40; top: calc(100% + 9px); right: 0; width: 220px; overflow: hidden; border: 1px solid #234361; border-radius: 10px; background: #04162e; box-shadow: 0 15px 35px rgba(0,0,0,.4); }
.mobile-nav nav a { display: block; padding: 12px 15px; border-bottom: 1px solid #173650; color: #fff; font-size: 12px; font-weight: 700; text-decoration: none; text-transform: uppercase; }
.mobile-nav nav a:last-child { border: 0; }
.stadium-hero {
  position: relative;
  min-height: 735px;
  padding: 38px 0 80px;
  background:
    linear-gradient(90deg, rgba(2,15,33,.98) 0%, rgba(2,15,33,.64) 33%, rgba(2,15,33,.05) 62%, rgba(2,15,33,.23) 100%),
    url("../img/stadium-hero-v2.jpg") center / cover no-repeat;
}
.stadium-hero::after { position: absolute; inset: auto 0 0; height: 140px; content: ""; background: linear-gradient(transparent, #031329); pointer-events: none; }
.stadium-layout { position: relative; z-index: 2; display: grid; grid-template-columns: minmax(500px, 1fr) 360px; gap: 34px; justify-content: space-between; align-items: start; }
.hero-copy { max-width: 610px; }
.hero-kicker { margin: 0 0 8px; color: #7fc32d; font-size: 14px; font-weight: 900; letter-spacing: .16em; text-transform: uppercase; }
.hero-copy h1 { margin: 0; color: #fff; font-size: clamp(42px, 5vw, 66px); font-weight: 950; letter-spacing: .005em; line-height: .91; text-transform: uppercase; text-shadow: 0 4px 18px rgba(0,0,0,.55); }
.hero-copy h1 strong { display: inline-block; color: #ffc01a; font-size: 1.35em; line-height: .98; }
.hero-copy h1 span { font-size: .62em; }
.hero-copy h1 b { color: #ffc01a; font-size: .58em; }
.hero-lead { max-width: 420px; margin: 22px 0 24px; font-size: 18px; line-height: 1.45; text-shadow: 0 2px 8px #000; }
.dark-code-form { max-width: 440px; padding: 20px 24px 15px; border: 1px solid #335273; border-radius: 12px; background: rgba(2,17,39,.91); box-shadow: 0 14px 40px rgba(0,0,0,.38); }
.dark-code-form label { margin-bottom: 10px; color: #fff; font-size: 17px; font-weight: 950; text-transform: uppercase; }
.dark-code-entry { display: grid; grid-template-columns: 1fr 138px; gap: 8px; }
.dark-code-entry input { min-height: 48px; border: 0; border-radius: 6px; font-size: 15px; letter-spacing: .03em; }
.dark-code-entry button { min-height: 48px; border-radius: 6px; background: linear-gradient(#58b632, #25840d); box-shadow: none; font-size: 16px; text-transform: uppercase; }
.dark-code-entry button span { font-size: 27px; line-height: 0; }
.distributor-help-button { width: 100%; display: flex; align-items: center; gap: 8px; margin-top: 12px; padding: 10px 12px; border: 1px solid #42617e; border-radius: 7px; color: #fff; background: #0a2542; box-shadow: none; font-size: 12px; font-weight: 800; text-align: left; cursor: pointer; }
.distributor-help-button span { width: 20px; height: 20px; display: grid; place-items: center; flex: 0 0 auto; border-radius: 50%; color: #07182d; background: #ffc928; font-family: Georgia,serif; font-weight: 900; }
.distributor-help-modal { width: min(920px, calc(100% - 30px)); max-height: calc(100vh - 30px); padding: 0; overflow: hidden; border: 1px solid #345674; border-radius: 15px; color: #eaf2fa; background: #061a35; box-shadow: 0 24px 80px rgba(0,0,0,.65); }
.distributor-help-modal::backdrop { background: rgba(0,8,22,.82); backdrop-filter: blur(4px); }
.distributor-help-modal-head { display: flex; align-items: center; justify-content: space-between; gap: 20px; padding: 18px 22px; border-bottom: 1px solid #294866; background: #081f3d; }
.distributor-help-modal-head span { color: #6fc53a; font-size: 11px; font-weight: 900; letter-spacing: .12em; text-transform: uppercase; }
.distributor-help-modal-head h2 { margin: 3px 0 0; color: #fff; font-size: 24px; }
.distributor-help-modal-head button { width: 40px; height: 40px; padding: 0; border: 1px solid #496782; border-radius: 50%; color: #fff; background: #102f4c; box-shadow: none; font-size: 28px; line-height: 1; cursor: pointer; }
.distributor-help-modal-body { display: grid; grid-template-columns: minmax(300px, 1fr) minmax(280px, 390px); gap: 24px; max-height: calc(100vh - 110px); padding: 24px; overflow-y: auto; }
.distributor-help-modal-body section { font-size: 15px; line-height: 1.55; }
.distributor-help-modal-body section > strong { display: block; color: #ffc928; font-size: 16px; }
.distributor-help-modal-body ol { margin: 18px 0; padding-left: 22px; }
.distributor-help-modal-body li { margin: 9px 0; }
.distributor-help-modal-body p { margin: 0; }
.distributor-help-modal code { padding: 3px 6px; border-radius: 4px; color: #07182d; background: #fff; font-weight: 900; white-space: nowrap; }
.ticket-code-example { margin: 0; }
.ticket-code-example img { display: block; width: 100%; height: auto; border: 1px solid #43627f; border-radius: 7px; }
.ticket-code-example figcaption { margin-top: 6px; color: #9fb3c7; font-size: 10px; font-style: italic; text-align: center; }
.dark-code-form > p { margin: 10px 0 0; color: #bbc7d8; font-size: 13px; }
.dark-code-form .alert { padding: 8px 10px; font-size: 13px; }
.quick-guide, .dark-panel {
  overflow: hidden;
  border: 1px solid #17395c;
  border-radius: 14px;
  background: linear-gradient(145deg, rgba(2,20,45,.97), rgba(2,13,31,.97));
  box-shadow: 0 18px 45px rgba(0,0,0,.36);
}
.guide-title { display: flex; align-items: center; gap: 14px; padding: 22px 27px 10px; }
.guide-title h2, .dark-panel h2 { margin: 0; font-size: 19px; text-transform: uppercase; }
.guide-icon { width: 55px; height: 55px; display: grid; place-items: center; border-radius: 50%; background: linear-gradient(#69c93c, #26870e); font-size: 28px; }
.quick-guide ol { margin: 4px 0 18px; padding: 0 28px 0 37px; list-style: none; }
.quick-guide li { position: relative; display: grid; grid-template-columns: 42px 1fr; gap: 15px; align-items: start; padding: 12px 0; }
.quick-guide li:not(:last-child)::after { position: absolute; top: 54px; left: 20px; width: 1px; height: 30px; content: ""; background: #75b931; }
.quick-guide li > span { width: 42px; height: 42px; display: grid; place-items: center; border: 2px solid #f7bd15; border-radius: 50%; color: #fff; background: #1a5b2a; font-size: 22px; font-weight: 950; }
.quick-guide li strong { color: #65be2c; font-size: 16px; text-transform: uppercase; }
.quick-guide li p { margin: 3px 0 0; line-height: 1.35; }
.guide-reward { display: grid; grid-template-columns: 84px 1fr; align-items: center; min-height: 90px; padding: 10px 24px; color: #071229; background: linear-gradient(105deg, #ffc21a, #ffd965); }
.guide-reward span { font-size: 54px; }
.guide-reward strong { font-size: 17px; text-transform: uppercase; }
.home-content { position: relative; z-index: 3; margin-top: -70px; padding: 0 0 18px; }
.content-grid { display: grid; grid-template-columns: 1fr 385px; gap: 24px; }
.dark-panel { padding: 24px 32px; }
.dark-panel h2 { margin-bottom: 25px; font-size: 22px; }
.participation-steps { display: grid; grid-template-columns: 1fr 28px 1fr 28px 1fr 28px 1fr; align-items: center; gap: 8px; }
.participation-step { position: relative; min-height: 186px; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 18px 12px 12px; border: 1px solid #4a9c25; border-radius: 9px; text-align: center; }
.step-number { position: absolute; top: -15px; width: 32px; height: 32px; display: grid; place-items: center; border-radius: 50%; background: #409b24; font-weight: 900; }
.participation-step i { margin: 10px 0 13px; font-size: 46px; font-style: normal; }
.participation-step strong { text-transform: uppercase; }
.participation-step p { margin: 4px 0 0; font-size: 13px; line-height: 1.25; }
.step-arrow { color: #59ae28; font-size: 48px; text-align: center; }
.ranking-button { width: 310px; display: block; margin: 14px auto -8px; padding: 10px 16px; border-radius: 6px; color: #fff; background: linear-gradient(#52b42e, #1c7909); font-size: 18px; font-weight: 950; text-align: center; text-decoration: none; text-transform: uppercase; }
.prizes-panel { padding-left: 28px; }
.prizes-panel h2 { display: flex; align-items: center; gap: 14px; }
.prizes-panel h2::before, .prizes-panel h2::after { height: 1px; flex: 1; content: ""; background: #31506d; }
.prize { display: grid; grid-template-columns: 58px 1fr; gap: 13px; align-items: center; padding: 9px 0; border-bottom: 1px solid #1b3855; }
.medal { width: 48px; height: 48px; display: grid; place-items: center; border: 4px solid #e9a90c; border-radius: 50%; color: #fff1a6; background: #9a6503; box-shadow: 0 0 0 3px #503400; font-size: 22px; font-weight: 950; }
.medal.silver { border-color: #cbd0d6; color: #fff; background: #6d747c; box-shadow: 0 0 0 3px #343a40; }
.medal.bronze { border-color: #d98e54; color: #ffe0bd; background: #81441e; box-shadow: 0 0 0 3px #3d2418; }
.prize strong { color: #ffc21a; text-transform: uppercase; }
.prize p { margin: 2px 0 0; font-size: 14px; text-transform: uppercase; }
.more-prizes { margin: 18px 0 0; color: #ffc21a; font-weight: 950; text-transform: uppercase; }
.info-strip { padding: 18px 0; border-top: 1px solid #173858; border-bottom: 1px solid #173858; background: #061a35; }
.info-strip .home-wrap { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; }
.info-strip div div { display: flex; gap: 14px; }
.info-strip strong { color: #ffc21a; text-transform: uppercase; }
.home-footer { padding: 20px 0; background: #021025; }
.home-footer .home-wrap { display: flex; justify-content: space-between; gap: 20px; align-items: center; }
.home-footer p { margin: 0; font-size: 12px; }
.home-footer nav { display: flex; gap: 36px; }
.home-footer a { font-size: 12px; }

@media (max-width: 1080px) {
  .main-nav { display: none; }
  .nav-wrap { justify-content: space-between; gap: 14px; }
  .mobile-nav { display: block; }
  .stadium-layout { grid-template-columns: 1fr 330px; }
  .content-grid { grid-template-columns: 1fr; }
  .prizes-panel { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
  .prizes-panel h2, .more-prizes { grid-column: 1 / -1; }
  .prize { border: 1px solid #1b3855; border-radius: 8px; padding: 12px; }
}

@media (max-width: 760px) {
  .home-wrap { width: min(100% - 24px, 1450px); }
  .nav-wrap { min-height: 76px; }
  .logo-ball { font-size: 42px; }
  .prono-logo strong, .prono-logo b { font-size: 21px; }
  .login-button { min-width: auto; padding: 10px 12px; font-size: 12px; }
  .stadium-hero { min-height: auto; padding: 35px 0 115px; background-position: 61% center; }
  .stadium-layout { grid-template-columns: 1fr; }
  .hero-copy { max-width: 100%; }
  .hero-copy h1 { font-size: clamp(38px, 12vw, 56px); }
  .hero-lead { max-width: 320px; font-size: 16px; }
  .dark-code-form { margin-top: 290px; padding: 17px; }
  .dark-code-entry { grid-template-columns: 1fr; }
  .distributor-help-modal-body { grid-template-columns: 1fr; padding: 18px; }
  .distributor-help-modal-head { padding: 15px 17px; }
  .distributor-help-modal-head h2 { font-size: 19px; }
  .quick-guide { display: none; }
  .home-content { margin-top: -80px; }
  .dark-panel { padding: 22px 16px; }
  .participation-steps { grid-template-columns: 1fr 1fr; gap: 18px 10px; }
  .step-arrow { display: none; }
  .participation-step { min-height: 170px; }
  .ranking-button { width: 100%; margin-top: 18px; }
  .prizes-panel { grid-template-columns: 1fr; }
  .prizes-panel h2, .more-prizes { grid-column: auto; }
  .info-strip .home-wrap { grid-template-columns: 1fr; }
  .info-strip div div { flex-direction: column; gap: 2px; }
  .home-footer .home-wrap { flex-direction: column; align-items: flex-start; }
  .home-footer nav { gap: 14px; flex-wrap: wrap; }
}

/* Pages publiques et espace participant */
.public-dark { min-height: 100vh; color: #f5f8fd; background: #031228; }
.public-main { min-height: calc(100vh - 170px); }
.public-hero {
  padding: 76px 0 64px;
  border-bottom: 1px solid #173858;
  background:
    radial-gradient(circle at 72% 15%, rgba(31,123,192,.28), transparent 30rem),
    linear-gradient(135deg, #071d3c, #031126 65%);
}
.compact-hero { padding: 58px 0 50px; }
.public-hero h1 { max-width: 820px; margin: 8px 0 10px; font-size: clamp(38px, 6vw, 66px); line-height: 1; letter-spacing: -.045em; text-transform: uppercase; }
.public-hero p { max-width: 720px; margin: 0; color: #c4cfdd; font-size: 17px; line-height: 1.6; }
.page-kicker { color: #ffc21a; font-size: 12px; font-weight: 800; letter-spacing: .14em; text-transform: uppercase; }
.public-section { padding-top: 42px; padding-bottom: 64px; }
.account-form { width: min(520px, 100%); margin: 0 auto; padding: 32px; }
.account-form h2, .contact-form h2 { margin-bottom: 22px; font-size: 28px; }
.account-form label, .contact-form label { margin: 18px 0 7px; color: #eaf0f8; }
.account-form input, .contact-form input, .contact-form textarea { border-color: #2b4c6e; color: #fff; background: #071c37; }
.account-form button, .contact-form button { width: 100%; margin-top: 20px; background: linear-gradient(#59bd32, #287f13); box-shadow: none; }
.form-note { margin: 14px 0 0; color: #98a9bd; font-size: 12px; line-height: 1.5; }
.account-heading { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; }
.outline-button { border: 1px solid #f0b918; color: #fff; background: transparent; box-shadow: none; }
.account-content { padding-top: 0; transform: translateY(-24px); }
.account-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin-bottom: 18px; }
.account-stats.account-stats-four { grid-template-columns: repeat(4, 1fr); }
.account-stats article { padding: 21px 24px; border: 1px solid #244563; border-radius: 12px; background: #061a35; box-shadow: 0 12px 28px rgba(0,0,0,.18); }
.account-stats span { display: block; color: #91a5ba; font-size: 12px; font-weight: 700; text-transform: uppercase; }
.account-stats strong { display: block; margin-top: 4px; color: #ffc21a; font-size: 27px; }
.prediction-results { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.account-section-heading { display: flex; align-items: end; justify-content: space-between; gap: 28px; margin: 34px 0 18px; }
.account-section-heading h2 { margin: 3px 0 0; color: #fff; font-size: clamp(25px, 3vw, 35px); }
.account-section-heading p { max-width: 560px; margin: 0; color: #9fb2c5; }
.account-code-list { display: grid; gap: 22px; }
.account-code-card { overflow: hidden; border: 1px solid #244563; border-radius: 15px; background: #04162d; box-shadow: 0 15px 35px rgba(0,0,0,.2); }
.account-code-head { display: flex; align-items: center; justify-content: space-between; gap: 20px; padding: 18px 22px; border-bottom: 1px solid #1b3a59; background: linear-gradient(120deg, #071e3d, #04152b); }
.account-code-head small { display: block; margin-top: 7px; color: #91a5ba; }
.code-badge { display: inline-block; color: #ffc21a; font-size: 18px; font-weight: 800; letter-spacing: .04em; }
.account-code-score { text-align: right; }
.account-code-score span { display: block; color: #91a5ba; font-size: 11px; font-weight: 800; text-transform: uppercase; }
.account-code-score strong { color: #fff; font-size: 23px; }
.code-predictions { padding: 18px; }
.result-card { overflow: hidden; border: 1px solid #21415f; border-radius: 13px; background: #06182f; box-shadow: 0 12px 30px rgba(0,0,0,.2); }
.result-card.is-finished { border-color: #326b31; }
.result-meta { display: flex; justify-content: space-between; gap: 12px; padding: 13px 16px; color: #93a9bf; background: #041328; font-size: 11px; font-weight: 700; }
.result-meta span { color: #64be2e; text-transform: uppercase; }
.result-teams { min-height: 105px; display: flex; align-items: center; justify-content: center; gap: 12px; padding: 20px; text-align: center; }
.result-teams span { color: #7890a7; font-size: 11px; text-transform: uppercase; }
.scores-comparison { display: grid; grid-template-columns: 1fr 1fr 72px; border-top: 1px solid #193852; background: #071d38; }
.scores-comparison div { padding: 13px 10px; border-right: 1px solid #193852; text-align: center; }
.scores-comparison div:last-child { border: 0; }
.scores-comparison span { display: block; color: #849bb1; font-size: 10px; text-transform: uppercase; }
.scores-comparison strong { display: block; margin-top: 4px; font-size: 18px; }
.points-earned strong { color: #ffc21a; }
.account-ranking-link { margin-top: 24px; }
.leaderboard { max-width: 900px; margin: 0 auto; padding: 12px 24px; }
.leaderboard-head, .leaderboard-row { display: grid; grid-template-columns: 80px 1fr 150px 110px; gap: 12px; align-items: center; }
.leaderboard-with-codes .leaderboard-head, .leaderboard-with-codes .leaderboard-row { grid-template-columns: 80px 1fr 90px 140px 110px; }
.leaderboard-head { padding: 14px 12px; color: #8298ad; font-size: 11px; font-weight: 800; text-transform: uppercase; }
.leaderboard-row { min-height: 63px; padding: 10px 12px; border-top: 1px solid #183650; }
.leaderboard-row > :nth-child(3), .leaderboard-row > :last-child { text-align: center; }
.podium-row { color: #fff; background: linear-gradient(90deg, rgba(255,194,26,.1), transparent); }
.rank-number { width: 34px; height: 34px; display: grid; place-items: center; border-radius: 50%; color: #041328; background: #ffc21a; }
.empty-state { padding: 30px; color: #9eb0c3; text-align: center; }
.lots-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.lot-card { position: relative; min-height: 330px; padding: 36px 28px; border: 1px solid #214362; border-radius: 14px; background: linear-gradient(145deg, #092341, #04142a); text-align: center; }
.first-lot { border-color: #c9910a; background: linear-gradient(145deg, #18334e, #08172c); }
.lot-card i { display: block; margin: 40px 0 20px; font-size: 72px; font-style: normal; }
.lot-card h2 { color: #ffc21a; font-size: 23px; }
.lot-card p { color: #aebed0; line-height: 1.6; }
.lot-rank { position: absolute; top: 18px; left: 18px; width: 38px; height: 38px; display: grid; place-items: center; border-radius: 50%; color: #07142a; background: #ffc21a; font-weight: 800; }
.prize-note { max-width: 760px; margin: 24px auto 0; text-align: center; }
.prize-note p { color: #acbdcf; line-height: 1.65; }
.faq-list { max-width: 900px; }
.faq-list details { margin-bottom: 12px; border: 1px solid #21415f; border-radius: 10px; background: #061a34; }
.faq-list summary { padding: 20px 22px; color: #fff; cursor: pointer; font-weight: 700; }
.faq-list details p { margin: 0; padding: 0 22px 22px; color: #adbed0; line-height: 1.65; }
.contact-layout { display: grid; grid-template-columns: .8fr 1.2fr; gap: 20px; }
.contact-copy, .contact-form { padding: 30px; }
.contact-copy p { color: #afbed0; line-height: 1.7; }
.contact-copy a, .legal-card a { color: #ffc21a; font-weight: 700; }
.legal-page { padding-top: 42px; }
.legal-card { color: #18231e; }
.legal-card .eyebrow { color: #b47c00; }
.legal-warning { margin-top: 30px; }

@media (max-width: 900px) {
  .prediction-results, .lots-grid { grid-template-columns: 1fr; }
  .contact-layout { grid-template-columns: 1fr; }
  .account-stats.account-stats-four { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 760px) {
  .public-hero { padding: 42px 0; }
  .public-section { padding-top: 28px; }
  .account-heading { align-items: flex-start; flex-direction: column; }
  .account-stats, .account-stats.account-stats-four { grid-template-columns: 1fr; }
  .account-section-heading, .account-code-head { align-items: flex-start; flex-direction: column; }
  .account-code-score { text-align: left; }
  .code-predictions { padding: 12px; }
  .leaderboard { padding: 8px 10px; }
  .leaderboard-head, .leaderboard-row { grid-template-columns: 45px 1fr 76px; }
  .leaderboard-head > :nth-child(3), .leaderboard-row > :nth-child(3) { display: none; }
  .leaderboard-head > :last-child, .leaderboard-row > :last-child { text-align: right; }
  .leaderboard-with-codes .leaderboard-head, .leaderboard-with-codes .leaderboard-row { grid-template-columns: 45px 1fr 76px; }
  .leaderboard-with-codes .leaderboard-head > :nth-child(3),
  .leaderboard-with-codes .leaderboard-row > :nth-child(3),
  .leaderboard-with-codes .leaderboard-head > :nth-child(4),
  .leaderboard-with-codes .leaderboard-row > :nth-child(4) { display: none; }
  .scores-comparison { grid-template-columns: 1fr 1fr 62px; }
}

/* Administration V2 */
.admin-v2 { margin: 0; color: #182535; background: #f2f5f8; font-family: "Plus Jakarta Sans", sans-serif; }
.admin-layout { min-height: 100vh; display: grid; grid-template-columns: 250px minmax(0,1fr); }
.admin-sidebar { position: sticky; top: 0; height: 100vh; display: flex; flex-direction: column; padding: 24px 16px; color: #fff; background: linear-gradient(180deg,#061a32,#031226); box-shadow: 8px 0 30px rgba(4,20,39,.12); }
.admin-logo { display: flex; align-items: center; gap: 11px; padding: 0 10px 28px; color: #fff; line-height: .9; text-decoration: none; }
.admin-logo > span { font-size: 39px; }
.admin-logo strong,.admin-logo b { display: block; font-size: 19px; font-weight: 800; }
.admin-logo b { color: #ffc21a; }
.admin-logo small { display: block; margin-top: 6px; font-size: 8px; letter-spacing: .25em; }
.admin-nav { display: grid; gap: 5px; }
.admin-nav a { display: flex; align-items: center; gap: 12px; padding: 12px 13px; border-radius: 9px; color: #aebed0; font-size: 13px; font-weight: 650; text-decoration: none; }
.admin-nav a span { width: 22px; color: #6e88a1; font-size: 17px; text-align: center; }
.admin-nav a:hover,.admin-nav a.is-active { color: #fff; background: #123453; }
.admin-nav a.is-active span { color: #ffc21a; }
.admin-sidebar-foot { display: grid; gap: 8px; margin-top: auto; padding-top: 20px; border-top: 1px solid #183550; }
.admin-sidebar-foot a,.admin-sidebar-foot button { width: 100%; min-height: auto; display: block; padding: 9px 12px; border: 0; border-radius: 7px; color: #9cb0c5; background: transparent; box-shadow: none; font-size: 12px; font-weight: 650; text-align: left; text-decoration: none; }
.admin-sidebar-foot a:hover,.admin-sidebar-foot button:hover { color: #fff; background: #102e49; transform: none; }
.admin-workspace { min-width: 0; }
.admin-topbar { min-height: 76px; display: flex; align-items: center; justify-content: space-between; gap: 20px; padding: 14px 34px; border-bottom: 1px solid #dfe5ea; background: #fff; }
.admin-topbar span,.admin-topbar strong { display: block; }
.admin-topbar span { color: #8794a1; font-size: 10px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; }
.admin-topbar strong { margin-top: 2px; font-size: 16px; }
.admin-site-link { padding: 9px 12px; border: 1px solid #d9e0e6; border-radius: 8px; color: #27415a; font-size: 12px; font-weight: 700; text-decoration: none; }
.admin-main { width: min(1440px,100%); margin: 0 auto; padding: 30px 34px 60px; }
.admin-page-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; margin-bottom: 24px; }
.admin-page-head h1 { margin: 4px 0 5px; color: #0c1f32; font-size: clamp(28px,3vw,39px); letter-spacing: -.04em; }
.admin-page-head p { margin: 0; color: #778693; font-size: 13px; }
.admin-eyebrow { color: #258915; font-size: 10px; font-weight: 800; letter-spacing: .13em; text-transform: uppercase; }
.admin-head-actions { display: flex; gap: 8px; }
.admin-primary-link,.admin-secondary-link { display: inline-flex; align-items: center; justify-content: center; min-height: 42px; padding: 10px 15px; border-radius: 8px; font-size: 12px; font-weight: 750; text-decoration: none; }
.admin-primary-link { color: #fff; background: #258915; box-shadow: 0 8px 20px rgba(37,137,21,.18); }
.admin-secondary-link { border: 1px solid #d3dce3; color: #263f57; background: #fff; }
.admin-card { margin-bottom: 18px; padding: 22px; border: 1px solid #e0e6eb; border-radius: 13px; background: #fff; box-shadow: 0 8px 24px rgba(22,45,67,.055); }
.admin-card h2 { margin: 0 0 4px; color: #14283b; font-size: 18px; }
.admin-card-head { display: flex; align-items: center; justify-content: space-between; gap: 18px; margin-bottom: 18px; }
.admin-card-head p { margin: 3px 0 0; color: #85929e; font-size: 12px; }
.admin-card-head > a { color: #258915; font-size: 12px; font-weight: 750; text-decoration: none; }
.admin-two-columns { display: grid; grid-template-columns: minmax(0,1.7fr) minmax(250px,.8fr); gap: 18px; align-items: start; }
.admin-help-card { padding: 23px; border: 1px solid #d7e1e8; border-radius: 13px; color: #536676; background: #eaf1f6; font-size: 13px; line-height: 1.65; }
.admin-help-card strong { color: #14283b; font-size: 15px; }
.admin-help-card code { color: #0a6840; background: #d9e8e1; }
.admin-form { display: grid; gap: 14px; margin-top: 18px; }
.admin-form label { margin: 0; color: #3a4d5e; font-size: 12px; font-weight: 700; }
.admin-form input,.admin-form select,.admin-form textarea,.admin-filters input,.admin-filters select { min-height: 43px; margin-top: 6px; padding: 10px 12px; border: 1px solid #ccd6de; border-radius: 8px; color: #14283b; background: #fff; font-size: 13px; }
.admin-form textarea { resize: vertical; }
.admin-form button,.admin-filters button,.score-form button { min-height: 42px; padding: 9px 15px; border-radius: 8px; background: linear-gradient(#46a82d,#258915); box-shadow: none; font-size: 12px; }
.admin-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.admin-check { display: flex!important; align-items: center; gap: 9px; }
.admin-check input { width: auto; min-height: auto; margin: 0; }
.admin-inline-form { grid-template-columns: 160px 1fr auto; align-items: end; }
.admin-match-form { grid-template-columns: repeat(3,minmax(170px,1fr)); align-items: end; }
.admin-disclosure > summary { color: #172c40; cursor: pointer; font-size: 15px; font-weight: 750; }
.admin-filters { display: flex; align-items: flex-end; gap: 8px; }
.admin-filters input,.admin-filters select { width: auto; min-width: 150px; margin: 0; }
.admin-table-wrap { overflow: auto; border: 1px solid #e1e7ec; border-radius: 10px; }
.admin-table { width: 100%; min-width: 760px; border-collapse: collapse; background: #fff; }
.admin-table th { padding: 11px 13px; color: #71808d; background: #f6f8fa; font-size: 10px; font-weight: 800; letter-spacing: .04em; text-align: left; text-transform: uppercase; }
.admin-table td { padding: 13px; border-top: 1px solid #e8edf1; color: #354a5b; font-size: 12px; vertical-align: middle; }
.admin-table td strong,.admin-table td small { display: block; }
.admin-table td small { margin-top: 3px; color: #8b98a4; }
.admin-table tr:hover td { background: #fbfcfd; }
.admin-actions { display: flex; align-items: center; gap: 10px; }
.admin-actions a,.admin-actions button,.admin-text-button,.admin-danger-button { min-height: auto; padding: 0; border: 0; color: #19731a; background: transparent; box-shadow: none; font-size: 11px; font-weight: 750; text-decoration: none; }
.admin-actions button:hover,.admin-text-button:hover,.admin-danger-button:hover { transform: none; box-shadow: none; }
.admin-danger-button,.admin-actions form:last-child button { color: #b93131; }
.team-flag-img { width: 28px; height: 20px; display: inline-block; border-radius: 3px; object-fit: cover; vertical-align: middle; box-shadow: 0 1px 4px rgba(0,0,0,.15); }
.team-flag-emoji,.flag-cell { font-size: 24px; }
.status-pill { display: inline-flex; padding: 5px 8px; border-radius: 999px; font-size: 10px; font-weight: 750; }
.status-ok,.status-available { color: #197038; background: #e2f5e8; }
.status-muted,.status-cancelled { color: #687680; background: #edf0f2; }
.status-used { color: #235e91; background: #e3f0fa; }
.code-value { color: #0f3454; font-family: Consolas,monospace; font-size: 12px; letter-spacing: .04em; }
.admin-stat-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 14px; margin-bottom: 18px; }
.admin-stat-grid article { padding: 20px; border: 1px solid #dfe6eb; border-radius: 12px; background: #fff; box-shadow: 0 8px 22px rgba(20,46,70,.05); }
.admin-stat-grid span,.admin-stat-grid small { display: block; color: #81909c; font-size: 11px; font-weight: 650; }
.admin-stat-grid strong { display: block; margin: 5px 0; color: #10263a; font-size: 31px; letter-spacing: -.04em; }
.admin-dashboard-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.admin-compact-list > div { display: grid; grid-template-columns: 90px 1fr; gap: 2px 14px; padding: 12px 0; border-top: 1px solid #e7ecf0; }
.admin-compact-list time { grid-row: 1/3; color: #768795; font-size: 11px; }
.admin-compact-list strong { color: #21384b; font-size: 12px; }
.admin-compact-list strong span { color: #9aa7b1; font-size: 9px; text-transform: uppercase; }
.admin-compact-list small { color: #8695a1; }
.admin-empty { color: #8695a1; font-size: 13px; }
.admin-quick-actions > div { display: grid; grid-template-columns: repeat(3,1fr); gap: 12px; margin-top: 16px; }
.admin-quick-actions a { display: grid; grid-template-columns: 42px 1fr; gap: 2px 10px; padding: 14px; border: 1px solid #dfe6eb; border-radius: 9px; color: #20374a; text-decoration: none; }
.admin-quick-actions a > span { grid-row: 1/3; display: grid; place-items: center; border-radius: 8px; color: #258915; background: #e7f3e4; font-size: 19px; }
.admin-quick-actions a small { color: #84929d; }
.admin-match-list { display: grid; gap: 9px; }
.admin-match-row { display: grid; grid-template-columns: 86px minmax(330px,1fr) auto; gap: 18px; align-items: center; padding: 15px; border: 1px solid #e0e6eb; border-radius: 10px; background: #fbfcfd; }
.admin-match-date { display: flex; align-items: center; gap: 8px; }
.admin-match-date strong { color: #163654; font-size: 25px; }
.admin-match-date span { color: #82919d; font-size: 10px; line-height: 1.4; }
.admin-match-info > small { color: #82919d; font-size: 10px; }
.admin-match-teams { display: grid; grid-template-columns: 1fr 55px 1fr; gap: 10px; align-items: center; margin: 6px 0; }
.admin-match-teams span { display: flex; align-items: center; gap: 7px; }
.admin-match-teams span:nth-child(3) { justify-content: flex-end; text-align: right; }
.admin-match-teams b { color: #258915; text-align: center; }
.admin-match-controls { display: flex; align-items: center; gap: 10px; }
.score-form { display: flex; align-items: center; gap: 5px; }
.score-form input { width: 48px; min-height: 38px; padding: 5px; text-align: center; }
.score-form button { min-height: 38px; }
.prize-admin-grid { display: grid; gap: 10px; }
.prize-admin-card { display: grid; grid-template-columns: 55px 1fr auto; gap: 14px; align-items: center; padding: 15px; border: 1px solid #e0e6eb; border-radius: 10px; }
.prize-admin-card.is-disabled { opacity: .5; }
.prize-admin-icon { font-size: 36px; text-align: center; }
.prize-admin-card small { color: #258915; font-weight: 750; text-transform: uppercase; }
.prize-admin-card h3 { margin: 3px 0; color: #1c3448; font-size: 15px; }
.prize-admin-card p { margin: 0; color: #84929e; font-size: 12px; }
.import-textarea { min-height: 390px; font-family: Consolas,monospace; line-height: 1.6; }
.import-help code { display: block; margin: 12px 0; padding: 10px; overflow-wrap: anywhere; }
.import-help pre { overflow: auto; padding: 12px; border-radius: 8px; color: #d7e7f4; background: #0a2239; font-size: 10px; line-height: 1.6; }
.participant-detail .detail-points { color: #258915; font-size: 25px; }
.prediction-detail-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 10px; }
.prediction-detail-grid article, .prediction-detail-grid > div { padding: 14px; border: 1px solid #e1e7eb; border-radius: 9px; background: #f8fafb; }
.prediction-detail-grid h3 { margin: 5px 0 10px; font-size: 13px; }
.prediction-detail-grid p { margin: 3px 0; color: #687987; font-size: 11px; }
.prediction-detail-grid > article > span, .prediction-detail-grid > div > span { display: inline-block; margin-top: 9px; padding: 4px 7px; border-radius: 6px; color: #24751d; background: #e5f3e2; font-size: 10px; font-weight: 750; }
.admin-code-list { display: grid; gap: 16px; }
.admin-code-card { padding: 16px; border: 1px solid #dce5eb; border-radius: 12px; background: #f8fafb; }
.admin-code-card-head { display: flex; align-items: center; justify-content: space-between; gap: 18px; margin-bottom: 14px; }
.admin-code-card-head small { display: block; margin-top: 5px; color: #738493; }
.admin-code-card-head > strong { color: #258915; font-size: 18px; }
.table-points { color: #258915; font-size: 18px; }
.admin-login-page { min-height: 100vh; display: grid; place-items: center; margin: 0; padding: 24px; color: #fff; background: radial-gradient(circle at 20% 10%,#123e62,#04162d 50%,#020d1d); font-family: "Plus Jakarta Sans",sans-serif; }
.admin-login-shell { width: min(900px,100%); display: grid; grid-template-columns: 1fr 420px; overflow: hidden; border: 1px solid rgba(255,255,255,.12); border-radius: 20px; box-shadow: 0 30px 80px rgba(0,0,0,.35); }
.admin-login-brand { display: flex; flex-direction: column; justify-content: center; padding: 55px; background: linear-gradient(145deg,rgba(11,44,73,.9),rgba(5,23,44,.95)); }
.admin-login-ball { font-size: 65px; }
.admin-login-brand strong,.admin-login-brand b { display: block; font-size: 42px; line-height: .9; }
.admin-login-brand b { color: #ffc21a; }
.admin-login-brand small { letter-spacing: .28em; }
.admin-login-brand p { max-width: 360px; margin-top: 30px; color: #aebed0; line-height: 1.7; }
.admin-login-card { padding: 50px 42px; color: #1b3043; background: #fff; }
.admin-login-card h1 { margin: 5px 0 24px; font-size: 31px; }
.admin-login-card > a { display: block; margin-top: 20px; color: #667987; font-size: 12px; text-decoration: none; }
.public-team-flag { display: inline-flex; align-items: center; margin-right: 6px; font-size: 20px; vertical-align: middle; }
.public-team-flag img { width: 25px; height: 17px; border-radius: 2px; object-fit: cover; }

/* Confirmation de participation */
.thanks-page { background: #031228; }
.thanks-hero { position: relative; overflow: hidden; padding: 80px 0 110px; text-align: center; background: radial-gradient(circle at 50% 10%,rgba(33,119,176,.34),transparent 30rem),linear-gradient(145deg,#082343,#031126); }
.thanks-hero::after { position: absolute; right: -60px; bottom: -130px; width: 420px; height: 420px; content: ""; border: 1px solid rgba(255,194,26,.13); border-radius: 50%; box-shadow: 0 0 0 55px rgba(255,194,26,.035),0 0 0 110px rgba(255,194,26,.02); }
.thanks-hero-content { position: relative; z-index: 1; display: flex; flex-direction: column; align-items: center; }
.thanks-check { width: 76px; height: 76px; display: grid; place-items: center; margin-bottom: 23px; border: 2px solid #7bd351; border-radius: 50%; color: #fff; background: linear-gradient(145deg,#55bb32,#247d12); box-shadow: 0 15px 35px rgba(47,151,24,.28); font-size: 38px; font-weight: 800; }
.thanks-hero h1 { margin: 8px 0 13px; color: #fff; font-size: clamp(42px,7vw,72px); letter-spacing: -.055em; line-height: 1; text-transform: uppercase; }
.thanks-hero p { max-width: 650px; margin: 0; color: #afc0d2; font-size: 17px; line-height: 1.65; }
.thanks-actions { display: flex; gap: 11px; margin-top: 29px; }
.thanks-primary,.thanks-secondary { min-height: 48px; display: inline-flex; align-items: center; justify-content: center; padding: 12px 19px; border-radius: 8px; font-size: 13px; font-weight: 800; text-decoration: none; text-transform: uppercase; }
.thanks-primary { color: #fff; background: linear-gradient(#58b934,#25840f); box-shadow: 0 12px 25px rgba(41,139,17,.25); }
.thanks-secondary { border: 1px solid #355571; color: #dfe9f3; background: #071c36; }
.thanks-content { position: relative; z-index: 2; margin-top: -53px; padding-bottom: 70px; }
.thanks-summary { display: grid; grid-template-columns: repeat(3,1fr); gap: 13px; }
.thanks-summary article { min-height: 160px; display: grid; grid-template-columns: 42px 1fr; gap: 14px; align-items: start; padding: 23px; border: 1px solid #1d405f; border-radius: 12px; background: linear-gradient(145deg,#071f3c,#04162e); box-shadow: 0 16px 35px rgba(0,0,0,.25); }
.thanks-summary article > span { width: 36px; height: 36px; display: grid; place-items: center; border-radius: 50%; color: #06162c; background: #ffc21a; font-weight: 800; }
.thanks-summary strong { color: #fff; font-size: 14px; }
.thanks-summary p { margin: 7px 0 0; color: #94a8bc; font-size: 12px; line-height: 1.6; }
.thanks-note { max-width: 720px; display: flex; align-items: center; gap: 17px; margin: 18px auto 0; padding: 17px 21px; border: 1px solid #2a4b68; border-radius: 11px; background: #081e39; }
.thanks-note > span { font-size: 35px; }
.thanks-note strong { color: #ffc21a; }
.thanks-note p { margin: 3px 0 0; color: #98aabc; font-size: 12px; }

@media(max-width:760px){
  .thanks-hero{padding:55px 0 92px}.thanks-check{width:63px;height:63px;font-size:31px}.thanks-hero h1{font-size:40px}.thanks-hero p{font-size:14px}
  .thanks-actions{width:100%;flex-direction:column}.thanks-primary,.thanks-secondary{width:100%}
  .thanks-content{margin-top:-43px}.thanks-summary{grid-template-columns:1fr}.thanks-summary article{min-height:0;padding:18px}
  .thanks-note{align-items:flex-start}
}

/* Participation compacte */
.participation-dark { min-height: 100vh; margin: 0; color: #f4f7fb; background: radial-gradient(circle at 75% 0,rgba(20,75,119,.28),transparent 34rem),#031228; }
.participation-nav { min-height: 78px; }
.participation-nav .logo-ball { font-size: 43px; }
.participation-nav .prono-logo strong,.participation-nav .prono-logo b { font-size: 21px; }
.participation-code { margin-left: auto; padding: 8px 13px; border: 1px solid #284966; border-radius: 9px; background: #071b35; text-align: right; }
.participation-code span,.participation-code strong { display: block; }
.participation-code span { color: #849bb1; font-size: 9px; font-weight: 700; text-transform: uppercase; }
.participation-code strong { margin-top: 2px; color: #ffc21a; font-size: 12px; letter-spacing: .04em; }
.participation-main { padding-top: 34px; padding-bottom: 70px; }
.participation-heading { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; margin-bottom: 23px; }
.participation-heading h1 { margin: 5px 0 6px; color: #fff; font-size: clamp(34px,4vw,50px); letter-spacing: -.045em; line-height: 1; text-transform: uppercase; }
.participation-heading p { margin: 0; color: #9fb0c2; font-size: 14px; }
.participation-heading .selection-counter { color: #8fa4b9; }
.participation-heading .selection-counter strong { color: #ffc21a; }
.participation-panel { margin-bottom: 16px; padding: 21px; border: 1px solid #173a5b; border-radius: 13px; background: linear-gradient(145deg,rgba(5,27,53,.98),rgba(3,18,38,.98)); box-shadow: 0 18px 42px rgba(0,0,0,.22); }
.participation-section-head { display: flex; align-items: center; gap: 13px; margin-bottom: 18px; }
.participation-section-head > span { width: 34px; height: 34px; display: grid; place-items: center; flex: 0 0 auto; border-radius: 50%; color: #fff; background: #278d19; font-size: 13px; font-weight: 800; }
.participation-section-head h2 { margin: 0 0 2px; color: #fff; font-size: 19px; }
.participation-section-head p { margin: 0; color: #8da3b7; font-size: 12px; }
.account-link-warning { margin: -4px 0 16px; padding: 11px 13px; border: 1px solid rgba(255,194,26,.35); border-radius: 8px; color: #d8e1e9; background: rgba(255,194,26,.08); font-size: 11px; line-height: 1.55; }
.account-link-warning strong { color: #ffc21a; }
.matches-section-head .selection-status { margin-left: auto; color: #dff5d8; background: #164a2d; }
.participant-fields { display: grid; grid-template-columns: repeat(4,1fr); gap: 11px; }
.participant-fields label { margin: 0; color: #b8c6d5; font-size: 11px; }
.participant-fields input { min-height: 42px; margin-top: 6px; border-color: #294b6a; border-radius: 8px; color: #fff; background: #071c37; font-size: 13px; }
.participation-consent { display: flex; align-items: center; gap: 9px; margin: 14px 0 0; padding-top: 13px; border-top: 1px solid #173752; color: #9eb0c1; font-size: 11px; font-weight: 500; }
.participation-consent input { width: 16px; min-height: 16px; flex: 0 0 auto; accent-color: #45aa2a; }
.match-filters { display: grid; grid-template-columns: minmax(210px,1fr) 180px 180px 75px; gap: 9px; align-items: end; margin-bottom: 12px; padding: 12px; border: 1px solid #173953; border-radius: 10px; background: #04172e; }
.match-filters label { margin: 0; color: #8198ad; font-size: 9px; font-weight: 750; text-transform: uppercase; }
.match-filters label > span { display: block; margin-bottom: 5px; }
.match-filters input,.match-filters select { min-height: 38px; padding: 8px 10px; border: 1px solid #294b68; border-radius: 7px; color: #eaf0f7; background: #08203c; font-size: 12px; }
.filter-result { min-height: 38px; display: flex; align-items: center; justify-content: center; gap: 4px; border-radius: 7px; color: #a6b6c6; background: #0d2945; font-size: 9px; }
.filter-result strong { color: #ffc21a; font-size: 16px; }
.compact-match-list { display: grid; gap: 7px; }
.compact-match[hidden] { display: none!important; }
.compact-match { min-height: 68px; display: grid; grid-template-columns: minmax(0,1fr) auto; align-items: stretch; overflow: hidden; border: 1px solid #1a3b59; border-radius: 9px; background: #061a33; transition: border-color .16s,background .16s,opacity .16s; }
.compact-match:has(.compact-match-select input:disabled) { opacity: .48; }
.compact-match.is-selected { border-color: #49a92d; background: #09273b; box-shadow: 0 0 0 2px rgba(73,169,45,.12); }
.compact-match-select { min-width: 0; display: grid; grid-template-columns: 30px 95px minmax(0,1fr); gap: 12px; align-items: center; margin: 0; padding: 9px 14px; cursor: pointer; }
.compact-match-select input { position: absolute; opacity: 0; pointer-events: none; }
.compact-check { width: 25px; height: 25px; display: grid; place-items: center; border: 1px solid #3d5972; border-radius: 7px; color: transparent; background: #0a2340; font-size: 12px; }
.is-selected .compact-check { border-color: #4bac30; color: #fff; background: #348f20; }
.compact-meta { display: grid; grid-template-columns: auto 1fr; gap: 0 5px; padding-right: 11px; border-right: 1px solid #1d405e; }
.compact-meta strong { color: #fff; font-size: 13px; }
.compact-meta small { color: #8da2b5; font-size: 10px; }
.compact-meta em { grid-column: 1/-1; color: #69b73c; font-size: 9px; font-style: normal; font-weight: 750; text-transform: uppercase; }
.compact-teams { min-width: 0; display: grid; grid-template-columns: minmax(0,1fr) 32px minmax(0,1fr); gap: 8px; align-items: center; }
.compact-teams strong { min-width: 0; display: flex; align-items: center; color: #f4f7fb; font-size: 13px; }
.compact-teams strong:last-child { justify-content: flex-end; text-align: right; }
.compact-teams b { color: #698097; font-size: 9px; text-align: center; }
.compact-teams .public-team-flag { flex: 0 0 auto; font-size: 18px; }
.compact-score { display: none; align-items: center; gap: 5px; padding: 8px 12px; border: 0; border-left: 1px solid #28506b; background: #0a2940; }
.compact-match.is-selected .compact-score { display: flex; }
.compact-score label { width: 58px; margin: 0; }
.compact-score label span { display: block; overflow: hidden; margin-bottom: 3px; color: #8ea3b7; font-size: 8px; text-align: center; text-overflow: ellipsis; white-space: nowrap; }
.compact-score input { width: 58px; min-height: 40px; padding: 5px; border-color: #3b627b; border-radius: 7px; color: #fff; background: #061a31; font-size: 18px; font-weight: 800; text-align: center; }
.compact-score > span { color: #8094a7; font-weight: 800; }
.match-filter-empty { padding: 28px; border: 1px dashed #2b4a64; border-radius: 9px; color: #8fa3b5; text-align: center; }
.participation-submit { border-color: #264967; background: rgba(3,18,38,.96); }

@media(max-width:900px){
  .participant-fields{grid-template-columns:1fr 1fr}
  .match-filters{grid-template-columns:1fr 1fr 1fr}.match-search{grid-column:1/-1}.filter-result{display:none}
  .compact-match-select{grid-template-columns:28px 78px minmax(0,1fr);gap:8px;padding:8px 10px}
}
@media(max-width:650px){
  .participation-nav{min-height:66px;gap:8px}
  .participation-nav .logo-ball{font-size:31px}
  .participation-nav .prono-logo{gap:7px}
  .participation-nav .prono-logo strong,.participation-nav .prono-logo b{font-size:15px}
  .participation-nav .prono-logo small{margin-top:5px;font-size:7px;letter-spacing:.2em}
  .participation-code{max-width:135px;padding:6px 8px;overflow:hidden}
  .participation-code span{font-size:8px}
  .participation-code strong{overflow:hidden;font-size:10px;text-overflow:ellipsis;white-space:nowrap}
  .participation-main{width:min(100% - 16px,1450px);padding-top:20px;padding-bottom:115px}
  .participation-heading{align-items:flex-start;flex-direction:column;gap:13px;margin-bottom:17px}
  .participation-heading h1{font-size:29px}
  .participation-heading p{max-width:none;font-size:12px;line-height:1.55}
  .participation-heading .selection-counter{min-width:0;flex-direction:row;align-items:baseline;align-self:stretch;justify-content:flex-end;padding:8px 11px;border:1px solid #284966;border-radius:9px;background:#071b35}
  .participation-heading .selection-counter strong{font-size:27px}
  .participation-heading .selection-counter span{font-size:10px}
  .participation-panel{padding:14px 11px;border-radius:11px}
  .participation-section-head{align-items:flex-start;gap:9px;margin-bottom:14px}
  .participation-section-head>span{width:29px;height:29px;font-size:11px}
  .participation-section-head h2{font-size:16px}
  .participation-section-head p{font-size:10px;line-height:1.45}
  .participant-fields{grid-template-columns:1fr;gap:10px}
  .participant-fields input{min-height:44px}
  .participation-consent{align-items:flex-start;font-size:10px;line-height:1.5}
  .matches-section-head{display:grid;grid-template-columns:30px 1fr;gap:9px}
  .matches-section-head .selection-status{grid-column:2;margin:0;justify-self:start;font-size:9px}
  .match-filters{grid-template-columns:1fr;gap:8px;padding:10px}
  .match-search{grid-column:auto}
  .match-filters input,.match-filters select{min-height:42px;font-size:13px}
  .compact-match{grid-template-columns:1fr;border-radius:8px}
  .compact-match-select{position:relative;display:block;min-height:104px;padding:10px 38px 10px 10px}
  .compact-check{position:absolute;top:10px;right:9px;width:27px;height:27px}
  .compact-meta{display:flex;align-items:center;gap:6px;margin-bottom:11px;padding:0 34px 7px 0;border-right:0;border-bottom:1px solid #1d405e}
  .compact-meta strong{font-size:12px}
  .compact-meta small{font-size:10px}
  .compact-meta em{margin-left:auto;font-size:8px}
  .compact-teams{grid-template-columns:minmax(0,1fr) 25px minmax(0,1fr);gap:4px}
  .compact-teams strong{display:flex;align-items:center;font-size:12px;line-height:1.25}
  .compact-teams strong:last-child{justify-content:flex-end}
  .compact-teams .public-team-flag{display:inline-flex;margin-right:4px;font-size:17px}
  .compact-teams .public-team-flag img{width:21px;height:14px}
  .compact-score{justify-content:center;border-top:1px solid #28506b;border-left:0;padding:9px 10px}
  .compact-score label{width:82px}
  .compact-score label span{font-size:8px}
  .compact-score input{width:82px;min-height:43px}
  .participation-submit{position:fixed;right:8px;bottom:8px;left:8px;align-items:stretch;gap:8px;margin:0;padding:11px;flex-direction:column;border-radius:12px}
  .participation-submit div{text-align:center}
  .participation-submit strong{font-size:12px}
  .participation-submit span{font-size:9px}
  .participation-submit button{width:100%;min-height:43px}
}

@media(max-width:1050px){
  .admin-layout{grid-template-columns:82px minmax(0,1fr)}
  .admin-logo div,.admin-nav a:not(.is-active)::after,.admin-nav a{font-size:0}
  .admin-logo{justify-content:center;padding-left:0;padding-right:0}.admin-logo>span{font-size:34px}
  .admin-nav a{justify-content:center;padding:12px}.admin-nav a span{font-size:18px}
  .admin-sidebar-foot a,.admin-sidebar-foot button{font-size:0;text-align:center}.admin-sidebar-foot a::before{content:"↗";font-size:18px}.admin-sidebar-foot button::before{content:"⇥";font-size:18px}
  .admin-stat-grid{grid-template-columns:1fr 1fr}
  .admin-match-row{grid-template-columns:75px 1fr}.admin-match-controls{grid-column:2}
}
@media(max-width:760px){
  .admin-layout{display:block}.admin-sidebar{position:static;width:100%;height:auto;padding:12px}.admin-logo{justify-content:flex-start;padding:4px 6px 12px}.admin-logo div{display:block}.admin-logo strong,.admin-logo b{font-size:16px}
  .admin-nav{grid-template-columns:repeat(3,1fr)}.admin-nav a{font-size:10px;justify-content:flex-start;gap:4px}.admin-nav a span{font-size:13px;width:18px}.admin-sidebar-foot{display:none}
  .admin-topbar{display:none}.admin-main{padding:22px 12px 45px}.admin-page-head{align-items:flex-start;flex-direction:column}.admin-head-actions,.admin-primary-link,.admin-secondary-link{width:100%}
  .admin-stat-grid,.admin-dashboard-grid,.admin-two-columns,.admin-quick-actions>div,.prediction-detail-grid{grid-template-columns:1fr}
  .admin-form-row,.admin-match-form,.admin-inline-form{grid-template-columns:1fr}.admin-filters{width:100%;align-items:stretch;flex-direction:column}.admin-filters input,.admin-filters select{width:100%}
  .admin-card-head{align-items:flex-start;flex-direction:column}.admin-match-row{grid-template-columns:1fr}.admin-match-date{border-bottom:1px solid #e1e7eb;padding-bottom:8px}.admin-match-controls{grid-column:auto;align-items:flex-start;flex-direction:column}
  .admin-match-teams{grid-template-columns:1fr 35px 1fr}.score-form{width:100%}.score-form button{flex:1}
  .prize-admin-card{grid-template-columns:45px 1fr}.prize-admin-card .admin-actions{grid-column:2}
  .admin-login-shell{grid-template-columns:1fr}.admin-login-brand{display:none}.admin-login-card{padding:34px 25px}
}
