/* ===== Contenu identique à public/css/style.css — dupliqué ici uniquement pour que cet aperçu autonome fonctionne ===== */
/* ==============================================================
   PRÉFACS.COM — FEUILLE DE STYLE
   Placer ce fichier dans : public/css/style.css
   ============================================================== */
 
/* ---------- 1. TOKENS ---------- */
:root{
  /* Couleurs de marque */
  --ink:        #241832;
  --aubergine:  #3E2A5C;
  --violet:     #6D3FC4;
  --violet-deep:#54279E;
  --amber:      #E8A33D;
  --amber-deep: #C97F1E;
  --emerald:    #1F8A63;
  --parchment:  #F7F4FB;
  --paper:      #FFFFFF;
  --line:       #E4DEF0;
  --line-strong:#D5CBEB;
 
  /* Échelle d'espacement (rem) */
  --sp-1: 0.25rem;
  --sp-2: 0.5rem;
  --sp-3: 0.75rem;
  --sp-4: 1rem;
  --sp-5: 1.5rem;
  --sp-6: 2rem;
  --sp-7: 3rem;
  --sp-8: 4rem;
 
  /* Échelle typographique fluide */
  --text-sm:   clamp(0.8125rem, 0.78rem + 0.15vw, 0.875rem);
  --text-base: clamp(0.9375rem, 0.9rem + 0.2vw, 1rem);
  --text-md:   clamp(1.0625rem, 1rem + 0.3vw, 1.1875rem);
  --text-lg:   clamp(1.25rem, 1.1rem + 0.6vw, 1.5rem);
  --text-xl:   clamp(1.75rem, 1.4rem + 1.4vw, 2.375rem);
  --text-2xl:  clamp(2.1rem, 1.6rem + 2.2vw, 3.25rem);
 
  /* Ombres */
  --shadow-sm: 0 1px 2px rgba(36,24,50,.06);
  --shadow-md: 0 6px 20px rgba(62,42,92,.10);
  --shadow-lg: 0 16px 40px rgba(62,42,92,.16);
 
  /* Rayons */
  --r-sm: 8px;
  --r-md: 14px;
  --r-lg: 22px;
  --r-pill: 999px;
 
  /* Typo */
  --font-display: 'Fraunces', serif;
  --font-body: 'Work Sans', sans-serif;
  --font-mono: 'IBM Plex Mono', monospace;
 
  /* Largeur de page */
  --wrap: 74rem;
 
  /* Hauteur du menu fixe — réutilisée pour ne rien faire passer dessous */
  --header-h: 4.5rem;
 
  /* Bascule mobile du menu — ajuster si les libellés changent */
  --nav-breakpoint: 860px;
}
 
/* ---------- 2. RESET / BASE ---------- */
*, *::before, *::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; font-size:100%; }
body{
  margin:0;
  font-family:var(--font-body);
  font-size:var(--text-base);
  color:var(--ink);
  background:var(--parchment);
  line-height:1.55;
  padding-top:var(--header-h); /* compense le menu fixe */
}
img{ max-width:100%; display:block; }
a{ color:var(--violet); }
button{ font:inherit; }
ul{ list-style:none; margin:0; padding:0; }
h1,h2,h3,h4{ font-family:var(--font-display); color:var(--aubergine); margin:0 0 var(--sp-3); }
 
/* Focus clavier visible partout (accessibilité) */
a:focus-visible,
button:focus-visible,
input:focus-visible{
  outline:2px solid var(--amber);
  outline-offset:2px;
}
 
@media (prefers-reduced-motion: reduce){
  *{ animation-duration:0.01ms !important; transition-duration:0.01ms !important; }
  html{ scroll-behavior:auto; }
}
 
/* ---------- 3. MISE EN PAGE GÉNÉRALE ---------- */
.container{
  max-width:var(--wrap);
  margin:0 auto;
  padding:0 var(--sp-4);
}
.section{ padding:var(--sp-7) 0; }
.section-tight{ padding:var(--sp-5) 0; }
 
