/* ==================================================================
   KAZIO — Site vitrine public. Charte noir/or, Playfair + DM Sans.
   Mobile-first, accessible (focus visible, contrastes AA).
   ================================================================== */
:root{
  --noir:#0d0d0d; --blanc:#f5f2ed; --or:#c9a84c; --or-clair:#e8d5a3;
  --gris:#6b6b6b; --gris-clair:#e8e4de; --bleu:#3b82f6;
}
*{margin:0;padding:0;box-sizing:border-box}
body.vitrine{background:var(--blanc);color:var(--noir);font-family:'DM Sans',system-ui,sans-serif;
  font-weight:300;line-height:1.7;-webkit-font-smoothing:antialiased}
img{max-width:100%}
a{color:inherit}
h1,h2,h3{font-family:'Playfair Display',Georgia,serif;line-height:1.1}
:focus-visible{outline:2px solid var(--or);outline-offset:3px}

.skip{position:absolute;left:-999px;top:0;background:var(--noir);color:#fff;padding:10px 16px;z-index:200}
.skip:focus{left:8px;top:8px}

.v-wrap{max-width:1100px;margin:0 auto;padding:0 24px}

/* En-tête */
.v-head{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;
  gap:16px;padding:14px 24px;background:rgba(13,13,13,.96);color:#fff}
.v-brand{font-family:'Playfair Display',serif;font-weight:900;font-size:24px;text-decoration:none;color:#fff}
.v-brand span{color:var(--or)}
.v-nav{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.v-nav a{text-decoration:none;font-size:14px;color:#e8e4de;padding:8px 12px;border-radius:5px}
.v-nav a:hover{color:var(--or)}
.v-nav .v-login{color:#fff}
.v-cta{display:inline-block;background:var(--or);color:var(--noir);font-weight:700;text-decoration:none;
  padding:10px 18px;border-radius:50px;transition:background .2s,transform .2s}
.v-cta:hover{background:var(--or-clair);transform:translateY(-1px)}
.v-cta-ghost{background:transparent;color:var(--noir);border:1px solid var(--noir)}
.v-cta-ghost:hover{background:var(--noir);color:#fff}

/* Hero */
.v-hero{background:var(--noir);color:var(--blanc);padding:90px 0 100px;position:relative;overflow:hidden}
.v-hero::before{content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 75% 20%,rgba(201,168,76,.22),transparent 55%)}
.v-hero .v-wrap{position:relative}
.v-tag{text-transform:uppercase;letter-spacing:5px;font-size:11px;color:var(--or);margin-bottom:22px}
.v-hero h1{font-size:clamp(34px,6.5vw,68px);font-weight:900;letter-spacing:-.02em;max-width:14ch}
.v-hero h1 em{color:var(--or);font-style:italic;font-weight:400}
.v-lead{margin:24px 0 34px;font-size:clamp(16px,2.2vw,20px);color:#cfcabf;max-width:60ch}
.v-actions{display:flex;flex-wrap:wrap;gap:16px;align-items:center}
.v-cta-lg{padding:15px 28px;font-size:16px}
.v-link-lg{color:#fff;text-decoration:none;font-size:15px;border-bottom:1px solid var(--or);padding-bottom:2px}
.v-link-lg:hover{color:var(--or)}

/* Sections */
.v-sec{padding:80px 0}
.v-sec-alt{background:#fff}
.v-sec-num{text-transform:uppercase;letter-spacing:3px;font-size:12px;color:var(--gris);margin-bottom:14px;
  padding-left:46px;position:relative}
.v-sec-num::before{content:"";position:absolute;left:0;top:50%;width:34px;height:2px;background:var(--or)}
.v-sec h2{font-size:clamp(26px,4vw,40px);font-weight:700;margin-bottom:40px;max-width:20ch}

/* Étapes */
.v-steps{display:grid;grid-template-columns:1fr;gap:24px}
.v-step{background:var(--blanc);border:1px solid var(--gris-clair);border-radius:8px;padding:30px 26px}
.v-sec-alt .v-step{background:var(--blanc)}
.v-step-n{font-family:'Playfair Display',serif;font-size:40px;font-weight:900;color:var(--or-clair);line-height:1}
.v-step h3{font-size:21px;font-weight:700;margin:14px 0 8px}
.v-step p{color:var(--gris)}

/* Cartes fonctionnalités */
.v-cards{display:grid;grid-template-columns:1fr;gap:22px}
.v-card{background:var(--blanc);border:1px solid var(--gris-clair);border-top:4px solid var(--or);
  border-radius:6px;padding:28px 24px;transition:transform .2s,box-shadow .2s}
.v-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px -18px rgba(201,168,76,.6)}
.v-card h3{font-size:20px;font-weight:700;margin-bottom:10px}
.v-card p{color:var(--gris);font-size:15px}

/* Tarifs */
.v-plans{display:grid;grid-template-columns:1fr;gap:24px;align-items:stretch}
.v-plan{position:relative;background:#fff;border:1px solid var(--gris-clair);border-top:4px solid var(--or);
  border-radius:8px;padding:34px 28px;display:flex;flex-direction:column}
.v-plan-hot{border-color:var(--or);box-shadow:0 18px 50px -22px rgba(201,168,76,.7)}
.v-plan-flag{position:absolute;top:-13px;right:24px;background:var(--or);color:var(--noir);
  font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;padding:5px 12px;border-radius:50px}
.v-plan h3{font-size:26px;font-weight:700;margin-bottom:6px}
.v-plan-prix{font-family:'Playfair Display',serif;font-size:30px;font-weight:700;color:var(--or);margin-bottom:18px}
.v-plan ul{list-style:none;margin:0 0 24px;display:flex;flex-direction:column;gap:10px}
.v-plan li{position:relative;padding-left:24px;font-size:15px;color:#333}
.v-plan li::before{content:"✓";position:absolute;left:0;color:var(--or);font-weight:700}
.v-plan .v-cta,.v-plan .v-cta-ghost{margin-top:auto;text-align:center}
.v-tarif-note{margin-top:28px;color:var(--gris);font-size:14px;text-align:center}

/* CTA final */
.v-final{background:var(--noir);color:var(--blanc);padding:80px 0;text-align:center}
.v-final h2{font-size:clamp(26px,4vw,42px);font-weight:700;margin-bottom:30px}
.v-final h2 em{color:var(--or);font-style:italic;font-weight:400}

/* Pied de page */
.v-foot{background:var(--noir);color:#cfcabf;padding:54px 0 28px;font-size:14px}
.v-foot .v-brand{font-size:22px;display:inline-block;margin-bottom:10px}
.v-foot p{max-width:42ch;color:#9a958b}
.v-foot strong{color:var(--or);font-weight:600}
.v-foot-grid{display:grid;grid-template-columns:1fr;gap:26px}
.v-foot nav{display:flex;flex-direction:column;gap:10px}
.v-foot nav a{color:#cfcabf;text-decoration:none}
.v-foot nav a:hover{color:var(--or)}
.v-foot-bottom{margin-top:30px;padding-top:20px;border-top:1px solid rgba(255,255,255,.12);color:#7c776e;font-size:13px}

/* Pages légales (prose) */
.v-legal{padding:56px 0 70px}
.v-legal .v-wrap{max-width:760px}
.v-legal h1{font-size:clamp(28px,5vw,40px);font-weight:900;margin-bottom:8px}
.v-legal .v-maj{color:var(--gris);font-size:14px;margin-bottom:28px}
.v-legal h2{font-size:21px;font-weight:700;margin:30px 0 10px}
.v-legal p,.v-legal li{color:#333;margin-bottom:10px}
.v-legal ul{margin:0 0 10px 22px}
.v-legal a{color:var(--noir)}

/* Tablette / desktop */
@media(min-width:680px){
  .v-steps{grid-template-columns:repeat(3,1fr)}
  .v-cards{grid-template-columns:repeat(2,1fr)}
  .v-plans{grid-template-columns:repeat(3,1fr)}
  .v-foot-grid{grid-template-columns:1.4fr 1fr}
  .v-foot nav{flex-direction:row;flex-wrap:wrap;gap:8px 22px;justify-content:flex-end}
}
@media(min-width:980px){
  .v-cards{grid-template-columns:repeat(3,1fr)}
  .v-sec{padding:100px 0}
}
