:root{
  --paper:#F6F1E7;
  --paper-2:#EFE6D6;
  --ink:#2B2420;
  --ink-soft:#6A6056;
  --plum:#6E2A4C;          /* couleur "navet", signature de la marque */
  --plum-deep:#4B1B33;
  --sage:#6B7355;
  --sage-deep:#454C37;
  --line:rgba(43,36,32,.14);
  --r:14px;
  --maxw:1180px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Mulish",system-ui,sans-serif;
  color:var(--ink);
  background:var(--paper);
  line-height:1.65;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3{font-family:"Fraunces",Georgia,serif;font-weight:500;line-height:1.08;letter-spacing:-.01em}
a{color:inherit}
img{display:block;max-width:100%}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.kicker{
  font-family:"Mulish";font-weight:600;font-size:.74rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--plum);line-height:1.7;
}

/* ---------- HEADER ---------- */
header{
  position:fixed;top:0;left:0;right:0;z-index:50;
  padding:18px 0;transition:box-shadow .4s ease,padding .4s ease;
}
/* Fond crème flouté porté par un pseudo-élément, PAS par <header> :
   un backdrop-filter sur <header> ferait de lui le bloc englobant des
   descendants position:fixed (le menu mobile), qui se retrouverait piégé
   dans la hauteur du header au lieu de couvrir tout l'écran. */
