/* =========================================================
   LA VIGIE — Maison d'hôtes · Le Thoronet, cœur du Var
   Design system : olive / pierre / laiton — Cormorant + Jost
   ========================================================= */

:root{
  --ink:#23241d;
  --olive:#3a4330;
  --olive-700:#4c573d;
  --sage:#7d8567;
  --brass:#a98a54;
  --brass-soft:#bfa173;
  --stone-50:#fbf8f1;
  --stone-100:#f4eee2;
  --stone-200:#ece3d3;
  --stone-300:#ddd1ba;
  --paper:#fffdf8;
  --line:rgba(58,67,48,.16);

  --serif:"Cormorant Garamond", Georgia, serif;
  --sans:"Jost", "Helvetica Neue", Arial, sans-serif;

  --maxw:1240px;
  --gut:clamp(20px,5vw,68px);
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{
  font-family:var(--sans);
  font-weight:300;
  color:var(--ink);
  background:var(--paper);
  line-height:1.7;
  font-size:17px;
  overflow-x:hidden;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}

/* ---------- typography helpers ---------- */
.overline{
  font-family:var(--sans);
  font-weight:500;
  font-size:.72rem;
  letter-spacing:.34em;
  text-transform:uppercase;
  color:var(--brass);
  display:inline-block;
}
h1,h2,h3{font-family:var(--serif);font-weight:500;line-height:1.04;letter-spacing:.01em}
h2{font-size:clamp(2.1rem,5vw,3.6rem)}
h3{font-size:clamp(1.5rem,3vw,2.1rem)}
.lead{font-size:clamp(1.15rem,2vw,1.4rem);font-weight:300;line-height:1.6}
p+p{margin-top:1.1em}
.serif-italic{font-family:var(--serif);font-style:italic}

/* ---------- layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gut)}
section{position:relative}
.section-pad{padding-block:clamp(70px,11vw,150px)}

/* ---------- reveal animation ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.12s}
.reveal.d2{transition-delay:.24s}
.reveal.d3{transition-delay:.36s}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* =========================================================
   HEADER
   ========================================================= */
.site-header{
  position:fixed;inset:0 0 auto 0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px var(--gut);
  transition:background .5s var(--ease),padding .5s var(--ease),box-shadow .5s var(--ease);
}
.site-header.solid{
  background:rgba(251,248,241,.93);
  backdrop-filter:blur(10px);
  padding-block:14px;
  box-shadow:0 1px 0 var(--line);
}
.brand{display:flex;flex-direction:column;line-height:1;color:#fff;transition:color .5s var(--ease)}
.site-header.solid .brand{color:var(--olive)}
.brand .mark{font-family:var(--serif);font-weight:600;font-size:1.7rem;letter-spacing:.06em}
.brand .sub{font-family:var(--sans);font-weight:400;font-size:.6rem;letter-spacing:.32em;text-transform:uppercase;margin-top:5px;opacity:.85}

.nav{display:flex;align-items:center;gap:38px}
.nav .btn-ghost{display:none}
.nav a{
  color:#fff;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;font-weight:400;
  position:relative;transition:color .4s var(--ease);
}
.site-header.solid .nav a{color:var(--olive-700)}
.nav a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:1px;background:var(--brass);transition:width .4s var(--ease)}
.nav a:hover::after{width:100%}
.nav a:hover{color:var(--brass)}

.btn{
  display:inline-block;font-family:var(--sans);font-weight:400;font-size:.76rem;
  letter-spacing:.18em;text-transform:uppercase;
  padding:13px 26px;border:1px solid currentColor;border-radius:2px;
  transition:background .4s var(--ease),color .4s var(--ease),border-color .4s var(--ease);
}
.btn-light{color:#fff}
.btn-light:hover{background:#fff;color:var(--olive);border-color:#fff}
.site-header.solid .btn-light{color:var(--olive)}
.site-header.solid .btn-light:hover{background:var(--olive);color:#fff;border-color:var(--olive)}
.btn-solid{background:var(--olive);color:var(--stone-50);border-color:var(--olive)}
.btn-solid:hover{background:var(--ink);border-color:var(--ink)}
.btn-ghost{color:var(--olive)}
.btn-ghost:hover{background:var(--olive);color:#fff}

.nav-toggle{display:none;width:34px;height:34px;position:relative;z-index:120}
.nav-toggle span{position:absolute;left:5px;right:5px;height:1.5px;background:#fff;transition:.4s var(--ease)}
.site-header.solid .nav-toggle span{background:var(--olive)}
.nav-toggle span:nth-child(1){top:12px}
.nav-toggle span:nth-child(2){top:21px}
.nav-open .nav-toggle span{background:var(--olive)}
.nav-open .nav-toggle span:nth-child(1){transform:rotate(45deg);top:16px}
.nav-open .nav-toggle span:nth-child(2){transform:rotate(-45deg);top:16px}

/* =========================================================
   HERO
   ========================================================= */
.hero{position:relative;height:100svh;min-height:620px;display:flex;align-items:flex-end;color:#fff;overflow:hidden}
.hero__bg{position:absolute;inset:0;z-index:-2}
.hero__bg img{width:100%;height:100%;object-fit:cover;animation:kenburns 22s ease-out forwards}
@keyframes kenburns{from{transform:scale(1.08)}to{transform:scale(1)}}
.hero::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg,rgba(35,36,29,.42) 0%,rgba(35,36,29,.05) 35%,rgba(35,36,29,.62) 100%)}
.hero__inner{width:100%;padding-bottom:clamp(48px,8vw,96px)}
.hero h1{font-size:clamp(3.6rem,12vw,9rem);font-weight:500;letter-spacing:.02em;line-height:.9;text-shadow:0 2px 40px rgba(0,0,0,.25)}
.hero .overline{color:rgba(255,255,255,.92);margin-bottom:22px}
.hero__tag{font-family:var(--serif);font-style:italic;font-size:clamp(1.25rem,2.6vw,1.9rem);font-weight:400;max-width:34ch;margin-top:18px;opacity:.96}
.hero__facts{
  display:flex;flex-wrap:wrap;gap:14px 30px;margin-top:36px;
  font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;font-weight:400;
}
.hero__facts span{display:flex;align-items:center;gap:14px}
.hero__facts span:not(:last-child)::after{content:"";width:5px;height:5px;border-radius:50%;background:var(--brass-soft)}
.scroll-cue{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:2;
  font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,.8);
  display:flex;flex-direction:column;align-items:center;gap:10px}
.scroll-cue::after{content:"";width:1px;height:46px;background:rgba(255,255,255,.6);animation:cue 2s var(--ease) infinite}
@keyframes cue{0%{transform:scaleY(0);transform-origin:top}45%{transform:scaleY(1);transform-origin:top}55%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* =========================================================
   INTRO / LA MAISON
   ========================================================= */
.intro{background:var(--stone-50)}
.intro__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(36px,6vw,90px);align-items:center}
.intro__copy .overline{margin-bottom:20px}
.intro__copy h2{margin-bottom:26px;color:var(--olive)}
.intro__copy p{color:#3c3d33}
.intro__media{position:relative}
.intro__media img{border-radius:2px;width:100%;aspect-ratio:4/5;object-fit:cover;box-shadow:0 30px 70px -40px rgba(58,67,48,.55)}
.intro__media .badge{
  position:absolute;bottom:-26px;left:-26px;background:var(--olive);color:var(--stone-50);
  padding:24px 30px;max-width:230px;border-radius:2px;box-shadow:0 24px 50px -30px rgba(0,0,0,.5)}
.intro__media .badge .num{font-family:var(--serif);font-size:2.8rem;line-height:1;color:var(--brass-soft)}
.intro__media .badge .lbl{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;margin-top:8px;opacity:.9}

.distances{display:flex;flex-wrap:wrap;gap:0;margin-top:40px;border-top:1px solid var(--line)}
.distances div{flex:1 1 140px;padding:20px 0;border-bottom:1px solid var(--line)}
.distances .d-num{font-family:var(--serif);font-size:1.7rem;color:var(--olive)}
.distances .d-lbl{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--sage);margin-top:4px}

/* =========================================================
   DOMAINE / amenities
   ========================================================= */
.domaine{background:var(--olive);color:var(--stone-100)}
.domaine .overline{color:var(--brass-soft)}
.domaine__head{max-width:680px;margin-bottom:60px}
.domaine__head h2{color:var(--stone-50);margin:20px 0}
.domaine__head p{opacity:.82}
.feature-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.12)}
.feature{background:var(--olive);padding:34px 26px;transition:background .5s var(--ease)}
.feature:hover{background:var(--olive-700)}
.feature .ico{width:30px;height:30px;stroke:var(--brass-soft);stroke-width:1.3;fill:none;margin-bottom:18px}
.feature h4{font-family:var(--serif);font-size:1.3rem;font-weight:500;color:var(--stone-50);margin-bottom:6px}
.feature p{font-size:.86rem;opacity:.72;line-height:1.5}

.domaine__strip{display:grid;grid-template-columns:2fr 1fr 1fr;gap:1px;margin-top:1px}
.domaine__strip img{width:100%;height:100%;object-fit:cover;aspect-ratio:3/2;filter:saturate(.95)}

/* =========================================================
   CHAMBRES
   ========================================================= */
.chambres{background:var(--stone-50)}
.chambres__head{text-align:center;max-width:640px;margin:0 auto 70px}
.chambres__head h2{color:var(--olive);margin:18px 0}
.chambres__head p{color:#3c3d33}

.room{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,76px);align-items:center;margin-bottom:clamp(64px,9vw,120px)}
.room:nth-child(even) .room__media{order:2}
.room__media{position:relative}
.room__media .main{width:100%;aspect-ratio:5/4;object-fit:cover;border-radius:2px;box-shadow:0 30px 70px -45px rgba(58,67,48,.6)}
.room__media .thumb{position:absolute;width:42%;aspect-ratio:1;object-fit:cover;border:6px solid var(--stone-50);border-radius:2px;bottom:-30px;box-shadow:0 20px 40px -24px rgba(0,0,0,.4)}
.room:nth-child(odd) .room__media .thumb{right:-22px}
.room:nth-child(even) .room__media .thumb{left:-22px}
.room__num{font-family:var(--serif);font-size:1rem;color:var(--brass);letter-spacing:.2em}
.room__copy h3{color:var(--olive);margin:8px 0 18px}
.room__copy p{color:#3c3d33;max-width:46ch}
.room__meta{display:flex;flex-wrap:wrap;gap:10px;margin:24px 0 26px}
.room__meta span{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--olive-700);
  border:1px solid var(--line);border-radius:40px;padding:8px 16px}
.room__meta span.hl{background:var(--olive);color:var(--stone-50);border-color:var(--olive)}
.room__gallery-btn{display:inline-flex;align-items:center;gap:10px;font-size:.74rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--olive);border-bottom:1px solid var(--brass);padding-bottom:5px;transition:.4s var(--ease)}
.room__gallery-btn:hover{color:var(--brass);gap:16px}

/* =========================================================
   GALERIE
   ========================================================= */
.galerie{background:var(--stone-100)}
.galerie__head{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:20px;margin-bottom:44px}
.galerie__head h2{color:var(--olive)}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:14px}
.gallery-grid figure{overflow:hidden;border-radius:2px;cursor:pointer;position:relative}
.gallery-grid img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.gallery-grid figure:hover img{transform:scale(1.07)}
.gallery-grid figure::after{content:"";position:absolute;inset:0;background:rgba(58,67,48,0);transition:background .5s var(--ease)}
.gallery-grid figure:hover::after{background:rgba(58,67,48,.12)}
.g-tall{grid-row:span 2}
.g-wide{grid-column:span 2}

