:root{
  --ivory:#f8f4ec; --lin:#f1ead9; --paper:#fffdf8; --cream:#efe7d6;
  --ink:#3a342c; --ink-soft:#6b6356; --muted:#9a9082;
  --wine:#7c3b3a; --wine-soft:#9a5450; --terra:#b07a4f;
  --olive:#6f7350; --gold:#b3924f; --gold-d:#977b3c;
  --line:rgba(58,52,44,.14);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;color:var(--ink);background:var(--ivory);line-height:1.75;font-weight:300;-webkit-font-smoothing:antialiased}
h1,h2,h3,.serif{font-family:'Cormorant Garamond',Georgia,serif;font-weight:500;letter-spacing:.005em}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.wrap{max-width:1240px;margin:0 auto;padding:0 32px}
.eyebrow{font-size:.7rem;letter-spacing:.4em;text-transform:uppercase;color:var(--gold-d);font-weight:400}
.divider{width:46px;height:1px;background:var(--gold);margin:18px 0}
.center{text-align:center}.center .divider{margin:18px auto}
.muted{color:var(--ink-soft)}
img.enh,video.enh{filter:saturate(1.05) contrast(1.02)}

/* Header — sable en permanence (menus toujours visibles) */
header{position:fixed;inset:0 0 auto 0;z-index:60;padding:16px 0;background:rgba(248,244,236,.96);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);transition:padding .4s}
header.scrolled{padding:11px 0}
.nav{display:flex;align-items:center;justify-content:space-between}
.brand{display:flex;flex-direction:column;line-height:1}
.brand .m{font-family:'Cormorant Garamond',serif;font-size:1.5rem;letter-spacing:.2em;color:var(--ink)}
.brand .s{font-size:.56rem;letter-spacing:.36em;text-transform:uppercase;color:var(--gold-d);margin-top:5px}
.nav-links{display:flex;gap:30px;align-items:center}
.nav-links a{font-size:.78rem;letter-spacing:.08em;color:var(--ink);transition:.3s;white-space:nowrap}
.nav-links a.on{color:var(--wine)}
.nav-links a:not(.btn):hover{color:var(--wine)}
.btn{display:inline-flex;align-items:center;gap:.5rem;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;padding:13px 28px;border-radius:2px;transition:.4s;cursor:pointer;border:1px solid var(--wine);font-weight:400}
.btn-wine{background:var(--wine);color:#fff!important;border-color:var(--wine);text-shadow:none!important}
.btn-wine:hover{background:var(--wine-soft)}
.btn-line{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-line:hover{background:var(--ink);color:var(--ivory)}
.menu-toggle{display:none}
@media(max-width:1040px){
  .nav-links a:not(.btn){display:none}
  .nav-links a.btn{padding:11px 20px}
}

/* Hero (home) */
.hero{position:relative;height:100vh;min-height:620px;display:flex;align-items:flex-end;overflow:hidden;background:#241d15}
.hero img.bg,.hero video.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 42%}
.hero::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;background:linear-gradient(180deg,transparent 0%,transparent 50%,rgba(20,15,10,.16) 72%,rgba(14,10,6,.6) 100%)}
.hero-inner{position:relative;z-index:2;color:#fff;padding-bottom:9vh;max-width:790px;text-shadow:0 2px 16px rgba(0,0,0,.5)}
.hero .eyebrow{color:#f6ecd8}
.hero h1{font-size:clamp(2.7rem,6.4vw,5.4rem);line-height:1.02;color:#fff;font-weight:400;margin:18px 0 6px;text-shadow:0 3px 26px rgba(0,0,0,.6),0 1px 3px rgba(0,0,0,.5)}
.hero h1 em{font-style:italic;color:#f4dcab}
.hero p{font-size:1.08rem;color:#fff;max-width:580px;font-weight:300;margin:14px 0 0;text-shadow:0 2px 16px rgba(0,0,0,.65),0 1px 3px rgba(0,0,0,.5)}
.cta-row{display:flex;gap:14px;margin-top:34px;flex-wrap:wrap}
.cta-row .btn-line{color:#fff;border-color:rgba(255,255,255,.65)}
.cta-row .btn-line:hover{background:#fff;color:var(--ink)}
/* Hero piscine (photo claire) : voile renforce pour lisibilite du texte */
.hero-pool::after{background:linear-gradient(180deg,rgba(28,22,16,.18) 0%,rgba(28,22,16,0) 30%,rgba(26,20,14,.34) 62%,rgba(20,15,10,.82) 100%),linear-gradient(75deg,rgba(20,15,10,.5) 0%,rgba(20,15,10,.12) 42%,rgba(20,15,10,0) 70%)}
.hero-pool .hero-inner{text-shadow:0 1px 18px rgba(0,0,0,.45)}
/* Hero rotator (slideshow en fondu) */
.hero-rotator img.bg{opacity:0;transition:opacity 1.6s ease}
.hero-rotator img.bg.active{opacity:1}

/* Sub-page banner */
.banner{position:relative;height:62vh;min-height:420px;display:flex;align-items:flex-end;overflow:hidden;background:#241d15}
.banner img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 45%}
.banner::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(30,24,18,.32) 0%,rgba(30,24,18,.05) 40%,rgba(28,22,16,.66) 100%)}
.banner .inner{position:relative;z-index:2;color:#fff;padding-bottom:7vh}
.banner .eyebrow{color:#f3e7cf}
.banner h1{font-size:clamp(2.4rem,5.4vw,4.4rem);color:#fff;font-weight:400;margin-top:12px;text-shadow:0 2px 30px rgba(0,0,0,.35)}
.banner h1 em{font-style:italic;color:#f4dcab}
.banner .inner p{color:rgba(255,255,255,.95);max-width:560px;margin-top:14px;font-weight:300;font-size:1.04rem;text-shadow:0 2px 14px rgba(0,0,0,.6),0 1px 3px rgba(0,0,0,.45)}

/* Blocks */
section.block{padding:104px 0}
section.block.sm{padding:80px 0}
h2.title{font-size:clamp(2rem,4vw,3.2rem);font-weight:400;line-height:1.08;margin:14px 0 0}
.lead-c{max-width:680px;margin:14px auto 0;color:var(--ink-soft)}
.band-paper{background:var(--paper)}.band-cream{background:var(--cream)}.band-lin{background:var(--lin)}

/* Altitude */
.alt{background:var(--paper);text-align:center;padding:84px 0}
.alt .big{font-family:'Cormorant Garamond',serif;font-size:clamp(2.6rem,6vw,4.4rem);color:var(--wine);line-height:1;font-weight:500}
.alt h2{font-size:clamp(1.7rem,3.2vw,2.5rem);font-weight:400;margin:6px 0 4px}
.alt p{color:var(--ink-soft);max-width:600px;margin:14px auto 0}
.feats{display:flex;justify-content:center;gap:50px;margin-top:40px;flex-wrap:wrap}
.feat .fl{font-family:'Cormorant Garamond',serif;font-size:1.05rem;color:var(--ink)}
.feat .fk{font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);margin-top:4px}

/* Split */
.split{display:grid;grid-template-columns:1.02fr 1fr;gap:64px;align-items:center}
.split.rev .txt{order:2}
.ph{border-radius:3px;overflow:hidden;box-shadow:0 30px 70px rgba(58,52,44,.16)}
.ph img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/5}
.split .txt p{margin-top:16px;color:var(--ink-soft)}
.split .txt p strong{color:var(--ink);font-weight:500}
@media(max-width:880px){.split,.split.rev{grid-template-columns:1fr;gap:34px}.split.rev .txt{order:0}}

/* Video */
.videoblock{border-radius:4px;overflow:hidden;box-shadow:0 30px 80px rgba(58,52,44,.22);background:#241d15}
.videoblock video{width:100%;display:block;aspect-ratio:16/9;object-fit:cover}
/* Video pleine largeur (embed, sans player) */
.videofull{width:100%;background:#1c1814;line-height:0}
.videofull video{width:100%;height:auto;max-height:90vh;display:block;object-fit:cover;pointer-events:none}

/* Full-bleed vista */
.vista{position:relative;height:78vh;min-height:500px;display:flex;align-items:center;overflow:hidden}
.vista.center-x{justify-content:center;text-align:center}
.vista img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 55%}
.vista::after{content:"";position:absolute;inset:0}
.vista.dim::after{background:linear-gradient(180deg,rgba(40,34,26,.32),rgba(40,34,26,.46))}
.vista.sunset::after{background:linear-gradient(110deg,rgba(28,20,14,.62) 0%,rgba(60,32,18,.34) 42%,rgba(176,122,79,.16) 100%)}
.vista .q{position:relative;z-index:2;color:#fff;max-width:680px;padding:0 32px}
.vista.center-x .q{margin:0 auto}
.vista .eyebrow{color:#f3e7cf}
.vista .q h2{font-size:clamp(2rem,4.2vw,3.3rem);font-weight:400;color:#fff;line-height:1.14;margin-top:12px}
.vista .q h2 em{font-style:italic;color:#f4dcab}
.vista .q p{margin-top:16px;color:rgba(255,255,255,.9);max-width:520px;font-weight:300}
.vista.center-x .q p{margin-left:auto;margin-right:auto}

/* Cards trio */
.tgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:54px}
.pcard{background:var(--paper);border-radius:4px;overflow:hidden;transition:.5s;box-shadow:0 10px 30px rgba(58,52,44,.07);display:flex;flex-direction:column}
.pcard:hover{transform:translateY(-7px);box-shadow:0 30px 64px rgba(58,52,44,.16)}
.pcard .pic{aspect-ratio:4/5;overflow:hidden}
.pcard .pic img{width:100%;height:100%;object-fit:cover;transition:1.1s ease}
.pcard:hover .pic img{transform:scale(1.06)}
.pcard .body{padding:26px 28px 30px}
.pcard h3{font-size:1.7rem;font-weight:500}
.pcard .e{font-size:.62rem;letter-spacing:.26em;text-transform:uppercase;color:var(--gold-d)}
.pcard p{margin-top:8px;color:var(--ink-soft);font-size:.94rem}
.pcard .more{margin-top:14px;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--wine)}
@media(max-width:880px){.tgrid{grid-template-columns:1fr;max-width:420px;margin:54px auto 0}}

/* Gallery */
.gal{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:40px}
.gal img{width:100%;height:100%;object-fit:cover;aspect-ratio:1/1;border-radius:3px}
.gal .tall{grid-row:span 2;aspect-ratio:auto}
@media(max-width:760px){.gal{grid-template-columns:1fr 1fr}}

/* Rooms list */
.rooms{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:54px}
.room{border-radius:4px;overflow:hidden;background:var(--paper);box-shadow:0 10px 28px rgba(58,52,44,.08)}
.room img{width:100%;aspect-ratio:4/3;object-fit:cover}
.room .b{padding:20px 22px 26px}
.room h3{font-size:1.5rem;font-weight:500}
.room p{color:var(--ink-soft);font-size:.9rem;margin-top:6px}
@media(max-width:880px){.rooms{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.rooms{grid-template-columns:1fr}}

/* Menu list */
.menucard{background:var(--paper);border:1px solid var(--line);border-radius:4px;padding:36px 40px;max-width:720px;margin:46px auto 0}
.menucard .mh{font-size:.64rem;letter-spacing:.26em;text-transform:uppercase;color:var(--gold-d);text-align:center}
.menucard h3{font-size:1.8rem;text-align:center;margin:6px 0 22px}
.menu-item{display:flex;justify-content:space-between;gap:16px;padding:12px 0;border-bottom:1px dashed var(--line)}
.menu-item:last-child{border-bottom:none}
.menu-item .n{font-family:'Cormorant Garamond',serif;font-size:1.2rem}
.menu-item .d{color:var(--muted);font-size:.86rem;text-align:right;max-width:280px}

/* Reserve */
.reserve{background:var(--ink);color:#fff;text-align:center}
.reserve .eyebrow{color:#e7c98f}
.reserve h2{color:#fff}
.reserve p{color:rgba(255,255,255,.72);max-width:540px;margin:16px auto 28px}
.reserve .cta-row{justify-content:center}
.reserve .btn-line{color:#fff;border-color:rgba(255,255,255,.55)}
.reserve .btn-line:hover{background:#fff;color:var(--ink)}
.reserve .tel{margin-top:24px;font-size:.85rem;color:rgba(255,255,255,.55)}

/* Reservation widgets (mock) */
.resgrid{display:grid;grid-template-columns:1fr 1fr;gap:30px;margin-top:50px}
.reswidget{background:var(--paper);border:1px solid var(--line);border-radius:5px;padding:32px 32px 36px;box-shadow:0 14px 40px rgba(58,52,44,.08)}
.reswidget h3{font-size:1.7rem;margin-bottom:4px}
.reswidget .e{font-size:.62rem;letter-spacing:.26em;text-transform:uppercase;color:var(--gold-d)}
.field{margin-top:16px}
.field label{display:block;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.field input,.field select{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:3px;background:#fff;font-family:inherit;font-size:.92rem;color:var(--ink)}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.reswidget .btn-wine{width:100%;justify-content:center;margin-top:22px}
.pay{margin-top:14px;font-size:.74rem;color:var(--muted);text-align:center}
@media(max-width:760px){.resgrid{grid-template-columns:1fr}}

/* Footer */
footer{background:var(--lin);color:var(--ink-soft);padding:64px 0 28px;font-size:.86rem}
.fgrid{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap}
footer .m{font-family:'Cormorant Garamond',serif;font-size:1.4rem;letter-spacing:.2em;color:var(--ink)}
footer a:hover{color:var(--wine)}
.ftit{color:var(--ink);letter-spacing:.2em;text-transform:uppercase;font-size:.68rem;margin-bottom:14px}
.fnote{margin-top:44px;padding-top:22px;border-top:1px solid var(--line);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.74rem;color:var(--muted)}
.badge{display:inline-block;margin-top:10px;font-size:.6rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold-d);border:1px solid var(--line);padding:6px 12px;border-radius:2px}

.reveal{opacity:0;transform:translateY(26px);transition:1s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
