/* =================================================================
   IN PROVENCE HÔTEL — direction artistique
   Pierre & encre d'olivier · garrigue · lavande poudrée · ocre
   Signature : arches gravées (voûtes, caves & puits de la bastide)
   ================================================================= */
:root{
  --pierre:#F2EBDD;
  --pierre-clair:#FAF6EC;
  --calcaire:#E7DCC6;
  --encre:#26251F;
  --encre-2:#5B5648;
  --garrigue:#3E5037;
  --garrigue-fonce:#2E3C29;
  --nuit:#20251C;
  --lavande:#8A89B4;
  --ocre:#B27A38;
  --ocre-texte:#8A5B1D;
  --or:#D9B98A;
  --serif:"Cormorant Garamond","Cormorant",Georgia,"Times New Roman",serif;
  --sans:"Jost","Avenir Next","Segoe UI",system-ui,sans-serif;
  --tr:260ms cubic-bezier(.4,0,.2,1);
  --arches:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='132' height='132'%3E%3Cpath d='M0 132V66a33 33 0 0 1 66 0v66M66 132V66a33 33 0 0 1 66 0v66' fill='none' stroke='%23FFFFFF' stroke-opacity='.16'/%3E%3C/svg%3E");
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--sans);font-weight:300;font-size:1.03rem;line-height:1.75;
  color:var(--encre);background:var(--pierre);-webkit-font-smoothing:antialiased;
  position:relative;
}
body::before{
  content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.45;
  mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)' opacity='.35'/%3E%3C/svg%3E");
}
img{max-width:100%;display:block}
a{color:var(--garrigue)}
a:focus-visible,button:focus-visible{outline:3px solid var(--lavande);outline-offset:3px;border-radius:4px}
::selection{background:var(--lavande);color:#fff}
h1,h2,h3{font-family:var(--serif);font-weight:500;line-height:1.06;margin:0 0 .45em;color:var(--encre)}
h1{font-size:clamp(2.6rem,10.5vw,5rem);letter-spacing:-.01em}
h2{font-size:clamp(1.9rem,6.8vw,3.1rem);letter-spacing:-.005em}
h3{font-size:clamp(1.3rem,4.6vw,1.75rem)}
p{margin:0 0 1.05em}
.it{font-style:italic;font-weight:500;color:var(--ocre-texte)}
.conteneur{max-width:1180px;margin-inline:auto;padding-inline:clamp(1.2rem,4.5vw,2.6rem)}

/* ---- surtitre & ornement olivier ---- */
.surtitre{
  display:flex;align-items:center;gap:.8rem;margin:0 0 1.15rem;
  font-size:.72rem;font-weight:500;letter-spacing:.3em;text-transform:uppercase;color:var(--ocre-texte);
}
.surtitre svg{width:30px;height:14px;flex:none;color:var(--ocre)}
.centre .surtitre{justify-content:center}

/* ---- bouton WhatsApp flottant ---- */
.whatsapp{
  position:fixed;right:clamp(16px,3.5vw,28px);bottom:clamp(16px,3.5vw,28px);z-index:90;
  width:58px;height:58px;border-radius:50%;
  display:grid;place-items:center;color:#fff;background:#25D366;
  box-shadow:0 10px 26px -8px rgba(37,211,102,.6),0 2px 8px rgba(38,37,31,.25);
  transition:transform var(--tr),box-shadow var(--tr);
  -webkit-tap-highlight-color:transparent;
}
.whatsapp svg{width:32px;height:32px}
.whatsapp::before{
  content:"";position:absolute;inset:0;border-radius:50%;background:#25D366;z-index:-1;
  animation:ondes 2.6s ease-out infinite;
}
.whatsapp:hover{transform:scale(1.08);box-shadow:0 14px 32px -8px rgba(37,211,102,.75),0 2px 10px rgba(38,37,31,.3)}
@keyframes ondes{0%{transform:scale(1);opacity:.55}70%{transform:scale(1.7);opacity:0}100%{opacity:0}}
@media (prefers-reduced-motion:reduce){.whatsapp::before{animation:none;display:none}}

/* ---- bandeau ---- */
.bandeau{
  background:var(--nuit);color:var(--or);text-align:center;
  font-size:.68rem;letter-spacing:.28em;text-transform:uppercase;padding:.55rem 1rem;
}

/* ---- header ---- */
.entete{
  position:sticky;top:0;z-index:60;
  background:rgba(242,235,221,.93);backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(38,37,31,.1);transition:box-shadow var(--tr);
}
.entete.ombre{box-shadow:0 10px 30px -20px rgba(38,37,31,.5)}
.entete-int{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-block:.8rem}
.logo{display:flex;align-items:center;text-decoration:none}
.logo img{height:54px;width:auto;display:block}
.nav{display:flex;align-items:center;gap:1.7rem}
.nav a{text-decoration:none;color:var(--encre-2);font-size:.86rem;letter-spacing:.12em;text-transform:uppercase;padding:.3rem 0;position:relative}
.nav a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:1px;background:var(--ocre);transition:right var(--tr)}
.nav a:hover::after,.nav a[aria-current]::after{right:0}
.nav a[aria-current]{color:var(--encre)}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  background:var(--garrigue);color:var(--pierre-clair)!important;border:1px solid var(--garrigue);
  font-family:var(--sans);font-size:.82rem;font-weight:400;letter-spacing:.18em;text-transform:uppercase;
  padding:.95rem 1.8rem;border-radius:0;text-decoration:none;cursor:pointer;
  transition:background var(--tr),color var(--tr),border-color var(--tr);
}
.btn:hover{background:var(--garrigue-fonce);border-color:var(--garrigue-fonce)}
.btn-clair{background:var(--pierre-clair);color:var(--garrigue-fonce)!important;border-color:var(--pierre-clair)}
.btn-clair:hover{background:var(--or);border-color:var(--or);color:var(--nuit)!important}
.btn-ligne{background:transparent;color:var(--pierre-clair)!important;border-color:rgba(250,246,236,.55)}
.btn-ligne:hover{background:rgba(250,246,236,.14);border-color:var(--pierre-clair)}