/* =========================================================
   SITUATION / LE THORONET
   ========================================================= */
.situation{background:var(--stone-50)}
.situation__grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:clamp(36px,6vw,80px);align-items:center}
.situation__copy .overline{margin-bottom:20px}
.situation__copy h2{color:var(--olive);margin-bottom:24px}
.situation__copy p{color:#3c3d33}
.situation__list{margin-top:30px;display:grid;gap:14px}
.situation__list li{list-style:none;display:flex;gap:16px;align-items:baseline;font-size:.96rem}
.situation__list li b{font-family:var(--serif);font-style:italic;font-weight:500;color:var(--olive);min-width:120px}
.map-frame{border-radius:2px;overflow:hidden;box-shadow:0 30px 70px -45px rgba(58,67,48,.6);aspect-ratio:4/3}
.map-frame iframe{width:100%;height:100%;border:0;filter:grayscale(.2) saturate(.9)}

/* =========================================================
   RESERVATION / CONTACT
   ========================================================= */
.contact{background:var(--ink);color:var(--stone-100);position:relative;overflow:hidden}
.contact__bg{position:absolute;inset:0;opacity:.16;z-index:0}
.contact__bg img{width:100%;height:100%;object-fit:cover}
.contact .wrap{position:relative;z-index:1}
.contact__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,7vw,100px)}
.contact .overline{color:var(--brass-soft)}
.contact h2{color:var(--stone-50);margin:18px 0 22px}
.contact__intro{opacity:.82;max-width:42ch}
.contact__info{margin-top:36px;display:grid;gap:22px}
.contact__info .item .k{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--brass-soft)}
.contact__info .item .v{font-family:var(--serif);font-size:1.5rem;color:var(--stone-50);margin-top:4px}
.contact__info .item .v a:hover{color:var(--brass-soft)}
.contact__cta{margin-top:38px;display:flex;flex-wrap:wrap;gap:16px}
.btn-brass{background:var(--brass);color:var(--ink);border-color:var(--brass);font-weight:500}
.btn-brass:hover{background:var(--brass-soft);border-color:var(--brass-soft)}
.btn-outline-light{color:var(--stone-100);border-color:rgba(255,255,255,.4)}
.btn-outline-light:hover{background:rgba(255,255,255,.1);border-color:#fff}

/* form */
.cform{display:grid;gap:18px;background:rgba(255,255,255,.04);padding:clamp(26px,4vw,42px);border:1px solid rgba(255,255,255,.12);border-radius:2px}
.cform .row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.cform label{display:block;font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--brass-soft);margin-bottom:8px}
.cform input,.cform textarea{width:100%;background:transparent;border:none;border-bottom:1px solid rgba(255,255,255,.25);
  color:var(--stone-50);font-family:var(--sans);font-size:1rem;padding:10px 0;transition:border-color .4s var(--ease)}
