/* ============================================================
   VakxTech — Feuille de style (noir & blanc, pro)
   ============================================================ */
:root{
  --noir:#0a0a0a;
  --noir-2:#161616;
  --gris-9:#1f1f1f;
  --gris-7:#4a4a4a;
  --gris-5:#8a8a8a;
  --gris-3:#cfcfcf;
  --gris-1:#f4f4f4;
  --blanc:#ffffff;
  --bord:#e4e4e4;
  --ombre:0 1px 2px rgba(0,0,0,.06),0 8px 24px rgba(0,0,0,.06);
  --r:14px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  color:var(--noir);
  background:var(--blanc);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
.container{max-width:1100px;margin:0 auto;padding:0 24px}
a{color:inherit}
h1,h2,h3,h4{font-family:'Space Grotesk','Inter',sans-serif;line-height:1.15;letter-spacing:-.02em}
.muted{color:var(--gris-5)}

/* ── Bandeau annonce ──────────────────────────────────── */
.annonce-bar{background:var(--noir);color:#fff;font-size:14.5px}
.annonce-inner{display:flex;align-items:center;gap:14px;padding:10px 24px;flex-wrap:wrap}
.annonce-txt{font-weight:500}
.annonce-lien{color:#fff;font-weight:700;text-decoration:underline;text-underline-offset:3px;white-space:nowrap}
.annonce-lien:hover{opacity:.8}
.annonce-x{margin-left:auto;background:none;border:none;color:var(--gris-5);font-size:16px;cursor:pointer;line-height:1;padding:4px}
.annonce-x:hover{color:#fff}

/* ── Header ───────────────────────────────────────────── */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.85);
  backdrop-filter:saturate(180%) blur(12px);
  border-bottom:1px solid var(--bord);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:70px}
.logo{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:22px;text-decoration:none;display:inline-flex;align-items:center;gap:10px;letter-spacing:-.03em}
.logo-img{width:32px;height:32px;border-radius:50%;display:block;flex:none}
.logo-mark{display:inline-block;font-size:20px}
.nav{display:flex;align-items:center;gap:28px}
.nav a{text-decoration:none;font-weight:500;font-size:15px;color:var(--gris-7);transition:color .2s}
.nav a:hover,.nav a.actif{color:var(--noir)}
.btn-nav{background:var(--noir);color:var(--blanc)!important;padding:10px 18px;border-radius:999px;font-weight:600}
.btn-nav:hover{background:var(--gris-9)}
.nav-toggle{display:none;background:none;border:none;font-size:24px;cursor:pointer}

/* ── Boutons ──────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:10px;background:var(--noir);color:var(--blanc);
  padding:15px 28px;border-radius:999px;text-decoration:none;font-weight:600;border:none;cursor:pointer;
  font-size:16px;transition:transform .15s,background .2s}
.btn:hover{background:var(--gris-9);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--noir);border:1.5px solid var(--noir)}
.btn-ghost:hover{background:var(--noir);color:var(--blanc)}
.btn-block{width:100%;justify-content:center}

/* ── Hero ─────────────────────────────────────────────── */
.hero{padding:90px 0 70px;border-bottom:1px solid var(--bord);position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;
  background-image:radial-gradient(var(--gris-3) 1px,transparent 1px);
  background-size:26px 26px;opacity:.5;mask-image:linear-gradient(180deg,#000,transparent 80%)}
.hero .container{position:relative}
.eyebrow{display:inline-block;font-size:13px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:var(--gris-7);border:1px solid var(--bord);padding:6px 14px;border-radius:999px;background:var(--blanc);margin-bottom:24px}
.hero h1{font-size:clamp(36px,6vw,64px);font-weight:800;max-width:14ch;margin-bottom:22px}
.hero p.lead{font-size:clamp(17px,2.2vw,21px);color:var(--gris-7);max-width:54ch;margin-bottom:34px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}

/* ── Sections ─────────────────────────────────────────── */
.section{padding:80px 0}
.section-alt{background:var(--gris-1)}
.section-titre{font-size:clamp(28px,4vw,40px);font-weight:800;margin-bottom:14px;max-width:18ch}
.section-sous{color:var(--gris-7);font-size:18px;max-width:60ch;margin-bottom:46px}

/* ── Grilles de cartes ────────────────────────────────── */
.grid{display:grid;gap:22px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.card{background:var(--blanc);border:1px solid var(--bord);border-radius:var(--r);padding:30px;transition:transform .2s,box-shadow .2s}
.card:hover{transform:translateY(-3px);box-shadow:var(--ombre)}
.card .ico{width:48px;height:48px;border-radius:12px;background:var(--noir);color:var(--blanc);
  display:flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:18px}
.card .ico svg{width:24px;height:24px;stroke:#fff;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.card h3{font-size:20px;margin-bottom:8px}
.card p{color:var(--gris-7);font-size:15px}

/* ── Étapes (process) ─────────────────────────────────── */
.etapes{counter-reset:e;display:grid;gap:18px;grid-template-columns:repeat(4,1fr)}
.etape{border:1px solid var(--bord);border-radius:var(--r);padding:26px;position:relative;background:var(--blanc)}
.etape::before{counter-increment:e;content:"0" counter(e);font-family:'Space Grotesk';font-weight:700;
  font-size:30px;color:var(--gris-3);display:block;margin-bottom:10px}
.etape h4{font-size:17px;margin-bottom:6px}
.etape p{font-size:14px;color:var(--gris-7)}

/* ── Bandeau contact ──────────────────────────────────── */
.bandeau{background:var(--noir);color:var(--blanc);border-radius:24px;padding:54px;text-align:center}
.bandeau h2{font-size:clamp(26px,4vw,38px);margin-bottom:14px}
.bandeau p{color:var(--gris-3);margin-bottom:28px;font-size:18px}
.bandeau .btn{background:var(--blanc);color:var(--noir)}
.bandeau .btn:hover{background:var(--gris-3)}

/* ── Formulaire ───────────────────────────────────────── */
.form-wrap{max-width:760px;margin:0 auto}
.form-section{background:var(--blanc);border:1px solid var(--bord);border-radius:var(--r);padding:30px;margin-bottom:22px}
.form-section h3{font-size:19px;margin-bottom:4px;display:flex;align-items:center;gap:10px}
.form-section .step-num{width:28px;height:28px;border-radius:8px;background:var(--noir);color:#fff;
  display:inline-flex;align-items:center;justify-content:center;font-size:14px;font-family:'Space Grotesk'}
.form-section .hint{color:var(--gris-5);font-size:14px;margin-bottom:20px}
.champ{margin-bottom:18px}
.champ:last-child{margin-bottom:0}
.champ label{display:block;font-weight:600;font-size:14px;margin-bottom:7px}
.champ label .req{color:var(--noir)}
.champ input[type=text],.champ input[type=tel],.champ input[type=email],
.champ select,.champ textarea{
  width:100%;padding:12px 14px;border:1.5px solid var(--bord);border-radius:10px;font-size:15px;
  font-family:inherit;background:var(--blanc);color:var(--noir);transition:border-color .2s}
.champ input:focus,.champ select:focus,.champ textarea:focus{outline:none;border-color:var(--noir)}
.champ textarea{resize:vertical;min-height:90px}
.champ .aide{font-size:13px;color:var(--gris-5);margin-top:6px}
.duo{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.radio-row{display:flex;gap:10px;flex-wrap:wrap}
.radio-row label{flex:1;min-width:120px;border:1.5px solid var(--bord);border-radius:10px;padding:12px;
  text-align:center;cursor:pointer;font-weight:500;font-size:14px;transition:all .15s}
.radio-row input{position:absolute;opacity:0}
.radio-row input:checked + span{font-weight:700}
.radio-row label:has(input:checked){border-color:var(--noir);background:var(--noir);color:var(--blanc)}
.radio-col{display:flex;flex-direction:column;gap:10px}
.radio-col label{border:1.5px solid var(--bord);border-radius:10px;padding:16px;cursor:pointer;font-weight:500;font-size:15px;transition:all .15s;display:flex;align-items:center;gap:10px}
.radio-col input{accent-color:#000;width:18px;height:18px;flex:none}
.radio-col label:has(input:checked){border-color:var(--noir);background:var(--gris-1)}

/* ── Wizard (questionnaire multi-étapes) ──────────────────── */
.wizard-progress{height:6px;background:var(--bord);border-radius:999px;overflow:hidden;margin-bottom:10px}
.wizard-bar{height:100%;background:var(--noir);width:20%;transition:width .3s ease}
.wizard-count{font-size:13px;color:var(--gris-5);font-weight:600;margin-bottom:18px}
.wizard-step{display:none;border:0;margin:0;padding:30px;min-inline-size:auto}
.wizard-step.active{display:block;animation:wizfade .25s ease}
@keyframes wizfade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.wizard-nav{display:flex;gap:12px;justify-content:space-between;margin-top:4px}
.wizard-nav .btn-ghost{margin-right:auto}
.wizard-nav #wizNext,.wizard-nav #wizSubmit{margin-left:auto}

/* ── Alertes ──────────────────────────────────────────── */
.alerte{border-radius:12px;padding:16px 20px;margin-bottom:22px;font-size:15px;border:1.5px solid}
.alerte-ok{background:var(--gris-1);border-color:var(--noir)}
.alerte-err{background:#fff;border-color:#000;color:#000}
.alerte ul{margin:8px 0 0 18px}

/* ── Suivi / tracking ─────────────────────────────────── */
.suivi-box{max-width:620px;margin:0 auto;text-align:center}
.code-input{font-family:'Space Grotesk';font-size:24px;letter-spacing:.15em;text-align:center;text-transform:uppercase}
.progress{display:flex;justify-content:space-between;margin:40px 0 30px;position:relative;counter-reset:p}
.progress::before{content:"";position:absolute;top:18px;left:8%;right:8%;height:2px;background:var(--bord);z-index:0}
.progress .pas{position:relative;z-index:1;flex:1;text-align:center}
.progress .dot{width:38px;height:38px;border-radius:50%;background:var(--blanc);border:2px solid var(--bord);
  margin:0 auto 10px;display:flex;align-items:center;justify-content:center;font-weight:700;font-family:'Space Grotesk';color:var(--gris-5)}
.progress .pas.fait .dot{background:var(--noir);border-color:var(--noir);color:var(--blanc)}
.progress .pas.actif .dot{border-color:var(--noir);color:var(--noir);box-shadow:0 0 0 4px rgba(0,0,0,.08)}
.progress .pas span{font-size:12px;color:var(--gris-7);font-weight:600}
.statut-carte{background:var(--blanc);border:1px solid var(--bord);border-radius:var(--r);padding:30px;text-align:left}
.badge{display:inline-block;background:var(--noir);color:#fff;padding:6px 14px;border-radius:999px;font-size:13px;font-weight:600}

/* ── Avis Google ──────────────────────────────────────── */
.avis-resume{display:flex;align-items:center;gap:22px;background:var(--blanc);border:1px solid var(--bord);
  border-radius:var(--r);padding:26px 30px;max-width:760px;margin:0 auto;flex-wrap:wrap}
.avis-note{font-family:'Space Grotesk';font-size:56px;font-weight:700;line-height:1}
.stars{display:inline-flex;gap:3px}
.stars svg{width:22px;height:22px}
.stars .st-on{fill:var(--noir)}
.stars .st-off{fill:none;stroke:var(--gris-3);stroke-width:1.5}
.avis-carte{display:flex;flex-direction:column}
.avis-tete{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.avis-photo{width:44px;height:44px;border-radius:50%;object-fit:cover;flex:none}
.avis-initiale{background:var(--noir);color:#fff;display:flex;align-items:center;justify-content:center;
  font-family:'Space Grotesk';font-weight:700;font-size:20px}
@media(max-width:640px){
  .avis-resume{justify-content:center;text-align:center}
  .avis-resume .btn{margin:6px auto 0!important}
}

/* ── Tableau admin ────────────────────────────────────── */
.admin-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:26px;flex-wrap:wrap;gap:12px}
.table-wrap{overflow-x:auto;border:1px solid var(--bord);border-radius:var(--r)}
table.admin{width:100%;border-collapse:collapse;font-size:14px;background:#fff}
table.admin th,table.admin td{padding:13px 14px;text-align:left;border-bottom:1px solid var(--bord);vertical-align:top}
table.admin th{background:var(--gris-1);font-weight:600;white-space:nowrap}
table.admin tr:last-child td{border-bottom:none}
.tag{display:inline-block;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600;border:1px solid var(--noir)}
.tag-Reçue{background:#fff;color:#000}
.tag-Enexamen{background:var(--gris-3)}
.tag-Planifiée{background:var(--gris-7);color:#fff}
.tag-Encours{background:var(--gris-9);color:#fff}
.tag-Résolue{background:var(--noir);color:#fff}
.detail-bloc{background:var(--gris-1);border-radius:10px;padding:16px;margin-top:8px;font-size:13px}
.detail-bloc dt{font-weight:700;margin-top:8px}
.detail-bloc dd{margin:0 0 4px}

/* ── Stats admin ──────────────────────────────────────── */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:26px}
.stat{border:1px solid var(--bord);border-radius:var(--r);padding:20px;background:#fff}
.stat .n{font-family:'Space Grotesk';font-size:34px;font-weight:700}
.stat .l{font-size:13px;color:var(--gris-7)}

/* ── Login ────────────────────────────────────────────── */
.login-wrap{max-width:380px;margin:80px auto;background:#fff;border:1px solid var(--bord);border-radius:var(--r);padding:36px}

/* ── Footer ───────────────────────────────────────────── */
.site-footer{background:var(--noir);color:var(--gris-3);margin-top:0;padding:60px 0 24px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;padding-bottom:40px;border-bottom:1px solid var(--gris-9)}
.site-footer .logo-footer{color:#fff;margin-bottom:14px}
.site-footer h4{color:#fff;font-size:14px;text-transform:uppercase;letter-spacing:.06em;margin:18px 0 8px}
.site-footer h4:first-child{margin-top:0}
.site-footer a{color:var(--gris-3);text-decoration:none}
.site-footer a:hover{color:#fff}
.footer-bas{display:flex;justify-content:space-between;align-items:center;padding-top:22px;font-size:13px;color:var(--gris-5)}

/* ── Responsive ───────────────────────────────────────── */
@media(max-width:860px){
  .grid-3,.etapes{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .stats{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  .nav-toggle{display:block}
  .nav{position:fixed;top:70px;left:0;right:0;background:#fff;flex-direction:column;gap:0;
    border-bottom:1px solid var(--bord);padding:10px 24px;display:none}
  body.nav-open .nav{display:flex}
  .nav a{padding:12px 0;width:100%;border-bottom:1px solid var(--gris-1)}
  .btn-nav{text-align:center;margin:10px 0}
  .grid-3,.grid-2,.etapes,.duo,.stats{grid-template-columns:1fr}
  .bandeau{padding:36px 24px}
  .form-section{padding:22px}
}