/* ---------- 4. BOUTONS ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-2);
  width:auto;
  padding:0.7rem 1.4rem;
  border-radius:var(--r-pill);
  font-weight:600;font-size:var(--text-sm);font-family:var(--font-body);
  border:none;cursor:pointer;text-decoration:none;white-space:nowrap;
  transition:transform .15s, box-shadow .15s, background .15s;
}
.btn:active{ transform:translateY(1px); }
.btn-primary{ background:var(--violet); color:#fff; box-shadow:0 6px 16px rgba(109,63,196,.30); }
.btn-primary:hover{ background:var(--violet-deep); }
.btn-amber{ background:var(--amber); color:var(--ink); box-shadow:0 6px 16px rgba(232,163,61,.32); }
.btn-amber:hover{ background:var(--amber-deep); color:#fff; }
.btn-ghost{ background:transparent; color:var(--aubergine); border:1.5px solid var(--line-strong); }
.btn-ghost:hover{ border-color:var(--violet); color:var(--violet); }
.btn-whatsapp{ background:var(--emerald); color:#fff; box-shadow:0 6px 16px rgba(31,138,99,.28); }
.btn-block{ width:100%; } /* pleine largeur — formulaires, menu mobile uniquement */
 
/* ---------- 5. TAMPON (élément signature) ---------- */
.stamp{
  --stamp-color: var(--violet);
  display:inline-flex;flex-direction:column;align-items:center;justify-content:center;
  width:6.5rem;height:6.5rem;border-radius:50%;
  border:2.5px dashed var(--stamp-color);color:var(--stamp-color);
  transform:rotate(-9deg);font-family:var(--font-mono);text-align:center;
  position:relative;flex-shrink:0;
}
.stamp::before{ content:"";position:absolute;inset:8px;border-radius:50%;border:1px solid var(--stamp-color);opacity:.5; }
.stamp-top{ font-size:0.6rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;margin-top:0.85rem; }
.stamp-main{ font-size:0.9rem;font-weight:700;line-height:1.1;margin-top:2px; }
.stamp-bottom{ font-size:0.56rem;letter-spacing:.1em;margin-bottom:0.7rem;text-transform:uppercase; }
.stamp.amber{ --stamp-color:var(--amber-deep); }
.stamp.emerald{ --stamp-color:var(--emerald); }
.stamp.sm{ width:4.6rem;height:4.6rem; }
.stamp.sm .stamp-top{ font-size:0.42rem; }
.stamp.sm .stamp-main{ font-size:0.68rem; }
 
/* ---------- 6. CARTE PRÉFAC ---------- */
.pf-card{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:var(--sp-5);display:flex;gap:var(--sp-4);align-items:flex-start;
  box-shadow:var(--shadow-sm);transition:box-shadow .2s, transform .2s;
}
.pf-card:hover{ box-shadow:var(--shadow-lg); transform:translateY(-3px); }
.pf-card-body h3{ font-size:var(--text-lg); margin:0 0 var(--sp-2); }
.pf-card-body p{ margin:0 0 var(--sp-3); font-size:var(--text-sm); color:#5C4C7A; }
.pf-tagline{
  font-family:var(--font-mono);font-size:0.68rem;text-transform:uppercase;letter-spacing:.1em;
  color:var(--amber-deep);font-weight:600;margin-bottom:var(--sp-1);display:block;
}
.card-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(17rem,1fr)); gap:var(--sp-4); }
 
