/* ============================================================
   FRANCO — Provincial de volleyball franco-ontarien 2026-2027
   Feuille de style partagée — v2
   ============================================================ */
:root{
  --ink:#10151a;
  --encre-2:#3c454e;
  --gris:#6b7680;
  --paper:#ffffff;
  --surface:#f5f7f9;
  --ligne:#e4e8ec;
  --bleu:#2ba9e0;        /* décoratif (logo) */
  --bleu-texte:#0e6f9f;  /* liens, contraste suffisant sur blanc */
  --font:"Archivo", system-ui, -apple-system, sans-serif;
  --maxw:1080px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none!important;transition:none!important}
}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--font);
  font-size:16.5px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:var(--bleu-texte);text-underline-offset:3px}
a:hover{color:var(--ink)}
:focus-visible{outline:2.5px solid var(--bleu-texte);outline-offset:3px;border-radius:3px}

/* ---------- Typo ---------- */
h1,h2,h3,h4{font-weight:700;letter-spacing:-.022em;line-height:1.12}
h1{font-size:clamp(38px,5.4vw,60px);letter-spacing:-.028em}
h2{font-size:clamp(28px,3.6vw,38px);margin-bottom:18px}
h3{font-size:21px;margin-bottom:8px}
.kicker{
  font-size:13px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:var(--gris);margin-bottom:16px;
}
.lede{font-size:18.5px;color:var(--encre-2);max-width:640px}
.texte p{margin-bottom:16px;color:var(--encre-2);max-width:680px}
.texte a{font-weight:500}
.sourdine{color:var(--gris);font-size:14.5px}

