/* =========================================================
   PAS À PAS — Thème global (rose + bleu du logo)
   ========================================================= */
:root{

  --bg:#fff7fb;
  --panel:#ffffff;
  --ink:#101218;
  --muted:#5f6673;

  --rose-050:#fdeff5;
  --rose-100:#f9dee9;
  --rose-200:#ffd0e3;
  --rose-300:#ffb4d3;
  --rose-500:#ec4899; 
  --rose-600:#db2777;

  --blue-050:#eef6ff;
  --blue-100:#dbeafe;
  --blue-200:#bfdbfe;
  --blue-300:#93c5fd;
  --blue-500:#3b82f6; 
  --blue-600:#2563eb;


  --ring: 0 0 0 3px rgba(236,72,153,.25);
  --radius: 22px;
  --container: min(1120px, 92vw);
  --shadow-pill: 0 8px 0 rgba(236,72,153,.18);
  --shadow:0 10px 28px rgba(236,72,153,.16);

  
  --field-radius:16px;
  --shadow-wrap:0 40px 70px rgba(0,0,0,.18);
  --shadow-field:0 3px 0 #cfd5df inset, 0 1px 0 rgba(16,18,24,.04);
  --ok-500:#16a34a; --ok-600:#15803d;
  --err-500:#ef4444; --err-600:#dc2626;
}

/* =========================================================
   Reset minimal
   ========================================================= */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0; font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--ink); background:var(--bg);
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
a{color:inherit; text-decoration:none}
img{max-width:100%; height:auto; display:block}
html { scroll-behavior: smooth; }

/* =========================================================
   Header / Nav
   ========================================================= */
.site-header{
  position:sticky; top:0; z-index:50;
  backdrop-filter:saturate(120%) blur(8px);
  background:linear-gradient(180deg,rgba(255,247,251,.9),rgba(255,247,251,.65) 70%,transparent);
  border-bottom:1px solid rgba(16,18,24,.06);
}
.nav{
  width:var(--container); margin-inline:auto;
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 0;
}
.brand{display:flex; align-items:center; gap:12px; font-weight:800; letter-spacing:.2px}
.brand img{width:96px; height:48px; object-fit:contain}
.menu{display:flex; align-items:center; gap:18px}


.menu a{
  padding:12px 22px; border-radius:999px; font-weight:700;
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease, color .2s ease, border-color .2s ease;
  line-height:1;
}
.menu a:focus-visible{outline:none; box-shadow:var(--ring)}


.ghost{
  background:#fff;
  border:2px solid var(--rose-300);
  color:var(--rose-600);
  box-shadow:var(--shadow-pill);
}
.ghost:hover{
  background:#fff;
  transform:translateY(-1px);
  border-color:var(--rose-500);
  color:var(--rose-600);
}
.ghost:active{transform:translateY(0)}


.cta{
  background:linear-gradient(180deg,var(--rose-500),var(--rose-600));
  color:#fff; border:2px solid transparent; box-shadow:var(--shadow-pill);
}
.cta:hover{transform:translateY(-1px)}
.cta:active{transform:translateY(0)}


.btn-blue{
  background:linear-gradient(180deg,var(--blue-500),var(--blue-600));
  color:#fff; border:2px solid transparent; box-shadow:0 8px 0 rgba(59,130,246,.18);
}
.btn-blue:hover{transform:translateY(-1px)}
.cta-duo{
  background:linear-gradient(90deg,var(--rose-500),var(--blue-500));
  color:#fff; border:2px solid transparent; box-shadow:0 8px 20px rgba(236,72,153,.25);
}


.burger{
  display:none; width:44px; height:44px; border-radius:12px;
  border:1px solid rgba(16,18,24,.08); background:#fff;
}
.burger:focus-visible{outline:none; box-shadow:var(--ring)}
.burger svg{width:22px; height:22px}


.overlay{
  position:fixed; inset:0; background:rgba(16,18,24,.32);
  opacity:0; pointer-events:none; transition:opacity .25s ease; z-index:60;
}
.overlay[hidden]{ display:none; }           
#overlay{ z-index:60; }                      