header::before{content:"";position:absolute;inset:0;z-index:-1;background:rgba(246,241,231,.92);backdrop-filter:blur(10px);opacity:0;transition:opacity .4s ease}
header.solid::before{opacity:1}
header.solid{box-shadow:0 1px 0 var(--line);padding:12px 0}
.nav{display:flex;align-items:center;justify-content:space-between}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.brand img{width:96px;height:96px;border-radius:50%;background:#fff;padding:3px;transition:width .4s ease,height .4s ease}
header.solid .brand img{width:46px;height:46px}
.brand b{font-family:"Fraunces";font-weight:500;font-size:1.06rem;color:#fff;letter-spacing:.01em;transition:color .4s}
header.solid .brand b{color:var(--plum)}
.links{display:flex;gap:30px;align-items:center}
.links a{
  text-decoration:none;font-size:.84rem;font-weight:600;letter-spacing:.04em;
  color:rgba(255,255,255,.92);position:relative;padding:4px 0;transition:color .4s;
}
header.solid .links a{color:var(--ink)}
.links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1.5px;background:currentColor;transition:width .3s}
.links a:hover::after,.links a[aria-current="page"]::after{width:100%}
/* Header transparent (sur la photo) : actif/survol en blanc pur, souligné blanc */
.links a:hover,.links a[aria-current="page"]{color:#fff}
/* Header opaque (fond crème) : actif/survol en prune */
header.solid .links a:hover,header.solid .links a[aria-current="page"]{color:var(--plum)}
.menu-btn{display:none;background:none;border:0;cursor:pointer;width:30px;height:24px;position:relative}
.menu-btn span{position:absolute;left:0;width:100%;height:2px;background:#fff;transition:.3s}
header.solid .menu-btn span{background:var(--ink)}
.menu-btn span:nth-child(1){top:2px}.menu-btn span:nth-child(2){top:11px}.menu-btn span:nth-child(3){top:20px}
/* Menu ouvert : le burger devient une croix sombre, visible sur le panneau crème */
.links.open ~ .menu-btn span{background:var(--ink)}
.links.open ~ .menu-btn span:nth-child(1){top:11px;transform:rotate(45deg)}
.links.open ~ .menu-btn span:nth-child(2){opacity:0}
.links.open ~ .menu-btn span:nth-child(3){top:11px;transform:rotate(-45deg)}

/* ---------- HERO ---------- */
.hero{position:relative;height:100vh;min-height:620px;display:flex;align-items:flex-end;overflow:hidden}
.hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transform:scale(1.06);animation:slowzoom 14s ease forwards}
@keyframes slowzoom{to{transform:scale(1)}}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(40,18,30,.42) 0%,rgba(40,18,30,.05) 38%,rgba(33,15,25,.72) 100%)}
.hero-inner{position:relative;z-index:2;padding-bottom:9vh;color:#fff}
.hero .kicker{color:#E9C6D5}
.hero h1{
  color:#fff;font-size:clamp(2.6rem,7.4vw,5.8rem);font-weight:600;margin:.3em 0 .35em;
  max-width:15ch;letter-spacing:-.025em;line-height:1.02;text-shadow:0 2px 30px rgba(0,0,0,.25)
}
.hero p{font-size:clamp(1rem,1.6vw,1.22rem);max-width:46ch;color:rgba(255,255,255,.92);font-weight:300}
.scroll-cue{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:2;color:#fff;opacity:.8;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:8px}
.scroll-cue i{display:block;width:1px;height:34px;background:#fff;animation:cue 1.8s ease-in-out infinite}
@keyframes cue{0%,100%{transform:scaleY(.4);opacity:.4;transform-origin:top}50%{transform:scaleY(1);opacity:1;transform-origin:top}}
/* Entrée orchestrée au chargement : kicker, titre, sous-titre puis indice de défilement
   montent un à un pour une première impression travaillée (désactivée si reduced-motion). */
@keyframes rise{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}
.hero-inner>*{opacity:0;animation:rise .9s cubic-bezier(.2,.7,.2,1) both}
.hero-inner .kicker{animation-delay:.35s}
.hero-inner h1{animation-delay:.5s}
.hero-inner p{animation-delay:.72s}
.scroll-cue{opacity:0;animation:rise .9s ease .95s both}

/* ---------- SECTIONS ---------- */
section{padding:clamp(70px,9vw,130px) 0}
.intro{text-align:center;background:var(--paper)}
.intro p{font-family:"Fraunces";font-weight:400;font-size:clamp(1.4rem,2.9vw,2.15rem);line-height:1.4;max-width:24ch;margin:18px auto 0;color:var(--ink)}
.intro .kicker{display:inline-block}

.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,5vw,80px);align-items:center}
.alt{background:var(--paper-2)}
.split .media{position:relative}
.split .media img{width:100%;aspect-ratio:4/3.1;object-fit:cover;border-radius:var(--r)}
.split .media.tall img{aspect-ratio:1/1.04}
.split .copy h2{font-size:clamp(1.9rem,4vw,2.9rem)}
.split .copy p{margin-top:18px;color:var(--ink-soft);font-size:1.04rem}
.frame{position:relative}
.frame::before{content:"";position:absolute;inset:14px -14px -14px 14px;border:1px solid var(--plum);border-radius:var(--r);z-index:-1;opacity:.5}

/* démarche */
.demarche{background:var(--plum);color:#fff;text-align:center}
.demarche .kicker{color:#E9C6D5}
.demarche h2{color:#fff;font-size:clamp(1.9rem,4vw,2.9rem);margin-top:12px}
.demarche .sub{max-width:40ch;margin:16px auto 0;color:rgba(255,255,255,.85);font-weight:300}
.principles{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;margin-top:54px;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.16);border-radius:var(--r);overflow:hidden}
.principle{position:relative;background:var(--plum);padding:38px 30px;text-align:left;transition:background .35s}
.principle:hover{background:var(--plum-deep)}
.principle .num{position:absolute;top:24px;right:26px;font-family:"Fraunces";font-size:1rem;color:#E9C6D5;opacity:.55}
.principle .ic{width:30px;height:30px;display:block;fill:none;stroke:#E9C6D5;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round;opacity:.9;margin-bottom:18px}
.principle h3{color:#fff;font-size:1.18rem;font-weight:500}
.principle p{margin-top:10px;color:rgba(255,255,255,.74);font-size:.95rem;font-weight:300;line-height:1.55}

/* saisons gallery */
.saisons{background:var(--paper)}
.sec-head{text-align:center;margin-bottom:54px}
.sec-head h2{font-size:clamp(1.9rem,4vw,2.9rem);margin-top:10px}
.sec-head p{color:var(--ink-soft);margin-top:12px}
.gallery{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:200px;gap:16px}
.gallery figure{overflow:hidden;border-radius:var(--r);position:relative}
.gallery img{width:100%;height:100%;object-fit:cover;transition:transform .9s ease}
.gallery figure:hover img{transform:scale(1.07)}
.g1{grid-column:span 5;grid-row:span 2}
.g2{grid-column:span 4;grid-row:span 1}
.g3{grid-column:span 3;grid-row:span 2}
.g4{grid-column:span 4;grid-row:span 1}

/* points de vente */
.vente{background:var(--paper-2)}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:50px}
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;display:flex;flex-direction:column;transition:transform .35s ease,box-shadow .35s ease}
.card:hover{transform:translateY(-6px);box-shadow:0 18px 40px -22px rgba(43,27,40,.45)}
.card .ph{height:190px;background:#fff;display:flex;align-items:center;justify-content:center;overflow:hidden}
.card .ph img{width:100%;height:100%;object-fit:cover}
.card .ph.logo img{object-fit:contain;padding:26px;width:auto;max-height:140px}
.card .body{padding:24px 24px 26px}
.card h3{font-size:1.3rem;font-weight:500}
.card p{color:var(--ink-soft);font-size:.95rem;margin-top:8px}
.card a.lnk{display:inline-block;margin-top:14px;font-weight:700;font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;color:var(--plum);text-decoration:none}
.card a.lnk:hover{text-decoration:underline}

/* visiter + formulaire */
.visiter{background:var(--sage);color:#fff;text-align:center}
.visiter .kicker{color:#E4EAD6}
.visiter h2{color:#fff;font-size:clamp(2rem,4.4vw,3.1rem);margin-top:12px}
.visiter p{max-width:46ch;margin:18px auto 0;color:rgba(255,255,255,.9);font-weight:300}
.addr{margin-top:34px;font-size:1.05rem;line-height:1.9}
.btn{display:inline-block;background:#fff;color:var(--sage-deep);padding:15px 34px;border-radius:50px;border:0;cursor:pointer;text-decoration:none;font-family:"Mulish";font-weight:700;letter-spacing:.04em;font-size:.9rem;transition:transform .3s,background .3s}
.btn:hover{transform:translateY(-3px);background:var(--paper)}

.contact{max-width:560px;margin:36px auto 0;text-align:left}
.contact .row{display:flex;gap:16px}
.contact input,.contact textarea,.contact select{
  width:100%;margin-top:14px;padding:14px 16px;border:0;border-radius:10px;
  font-family:"Mulish";font-size:1rem;background:rgba(255,255,255,.94);color:var(--ink);
}
.contact textarea{resize:vertical}
.contact .hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.contact button{margin-top:18px}
.form-msg{margin-top:16px;font-weight:600;color:#fff}
.form-msg.error{color:#FFD9C0}
@media(max-width:560px){.contact .row{flex-direction:column;gap:0}}

/* Variante "inscription" : formulaire posé sur fond crème (page soirées) */
.reserve input,.reserve textarea,.reserve select{background:#fff;border:1px solid rgba(110,42,76,.18)}
.reserve button.btn{background:var(--plum);color:#fff}
.reserve button.btn:hover{background:var(--plum-deep)}
.reserve .form-msg{color:var(--plum)}
.reserve .form-msg.error{color:#B23A1E}

/* footer */
footer{background:var(--plum-deep);color:rgba(255,255,255,.82);text-align:center;padding:64px 0 56px}
footer img.logo{width:80px;height:80px;border-radius:50%;background:#fff;padding:6px;margin:0 auto 22px}
footer .fname{font-family:"Fraunces";font-size:1.5rem;color:#fff;font-weight:500}
footer .fline{margin-top:6px;font-size:.95rem;line-height:1.8}
footer .social{margin-top:22px;display:flex;gap:20px;justify-content:center}
footer .social a{width:40px;height:40px;border:1px solid rgba(255,255,255,.32);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:.3s}
footer .social a:hover{background:#fff;border-color:#fff}
footer .social svg{width:18px;height:18px;fill:#fff;transition:fill .3s}
footer .social a:hover svg{fill:var(--plum-deep)}
footer .legal{margin-top:34px;font-size:.78rem;opacity:.6}

/* reveal */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:none}

/* Accessibilité : on coupe les animations pour qui préfère moins de mouvement,
   tout en garantissant que le contenu reste visible (pas figé à opacity:0). */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.001ms!important;scroll-behavior:auto!important;
  }
  .hero-inner>*,.scroll-cue,.reveal{opacity:1;transform:none}
}

/* ---------- RESPONSIVE ---------- */
@media(max-width:860px){
  /* Menu plein écran : couvre toute la page (plus de bleed de la photo derrière) */
  .links{
    position:fixed;inset:0;width:100%;background:var(--paper);
    flex-direction:column;justify-content:center;gap:30px;padding:40px;
    transform:translateX(100%);transition:transform .4s ease;
  }
  .links.open{transform:translateX(0)}
  .links a,header.solid .links a{color:var(--ink);font-size:1.2rem}
  /* Logo au-dessus du panneau pour garder un repère en haut quand le menu est ouvert */
  .brand{position:relative;z-index:60}
  /* Menu ouvert : le titre passe en prune pour rester lisible sur le panneau crème
     (sinon il resterait blanc tant que le header n'est pas "solid", ex. en haut du hero) */
  .nav:has(.links.open) .brand b{color:var(--plum)}
  /* Panneau mobile sur fond crème : l'actif repasse en prune (jamais en blanc) */
  .links a:hover,.links a[aria-current="page"]{color:var(--plum)}
  .menu-btn{display:block;z-index:60}
  .brand img{width:58px;height:58px}
  header.solid .brand img{width:42px;height:42px}
  .split{grid-template-columns:1fr}
  .split .copy{order:2}
  .principles{grid-template-columns:1fr 1fr}
  .cards{grid-template-columns:1fr}
  .gallery{grid-template-columns:repeat(6,1fr);grid-auto-rows:150px}
  .g1{grid-column:span 6;grid-row:span 2}
  .g2{grid-column:span 3}.g3{grid-column:span 3;grid-row:span 2}.g4{grid-column:span 3}
  .frame::before{inset:10px -10px -10px 10px}
}
@media(max-width:480px){
  .principles{grid-template-columns:1fr}
  .gallery{grid-template-columns:1fr;grid-auto-rows:230px}
  .g1,.g2,.g3,.g4{grid-column:span 1;grid-row:span 1}
  /* Téléphone : titre toujours visible, réduit + nowrap pour tenir sur une ligne sans
     déborder sur le burger (le défaut de l'ancienne taille qui passait à la ligne) */
  .brand b{font-size:.9rem;white-space:nowrap}
  .brand img{width:48px;height:48px}
  header.solid .brand img{width:40px;height:40px}
}

/* ============================================================
   AJOUTS MULTI-PAGES (structure : 3 piliers, soirées, écoles)
   ============================================================ */

/* Bannière des pages intérieures (hero court) */
.page-hero{position:relative;min-height:48vh;display:flex;align-items:flex-end;overflow:hidden}
.page-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
/* Cadrage ancré en haut : garde le soleil visible, rogne le bas quand l'écran est large */
.page-hero--top img{object-position:center top}
.page-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(40,18,30,.30),rgba(33,15,25,.74))}
.page-hero .inner{position:relative;z-index:2;color:#fff;padding-bottom:7vh}
.page-hero .kicker{color:#E9C6D5}
.page-hero h1{color:#fff;font-size:clamp(2.3rem,5.6vw,4.1rem);font-weight:600;letter-spacing:-.02em;line-height:1.04;margin-top:.3em;max-width:18ch}

.page-section{padding:clamp(56px,7vw,100px) 0}
.lead{font-family:"Fraunces";font-weight:400;font-size:clamp(1.25rem,2.4vw,1.7rem);line-height:1.45;max-width:34ch;color:var(--ink)}
.prose{max-width:62ch;margin-top:22px;color:var(--ink-soft);font-size:1.05rem}
.prose p+p{margin-top:16px}

/* Les 3 piliers */
.pillars{margin-top:48px;display:grid;gap:22px}
.pillar-row{display:grid;grid-template-columns:auto 1fr;gap:26px;align-items:start;padding:32px;background:var(--paper);border-radius:var(--r);border:1px solid var(--line)}
.pillar-row .no{font-family:"Fraunces";font-size:2.6rem;color:var(--plum);line-height:.9}
.pillar-row h3{font-size:1.4rem;font-weight:500}
.pillar-row p{margin-top:8px;color:var(--ink-soft)}

/* Note "contenu provisoire" */
.note{margin-top:30px;padding:16px 20px;border-left:3px solid var(--plum);background:var(--paper-2);border-radius:6px;font-size:.92rem;color:var(--ink-soft)}

/* Soirées : liste de dates */
.dates{margin-top:34px;display:grid;gap:12px;max-width:540px}
.date-item{display:flex;justify-content:space-between;gap:16px;padding:16px 20px;background:var(--paper-2);border-radius:10px;border:1px solid var(--line)}
.date-item b{font-weight:600;color:var(--ink)}
.date-item span{color:var(--ink-soft)}

@media(max-width:600px){
  .pillar-row{grid-template-columns:1fr;gap:8px;padding:24px}
  .date-item{flex-direction:column;gap:4px}
  /* Eyebrow long (ex. hero) : tracking réduit pour un retour à la ligne propre */
  .kicker{letter-spacing:.14em;font-size:.72rem}
}

/* lien dans les cartes (span ou a) */
.card .lnk{display:inline-block;margin-top:14px;font-weight:700;font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;color:var(--plum);text-decoration:none}
.card.link:hover .lnk{text-decoration:underline}

/* ---------- SOIRÉE : bande photo pleine largeur ---------- */
.band img{width:100%;height:clamp(280px,46vh,500px);object-fit:cover}

/* ---------- SOIRÉE : galerie de l'édition ---------- */
.shots{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.shots figure{overflow:hidden;border-radius:var(--r)}
.shots img{width:100%;aspect-ratio:3/4;object-fit:cover;transition:transform .9s ease}
.shots figure:hover img{transform:scale(1.06)}
@media(max-width:860px){.shots{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.shots{grid-template-columns:1fr}}
