:root{
  --pierre:#E8E1D4; --pierre-clr:#F5F1E8;
  --sauge:#8A9A7B; --sauge-fonce:#5F6E52;
  --bois:#9A7B5A; --terracotta:#C77B4F;
  --encre:#2E2A24; --blanc:#FCFAF6;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Inter',system-ui,sans-serif;
  --shadow:0 12px 40px rgba(46,42,36,.10);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--encre);background:var(--blanc);line-height:1.65;font-weight:400}
h1,h2,h3{font-family:var(--serif);font-weight:500;line-height:1.12;letter-spacing:.3px}
h1{font-size:clamp(2.6rem,7vw,5rem)}
h2{font-size:clamp(2rem,4.5vw,3.2rem);margin-bottom:1rem}
h3{font-size:1.55rem;margin-bottom:.4rem}
p{margin-bottom:1rem;max-width:64ch}
a{color:var(--sauge-fonce)}
img{max-width:100%;display:block}
.container{width:min(1140px,92%);margin-inline:auto}
.narrow{width:min(820px,92%);margin-inline:auto}
section{padding:5.5rem 0}
.eyebrow{text-transform:uppercase;letter-spacing:3px;font-size:.78rem;color:var(--bois);
  margin-bottom:.8rem;font-weight:500}
.lead{font-family:var(--serif);font-size:clamp(1.4rem,2.4vw,1.9rem);color:var(--sauge-fonce);line-height:1.35;max-width:30ch}
.center{text-align:center}
.bg-pierre{background:var(--pierre-clr)}
.bg-sauge{background:var(--sauge-fonce);color:var(--pierre-clr)}
.bg-sauge h2,.bg-sauge h3{color:var(--blanc)}

/* Header */
.header{position:sticky;top:0;z-index:60;background:rgba(252,250,246,.9);
  backdrop-filter:blur(10px);border-bottom:1px solid rgba(154,123,90,.18)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:.7rem 0;
  width:min(1140px,92%);margin-inline:auto}
.nav__brand{display:flex;align-items:center;text-decoration:none}
.brand-logo{height:60px;width:auto;display:block}
.nav__links{display:flex;gap:1.7rem;list-style:none;align-items:center}
.nav__links a{text-decoration:none;color:var(--encre);font-size:.92rem;letter-spacing:.3px}
.nav__links a:hover,.nav__links a[aria-current]{color:var(--terracotta)}
.nav__toggle{display:none;background:none;border:0;font-size:1.6rem;cursor:pointer;color:var(--encre)}

/* Buttons */
.btn{display:inline-block;padding:1rem 2.2rem;border-radius:1px;font-weight:500;text-decoration:none;
  cursor:pointer;border:0;font-size:.82rem;letter-spacing:.8px;text-transform:uppercase;font-family:var(--sans);
  transition:transform .25s ease,background .25s ease,color .25s ease}
.btn--primary{background:var(--sauge-fonce);color:var(--blanc)}
.btn--primary:hover{background:var(--encre);transform:translateY(-2px)}
.btn--secondary{background:transparent;color:var(--sauge-fonce);border:1px solid var(--sauge-fonce)}
.btn--secondary:hover{background:var(--sauge-fonce);color:var(--blanc)}
.btn--light{background:var(--blanc);color:var(--sauge-fonce)}
.btn--light:hover{background:var(--pierre);transform:translateY(-2px)}
.btn + .btn{margin-left:.6rem}

/* Hero */
.hero{position:relative;min-height:92vh;display:grid;align-items:end;color:var(--blanc);overflow:hidden}
.hero__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2}
.hero::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(to top,rgba(46,42,36,.78) 0%,rgba(46,42,36,.25) 45%,rgba(46,42,36,.30) 100%)}
.hero__inner{width:min(1140px,92%);margin-inline:auto;padding-bottom:4.5rem}
.hero h1{color:var(--blanc);max-width:16ch;margin-bottom:1rem;font-size:clamp(2.8rem,7.5vw,5.4rem);letter-spacing:.5px;text-shadow:0 2px 24px rgba(46,42,36,.35)}
.hero p{color:var(--pierre-clr);font-size:1.25rem;max-width:48ch;margin-bottom:2rem}
.hero__rating{display:inline-flex;align-items:center;gap:.5rem;font-size:.9rem;
  letter-spacing:1px;text-transform:uppercase;margin-bottom:1.2rem;color:var(--pierre-clr);backdrop-filter:blur(2px)}
.hero__rating b{color:var(--blanc)}

/* Intro / story */
.story{display:grid;grid-template-columns:1fr 1.2fr;gap:3.5rem;align-items:center}
.story__media img{width:100%;height:100%;object-fit:cover;border-radius:4px;box-shadow:var(--shadow);min-height:340px}

/* Logements */
.stay{display:grid;grid-template-columns:1.1fr 1fr;gap:2.5rem;align-items:center;margin-bottom:4rem}
.stay:nth-child(even){grid-template-columns:1fr 1.1fr}
.stay:nth-child(even) .stay__media{order:2}
.stay__media{overflow:hidden;border-radius:4px;box-shadow:var(--shadow)}
.stay__media img{width:100%;height:420px;object-fit:cover;transition:transform .8s ease}
.stay:hover .stay__media img{transform:scale(1.02)}
.stay__meta{display:flex;flex-wrap:wrap;gap:.5rem;margin:.8rem 0 1.2rem;font-size:.85rem}
.stay__meta span{background:var(--pierre);color:var(--sauge-fonce);padding:.3rem .8rem;border-radius:2px}
.amenities{list-style:none;display:flex;flex-wrap:wrap;gap:.4rem 1.2rem;margin:0 0 1.4rem;
  font-size:.9rem;color:var(--encre)}