.cform input:focus,.cform textarea:focus{outline:none;border-color:var(--brass)}
.cform textarea{resize:vertical;min-height:90px}
.cform .btn{justify-self:start;margin-top:8px}
.cform__note{font-size:.78rem;opacity:.6;margin-top:4px}

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer{background:#1b1c16;color:rgba(244,238,226,.7);padding-block:64px 30px;font-size:.86rem}
.footer__top{display:flex;justify-content:space-between;flex-wrap:wrap;gap:36px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer__brand .mark{font-family:var(--serif);font-size:1.8rem;color:var(--stone-50);letter-spacing:.06em}
.footer__brand .sub{font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;margin-top:6px;color:var(--brass-soft)}
.footer__brand p{margin-top:16px;max-width:30ch;opacity:.8}
.footer__cols{display:flex;gap:clamp(40px,8vw,100px);flex-wrap:wrap}
.footer__cols h5{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--brass-soft);margin-bottom:16px}
.footer__cols ul{list-style:none;display:grid;gap:9px}
.footer__cols a:hover{color:var(--stone-50)}
.footer__bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;padding-top:24px;font-size:.76rem;opacity:.6}
.footer__bottom a{color:var(--brass-soft)}

/* =========================================================
   LIGHTBOX
   ========================================================= */