/* ---------- En-tête ---------- */
.topbar{
  position:sticky;top:0;z-index:50;background:rgba(255,255,255,.94);
  backdrop-filter:blur(8px);border-bottom:1px solid var(--ligne);
}
.topbar-inner{
  max-width:1280px;margin:0 auto;padding:0 24px;height:66px;
  display:flex;align-items:center;gap:12px;
}
.marque{
  display:flex;align-items:center;gap:11px;text-decoration:none;color:var(--ink);
  font-weight:700;font-size:19px;letter-spacing:.01em;
}
.marque img{height:40px;width:auto}
.menu{margin-left:auto;display:flex;gap:4px;list-style:none;align-items:center}
.menu a{
  color:var(--encre-2);text-decoration:none;font-weight:500;font-size:13.5px;
  padding:8px 9px;border-radius:999px;white-space:nowrap;
  transition:background .15s, color .15s;
}
.menu a:hover{background:var(--surface);color:var(--ink)}
.menu a[aria-current="page"]{color:var(--ink);font-weight:650;background:var(--surface)}
.menu .btn-nav{
  background:var(--ink);color:#fff;font-weight:600;padding:9px 18px;margin-left:8px;
}
.menu .btn-nav:hover{background:var(--bleu-texte);color:#fff}
.burger{
  display:none;margin-left:auto;background:none;border:1px solid var(--ligne);
  border-radius:999px;color:var(--ink);padding:8px 14px;font-size:18px;
  line-height:1;cursor:pointer;
}
@media (max-width:1200px){
  .burger{display:block}
  .menu{
    display:none;position:absolute;top:66px;left:0;right:0;
    flex-direction:column;align-items:stretch;gap:0;
    background:var(--paper);border-bottom:1px solid var(--ligne);padding:8px 12px 14px;
  }
  .menu.ouvert{display:flex}
  .menu a{display:block;padding:13px 14px;border-radius:10px;font-size:16px}
  .menu .btn-nav{margin:10px 2px 0;text-align:center}
}

/* ---------- Mise en page ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
section{padding:72px 0}
.regle{border:none;border-top:1px solid var(--ligne);margin:0}
.entete-page{padding:64px 0 52px;border-bottom:1px solid var(--ligne)}
.entete-page .lede{margin-top:14px}

/* ---------- Boutons ---------- */
.btn{
  display:inline-block;text-decoration:none;font-weight:600;font-size:15.5px;
  padding:13px 26px;border-radius:999px;cursor:pointer;border:none;
  font-family:var(--font);transition:background .15s, color .15s, border-color .15s;
}
.btn-noir{background:var(--ink);color:#fff}
.btn-noir:hover{background:var(--bleu-texte);color:#fff}
.btn-contour{border:1.5px solid var(--ligne);color:var(--ink);background:var(--paper)}
.btn-contour:hover{border-color:var(--ink);color:var(--ink)}

/* ---------- Rangée de faits ---------- */
.faits{
  display:grid;grid-template-columns:1fr 1fr;max-width:560px;
  border-top:1px solid var(--ligne);border-bottom:1px solid var(--ligne);
  padding:6px 0;
}
.faits > div{padding:12px 24px 12px 0}
.faits .k{font-size:12.5px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--gris)}
.faits .v{font-weight:650;font-size:17px;margin-top:2px}

/* ---------- Cartes ---------- */
.grille{display:grid;gap:14px}
.grille.deux{grid-template-columns:1fr 1fr}
.grille.trois{grid-template-columns:repeat(3,1fr)}
@media (max-width:860px){ .grille.deux,.grille.trois{grid-template-columns:1fr} }
.carte{
  background:var(--surface);border-radius:16px;padding:28px;
}
.carte h3{margin-bottom:6px}
.carte p{color:var(--encre-2);font-size:15.5px;margin-bottom:8px}
.carte p:last-child{margin-bottom:0}
.carte .etiquette{
  display:inline-block;font-size:12.5px;font-weight:600;letter-spacing:.1em;
  text-transform:uppercase;color:var(--gris);margin-bottom:12px;
}
a.carte{display:block;text-decoration:none;color:var(--ink);transition:background .15s}
a.carte:hover{background:#eef2f5}
a.carte .aller{font-weight:600;color:var(--bleu-texte);font-size:14.5px}

/* ---------- Tableaux ---------- */
.enveloppe-tableau{overflow-x:auto;margin:8px 0 40px}
.tableau{width:100%;border-collapse:collapse;font-size:15.5px}
.tableau caption{
  text-align:left;font-weight:700;font-size:19px;letter-spacing:-.01em;
  padding-bottom:12px;
}
.tableau th{
  font-size:12.5px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  color:var(--gris);text-align:left;padding:10px 14px 10px 0;
  border-bottom:1.5px solid var(--ink);
}
.tableau td{
  padding:12px 14px 12px 0;border-bottom:1px solid var(--ligne);color:var(--encre-2);
}
.tableau td strong{color:var(--ink);font-weight:650}
.tableau .num{font-variant-numeric:tabular-nums}
.note-maj{font-size:13.5px;color:var(--gris);margin:10px 0 28px}
.message-vide{
  background:var(--surface);border-radius:16px;padding:34px;
  color:var(--gris);margin:8px 0 40px;
}

/* ---------- Onglets (segmenté) ---------- */
.segmente{
  display:inline-flex;background:var(--surface);border-radius:999px;padding:4px;
  margin:6px 0 30px;gap:2px;
}
.segmente button{
  border:none;background:none;font-family:var(--font);font-weight:600;
  font-size:14.5px;color:var(--gris);padding:9px 20px;border-radius:999px;
  cursor:pointer;transition:background .15s, color .15s;
}
.segmente button:hover{color:var(--ink)}
.segmente button[aria-selected="true"]{background:var(--ink);color:#fff}

/* ---------- Listes ---------- */
ul.liste{list-style:none;max-width:680px}
ul.liste li{
  padding:12px 0;border-bottom:1px solid var(--ligne);color:var(--encre-2);
}
ul.liste li:last-child{border-bottom:none}
ul.liste li strong{color:var(--ink);font-weight:650}

ol.etapes{list-style:none;counter-reset:e;max-width:680px}
ol.etapes li{
  counter-increment:e;position:relative;padding:18px 0 18px 56px;
  border-bottom:1px solid var(--ligne);color:var(--encre-2);
}
ol.etapes li:last-child{border-bottom:none}
ol.etapes li strong{color:var(--ink)}
ol.etapes li::before{
  content:counter(e);position:absolute;left:0;top:16px;
  width:34px;height:34px;border-radius:999px;background:var(--ink);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:15px;
}

/* ---------- Encadré ---------- */
.encadre{
  background:var(--surface);border-radius:16px;padding:22px 26px;
  color:var(--encre-2);max-width:760px;margin:28px 0;
}
.encadre strong{color:var(--ink)}

/* ---------- Pied de page ---------- */
footer{background:var(--ink);color:#aeb7bf;margin-top:40px}
.foot{
  max-width:var(--maxw);margin:0 auto;padding:42px 24px;
  display:flex;align-items:center;gap:18px;flex-wrap:wrap;font-size:14px;
}
.foot img{height:44px;width:auto}
.foot a{color:#dfe5ea;text-decoration:none}
.foot a:hover{color:#fff;text-decoration:underline}
.foot .fin{margin-left:auto}

/* ---------- Statuts d'équipe ---------- */
.badge{
  display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:600;
  padding:4px 12px;border-radius:999px;white-space:nowrap;
}
.badge::before{content:"";width:7px;height:7px;border-radius:50%}
.badge-ok{background:#e7f5ec;color:#1c6e3a}
.badge-ok::before{background:#23924c}
.badge-attente{background:#fbf1dd;color:#8d6310}
.badge-attente::before{background:#d99a1f}
.legende{
  display:flex;gap:18px;flex-wrap:wrap;align-items:center;
  font-size:14px;color:var(--gris);margin:-12px 0 30px;
}

/* ---------- Hôtels confirmés ---------- */
.carte-confirmee{
  background:var(--paper);
  border:2px solid var(--ink);
}
.carte .badge{align-self:flex-start}