/* Bouton Réserver du header — finition soignée */
.btn-nav{
  position:relative;overflow:hidden;gap:.55rem;padding:.85rem 1.7rem;
  background:linear-gradient(135deg,var(--garrigue),var(--garrigue-fonce));
  box-shadow:0 6px 18px -10px rgba(46,60,41,.7),inset 0 1px 0 rgba(217,185,138,.25);
  border-color:var(--garrigue-fonce);
}
.btn-nav svg{width:16px;height:16px;flex:none}
.btn-nav::after{
  content:"";position:absolute;top:0;left:-120%;width:55%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(217,185,138,.55),transparent);
  transform:skewX(-18deg);transition:left 650ms ease;
}
.btn-nav:hover{
  background:linear-gradient(135deg,var(--garrigue),var(--garrigue-fonce));
  transform:translateY(-2px);
  box-shadow:0 12px 26px -12px rgba(46,60,41,.85),inset 0 1px 0 rgba(217,185,138,.4);
}
.btn-nav:hover::after{left:130%}
.burger{display:none;background:none;border:none;padding:.5rem;cursor:pointer}
.burger svg,.nav-fermer svg{width:27px;height:27px;stroke:var(--encre);fill:none;stroke-width:1.6}
.nav-fermer{display:none;position:absolute;top:1.1rem;right:1.2rem;background:none;border:none;cursor:pointer;padding:.5rem}