.lightbox{position:fixed;inset:0;z-index:200;background:rgba(20,21,16,.96);display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity .45s var(--ease)}
.lightbox.open{opacity:1;pointer-events:auto}
.lightbox img{max-width:90vw;max-height:84vh;object-fit:contain;border-radius:2px;box-shadow:0 40px 80px -30px #000}
.lb-btn{position:absolute;color:#fff;font-size:2rem;width:60px;height:60px;display:flex;align-items:center;justify-content:center;opacity:.8;transition:.3s}
.lb-btn:hover{opacity:1}
.lb-close{top:20px;right:24px;font-size:1.6rem}
.lb-prev{left:14px;top:50%;transform:translateY(-50%)}
.lb-next{right:14px;top:50%;transform:translateY(-50%)}
.lb-count{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.7);
  font-size:.74rem;letter-spacing:.2em}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media(max-width:1000px){
  .feature-grid{grid-template-columns:repeat(2,1fr)}
  .gallery-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:180px}
  .g-wide{grid-column:span 1}
}
@media(max-width:860px){
  .nav,.header-cta{display:none}
  .nav-toggle{display:block}
  .nav.mobile{display:flex;position:fixed;inset:0;flex-direction:column;justify-content:center;align-items:center;gap:30px;
    background:var(--stone-50);transform:translateY(-100%);transition:transform .55s var(--ease);z-index:110}
  .nav-open .nav.mobile{transform:none}
  .nav.mobile a{color:var(--olive)!important;font-size:1rem;letter-spacing:.22em}
  .nav.mobile .btn-ghost{display:inline-block;margin-top:10px}
  .intro__grid,.situation__grid,.contact__grid{grid-template-columns:1fr}
  .room{grid-template-columns:1fr;gap:40px}
  .room:nth-child(even) .room__media{order:0}
  .room__media .thumb{display:none}
  .domaine__strip{grid-template-columns:1fr 1fr}
  .cform .row{grid-template-columns:1fr}
  .intro__media{margin-bottom:30px}
  .intro__media .badge{left:0;bottom:-20px}
}
@media(max-width:560px){
  body{font-size:16px}
  .feature-grid{grid-template-columns:1fr 1fr}
  .gallery-grid{grid-template-columns:1fr;grid-auto-rows:240px}
  .g-tall{grid-row:span 1}
  .footer__top{flex-direction:column}
  .hero__facts{gap:10px 18px}
  .hero__facts span:not(:last-child)::after{display:none}
}