.drawer{
  position:fixed; top:0; right:-360px; width:min(86vw,340px); height:100dvh;
  background:#fff; box-shadow:-30px 0 60px rgba(0,0,0,.08);
  border-left:1px solid rgba(16,18,24,.06);
  transition:right .25s ease; z-index:70; display:flex; flex-direction:column;
}
.drawer header{display:flex; align-items:center; justify-content:space-between; padding:18px 18px; border-bottom:1px solid rgba(16,18,24,.06)}
.drawer nav{display:grid; gap:12px; padding:16px}
.drawer a{
  padding:12px 18px; border-radius:999px; font-weight:700; line-height:1;
  border:2px solid var(--rose-300); color:var(--rose-600); background:#fff; box-shadow:var(--shadow-pill);
}
.drawer a:hover{border-color:var(--rose-500)}
.drawer .cta{background:linear-gradient(180deg,var(--rose-500),var(--rose-600)); color:#fff; border-color:transparent}

.open .overlay{opacity:1; pointer-events:auto}
.open .drawer{right:0}
.open body, body.open{overflow:hidden; height:100dvh}

/* =========================================================
   Hero
   ========================================================= */
.hero{
  width:var(--container); margin:28px auto 40px; display:grid; gap:36px;
  grid-template-columns: 1.15fr .85fr; align-items:center;
}
.eyebrow{font-size:clamp(34px,5.2vw,56px); font-weight:800; letter-spacing:-.6px; margin:8px 0 18px}
.eyebrow strong{color:var(--rose-600)}


/* Harmonisation des couleurs selon le logo Pas à Pas */
.eyebrow .ppp .p-rose {
  color: var(--rose-500); /* rose logo ex: #ec4899 */
}
.eyebrow .ppp .p-bleu {
  color: var(--blue-500); /* bleu logo ex: #3b82f6 */
}
.eyebrow .ppp .p-noir {
  color: var(--ink); /* noir du texte global ex: #101218 */
}

/* Style général */
.eyebrow .ppp span {
  font-weight: 800;
  letter-spacing: -0.3px;
}



.title{font-size:clamp(28px,3.6vw,40px); line-height:1.1; font-weight:800; margin:0 0 12px}
.lead{font-size:clamp(18px,2.1vw,22px); color:var(--ink); margin:0 0 14px}
.copy{color:var(--muted); font-size:clamp(16px,1.7vw,18px); line-height:1.65; margin:0 0 8px}

.actions{display:flex; gap:14px; margin-top:22px; flex-wrap:wrap}
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:14px 20px; border-radius:999px; font-weight:700; border:0; cursor:pointer;
  transition:transform .2s ease, box-shadow .2s ease; text-decoration:none;
}
.btn:focus-visible{outline:none; box-shadow:var(--ring)}
.btn-primary{background:linear-gradient(180deg,var(--rose-500),var(--rose-600)); color:#fff; box-shadow:var(--shadow-pill)}
.btn-primary:hover{transform:translateY(-1px)}
.btn-secondary{background:#fff; border:2px solid var(--rose-300); color:var(--rose-600); box-shadow:var(--shadow-pill)}

.media{
  background:linear-gradient(180deg,rgba(255,180,211,.25),rgba(255,247,251,1));
  padding:14px; border-radius:calc(var(--radius) + 6px);
}
.media img{ border-radius:var(--radius); aspect-ratio: 16/11; object-fit:cover; }

.skip{position:absolute; left:-9999px}
.skip:focus{
  left:12px; top:12px; background:#fff; padding:10px 14px;
  border-radius:10px; box-shadow:0 6px 20px rgba(0,0,0,.15); z-index:100
}

/* =========================================================
   Bande 1 : Topbar (compte à rebours + alerte)
   ========================================================= */
.topbar{
  width:var(--container); margin:38px auto 0;
  display:grid; align-items:center; column-gap:24px;
  grid-template-columns: 1fr auto auto;
}
.topbar h1{margin:0; font-size:clamp(22px,3.2vw,34px); font-weight:900}
.countdown{display:flex; gap:16px; align-items:center; justify-content:center}
.time-box{
  background:var(--panel); border:1px solid var(--rose-300);
  border-radius:16px; padding:12px 18px; text-align:center; box-shadow:var(--shadow);
  min-width:92px;
}
.time-box strong{display:block; font-size:22px; font-weight:900; color:var(--rose-600)}
.time-box span{font-size:13px; font-weight:700; color:var(--rose-500)}
.alert-btn{
  display:inline-flex; align-items:center; gap:8px; padding:12px 20px;
  border-radius:999px; background:var(--blue-500); color:#fff;
  font-weight:800; box-shadow:0 10px 24px rgba(37,99,235,.22); white-space:nowrap; justify-self:end;
  transition:transform .2s ease;
}
.alert-btn:hover{transform:translateY(-1px)}
.alert-btn:focus-visible{outline:none; box-shadow:0 0 0 3px rgba(59,130,246,.25)}

/* =========================================================
   Bande 2 : Brand
   ========================================================= */
.brand-band{
  margin-top:24px; background:var(--rose-100);
  border-top:1px solid rgba(15,17,21,.06);
  border-bottom:1px solid rgba(15,17,21,.06);
}
.brand-wrap{
  width:var(--container); margin:0 auto; padding:18px 0 22px;
  display:flex; flex-direction:column; align-items:center; text-align:center; gap:6px;
}
.brand-logo{
  height:92px; width:auto; object-fit:contain;
  border-radius:20px; border:4px solid #fff; box-shadow:0 6px 24px rgba(0,0,0,.08);
}
.brand-title{
  font-size:clamp(32px,5vw,56px); line-height:1; font-weight:900; letter-spacing:.2px;
  margin:6px 0 4px;
  background:linear-gradient(90deg,var(--rose-500),var(--blue-500));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.brand-sub{margin:0; color:#333; font-weight:800; font-size:clamp(14px,1.6vw,18px)}

/* =========================================================
   Cartes texte (about)
   ========================================================= */
.about-cards{background:#f7e9f0; padding:28px 0 36px}
.ac-wrap{width:var(--container); margin:0 auto; display:grid; gap:18px}
.ac-card{
  background:#fff; border-radius:18px; box-shadow:0 10px 26px rgba(0,0,0,.08);
  padding:22px 26px;
}
.ac-card h2{margin:0 0 10px; font-weight:900; font-size:clamp(22px,3vw,28px)}
.ac-card p{margin:0 0 10px; line-height:1.7; font-size:18px}
.ac-card .hl{color:#c4296b; font-weight:800}
.ac-list{margin:4px 0 0; padding-left:22px; display:grid; gap:6px}
.ac-list li{font-size:18px; line-height:1.7}
.ac-card--callout{padding-top:18px; padding-bottom:18px}
.ac-link{color:var(--blue-600); font-weight:800; text-decoration:underline; text-underline-offset:3px}

/* =========================================================
   Programme
   ========================================================= */
.section-program{position:relative; isolation:isolate; padding:48px 0 64px; overflow:hidden}
.pg-bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    linear-gradient(180deg, rgba(59,130,246,0.75), rgba(37,99,235,0.78) 60%, rgba(29,78,216,0.85)),
    radial-gradient(1200px 600px at 40% 20%, rgba(147,197,253,0.35), transparent 60%),
    url('/assets/bg-program.png') center/cover no-repeat;
}

.pg-wrap{width:var(--container); margin:0 auto; display:grid; grid-template-columns: 1.1fr .9fr; gap:28px}
.pg-left{display:grid; gap:22px}
.pg-card{
  display:grid; grid-template-columns:64px 1fr; gap:18px; align-items:center;
  background:#fff; border-radius:28px; padding:26px 28px; box-shadow:0 20px 40px rgba(0,0,0,.15)
}
.pg-ico{width:64px; height:64px; border-radius:999px; display:grid; place-items:center; background:linear-gradient(180deg,#ffe6f2,#fff); border:1px solid var(--rose-300); color:var(--rose-600)}
.pg-ico svg{width:34px; height:34px}
.pg-txt h3{margin:0 0 6px; font-size:clamp(20px,2.6vw,28px); line-height:1.1}
.pg-txt p{margin:0; color:#6c7380; font-weight:600}
.pg-right{background:#fff; border-radius:28px; padding:28px 28px 8px; box-shadow:0 20px 40px rgba(0,0,0,.15)}
.pg-right h2{margin:0; font-size:clamp(26px,3.2vw,40px)}
.pg-sub{margin:6px 0 16px; color:var(--muted); font-weight:600}
.pg-steps{list-style:none; margin:0; padding:8px 0 8px; display:grid; gap:18px}
.pg-step{display:grid; grid-template-columns:auto 1fr; gap:16px; align-items:start}
.pg-step h4{margin:0 0 6px; font-size:18px}
.pg-step p{margin:0; color:#4b5563}
.pg-pill{
  display:inline-flex; align-items:center; justify-content:center; padding:8px 14px; border-radius:999px;
  background:#fff; border:1.5px solid var(--rose-300); color:var(--rose-600); font-weight:800; min-width:88px;
  box-shadow:0 6px 18px rgba(236,72,153,.18)
}

.pg-pill.pg-pill--blue{
  border-color:var(--blue-300); color:var(--blue-600);
  box-shadow:0 6px 18px rgba(59,130,246,.18)
}

/* =========================================================
   Features
   ========================================================= */
.features{padding:36px 0 8px}
.features-wrap{width:var(--container); margin:0 auto}
.features h2{text-align:center; font-size:clamp(26px,4.2vw,40px); font-weight:900; margin:8px 0 24px}
.feat-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:22px}
.feat-card{
  background:#fff; border-radius:20px; padding:26px 20px; text-align:center;
  box-shadow:0 18px 38px rgba(0,0,0,.12); transition:transform .18s ease, box-shadow .18s ease
}
.feat-card:hover{transform:translateY(-2px); box-shadow:0 22px 46px rgba(0,0,0,.14)}
.feat-ico{width:64px; height:64px; margin:0 auto 10px; border-radius:999px; display:grid; place-items:center; background:linear-gradient(180deg,#eaf2ff,#fff); border:1px solid var(--blue-300); color:var(--blue-600)}
.feat-ico svg{width:34px; height:34px}
.feat-card h3{margin:6px 0 6px; font-size:18px}
.feat-card p{margin:0; color:#9aa2ac; font-weight:600; line-height:1.6; font-size:15px}

/* =========================================================
   Sponsors
   ========================================================= */
.sponsors{padding:10px 0 28px}
.spon-wrap{width:var(--container); margin:0 auto}
.sponsors h3{text-align:center; font-size:clamp(22px,3.4vw,34px); font-weight:900; margin:10px 0 16px}
.spon-strip{
  background:#f3f4f6; border-top:1px solid rgba(0,0,0,.06); border-bottom:1px solid rgba(0,0,0,.06);
  border-radius:12px; padding:14px 12px; display:grid; grid-template-columns:repeat(6,1fr); gap:14px;
  align-items:center; justify-items:center
}
.spon-strip img{max-height:54px; width:auto; object-fit:contain; filter:saturate(1.05) contrast(1.02)}

/* =========================================================
   FOOTER (global)
   ========================================================= */
.site-footer{
  max-width:var(--container); margin:36px auto 18px; padding:12px min(24px,3vw);
  border-radius:16px;
  background:linear-gradient(90deg,var(--rose-500),var(--blue-500) 35%,var(--blue-600) 65%,var(--rose-600));
  color:#fff; box-shadow:0 10px 30px rgba(59,130,246,.18)
}
.site-footer a{color:#fff;text-decoration:none}
.site-footer a:hover{text-decoration:underline}

/* =========================================================
   FORMULAIRE 
   ========================================================= */
.sheet{
  width:var(--container);margin:34px auto;background:var(--panel);
  border-radius:34px;display:grid;grid-template-columns:1.1fr .9fr;overflow:hidden;box-shadow:var(--shadow-wrap)
}
.form-side{padding:34px clamp(18px,3.6vw,46px)}
.p-media{min-height:560px;background:#ddd url('/assets/women.png') center/cover no-repeat}

h1{font-size:clamp(28px,3.6vw,44px);margin:0 0 6px;letter-spacing:.2px}
.lead{margin:0 0 22px;color:#241222;font-weight:600;font-size:clamp(16px,1.8vw,18px)}

.row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{margin:0 0 16px}
.label{display:block;font-weight:800;margin:8px 0 10px}
.ctrl{
  position:relative;display:flex;align-items:center;gap:10px;background:#fff;border:1.6px solid #d8dde5;border-radius:var(--field-radius);
  padding:13px 14px;box-shadow:var(--shadow-field);transition:box-shadow .15s ease,border-color .15s ease,transform .05s ease
}
.ctrl:focus-within{border-color:#c3c9d7;box-shadow:var(--shadow-field),var(--ring)}
.ctrl input,.ctrl select{width:100%;border:0;outline:0;background:transparent;font:inherit;color:var(--ink)}
.ctrl.select{padding-right:38px}
.ctrl.select:after{content:"▾";position:absolute;right:14px;top:50%;transform:translateY(-50%);color:#9aa2ac;font-size:14px;pointer-events:none}
.icon{width:22px;height:22px;color:#a72e61;flex:0 0 22px}
.hint{font-size:13.5px;color:var(--muted)}
.error-msg{font-size:13px;color:#b00020;margin-top:6px;display:none}
.invalid .ctrl{border-color:#ff9494;box-shadow:0 0 0 3px rgba(255,0,0,.1),var(--shadow-field)}
.invalid .error-msg{display:block}

.checks{display:flex;gap:22px;align-items:center;margin:6px 0 4px}
.check{display:inline-flex;align-items:center;gap:10px;font-weight:800;cursor:pointer;user-select:none}
.check input{
  appearance:none;width:22px;height:22px;border:2.2px solid var(--rose-500);border-radius:6px;display:grid;place-items:center;background:#fff;
  transition:background .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.check input:focus-visible{outline:none;box-shadow:0 0 0 3px rgba(236,72,153,.25)}
.check input:checked{background:var(--rose-500);border-color:var(--rose-600)}
.check input:checked::after{
  content:"";width:12px;height:12px;
  mask: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 20 20" fill="white"><path d="M7.629 13.314l-3.3-3.3-1.414 1.414 4.714 4.714 9.193-9.193-1.414-1.414z"/></svg>') center/contain no-repeat;
  background:#fff;
}

.actions{display:flex;gap:16px;align-items:center;margin-top:10px}
.btn.ok{background:var(--ok-500);color:#fff}
.btn.err{background:var(--err-500);color:#fff}
.btn.ghost{background:#111827;color:#fff}

/* =========================================================
   Overlays & Modals
   ========================================================= */

.modal{
  background:#fff; padding:18px; border-radius:12px; max-width:520px; width:100%;
  box-shadow:0 10px 30px rgba(0,0,0,.2);
}

#pay-overlay{
  position:fixed; inset:0;
  display:flex; align-items:center; justify-content:center;
  background:rgba(0,0,0,.4);
  z-index:80;                 
  padding:16px;
}
#pay-overlay[hidden]{ display:none; }

#pay-modal:focus { outline: 3px solid rgba(59,130,246,.45); outline-offset: 2px; }
button[disabled]{ opacity:.6; pointer-events:none; }


#confetti{position:fixed;inset:0;pointer-events:none;z-index:90;display:none}

/* =========================================================
   SECTION INSCRIPTION — 
   ========================================================= */
.pasins{
  --bg:#fff7fb; --panel:#ffffff; --ink:#0f1115; --muted:#6b7280;
  --rose-100:#ffe4f0; --rose-300:#ffb4d3; --rose-500:#ec4899; --rose-600:#db2777;
  --blue-300:#93c5fd; --blue-500:#3b82f6; --blue-600:#2563eb;
  --radius:26px; --field-radius:16px; --container:min(1240px, 94vw);
  --shadow-wrap:0 40px 70px rgba(0,0,0,.18);
  --shadow-field:0 3px 0 #cfd5df inset, 0 1px 0 rgba(16,18,24,.04);
  --ring: 0 0 0 3px rgba(236,72,153,.18);
}
.pasins *{box-sizing:border-box}

.pasins .pasins-sheet{
  width:var(--container); margin:34px auto; background:var(--panel);
  border-radius:34px; display:grid; grid-template-columns:1.1fr .9fr;
  overflow:hidden; box-shadow:var(--shadow-wrap);
}
.pasins .pasins-form-side{ padding:34px clamp(18px,3.6vw,46px) }
.pasins .pasins-media{
  min-height:560px; background:#ddd url('/assets/f.png') center/cover no-repeat;
}

.pasins h1{ font-size:clamp(28px,3.6vw,44px); margin:0 0 6px; letter-spacing:.2px }
.pasins .pasins-lead{ margin:0 0 22px; color:#241222; font-weight:600; font-size:clamp(16px,1.8vw,18px) }

.pasins .pasins-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px }
.pasins .pasins-field{ margin:0 0 16px }
.pasins .pasins-label{ display:block; font-weight:800; margin:8px 0 10px }
.pasins .pasins-ctrl{
  position:relative; display:flex; align-items:center; gap:10px; background:#fff;
  border:1.6px solid #d8dde5; border-radius:var(--field-radius); padding:13px 14px;
  box-shadow:var(--shadow-field); transition:box-shadow .15s ease,border-color .15s ease,transform .05s ease;
}
.pasins .pasins-ctrl:focus-within{ border-color:#c3c9d7; box-shadow:var(--shadow-field),var(--ring) }
.pasins .pasins-ctrl input, .pasins .pasins-ctrl select{
  width:100%; border:0; outline:0; background:transparent; font:inherit; color:var(--ink)
}
.pasins .pasins-ctrl.select{ padding-right:38px }
.pasins .pasins-ctrl.select:after{
  content:"▾"; position:absolute; right:14px; top:50%; transform:translateY(-50%);
  color:#9aa2ac; font-size:14px; pointer-events:none;
}
.pasins .pasins-icon{ width:22px; height:22px; color:#a72e61; flex:0 0 22px }
.pasins .pasins-hint{ font-size:13.5px; color:var(--muted) }
.pasins .pasins-error{ font-size:13px; color:#b00020; margin-top:6px; display:none }
.pasins .invalid .pasins-ctrl{ border-color:#ff9494; box-shadow:0 0 0 3px rgba(255,0,0,.1),var(--shadow-field) }
.pasins .invalid .pasins-error{ display:block }

.pasins .pasins-checks{ display:flex; gap:22px; align-items:center; margin:6px 0 4px }
.pasins .pasins-check{ display:inline-flex; align-items:center; gap:8px; font-weight:800; cursor:pointer }
.pasins .pasins-check input{
  appearance:none; width:18px; height:18px; border:2px solid var(--rose-500); border-radius:4px; display:grid; place-items:center;
}
.pasins .pasins-check input:checked{ background:var(--rose-500) }
.pasins .pasins-check input:checked::after{ content:""; width:10px; height:10px; background:#fff }

.pasins .pasins-actions{ display:flex; gap:16px; align-items:center; margin-top:10px }
.pasins .pasins-btn{
  display:inline-flex; justify-content:center; align-items:center; gap:10px;
  padding:16px 26px; border-radius:999px; border:0; cursor:pointer;
  background:var(--blue-500); color:#fff; font-weight:900; letter-spacing:.2px; min-width:260px;
  box-shadow:0 14px 30px rgba(59,130,246,.28); transition:transform .15s ease,box-shadow .15s ease;
}
.pasins .pasins-btn:hover{ transform:translateY(-1px); box-shadow:0 18px 36px rgba(59,130,246,.34) }
.pasins .pasins-btn:focus-visible{ outline:none; box-shadow:0 0 0 3px rgba(59,130,246,.25),0 14px 30px rgba(59,130,246,.28) }

.pasins .pasins-overlay{
  position:fixed; inset:0; background:rgba(0,0,0,.35);
  display:none; align-items:center; justify-content:center; z-index:80;
}
.pasins .pasins-modal{
  background:#fff; border-radius:20px; max-width:520px; width:min(92vw,520px);
  padding:22px; box-shadow:0 30px 80px rgba(0,0,0,.25); text-align:center;
}
.pasins .pasins-modal h3{ margin:0 0 10px; font-size:22px }
.pasins .pasins-modal p{ margin:0 0 14px; color:#374151 }
.pasins .ok{ background:var(--ok-500) }
.pasins .err{ background:var(--err-500) }
.pasins .close{ margin-top:6px; background:#111827 }

.pasins #pasins-confetti{ position:fixed; inset:0; pointer-events:none; z-index:90; display:none }

.pasins .site-footer{
  margin-top:36px;
  background:linear-gradient(90deg, var(--rose-500), var(--blue-500) 35%, var(--blue-600) 65%, var(--rose-600));
  color:#fff; border-radius:14px; box-shadow:0 10px 30px rgba(59,130,246,.25) inset;
}
.pasins .foot-wrap{
  max-width:min(1180px, 92vw); margin:0 auto; padding:10px min(24px, 3vw);
  display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:12px;
}
.pasins .foot-left,.pasins .foot-center,.pasins .foot-right{ display:flex; align-items:center; gap:8px; min-width:0 }
.pasins .foot-left{ font-weight:700; white-space:nowrap }
.pasins .foot-center{ justify-content:center; text-align:center; font-weight:800 }
.pasins .foot-right{ justify-content:flex-end; gap:10px; font-weight:800 }
.pasins .site-footer a{ color:#fff; text-decoration:none; position:relative }
.pasins .site-footer a:focus-visible{ outline:none; box-shadow:0 0 0 3px rgba(255,255,255,.5); border-radius:6px }
.pasins .site-footer a:hover{ text-decoration:underline }
.pasins .dot{ opacity:.9 }

/* =========================================================
   Responsive
   ========================================================= */
@media (max-width: 1100px){
  .feat-grid{grid-template-columns:repeat(3,1fr)}
  .spon-strip{grid-template-columns:repeat(4,1fr)}
}
@media (max-width: 980px){
  .menu{display:none}
  .burger{display:inline-grid; place-items:center}
  .hero{grid-template-columns:1fr; gap:28px}
  .media{order:-1}
  .pg-wrap{grid-template-columns:1fr; gap:22px}
  .sheet{grid-template-columns:1fr}
  .p-media{min-height:280px;order:-1}
  .pasins .pasins-sheet{ grid-template-columns:1fr }
  .pasins .pasins-media{ min-height:280px; order:-1 }
}
@media (max-width: 820px){
  .pasins .foot-wrap{ grid-template-columns:1fr; text-align:center; row-gap:6px }
  .pasins .foot-left{ order:2 } .pasins .foot-center{ order:1 } .pasins .foot-right{ order:3 }
}
@media (max-width: 780px){
  .feat-grid{grid-template-columns:repeat(2,1fr)}
  .spon-strip{grid-template-columns:repeat(3,1fr)}
}
@media (max-width: 640px){
  .topbar{grid-template-columns:1fr; row-gap:16px; text-align:center}
  .alert-btn{justify-self:center}
  .time-box{min-width:80px}
}
@media (max-width: 520px){
  .feat-grid{grid-template-columns:1fr}
  .spon-strip{grid-template-columns:repeat(2,1fr)}
}
@media (prefers-reduced-motion: reduce){
  *{animation:none !important; transition:none !important}
}

/* =========================================================
   États & aides formulaire
   ========================================================= */
.avail-ok .ctrl input { outline: 2px solid #1aa34a; }
.avail-bad .ctrl input { outline: 2px solid #d32f2f; }
#avail-msg.ok { color: #1aa34a; }
#avail-msg.err { color: #d32f2f; }
.invalid .error-msg { display:block; }

/* =========================================================
   Boutons génériques (formulaire)
   ========================================================= */
.btn{
  --btn-bg: var(--rose-500, #ec4899);
  --btn-bg-hover: var(--rose-600, #db2777);
  --btn-ink: #fff;
  --btn-ring: var(--ring, 0 0 0 3px rgba(236,72,153,.25));

  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;

  min-height: 44px;
  padding: 10px 16px;
  border: 0;
  border-radius: var(--radius, 12px);

  background: var(--btn-bg);
  color: var(--btn-ink);
  font-weight: 700;
  line-height: 1;
  cursor: pointer;
  user-select: none;

  box-shadow: var(--shadow-pill, 0 8px 0 rgba(236,72,153,.18));
  transition: transform .06s ease, box-shadow .2s ease, background-color .2s ease, opacity .2s ease;
}
.btn:hover{
  background: var(--btn-bg-hover);
  box-shadow: 0 10px 0 rgba(219,39,119,.22);
}
.btn:focus-visible{
  outline: none;
  box-shadow:
    0 10px 0 rgba(219,39,119,.22),
    var(--btn-ring);
}
.btn:active{
  transform: translateY(1px);
  box-shadow: 0 7px 0 rgba(219,39,119,.22);
}
.btn[disabled],
.btn:disabled{
  opacity: .6;
  cursor: not-allowed;
  box-shadow: none;
}
.btn-secondary{
  --btn-bg: var(--blue-500, #3b82f6);
  --btn-bg-hover: var(--blue-600, #2563eb);
  --btn-ink: #fff;
  box-shadow: 0 8px 0 rgba(59,130,246,.18);
}
.btn > svg{
  width: 18px; height: 18px;
}
@media (prefers-reduced-motion: reduce){
  .btn{ transition: none; }
}


.sr-only {
  position: absolute !important;
  width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden;
  clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}


.sponsor-marquee{
  --bg1: rgba(255,180,211,.12); 
  --bg2: rgba(59,130,246,.10); 
  --ring: 0 0 0 3px rgba(59,130,246,.22);
  padding: 24px 0;
  background: linear-gradient(180deg, var(--bg1), var(--bg2));
  border-top: 1px solid rgba(16,18,24,.06);
  border-bottom: 1px solid rgba(16,18,24,.06);
}

.sponsor-marquee .marquee{
  width: min(1120px, 92vw);
  margin: 0 auto;
  overflow: hidden;
  border-radius: 18px;
  border: 1px solid rgba(16,18,24,.06);
  background: rgba(255,255,255,.72);

  -webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
          mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
}


.sponsor-marquee .track{
  display: flex;
  align-items: center;
  gap: clamp(24px, 4vw, 40px);
  padding: 14px clamp(16px, 3vw, 24px);

  animation: marquee-scroll 28s linear infinite;
  will-change: transform;
}


.sponsor-marquee .marquee:hover .track,
.sponsor-marquee .marquee:focus-within .track{
  animation-play-state: paused;
}


.sponsor-marquee .logo{
  flex: 0 0 auto;
  height: clamp(72px, 11vw, 88px);
  width: clamp(132px, 20vw, 180px);
  display: grid; place-items: center;
  background: #fff;
  border: 1px solid rgba(16,18,24,.06);
  border-radius: 16px;
  box-shadow: 0 1px 0 rgba(16,18,24,.02), 0 12px 28px rgba(16,18,24,.06);
  transition: transform .18s ease, box-shadow .18s ease, filter .18s ease, opacity .18s ease;
  filter: grayscale(.12) saturate(.9);
  opacity: .95;
}
.sponsor-marquee .logo:focus-within{
  box-shadow: var(--ring);
}
.sponsor-marquee .logo:hover{
  transform: translateY(-2px);
  filter: none; opacity: 1;
}

.sponsor-marquee .logo img{
  max-height: 54px; width: auto; max-width: 90%;
  object-fit: contain; display: block;
}

@keyframes marquee-scroll{
  from{ transform: translateX(0); }
  to  { transform: translateX(-50%); }
}

@media (prefers-reduced-motion: reduce){
  .sponsor-marquee .track{ animation: none; }
}



/* =========================================================
   ANIMATIONS
   ========================================================= */


@media (prefers-reduced-motion:no-preference){
  .menu .cta.btn{
    position:relative; isolation:isolate;
    animation:cta-breathe 3.2s ease-in-out infinite;
    will-change:transform, box-shadow;
  }
  .menu .cta.btn::after{
    content:""; position:absolute; inset:0; pointer-events:none; border-radius:inherit;
    background:linear-gradient(120deg,transparent 0%,rgba(255,255,255,.35) 35%,transparent 70%);
    transform:skewX(-18deg) translateX(-120%);
    animation:cta-shine 10s ease-in-out infinite;
  }
  @keyframes cta-breathe{
    0%,100%{ transform:none; box-shadow:0 6px 18px rgba(236,72,153,.20) }
    50%    { transform:scale(1.045); box-shadow:0 12px 28px rgba(236,72,153,.30) }
  }
  @keyframes cta-shine{
    0%,94%  { transform:skewX(-18deg) translateX(-120%) }
    98%,100%{ transform:skewX(-18deg) translateX(120%) }
  }
  .menu .cta.btn:hover,
  .menu .cta.btn:focus-visible{
    animation-play-state:paused;
    transform:translateY(-1px) scale(1.04);
    box-shadow:0 16px 38px rgba(236,72,153,.36);
  }
  .menu .cta.btn:active{ transform:translateY(0) scale(.98) }
}
.menu .cta.btn:focus-visible{ outline:none; box-shadow:0 0 0 3px rgba(59,130,246,.45) }


:where(.ac-card,.pg-card,.feat-card){ transition:transform .25s ease, box-shadow .25s ease }
:where(.ac-card,.pg-card,.feat-card):hover{ transform:translateY(-4px); box-shadow:0 12px 30px rgba(16,18,24,.12) }

.img-zoom{ display:block; overflow:hidden; border-radius:inherit }
.img-zoom img{ display:block; width:100%; height:auto; transition:transform .35s ease }
.img-zoom:hover img{ transform:scale(1.04) }


@media (prefers-reduced-motion:no-preference){
  [data-reveal]{
    opacity:0; transform:translateY(16px);
    transition:opacity .6s ease, transform .6s ease;
    will-change:opacity, transform;
  }
  [data-reveal].in{ opacity:1; transform:none }
}

@media (prefers-reduced-motion:no-preference){
  .time-box strong{
    display:inline-block;
    transform-origin:50% 60%;
    backface-visibility:hidden;
  }

  .time-box strong.flip{
    animation:tick-pop .45s ease both;
  }
  @keyframes tick-pop{
    0%   { transform:translateY(0) scale(1);   opacity:1 }
    40%  { transform:translateY(-4px) scale(1.06); opacity:.85 }
    60%  { transform:translateY(2px) scale(.98);  opacity:.96 }
    100% { transform:translateY(0) scale(1);   opacity:1 }
  }
}

@media (prefers-reduced-motion:no-preference){
  #pay-overlay:not([hidden]){ animation:pay-fade .22s ease both }
  #pay-modal{ transform:scale(.96); opacity:0 }
  #pay-overlay:not([hidden]) #pay-modal{ animation:pay-in .24s ease .02s both }
  @keyframes pay-fade{ from{ background:rgba(0,0,0,.0) } to{ background:rgba(0,0,0,.4) } }
  @keyframes pay-in{ to{ transform:scale(1); opacity:1 } }
}

@media (prefers-reduced-motion:reduce){
  .menu .cta.btn{ animation:none !important }
  .menu .cta.btn::after{ animation:none !important }
  .img-zoom img, [data-reveal], .time-box strong{ transition:none !important; animation:none !important }
}



/* =========================================================
   ANIMATIONS
   ========================================================= */

@media (prefers-reduced-motion:no-preference){

  .menu .cta.btn{
    position:relative; isolation:isolate;
    animation:btn-breathe 3.2s ease-in-out infinite;
    will-change:transform, box-shadow, filter;
  }
  .menu .cta.btn::after{
    content:""; position:absolute; inset:0; border-radius:inherit; pointer-events:none;
    background:linear-gradient(120deg,transparent 0%,rgba(255,255,255,.35) 35%,transparent 70%);
    transform:skewX(-18deg) translateX(-120%);
    animation:btn-shine 10s ease-in-out infinite;
  }

  .btn.btn-primary[href="#inscription"]{
    position:relative; isolation:isolate;
    animation:btn-breathe 3.6s ease-in-out infinite;
  }
  .btn.btn-primary[href="#inscription"]::after{
    content:""; position:absolute; inset:0; border-radius:inherit; pointer-events:none;
    background:linear-gradient(120deg,transparent 0%,rgba(255,255,255,.35) 40%,transparent 70%);
    transform:skewX(-18deg) translateX(-120%);
    animation:btn-shine 11s ease-in-out infinite;
  }

  .form-side form .btn[type="submit"]{
    position:relative; isolation:isolate;
    animation:btn-breathe 3.8s ease-in-out infinite;
  }
  .form-side form .btn[type="submit"]::after{
    content:""; position:absolute; inset:0; border-radius:inherit; pointer-events:none;
    background:linear-gradient(120deg,transparent 0%,rgba(255,255,255,.30) 40%,transparent 70%);
    transform:skewX(-18deg) translateX(-120%);
    animation:btn-shine 12s ease-in-out infinite;
  }

  @keyframes btn-breathe{
    0%,100%{ transform:none; box-shadow:0 8px 0 rgba(236,72,153,.18) }
    50%{ transform:scale(1.04); box-shadow:0 14px 24px rgba(236,72,153,.28) }
  }
  @keyframes btn-shine{
    0%,94%{ transform:skewX(-18deg) translateX(-120%) }
    98%,100%{ transform:skewX(-18deg) translateX(120%) }
  }
}

.menu .cta.btn:focus-visible,
.btn.btn-primary[href="#inscription"]:focus-visible,
.form-side form .btn[type="submit"]:focus-visible{
  outline:none; box-shadow:0 0 0 3px rgba(59,130,246,.45), 0 12px 28px rgba(16,18,24,.16);
}


:where(.ac-card,.pg-card,.feat-card){
  transition:transform .25s ease, box-shadow .25s ease, filter .25s ease;
}
:where(.ac-card,.pg-card,.feat-card):hover{
  transform:translateY(-4px);
  box-shadow:0 16px 38px rgba(16,18,24,.14);
}
.img-zoom{ display:block; overflow:hidden; border-radius:inherit }
.img-zoom img{ display:block; width:100%; height:auto; transition:transform .35s ease }
.img-zoom:hover img{ transform:scale(1.04) }

/* --------- Révélation au scroll (progressive enhancement) --------- */
@media (prefers-reduced-motion:no-preference){
  .reveal{ opacity:0; transform:translateY(16px); }
  .reveal.in{ opacity:1; transform:none; transition:opacity .6s ease, transform .6s ease; }
}

/* --------- Micro-parallaxe optionnelle --------- */
@media (prefers-reduced-motion:no-preference){
  [data-parallax]{ --pary:0px; will-change:transform; transform:translateY(var(--pary)); }
}

/* --------- Ripple au clic (sur .btn) --------- */
.btn{
  --ripple-x:50%; --ripple-y:50%; --ripple-s:0; --ripple-a:0;
  position:relative; overflow:hidden;
}
.btn::before{
  content:""; position:absolute; left:var(--ripple-x); top:var(--ripple-y);
  width:var(--ripple-s); height:var(--ripple-s); transform:translate(-50%,-50%);
  border-radius:50%;
  background:currentColor; opacity:var(--ripple-a);
  pointer-events:none;
}
@media (prefers-reduced-motion:no-preference){
  .btn.rippling::before{
    animation:ripple .6s ease-out forwards;
  }
  @keyframes ripple{
    0%   { width:0; height:0; opacity:.18 }
    60%  { opacity:.14 }
    100% { width:360px; height:360px; opacity:0 }
  }
}

/* --------- Countdown : "tick-pop"  --------- */
@media (prefers-reduced-motion:no-preference){
  .time-box strong{ display:inline-block; transform-origin:50% 60%; backface-visibility:hidden; }
  .time-box strong.flip{ animation:tick-pop .45s ease both; }
  @keyframes tick-pop{
    0%{ transform:translateY(0) scale(1); opacity:1 }
    40%{ transform:translateY(-4px) scale(1.06); opacity:.85 }
    60%{ transform:translateY(2px) scale(.98); opacity:.96 }
    100%{ transform:translateY(0) scale(1); opacity:1 }
  }
}

/* --------- Modal paiement : apparition douce --------- */
@media (prefers-reduced-motion:no-preference){
  #pay-overlay:not([hidden]){ animation:pay-fade .22s ease both }
  #pay-modal{ transform:scale(.96); opacity:0 }
  #pay-overlay:not([hidden]) #pay-modal{ animation:pay-in .24s ease .02s both }
  @keyframes pay-fade{ from{ background:rgba(0,0,0,0) } to{ background:rgba(0,0,0,.4) } }
  @keyframes pay-in{ to{ transform:scale(1); opacity:1 } }
}

/* --------- Accessibilité --------- */
@media (prefers-reduced-motion:reduce){
  .menu .cta.btn,
  .btn.btn-primary[href="#inscription"],
  .form-side form .btn[type="submit"]{ animation:none !important }
  .btn::before{ display:none !important }
}