.amenities li::before{content:"·  ";color:var(--terracotta);font-weight:700}

/* Gallery */
.gallery{columns:3;column-gap:.8rem}
.gallery img{width:100%;margin-bottom:.8rem;border-radius:3px;cursor:pointer;transition:filter .3s ease}
.gallery img:hover{filter:brightness(1.05)}
.gallery__label{font-family:var(--serif);font-size:1.6rem;color:var(--sauge-fonce);margin:2.5rem 0 1.2rem;break-after:avoid}
.lightbox{position:fixed;inset:0;background:rgba(46,42,36,.94);display:none;place-items:center;z-index:200;padding:2rem}
.lightbox.open{display:grid}
.lightbox img{max-height:90vh;max-width:92vw;border-radius:4px}
.lightbox__close{position:absolute;top:1.2rem;right:1.8rem;color:var(--blanc);font-size:2.4rem;
  background:none;border:0;cursor:pointer;line-height:1}

/* Activities */
.acts{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}
.act{padding:1.8rem;background:var(--blanc);border:1px solid rgba(154,123,90,.22);border-radius:4px}
.act .dist{display:inline-block;margin-top:.5rem;font-size:.82rem;color:var(--terracotta);letter-spacing:.5px}

/* Proof */
.proof{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:2rem;text-align:center}
.proof .num{font-family:var(--serif);font-size:3rem;color:var(--sauge-fonce);line-height:1}
.proof .lbl{font-size:.85rem;color:var(--bois);letter-spacing:1px;text-transform:uppercase}
.quote{font-family:var(--serif);font-size:clamp(1.5rem,3vw,2.1rem);font-style:italic;
  max-width:24ch;margin:1.5rem auto 0;line-height:1.3;color:var(--encre);position:relative}
.quote::before{content:"“";font-family:var(--serif);font-size:3.4rem;color:var(--terracotta);
  display:block;line-height:.4;margin-bottom:.6rem;opacity:.85}

/* Forms */
form{display:grid;gap:1.1rem;max-width:560px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
label{display:grid;gap:.35rem;font-size:.85rem;letter-spacing:.3px;color:var(--sauge-fonce)}
input,textarea,select{padding:.8rem;border:1px solid rgba(154,123,90,.4);border-radius:3px;
  font-family:inherit;font-size:1rem;background:var(--blanc);color:var(--encre)}
input:focus,textarea:focus,select:focus{outline:2px solid var(--sauge);outline-offset:1px;border-color:var(--sauge)}
textarea{min-height:120px;resize:vertical}
.reassure{display:flex;gap:1.6rem;flex-wrap:wrap;margin:1.4rem 0;font-size:.9rem;color:var(--sauge-fonce)}
.reassure span::before{content:"✓ ";color:var(--terracotta);font-weight:700}

/* FAQ */
details{border-bottom:1px solid rgba(154,123,90,.25);padding:1.2rem 0}
summary{font-family:var(--serif);font-size:1.3rem;cursor:pointer;color:var(--encre);list-style:none;
  display:flex;justify-content:space-between;align-items:center;gap:1rem}
summary::-webkit-details-marker{display:none}
summary::after{content:"+";color:var(--terracotta);font-size:1.6rem;transition:transform .2s}
details[open] summary::after{content:"−"}
details[open] summary{color:var(--sauge-fonce)}
details p{margin-top:.8rem;color:var(--encre)}

/* Footer */
.footer{background:var(--encre);color:var(--pierre);padding:3.5rem 0 2rem}
.footer a{color:var(--pierre-clr);text-decoration:none}
.footer a:hover{color:var(--terracotta)}
.footer__grid{display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(190px,1fr))}
.footer h3{color:var(--pierre-clr);margin-bottom:.6rem}
.footer__links{list-style:none;display:grid;gap:.4rem;font-size:.92rem}
.footer small{color:var(--bois)}
.footer__bottom{margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid rgba(232,225,212,.15)}

/* Reveal */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .8s ease,transform .8s ease}
.reveal.is-visible{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}}

/* Ornement */
.orn{display:block;width:54px;height:1px;background:var(--terracotta);opacity:.8;margin:1.2rem 0}
.center .orn{margin-inline:auto}

@media(max-width:860px){
  .story,.stay,.stay:nth-child(even){grid-template-columns:1fr;gap:1.8rem}
  .stay:nth-child(even) .stay__media{order:0}
  .gallery{columns:2}
}
@media(max-width:680px){
  .nav__links{position:absolute;top:100%;left:0;right:0;background:var(--blanc);flex-direction:column;
    padding:1.2rem;display:none;border-bottom:1px solid var(--pierre);gap:1.1rem}
  .nav__links.open{display:flex}
  .nav__toggle{display:block}
  .brand-logo{height:48px}
  .form-row{grid-template-columns:1fr}
  .btn + .btn{margin-left:0;margin-top:.6rem}
  section{padding:3.5rem 0}
}