/* ---- photos avec repli élégant ---- */
.ph{position:relative;overflow:hidden;background:var(--calcaire)}
.ph img{width:100%;height:100%;object-fit:cover}
.ph .fond{
  position:absolute;inset:0;display:none;place-items:center;
  background-image:var(--arches),linear-gradient(160deg,var(--g1,#6B7B5E),var(--g2,#3E5037));
  background-size:132px 132px,cover;
}
.ph .fond span{
  font-family:var(--serif);font-style:italic;font-size:1.05rem;color:rgba(250,246,236,.92);
  border:1px solid rgba(250,246,236,.4);padding:.5rem 1.1rem;letter-spacing:.04em;
}
.ph.absente img{visibility:hidden}
.ph.absente .fond{display:grid}
.t-lavande{--g1:#9C9BC4;--g2:#54537C}
.t-ocre{--g1:#CB9A5C;--g2:#8A5B1D}
.t-pierre{--g1:#CDBF9F;--g2:#8F805F}
.t-olive{--g1:#71815F;--g2:#2E3C29}

/* ---- arche gravée (signature) ---- */
.arche{border-radius:999px 999px 0 0}
.arche,.arche .fond,.arche img{border-radius:999px 999px 0 0}
.arche img{aspect-ratio:3.4/4.4;transition:transform 700ms ease}
.arche:hover img{transform:scale(1.04)}
.grav{position:relative;padding:14px;background:transparent}
.grav::before{
  content:"";position:absolute;inset:0;border:1px solid rgba(38,37,31,.28);
  border-radius:999px 999px 0 0;pointer-events:none;
}
.grav::after{
  content:"";position:absolute;inset:7px;border:1px solid rgba(178,122,56,.5);
  border-radius:999px 999px 0 0;pointer-events:none;
}
.fonce .grav::before{border-color:rgba(250,246,236,.3)}
.fonce .grav::after{border-color:rgba(217,185,138,.45)}
.cadre,.cadre img,.cadre .fond{border-radius:2px}
.cadre img{aspect-ratio:4/3;transition:transform 700ms ease}
.cadre:hover img{transform:scale(1.04)}
figure{margin:0}
figcaption{
  margin-top:.7rem;text-align:center;font-size:.7rem;letter-spacing:.3em;
  text-transform:uppercase;color:var(--encre-2);
}
.fonce figcaption{color:rgba(231,220,198,.7)}

/* ---- hero ---- */
.hero{position:relative;isolation:isolate;color:var(--pierre-clair);overflow:hidden;background:var(--nuit)}
.hero .ph-hero{position:absolute;inset:0;z-index:-2}
.hero .ph-hero img{width:100%;height:100%;object-fit:cover}
.hero::after{content:"";position:absolute;inset:0;z-index:-1;background:radial-gradient(120% 90% at 50% 18%,rgba(32,37,28,.25),transparent 55%),linear-gradient(180deg,rgba(32,37,28,.5) 0%,rgba(32,37,28,.4) 42%,rgba(32,37,28,.78) 100%)}
.hero-cadre{position:absolute;inset:clamp(12px,2.4vw,26px);border:1px solid rgba(250,246,236,.35);pointer-events:none;z-index:1}
.hero-cadre::after{content:"";position:absolute;inset:6px;border:1px solid rgba(217,185,138,.3)}
.hero-int{
  position:relative;z-index:2;min-height:min(92svh,720px);
  display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;
  padding-block:5.5rem;
}
.hero .surtitre{color:var(--or);justify-content:center}
.hero h1{color:var(--pierre-clair);max-width:14ch}
.hero h1 .it{color:var(--or)}
.hero p{max-width:46ch;font-size:1.08rem;color:rgba(250,246,236,.9)}
.hero-actions{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:1.6rem;justify-content:center}
.souris{
  position:absolute;bottom:clamp(26px,4vw,44px);left:50%;transform:translateX(-50%);z-index:2;
  font-size:.62rem;letter-spacing:.4em;text-transform:uppercase;color:rgba(250,246,236,.75);
  display:flex;flex-direction:column;align-items:center;gap:.55rem;text-decoration:none;
}
.souris::after{content:"";width:1px;height:42px;background:linear-gradient(rgba(250,246,236,.8),transparent);animation:goutte 2.2s ease-in-out infinite}
@keyframes goutte{0%{transform:scaleY(.2);transform-origin:top}55%{transform:scaleY(1);transform-origin:top}56%{transform-origin:bottom}100%{transform:scaleY(.15);transform-origin:bottom}}

/* ---- chiffres clés ---- */
.chiffres{background:var(--calcaire);border-block:1px solid rgba(38,37,31,.12)}
.chiffres-int{display:grid;grid-template-columns:repeat(4,1fr);text-align:center}
.chiffres div{padding:1.9rem .8rem;border-left:1px solid rgba(38,37,31,.12)}
.chiffres div:first-child{border-left:none}
.chiffres b{display:block;font-family:var(--serif);font-weight:500;font-size:clamp(2rem,6vw,2.9rem);line-height:1;color:var(--garrigue-fonce)}
.chiffres span{font-size:.68rem;letter-spacing:.26em;text-transform:uppercase;color:var(--encre-2)}

/* ---- sections ---- */
.section{padding-block:clamp(3.6rem,10vw,6.5rem)}
.fonce{background:var(--garrigue-fonce);color:var(--calcaire)}
.fonce h2,.fonce h3{color:var(--pierre-clair)}
.fonce .surtitre{color:var(--or)}
.fonce .it{color:var(--or)}
.centre{max-width:64ch;margin-inline:auto;text-align:center}
.duo{display:grid;grid-template-columns:.92fr 1.08fr;gap:clamp(2.2rem,6vw,5rem);align-items:center}
.duo-inv{grid-template-columns:1.08fr .92fr}
.trio{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.3rem,3vw,2.2rem)}
.paire{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(1rem,3vw,2rem)}

/* ---- défilé (ruban) ---- */
.defile{background:var(--nuit);color:var(--or);overflow:hidden;border-block:1px solid rgba(217,185,138,.25);padding-block:.85rem}
.defile-piste{display:flex;width:max-content;gap:3.2rem;animation:defiler 36s linear infinite;will-change:transform}
.defile span{font-family:var(--serif);font-style:italic;font-size:1.05rem;letter-spacing:.12em;white-space:nowrap;display:flex;align-items:center;gap:3.2rem}
.defile span::after{content:"✦";font-style:normal;font-size:.7rem;color:rgba(217,185,138,.6)}
@keyframes defiler{to{transform:translateX(-50%)}}

/* ---- atouts ---- */
.atouts{list-style:none;margin:2.6rem 0 0;padding:0}
.atouts li{padding:1.7rem 0;border-top:1px solid rgba(250,246,236,.16);display:grid;grid-template-columns:52px 1fr;gap:1.2rem;align-items:start}
.atouts li:last-child{border-bottom:1px solid rgba(250,246,236,.16)}
.aico{width:52px;height:52px;border-radius:50%;border:1px solid rgba(217,185,138,.5);display:grid;place-items:center;color:var(--or)}
.aico svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:1.5}
.atouts h3{font-size:1.35rem;margin-bottom:.2rem}
.atouts p{margin:0;font-size:.96rem;color:rgba(231,220,198,.82)}

/* ---- cartes univers ---- */
.carte{display:flex;flex-direction:column;text-decoration:none;color:inherit;group:1}
.carte .ph{aspect-ratio:4/4.6}
.carte .ph img{transition:transform 700ms ease}
.carte:hover .ph img{transform:scale(1.05)}
.carte-corps{padding:1.3rem .2rem 0}
.carte-eti{font-size:.66rem;letter-spacing:.32em;text-transform:uppercase;color:var(--ocre-texte);display:block;margin-bottom:.45rem}
.carte-corps h3{margin-bottom:.3rem}
.carte-corps p{color:var(--encre-2);font-size:.96rem;margin-bottom:.7rem}
.lien{
  display:inline-flex;align-items:center;gap:.5rem;text-decoration:none;
  font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--garrigue);
  border-bottom:1px solid rgba(62,80,55,.4);padding-bottom:.25rem;
}
.lien svg{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:1.7;transition:transform var(--tr)}
.lien:hover svg{transform:translateX(5px)}

/* ---- citation ---- */
.citation{font-family:var(--serif);font-style:italic;font-weight:400;font-size:clamp(1.5rem,5.4vw,2.4rem);line-height:1.32;color:var(--encre);max-width:26ch;margin-inline:auto;text-align:center}
.citation em{color:var(--ocre-texte)}

/* ---- CTA ---- */
.cta{position:relative;isolation:isolate;color:var(--pierre-clair);text-align:center;overflow:hidden;background:var(--garrigue-fonce)}
.cta .ph-hero{position:absolute;inset:0;z-index:-2}
.cta .ph-hero img{width:100%;height:100%;object-fit:cover}
.cta::after{content:"";position:absolute;inset:0;z-index:-1;background:rgba(46,60,41,.82)}
.cta h2{color:var(--pierre-clair)}
.cta p{max-width:50ch;margin-inline:auto;color:rgba(231,220,198,.88)}

/* ---- footer ---- */
.pied{background:var(--nuit);color:rgba(231,220,198,.75);font-size:.95rem}
.pied-int{display:grid;grid-template-columns:1.5fr 1fr 1.2fr;gap:2.6rem;padding-block:3.6rem}
.pied h3{color:var(--pierre-clair);font-size:1.4rem}
.pied a{color:rgba(231,220,198,.75);text-decoration:none}
.pied a:hover{color:var(--or)}
.pied ul{list-style:none;margin:0;padding:0;display:grid;gap:.6rem}
.coords li{display:flex;gap:.75rem;align-items:center}
.coords svg{width:18px;height:18px;color:var(--or);flex:none;fill:none;stroke:currentColor;stroke-width:1.5}
.reseaux{display:flex;gap:.8rem;margin-top:1.2rem}
.reseaux a{width:42px;height:42px;border-radius:50%;border:1px solid rgba(231,220,198,.3);display:grid;place-items:center;transition:background var(--tr),border-color var(--tr)}
.reseaux a:hover{background:var(--garrigue);border-color:var(--garrigue)}
.reseaux svg{width:17px;height:17px}
.pied-bas{border-top:1px solid rgba(231,220,198,.14);padding-block:1.15rem;font-size:.8rem;display:flex;flex-wrap:wrap;gap:.5rem;justify-content:space-between;letter-spacing:.06em}

/* ---- apparitions ---- */
.app{opacity:0;transform:translateY(26px);transition:opacity 700ms ease,transform 700ms ease}
.app.visible{opacity:1;transform:none}

/* ================= MOBILE ================= */
@media (max-width:1024px){
  .trio{grid-template-columns:repeat(2,1fr)}
  .pied-int{grid-template-columns:1fr 1fr}
}
@media (max-width:840px){
  .duo,.duo-inv{grid-template-columns:1fr}
  .duo .grav,.duo-inv .grav{max-width:380px;margin-inline:auto}
  .burger{display:block}
  .nav-fermer{display:block}
  .nav{
    position:fixed;inset:0;z-index:80;flex-direction:column;justify-content:center;gap:1.7rem;
    background:var(--pierre);transform:translateX(100%);transition:transform 340ms ease;
  }
  .nav.ouvert{transform:none}
  .nav a{font-size:1.05rem;letter-spacing:.22em}
}
@media (max-width:640px){
  .trio,.paire{grid-template-columns:1fr}
  .pied-int{grid-template-columns:1fr}
  .chiffres-int{grid-template-columns:1fr 1fr}
  .chiffres div:nth-child(3){border-left:none}
  .chiffres div:nth-child(n+3){border-top:1px solid rgba(38,37,31,.12)}
  .hero-int{min-height:min(88svh,640px);padding-block:4.2rem}
  .hero-actions{width:100%}
  .hero-actions .btn{flex:1 1 100%}
  .duo .paire{grid-template-columns:1fr 1fr;gap:.9rem}
  .duo .paire figure:last-child{margin-top:1.8rem}
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .app{opacity:1;transform:none}
  .defile-piste{animation:none}
}
/* ===================================================================
   COMPOSANTS DE PAGES INTÉRIEURES (suites, business, œnologie, carnet…)
   =================================================================== */

/* hero de page intérieure (plus court) */
.hero-page .hero-int{min-height:min(56svh,460px);padding-block:4.5rem}
.hero-page h1{font-size:clamp(2.2rem,8vw,3.8rem)}

/* fil d'Ariane */
.ariane{padding-block:1.2rem .2rem;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--encre-2)}
.ariane ol{list-style:none;display:flex;flex-wrap:wrap;gap:.55rem;margin:0;padding:0}
.ariane li+li::before{content:"·";margin-right:.55rem;color:var(--ocre)}
.ariane a{text-decoration:none;color:var(--encre-2)}
.ariane a:hover{color:var(--garrigue)}
.ariane [aria-current]{color:var(--encre)}

/* prix */
.prix{display:inline-flex;align-items:baseline;gap:.55rem;margin:.4rem 0 1.3rem}
.prix b{font-family:var(--serif);font-weight:600;font-size:3rem;line-height:1;color:var(--ocre-texte)}
.prix span{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--encre-2)}

/* atouts sur fond clair (les .atouts par défaut sont pensés pour fond foncé) */
.clair .atouts li{border-color:rgba(38,37,31,.14)}
.clair .atouts li:last-child{border-color:rgba(38,37,31,.14)}
.clair .aico{border-color:rgba(62,80,55,.3);color:var(--garrigue)}
.clair .atouts p{color:var(--encre-2)}
.atouts.deux{display:grid}
@media(min-width:760px){.atouts.deux{grid-template-columns:1fr 1fr;gap:0 2.4rem}.atouts.deux li{border-top:1px solid rgba(38,37,31,.14)}}

/* note encadrée */
.note{border-left:2px solid var(--ocre);background:rgba(178,122,56,.08);padding:1rem 1.3rem;font-size:.95rem;color:var(--encre-2);margin:1.4rem 0}
.fonce .note{border-color:var(--or);background:rgba(217,185,138,.1);color:rgba(231,220,198,.85)}

/* galerie mosaïque */
.galerie{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:2.6rem}
.galerie .ph{aspect-ratio:1/1;border-radius:2px;transition:transform var(--tr)}
.galerie .ph img{transition:transform 700ms ease}
.galerie a:hover .ph img{transform:scale(1.07)}
.galerie a{display:block;overflow:hidden;border-radius:2px;box-shadow:0 10px 24px -20px rgba(38,37,31,.5)}
.galerie a:first-child{grid-column:span 2;grid-row:span 2}
.galerie a:first-child .ph{aspect-ratio:1/1}
@media(max-width:840px){.galerie{grid-template-columns:repeat(3,1fr)}.galerie a:first-child{grid-column:span 2;grid-row:span 2}}
@media(max-width:540px){.galerie{grid-template-columns:repeat(2,1fr)}.galerie a:first-child{grid-column:span 2;grid-row:auto}}

/* guide numéroté (carnet) */
.guide{counter-reset:e;list-style:none;margin:0;padding:0;display:grid;gap:1.1rem}
.guide li{counter-increment:e;position:relative;padding:1.4rem 1.5rem 1.4rem 4.6rem;background:var(--pierre-clair);border:1px solid rgba(38,37,31,.08);border-radius:2px}
.guide li::before{content:counter(e,decimal-leading-zero);position:absolute;left:1.4rem;top:1.3rem;font-family:var(--serif);font-size:1.5rem;font-weight:600;color:var(--ocre)}
.guide h3{font-size:1.2rem;margin-bottom:.25rem}
.guide p{margin:0;color:var(--encre-2);font-size:.95rem}

/* liens utiles */
.utiles{list-style:none;margin:.6rem 0 0;padding:0;display:grid;gap:.6rem}
.utiles a{display:inline-flex;align-items:center;gap:.5rem}

/* formulaire (contact / œnologie) */
.form{display:grid;gap:1.1rem}
.form label{display:grid;gap:.4rem;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--encre-2)}
.form input,.form textarea{
  font-family:var(--sans);font-size:1rem;font-weight:300;color:var(--encre);
  background:var(--pierre-clair);border:1px solid rgba(38,37,31,.2);border-radius:2px;padding:.85rem 1rem;width:100%;
  transition:border-color var(--tr),box-shadow var(--tr);
}
.form input:focus,.form textarea:focus{outline:none;border-color:var(--garrigue);box-shadow:0 0 0 3px rgba(62,80,55,.12)}
.form textarea{min-height:130px;resize:vertical}

/* bloc info terrasse / contact en grille */
.duo.haut{align-items:start}

/* ---- FAQ (accordéon) ---- */
.faq{display:grid;gap:.9rem}
.faq details{background:var(--pierre-clair);border:1px solid rgba(38,37,31,.1);border-radius:2px;overflow:hidden}
.faq summary{
  list-style:none;cursor:pointer;padding:1.15rem 3rem 1.15rem 1.4rem;position:relative;
  font-family:var(--serif);font-size:1.2rem;color:var(--encre);transition:color var(--tr);
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:"";position:absolute;right:1.4rem;top:50%;width:11px;height:11px;
  border-right:1.5px solid var(--ocre);border-bottom:1.5px solid var(--ocre);
  transform:translateY(-65%) rotate(45deg);transition:transform var(--tr);
}
.faq details[open] summary::after{transform:translateY(-35%) rotate(-135deg)}
.faq summary:hover{color:var(--ocre-texte)}
.faq details p{margin:0;padding:0 1.4rem 1.3rem;color:var(--encre-2);font-size:.97rem}

/* ---- liens légaux du footer ---- */
.pied-legal a{color:rgba(231,220,198,.75);text-decoration:none}
.pied-legal a:hover{color:var(--or)}