/* ---------- 7. FORMULAIRE DE CONNEXION ---------- */
.pf-login{
  background:linear-gradient(155deg,var(--aubergine),var(--violet-deep));
  border-radius:var(--r-lg);padding:var(--sp-6);color:#fff;max-width:26rem;
  box-shadow:var(--shadow-lg);position:relative;overflow:hidden;
}
.pf-login::after{
  content:"";position:absolute;width:14rem;height:14rem;border-radius:50%;
  background:rgba(232,163,61,.18);top:-5.5rem;right:-5.5rem;
}
.pf-login h3{ font-size:var(--text-lg); margin:0 0 0.3rem; position:relative; color:#fff; }
.pf-login p{ color:#D9CCF0; font-size:var(--text-sm); margin:0 0 var(--sp-5); position:relative; }
.pf-field{ margin-bottom:var(--sp-3); position:relative; }
.pf-field label{ display:block; font-size:0.8rem; font-weight:600; margin-bottom:var(--sp-1); color:#E9E1F7; }
.pf-field input[type=text], .pf-field input[type=email],
.pf-field input[type=password]{
  width:100%;padding:0.7rem 0.85rem;border-radius:var(--r-sm);
  border:1px solid rgba(255,255,255,.25);background:rgba(255,255,255,.08);
  color:#fff;font-family:var(--font-body);font-size:var(--text-sm);
}
.pf-field input::placeholder{ color:rgba(255,255,255,.45); }
.pf-row-between{
  display:flex;align-items:center;justify-content:space-between;
  margin:var(--sp-1) 0 var(--sp-4);flex-wrap:wrap;gap:var(--sp-2);position:relative;
}
.pf-check{ display:flex; align-items:center; gap:0.4rem; font-size:0.8rem; color:#E9E1F7; cursor:pointer; }
.pf-check input{ width:1rem; height:1rem; accent-color:var(--amber); }
.pf-forgot{ font-size:0.8rem; color:#F3D9A0; text-decoration:underline; text-underline-offset:2px; }
.pf-forgot:hover{ color:var(--amber); }
 
/* Variante claire — pour poser la carte de connexion sur le hero violet
   sans qu'un dégradé violet se retrouve sur un autre dégradé violet */
.pf-login--light{ background:var(--paper); }
.pf-login--light::after{ display:none; }
.pf-login--light h3{ color:var(--aubergine); }
.pf-login--light p{ color:#5C4C7A; }
.pf-login--light .pf-field label{ color:var(--aubergine); }
.pf-login--light .pf-field input[type=email],
.pf-login--light .pf-field input[type=password]{
  background:var(--parchment); border:1px solid var(--line-strong); color:var(--ink);
}
.pf-login--light .pf-field input::placeholder{ color:#9C8DB8; }
.pf-login--light .pf-check{ color:var(--aubergine); }
.pf-login--light .pf-forgot{ color:var(--violet-deep); }
.pf-login--light .pf-forgot:hover{ color:var(--amber-deep); }
 
/* ---------- 8. HERO ---------- */
.pf-hero{
  background:linear-gradient(160deg,var(--aubergine) 0%,var(--violet-deep) 60%,var(--violet) 100%);
  border-radius:var(--r-lg);padding:var(--sp-7) var(--sp-6);color:#fff;
  position:relative;overflow:hidden;
}
.pf-hero::before{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(circle at 85% 20%, rgba(232,163,61,.25), transparent 45%);
}
.pf-hero-eyebrow{
  font-family:var(--font-mono);font-size:0.75rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--amber);font-weight:600;position:relative;
}
.pf-hero h1{
  color:#fff;font-size:var(--text-2xl);line-height:1.08;margin:var(--sp-3) 0 var(--sp-4);
  max-width:34rem;position:relative;font-weight:700;
}
.pf-hero p{ color:#E4D9F5; max-width:28rem; font-size:var(--text-md); margin-bottom:var(--sp-5); position:relative; }
.pf-hero-actions{ display:flex; gap:var(--sp-3); flex-wrap:wrap; position:relative; }
 
/* ---------- 9. PIED DE PAGE ---------- */
/* .pf-footer est plein-largeur (posé directement sur <footer>) ;
   .pf-footer-inner recentre le contenu comme .container */
   .pf-footer{ background:var(--ink); color:#C9BEE0; width:100%; }
.pf-footer-inner{
  max-width:74rem;
  margin:0 auto;
  padding:3rem 1.5rem 2rem;
  box-sizing:border-box;
}
/*.pf-footer-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(9.5rem,1fr));
  gap:var(--sp-5);margin-bottom:var(--sp-5);
}*/
.pf-footer-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(9.5rem,12rem));
  justify-content:space-between;
  gap:var(--sp-5);
  margin-bottom:var(--sp-5);
}
.pf-footer h4{
  font-family:var(--font-mono);font-size:0.7rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--amber);margin:0 0 var(--sp-3);
}
.pf-footer a{ display:block; color:#C9BEE0; text-decoration:none; font-size:var(--text-sm); margin-bottom:var(--sp-2); opacity:.85; }
.pf-footer a:hover{ opacity:1; color:#fff; }
.pf-footer-bottom{
  border-top:1px solid rgba(255,255,255,.12);padding-top:var(--sp-4);font-size:0.8rem;
  color:#8A7BA8;display:flex;justify-content:space-between;flex-wrap:wrap;gap:var(--sp-2);
}
 
/* ---------- 10. NAVIGATION MULTI-NIVEAUX RESPONSIVE ---------- */
.pf-header{
  background:var(--paper); border-bottom:1px solid var(--line);
  position:fixed; top:0; left:0; right:0; width:100%; z-index:100;
}
.pf-header-inner{
  max-width:var(--wrap);margin:0 auto;padding:0 var(--sp-4);
  display:flex;align-items:center;justify-content:space-between;min-height:var(--header-h);gap:var(--sp-3);
}
.pf-brand{
  display:flex;align-items:center;gap:var(--sp-2);font-family:var(--font-display);
  font-weight:700;font-size:var(--text-md);color:var(--aubergine);text-decoration:none;flex-shrink:0;
}
.pf-brand-mark{
  width:2.3rem;height:2.3rem;border-radius:0.6rem;
  background:linear-gradient(155deg,var(--violet),var(--aubergine));
  display:flex;align-items:center;justify-content:center;color:#fff;font-size:1rem;flex-shrink:0;
}
 
.pf-menu-toggle{
  display:none;background:none;border:1px solid var(--line-strong);border-radius:var(--r-sm);
  width:2.6rem;height:2.6rem;align-items:center;justify-content:center;cursor:pointer;
  color:var(--aubergine);flex-shrink:0;
}
.pf-menu-toggle svg{ width:1.2rem; height:1.2rem; }
 
.pf-nav{ display:flex; align-items:center; gap:var(--sp-3); flex:1; justify-content:flex-end; }
.pf-menu{ display:flex; align-items:stretch; gap:0.15rem; }
.pf-menu > li{ position:relative; display:flex; align-items:stretch; }
.pf-link{
  display:flex;align-items:center;gap:0.3rem;padding:0 var(--sp-3);height:4.5rem;
  font-size:var(--text-sm);font-weight:600;color:var(--ink);text-decoration:none;
  background:none;border:none;cursor:pointer;white-space:nowrap;position:relative;
}
.pf-link:hover{ color:var(--violet-deep); }
.pf-link.active{ color:var(--violet-deep); }
.pf-link.active::after{
  content:"";position:absolute;left:var(--sp-3);right:var(--sp-3);bottom:0;
  height:3px;background:var(--amber);border-radius:3px 3px 0 0;
}
.pf-chevron{ width:0.7rem; height:0.7rem; transition:transform .18s; flex-shrink:0; }
.has-sub.open > .pf-link .pf-chevron{ transform:rotate(180deg); }
 
/* Sous-menu (dropdown desktop) */
.pf-submenu{
  position:absolute;top:100%;left:0;min-width:13rem;
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r-md);
  box-shadow:var(--shadow-lg);padding:var(--sp-2);
  opacity:0;visibility:hidden;transform:translateY(6px);
  transition:opacity .16s, transform .16s, visibility .16s;
  z-index:70;
}
.has-sub.open > .pf-submenu{ opacity:1; visibility:visible; transform:translateY(0); }
.pf-submenu a{
  display:flex;align-items:center;justify-content:space-between;padding:0.55rem 0.75rem;
  border-radius:var(--r-sm);font-size:var(--text-sm);color:var(--ink);text-decoration:none;gap:var(--sp-2);
}
.pf-submenu a:hover{ background:var(--parchment); color:var(--violet-deep); }
.pf-submenu .meta{
  font-size:0.62rem;font-family:var(--font-mono);text-transform:uppercase;
  color:#8A7BA8;letter-spacing:.06em;
}
 
.pf-nav-cta{ display:flex; align-items:center; gap:var(--sp-2); flex-shrink:0; }
 
/* --- Mobile : hamburger + accordéon --- */
@media (max-width: 860px){
  .pf-menu-toggle{ display:inline-flex; }
  .pf-nav{
    position:fixed;inset:var(--header-h) 0 0 0;background:var(--paper);
    flex-direction:column;align-items:stretch;justify-content:flex-start;
    padding:var(--sp-4);overflow-y:auto;
    transform:translateX(100%);transition:transform .22s ease;
  }
  .pf-nav.open{ transform:translateX(0); }
  .pf-menu{ flex-direction:column; gap:0; width:100%; }
  .pf-menu > li{ flex-direction:column; align-items:stretch; border-bottom:1px solid var(--line); }
  .pf-link{ height:auto; padding:var(--sp-3) var(--sp-1); width:100%; justify-content:space-between; }
  .pf-link.active::after{ display:none; }
  .pf-link.active{ background:var(--parchment); border-radius:var(--r-sm); }
  .pf-submenu{
    position:static;box-shadow:none;border:none;opacity:1;visibility:visible;transform:none;
    max-height:0;overflow:hidden;padding:0 0 0 var(--sp-3);transition:max-height .22s ease;
  }
  .has-sub.open > .pf-submenu{ max-height:20rem; padding:0 0 var(--sp-2) var(--sp-3); }
  .pf-nav-cta{ width:100%; margin-top:var(--sp-4); }
  .pf-nav-cta .btn{ width:100%; }
}
 
/* ---------- 11. UTILITAIRES ---------- */
.note{
  max-width:40rem;background:var(--paper);border:1px solid var(--line);border-radius:var(--r-md);
  padding:var(--sp-4) var(--sp-5);font-size:var(--text-sm);color:#5C4C7A;margin-top:var(--sp-5);
}
.note strong{ color:var(--aubergine); }
.text-center{ text-align:center; }
.mt-0{ margin-top:0; } .mb-0{ margin-bottom:0; }
.text-amber{ color:var(--amber); }
 
/* Sections alternées : le fond du body est déjà "parchment",
   ces classes servent à ponctuer la page d'un blanc franc */
.section-white{ background:var(--paper); }
 
/* ---------- 12. EN-TÊTES DE SECTION (réutilisables sur toutes les pages) ---------- */
.section-eyebrow{
  font-family:var(--font-mono);font-size:0.75rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--violet-deep);font-weight:600;margin:0 0 var(--sp-2);
}
.section-title{ font-size:var(--text-xl); margin:0 0 var(--sp-3); }
.section-lede{ max-width:40rem; color:#4A3A63; font-size:var(--text-md); margin:0 0 var(--sp-6); }
 
/* ---------- 13. HERO D'ACCUEIL + CONNEXION CÔTE À CÔTE ---------- */
.home-hero-grid{
  display:grid; grid-template-columns:1.15fr 0.85fr; gap:var(--sp-7);
  align-items:center; position:relative;
}
@media (max-width: 860px){
  .home-hero-grid{ grid-template-columns:1fr; gap:var(--sp-6); }
}
 
/* ---------- 14. GROUPES D'INSTITUTIONS ---------- */
.institution-grid{
  display:grid; grid-template-columns:repeat(auto-fit,minmax(15.5rem,1fr)); gap:var(--sp-5);
}
.institution-card{
  background:var(--paper); border:1px solid var(--line); border-top:4px solid var(--line-strong);
  border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow-sm);
  display:flex; flex-direction:column; transition:transform .2s, box-shadow .2s;
}
.institution-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow-lg); }
.institution-card.is-violet{ border-top-color:var(--violet); }
.institution-card.is-amber{ border-top-color:var(--amber); }
.institution-card.is-emerald{ border-top-color:var(--emerald); }
.institution-card.is-aubergine{ border-top-color:var(--aubergine); }
.institution-card.is-violet-deep{ border-top-color:var(--violet-deep); }
 
.institution-card .card-image{
  width:100%; height:9.5rem; object-fit:cover; background:var(--parchment);
}
.institution-card .card-body{
  padding:var(--sp-4) var(--sp-5) var(--sp-5); display:flex; flex-direction:column; gap:var(--sp-2); flex:1;
}
.institution-tag{
  display:inline-block; width:fit-content; font-family:var(--font-mono); font-size:0.66rem;
  letter-spacing:.08em; text-transform:uppercase; font-weight:700; padding:0.2rem 0.55rem;
  border-radius:var(--r-pill); background:var(--parchment);
}
.institution-card.is-violet .institution-tag{ color:var(--violet-deep); }
.institution-card.is-amber .institution-tag{ color:var(--amber-deep); }
.institution-card.is-emerald .institution-tag{ color:var(--emerald); }
.institution-card.is-aubergine .institution-tag{ color:var(--aubergine); }
.institution-card.is-violet-deep .institution-tag{ color:var(--violet-deep); }
 
.institution-card h3{ font-size:var(--text-md); margin:0; }
.institution-card p{ font-size:var(--text-sm); color:#5C4C7A; margin:0; flex:1; }
.institution-card .btn{ align-self:flex-start; margin-top:var(--sp-1); }
 
/* ---------- 15. SPONSORS ---------- */
.sponsor-grid{
  display:grid; grid-template-columns:repeat(auto-fit,minmax(12.5rem,1fr)); gap:var(--sp-4);
}
.sponsor-card{
  background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg);
  padding:var(--sp-5); text-align:center; box-shadow:var(--shadow-sm);
  display:flex; flex-direction:column; align-items:center; gap:var(--sp-3);
  transition:box-shadow .2s, transform .2s;
}
.sponsor-card:hover{ box-shadow:var(--shadow-md); transform:translateY(-2px); }
.sponsor-logo{
  width:4.75rem; height:4.75rem; border-radius:50%; object-fit:cover;
  border:1px solid var(--line); background:var(--parchment);
}
.sponsor-name{ font-weight:700; font-size:var(--text-sm); color:var(--aubergine); }
.social-row{ display:flex; gap:var(--sp-2); }
.social-btn{
  width:2.2rem; height:2.2rem; border-radius:50%; display:flex; align-items:center; justify-content:center;
  background:var(--parchment); color:var(--aubergine); text-decoration:none;
  transition:background .15s, color .15s;
}
.social-btn:hover{ background:var(--violet); color:#fff; }
.social-btn svg{ width:1rem; height:1rem; }
 
/* ---------- 16. COORDINATION GÉNÉRALE (ÉQUIPE) ---------- */
.team-grid{
  display:grid; grid-template-columns:repeat(auto-fit,minmax(13rem,1fr)); gap:var(--sp-5);
}
.team-card{
  background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg);
  padding:var(--sp-5); text-align:center; box-shadow:var(--shadow-sm);
  display:flex; flex-direction:column; align-items:center; gap:var(--sp-1);
}
.team-photo{
  width:6rem; height:6rem; border-radius:50%; object-fit:cover;
  border:3px solid var(--parchment); box-shadow:var(--shadow-sm); margin-bottom:var(--sp-2);
}
.team-name{ font-family:var(--font-display); font-size:var(--text-md); color:var(--aubergine); margin:0; }
.team-role{
  font-size:0.76rem; color:#8A7BA8; font-family:var(--font-mono);
  text-transform:uppercase; letter-spacing:.05em; margin:0 0 var(--sp-3);
}
.team-card .btn-whatsapp{ margin-top:auto; }
 
/* ---------- 12. EN-TÊTE DE SECTION (titre + sous-titre) ---------- */
/* Portée : uniquement à l'intérieur de .section-head, ne touche à rien d'existant */
.eyebrow{
  font-family:var(--font-mono);font-size:0.75rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--violet-deep);font-weight:600;margin:0 0 var(--sp-2);
}
.section-head{ max-width:36rem;margin:0 auto var(--sp-6);text-align:center; }
.section-head h2{ margin:0 0 var(--sp-2); }
.section-head p{ color:#5C4C7A;font-size:var(--text-md);margin:0; }
 
/* ---------- 13. HERO + FORMULAIRE D'INSCRIPTION (page d'accueil) ---------- */
.hero-grid{ display:grid;grid-template-columns:1.1fr 0.9fr;gap:var(--sp-6);align-items:stretch; }
@media (max-width: 960px){
  .hero-grid{ grid-template-columns:1fr; }
}
 
/* Carte d'inscription : même famille que .pf-login mais claire, donc on ne réutilise
   pas .pf-login tel quel — on surcharge uniquement DANS .pf-signup pour ne rien casser
   ailleurs où .pf-field / .pf-check sont utilisés sur fond sombre (ex. connexion). */
.pf-signup{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:var(--sp-6);box-shadow:var(--shadow-lg);
}
.pf-signup h3{ font-size:var(--text-lg);margin:0 0 0.3rem;color:var(--aubergine); }
.pf-signup > p{ color:#5C4C7A;font-size:var(--text-sm);margin:0 0 var(--sp-5); }
.pf-signup .pf-field label{ color:var(--ink); }
.pf-signup .pf-field input{
  background:var(--parchment);border:1px solid var(--line-strong);color:var(--ink);
}
.pf-signup .pf-field input::placeholder{ color:#9C8CBB; }
.pf-signup .pf-check{ color:#5C4C7A; }
.pf-signup .pf-check input{ accent-color:var(--violet); }
.pf-signup-footer{
  text-align:center;font-size:var(--text-sm);color:#5C4C7A;margin-top:var(--sp-4);
}
.pf-signup-footer a{ font-weight:600;text-decoration:none; }
.pf-signup-footer a:hover{ text-decoration:underline; }
 
/* ---------- 14. SPONSORS ---------- */
.pf-sponsor-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(9.5rem,1fr));
  gap:var(--sp-5);align-items:stretch;
}
.pf-sponsor-card{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r-md);
  padding:var(--sp-5) var(--sp-4);display:flex;flex-direction:column;align-items:center;
  gap:var(--sp-3);text-align:center;box-shadow:var(--shadow-sm);
  transition:transform .2s, box-shadow .2s;
}
.pf-sponsor-card:hover{ transform:translateY(-3px);box-shadow:var(--shadow-md); }
.pf-sponsor-logo{
  width:4.5rem;height:4.5rem;border-radius:50%;object-fit:cover;background:var(--parchment);
  display:flex;align-items:center;justify-content:center;font-family:var(--font-display);
  font-weight:700;color:var(--violet);font-size:1.1rem;overflow:hidden;
}
.pf-sponsor-name{ font-size:var(--text-sm);font-weight:600;color:var(--aubergine); }
 
/* ---------- 15. COORDINATION GÉNÉRALE (équipe) ---------- */
.pf-team-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(13rem,1fr));gap:var(--sp-5);
}
.pf-team-card{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:var(--sp-5);text-align:center;box-shadow:var(--shadow-sm);
  transition:transform .2s, box-shadow .2s;
}
.pf-team-card:hover{ transform:translateY(-3px);box-shadow:var(--shadow-lg); }
.pf-team-photo{
  width:6rem;height:6rem;border-radius:50%;margin:0 auto var(--sp-3);object-fit:cover;
  background:linear-gradient(155deg,var(--violet),var(--aubergine));
  display:flex;align-items:center;justify-content:center;color:#fff;
  font-family:var(--font-display);font-weight:700;font-size:1.4rem;
}
.pf-team-name{ font-size:var(--text-md);margin:0 0 0.2rem;color:var(--aubergine); }
.pf-team-role{
  font-size:0.78rem;font-family:var(--font-mono);text-transform:uppercase;
  letter-spacing:.06em;color:var(--violet-deep);margin:0 0 var(--sp-3);
}
 
 
/* ===== Bandeau d'avertissement, propre à cet aperçu uniquement ===== */
.preview-banner{
  background:var(--amber); color:var(--ink); text-align:center; font-family:var(--font-mono);
  font-size:0.75rem; padding:0.5rem; position:fixed; bottom:0; left:0; right:0; z-index:200;
  letter-spacing:.03em;
}

/* ==============================================================
   17. CLASSES UTILITAIRES GÉNÉRIQUES
   À utiliser directement dans le HTML pour des ajustements
   ponctuels, sans écrire de CSS supplémentaire.
   ============================================================== */

/* ---- Couleurs de texte ---- */
.text-ink{ color:var(--ink); }
.text-aubergine{ color:var(--aubergine); }
.text-violet{ color:var(--violet); }
.text-violet-deep{ color:var(--violet-deep); }
.text-amber{ color:var(--amber); }
.text-amber-deep{ color:var(--amber-deep); }
.text-emerald{ color:var(--emerald); }
.text-muted{ color:#8A7BA8; }
.text-white{ color:#fff; }

/* ---- Couleurs de fond ---- */
.bg-ink{ background:var(--ink); }
.bg-aubergine{ background:var(--aubergine); }
.bg-violet{ background:var(--violet); }
.bg-amber{ background:var(--amber); }
.bg-emerald{ background:var(--emerald); }
.bg-paper{ background:var(--paper); }
.bg-parchment{ background:var(--parchment); }
.bg-white{ background:#fff; }

/* ---- Bordures ---- */
.border{ border:1px solid var(--line); }
.border-strong{ border:1px solid var(--line-strong); }
.border-none{ border:none; }

/* ---- Rayons ---- */
.rounded-none{ border-radius:0; }
.rounded-sm{ border-radius:var(--r-sm); }
.rounded-md{ border-radius:var(--r-md); }
.rounded-lg{ border-radius:var(--r-lg); }
.rounded-pill{ border-radius:var(--r-pill); }
.rounded-circle{ border-radius:50%; }

/* ---- Ombres ---- */
.shadow-none{ box-shadow:none; }
.shadow-sm{ box-shadow:var(--shadow-sm); }
.shadow-md{ box-shadow:var(--shadow-md); }
.shadow-lg{ box-shadow:var(--shadow-lg); }

/* ---- Espacement — padding (p, pt, pr, pb, pl, px, py) ---- */
.p-0{padding:0;} .p-1{padding:var(--sp-1);} .p-2{padding:var(--sp-2);} .p-3{padding:var(--sp-3);}
.p-4{padding:var(--sp-4);} .p-5{padding:var(--sp-5);} .p-6{padding:var(--sp-6);} .p-7{padding:var(--sp-7);} .p-8{padding:var(--sp-8);}

.pt-1{padding-top:var(--sp-1);} .pt-2{padding-top:var(--sp-2);} .pt-3{padding-top:var(--sp-3);}
.pt-4{padding-top:var(--sp-4);} .pt-5{padding-top:var(--sp-5);} .pt-6{padding-top:var(--sp-6);}

.pb-1{padding-bottom:var(--sp-1);} .pb-2{padding-bottom:var(--sp-2);} .pb-3{padding-bottom:var(--sp-3);}
.pb-4{padding-bottom:var(--sp-4);} .pb-5{padding-bottom:var(--sp-5);} .pb-6{padding-bottom:var(--sp-6);}

.px-1{padding-left:var(--sp-1);padding-right:var(--sp-1);} .px-2{padding-left:var(--sp-2);padding-right:var(--sp-2);}
.px-3{padding-left:var(--sp-3);padding-right:var(--sp-3);} .px-4{padding-left:var(--sp-4);padding-right:var(--sp-4);}
.px-5{padding-left:var(--sp-5);padding-right:var(--sp-5);} .px-6{padding-left:var(--sp-6);padding-right:var(--sp-6);}

.py-1{padding-top:var(--sp-1);padding-bottom:var(--sp-1);} .py-2{padding-top:var(--sp-2);padding-bottom:var(--sp-2);}
.py-3{padding-top:var(--sp-3);padding-bottom:var(--sp-3);} .py-4{padding-top:var(--sp-4);padding-bottom:var(--sp-4);}
.py-5{padding-top:var(--sp-5);padding-bottom:var(--sp-5);} .py-6{padding-top:var(--sp-6);padding-bottom:var(--sp-6);}

/* ---- Espacement — margin (m, mt, mb, mx, my) ---- */
.m-0{margin:0;} .m-1{margin:var(--sp-1);} .m-2{margin:var(--sp-2);} .m-3{margin:var(--sp-3);}
.m-4{margin:var(--sp-4);} .m-5{margin:var(--sp-5);} .m-6{margin:var(--sp-6);}

.mt-0{margin-top:0;} .mt-1{margin-top:var(--sp-1);} .mt-2{margin-top:var(--sp-2);} .mt-3{margin-top:var(--sp-3);}
.mt-4{margin-top:var(--sp-4);} .mt-5{margin-top:var(--sp-5);} .mt-6{margin-top:var(--sp-6);}

.mb-0{margin-bottom:0;} .mb-1{margin-bottom:var(--sp-1);} .mb-2{margin-bottom:var(--sp-2);} .mb-3{margin-bottom:var(--sp-3);}
.mb-4{margin-bottom:var(--sp-4);} .mb-5{margin-bottom:var(--sp-5);} .mb-6{margin-bottom:var(--sp-6);}

.mx-auto{margin-left:auto;margin-right:auto;}
.my-1{margin-top:var(--sp-1);margin-bottom:var(--sp-1);} .my-2{margin-top:var(--sp-2);margin-bottom:var(--sp-2);}
.my-4{margin-top:var(--sp-4);margin-bottom:var(--sp-4);} .my-6{margin-top:var(--sp-6);margin-bottom:var(--sp-6);}

/* ---- Disposition flex ---- */
.flex{ display:flex; }
.flex-col{ display:flex; flex-direction:column; }
.flex-wrap{ flex-wrap:wrap; }
.items-center{ align-items:center; }
.items-start{ align-items:flex-start; }
.items-end{ align-items:flex-end; }
.justify-center{ justify-content:center; }
.justify-between{ justify-content:space-between; }
.justify-start{ justify-content:flex-start; }
.justify-end{ justify-content:flex-end; }
.gap-1{gap:var(--sp-1);} .gap-2{gap:var(--sp-2);} .gap-3{gap:var(--sp-3);}
.gap-4{gap:var(--sp-4);} .gap-5{gap:var(--sp-5);} .gap-6{gap:var(--sp-6);}

/* ---- Texte ---- */
.text-sm{ font-size:var(--text-sm); }
.text-base{ font-size:var(--text-base); }
.text-md{ font-size:var(--text-md); }
.text-lg{ font-size:var(--text-lg); }
.text-xl{ font-size:var(--text-xl); }
.font-semibold{ font-weight:600; }
.font-bold{ font-weight:700; }
.text-left{ text-align:left; }
.text-center{ text-align:center; }
.text-right{ text-align:right; }