/* ============================================================
   MAS BEAUREGARD — Anduze, porte des Cévennes
   Thème CLAIR : ciel, nuages & soleil · olivier · terre cuite
   ============================================================ */

:root {
  --paper:    #fbfcf9;
  --paper-2:  #f4f7f1;
  --cloud:    #ffffff;
  --mist:     #eef2ea;

  --olive-100: #eef1e6;
  --olive-200: #dfe5d2;
  --olive-300: #c8d2b4;
  --olive-400: #a7b487;
  --olive-500: #8a986a;
  --olive-600: #6d7a5a;
  --olive-700: #566248;
  --olive-800: #3f4a37;

  --terra:    #c0724f;
  --terra-dk: #a85e3d;
  --sun:      #ffd27a;

  --ink:      #3a4231;
  --ink-soft: #5d6650;
  --muted:    #828b73;

  --glass:        rgba(255, 255, 255, .60);
  --glass-strong: rgba(255, 255, 255, .85);
  --hairline:     rgba(86, 98, 72, .14);

  --shadow-sm: 0 2px 10px rgba(86, 98, 72, .06);
  --shadow-md: 0 14px 40px -18px rgba(63, 74, 55, .28);
  --shadow-lg: 0 30px 70px -30px rgba(63, 74, 55, .35);

  --radius:    22px;
  --radius-sm: 14px;
  --maxw:      1180px;
  --ease:      cubic-bezier(.22, .61, .36, 1);

  --serif: "Fraunces", "Iowan Old Style", Georgia, serif;
  --sans:  "Mulish", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
  font-family: var(--sans);
  color: var(--ink);
  background: var(--paper);
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; }

h1, h2, h3, h4 { font-family: var(--serif); font-weight: 500; line-height: 1.12; letter-spacing: -.01em; color: var(--ink); }
::selection { background: var(--olive-300); color: var(--olive-800); }

.wrap { width: min(var(--maxw), 92vw); margin-inline: auto; }
.section { padding: clamp(60px, 9vw, 124px) 0; position: relative; }
.center { text-align: center; }

.two-col { display: grid; grid-template-columns: 1.05fr 1fr; gap: clamp(32px, 5vw, 76px); align-items: center; }
.two-col.reverse { grid-template-columns: 1fr 1.05fr; }

.eyebrow { text-transform: uppercase; letter-spacing: .26em; font-size: .72rem; font-weight: 700; color: var(--terra-dk); margin-bottom: 1.1rem; }
h2 { font-size: clamp(1.9rem, 4vw, 3rem); }
.lede { font-size: clamp(1.02rem, 1.6vw, 1.18rem); color: var(--ink-soft); max-width: 60ch; }
.section-head { text-align: center; max-width: 46rem; margin: 0 auto clamp(38px, 5vw, 64px); }
.section-head .lede { margin-inline: auto; }

/* ---------- Buttons ---------- */
.btn { display: inline-flex; align-items: center; gap: .5rem; padding: .92rem 1.8rem; border-radius: 999px; font-weight: 700; font-size: .96rem; letter-spacing: .01em; transition: transform .35s var(--ease), box-shadow .35s var(--ease), background .3s, color .3s; border: 1.5px solid transparent; }
.btn-primary { background: var(--terra); color: #fff; box-shadow: 0 14px 28px -12px rgba(168, 94, 61, .6); }
.btn-primary:hover { transform: translateY(-2px); background: var(--terra-dk); }
.btn-ghost { background: var(--glass); color: var(--ink); border-color: var(--hairline); backdrop-filter: blur(8px); }
.btn-ghost:hover { transform: translateY(-2px); background: var(--cloud); }

/* ============================================================ HEADER */
.site-header { position: fixed; inset: 0 0 auto 0; z-index: 50; display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: 1.1rem clamp(18px, 4vw, 46px); transition: background .4s var(--ease), box-shadow .4s var(--ease), padding .4s var(--ease); }
.site-header.scrolled { background: var(--glass-strong); backdrop-filter: blur(16px) saturate(1.3); box-shadow: 0 1px 0 var(--hairline), var(--shadow-sm); padding-block: .7rem; }
.brand { display: inline-flex; align-items: center; gap: .6rem; color: var(--ink); z-index: 60; }
.brand-sprig { width: 27px; height: 35px; color: var(--ink); flex: none; }
.brand-name { font-family: var(--serif); font-size: 1.32rem; font-weight: 600; letter-spacing: .01em; }
.nav { display: flex; align-items: center; gap: clamp(.6rem, 1.6vw, 1.5rem); }
.nav a { font-size: .92rem; font-weight: 600; color: var(--ink-soft); padding: .4rem .2rem; position: relative; transition: color .25s; }
.nav a:not(.nav-cta)::after { content: ""; position: absolute; left: 0; bottom: -2px; width: 100%; height: 1.5px; background: var(--terra); transform: scaleX(0); transform-origin: left; transition: transform .35s var(--ease); }
.nav a:not(.nav-cta):hover { color: var(--ink); }
.nav a:not(.nav-cta):hover::after { transform: scaleX(1); }
.nav-cta { background: var(--terra); color: #fff !important; padding: .55rem 1.2rem !important; border-radius: 999px; transition: background .25s, transform .25s; }
.nav-cta:hover { background: var(--terra-dk); transform: translateY(-1px); }
.burger { display: none; flex-direction: column; gap: 5px; padding: 8px; z-index: 60; }
.burger span { width: 24px; height: 2px; border-radius: 2px; background: var(--ink); transition: transform .35s var(--ease), opacity .25s; }
.burger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.burger.open span:nth-child(2) { opacity: 0; }
.burger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ============================================================ HERO — ciel, nuages, soleil */
.hero { position: relative; min-height: 100svh; display: flex; align-items: center; overflow: hidden; padding-top: 80px; }
.hero-sky {
  position: absolute; inset: 0; z-index: -2;
  background:
    radial-gradient(42% 34% at 14% 20%, rgba(255, 226, 168, .75), rgba(255, 226, 168, 0) 60%),
    linear-gradient(180deg, #cfe6f3 0%, #deebef 38%, #eef4f0 68%, var(--paper) 100%);
}
.sun {
  position: absolute; top: 13%; left: 10%; width: 88px; height: 88px; border-radius: 50%; z-index: -1;
  background: radial-gradient(circle, #fff8ec 0%, var(--sun) 52%, rgba(255, 210, 122, 0) 72%);
  box-shadow: 0 0 80px 26px rgba(255, 211, 130, .45);
  animation: sunpulse 7s ease-in-out infinite;
}
@keyframes sunpulse { 0%, 100% { transform: scale(1); opacity: .96; } 50% { transform: scale(1.07); opacity: 1; } }
.ridge { position: absolute; left: 0; right: 0; bottom: 0; height: 42vh; background: radial-gradient(80% 120% at 20% 100%, rgba(122,135,98,.18), transparent 60%), radial-gradient(90% 130% at 75% 100%, rgba(138,152,106,.16), transparent 62%); -webkit-mask: linear-gradient(180deg, transparent, #000 70%); mask: linear-gradient(180deg, transparent, #000 70%); }

.cloud { position: absolute; background: #fff; border-radius: 100px; filter: blur(4px); opacity: .96; box-shadow: 0 12px 30px -14px rgba(120,140,160,.35); }
.cloud::before, .cloud::after { content: ""; position: absolute; background: #fff; border-radius: 100px; }
.cloud-1 { width: 220px; height: 56px; top: 16%; left: 30%; animation: drift 50s linear infinite; }
.cloud-1::before { width: 120px; height: 100px; top: -44px; left: 34px; }
.cloud-1::after  { width: 94px;  height: 76px; top: -28px; left: 120px; }
.cloud-2 { width: 190px; height: 48px; top: 24%; right: 10%; opacity: .92; animation: drift 64s linear infinite reverse; }
.cloud-2::before { width: 96px; height: 82px; top: -38px; left: 28px; }
.cloud-2::after  { width: 74px; height: 60px; top: -22px; left: 98px; }
.cloud-3 { width: 150px; height: 40px; top: 52%; left: 16%; opacity: .8; animation: drift 78s linear infinite; }
.cloud-3::before { width: 78px; height: 64px; top: -28px; left: 22px; }
.cloud-3::after  { width: 58px; height: 46px; top: -16px; left: 80px; }
.cloud-4 { width: 210px; height: 52px; top: 9%; right: 28%; opacity: .85; animation: drift 92s linear infinite reverse; }
.cloud-4::before { width: 100px; height: 84px; top: -38px; left: 32px; }
.cloud-4::after  { width: 78px; height: 64px; top: -22px; left: 104px; }
.cloud.soft { opacity: .55; filter: blur(10px); }
@keyframes drift { from { transform: translateX(-16vw); } to { transform: translateX(116vw); } }

.hero-grove { position: absolute; left: 0; right: 0; bottom: 0; width: 100%; height: auto; z-index: -1; pointer-events: none; opacity: .95; transform-origin: 50% 100%; animation: sway 9s ease-in-out infinite alternate; }
@keyframes sway { from { transform: rotate(-.35deg); } to { transform: rotate(.5deg); } }

.hero-content { position: relative; width: min(720px, 92vw); padding-left: clamp(18px, 4vw, 46px); }
.hero-eyebrow { text-transform: uppercase; letter-spacing: .32em; font-size: .76rem; font-weight: 700; color: var(--terra-dk); margin-bottom: 1.1rem; }
.hero h1 { font-size: clamp(3.1rem, 9vw, 6.4rem); line-height: .96; font-weight: 500; margin-bottom: 1.3rem; letter-spacing: -.02em; }
.hero-tag { font-size: clamp(1.06rem, 2vw, 1.32rem); color: var(--ink-soft); max-width: 40ch; margin-bottom: 2.2rem; }
.hero-actions { display: flex; flex-wrap: wrap; gap: .9rem; margin-bottom: 2.6rem; }
.hero-score { display: inline-flex; align-items: center; gap: .8rem; padding: .7rem 1.1rem; background: var(--glass); backdrop-filter: blur(10px); border: 1px solid var(--hairline); border-radius: var(--radius-sm); box-shadow: var(--shadow-sm); }
.hero-score strong { font-family: var(--serif); font-size: 1.8rem; color: var(--olive-700); line-height: 1; }
.hero-score span { font-size: .82rem; color: var(--ink-soft); font-weight: 600; }
.hero-score em { font-style: normal; font-weight: 400; color: var(--muted); font-size: .78rem; }
.scroll-cue { position: absolute; left: 50%; bottom: 26px; transform: translateX(-50%); width: 26px; height: 42px; border: 1.5px solid var(--olive-400); border-radius: 14px; display: grid; place-items: start center; padding-top: 7px; }
.scroll-cue span { width: 4px; height: 8px; border-radius: 4px; background: var(--olive-500); animation: scrollcue 1.8s var(--ease) infinite; }
@keyframes scrollcue { 0% { transform: translateY(0); opacity: 0; } 35% { opacity: 1; } 70% { transform: translateY(12px); opacity: 0; } 100% { opacity: 0; } }

/* ===== Fond clair animé : ciel + soleil + nuage + branche d'olivier ===== */
.sky-bg { position: fixed; inset: 0; z-index: 0; overflow: hidden; background: linear-gradient(180deg, #cfe6f3 0%, #dce9ee 34%, #edf3ef 64%, var(--paper) 100%); }
.sky-sun { position: absolute; top: 7%; left: 7%; width: clamp(220px, 26vw, 360px); aspect-ratio: 1; border-radius: 50%; background: radial-gradient(circle at 50% 50%, rgba(255,249,235,.95) 0%, #ffd97f 13%, rgba(255,214,120,.4) 32%, rgba(255,214,120,0) 70%); animation: sunbreath 7s ease-in-out infinite; will-change: transform; }
@keyframes sunbreath { 0%, 100% { transform: scale(1); opacity: .95; } 50% { transform: scale(1.05); opacity: 1; } }
.sky-cloud { position: absolute; top: 15%; left: 0; width: 240px; height: 62px; animation: clouddrift 72s linear infinite; will-change: transform; }
.sky-cloud i { position: absolute; background: #fff; border-radius: 100px; filter: blur(7px); }
.sky-cloud i:nth-child(1) { left: 46px; bottom: 0; width: 150px; height: 60px; }
.sky-cloud i:nth-child(2) { left: 12px; bottom: 6px; width: 80px; height: 48px; }
.sky-cloud i:nth-child(3) { left: 108px; bottom: 14px; width: 100px; height: 62px; background: #fbfdff; }
.sky-cloud i:nth-child(4) { left: 0; bottom: 2px; width: 240px; height: 26px; filter: blur(9px); }
@keyframes clouddrift { from { transform: translateX(-20vw); } to { transform: translateX(122vw); } }
.sky-olive { position: absolute; top: 13%; right: -6px; height: min(70vh, 600px); transform-origin: top right; animation: branchsway 9s ease-in-out infinite alternate; }
@keyframes branchsway { from { transform: rotate(-1.6deg); } to { transform: rotate(2deg); } }
.hero-content { position: relative; z-index: 6; }
.scroll-cue { z-index: 6; }
@media (max-width: 900px) { .sky-olive { opacity: .55; height: 48vh; } .sky-sun { top: 5%; left: 3%; } }

/* ============================================================ PHOTOS */
.photo { position: relative; display: block; width: 100%; border-radius: var(--radius); overflow: hidden; background: linear-gradient(135deg, var(--olive-100), var(--mist) 60%, #fff); box-shadow: var(--shadow-md); isolation: isolate; min-height: 220px; cursor: zoom-in; padding: 0; transition: transform .45s var(--ease), box-shadow .45s var(--ease); }
.photo img { position: absolute; inset: 0; z-index: 2; width: 100%; height: 100%; object-fit: cover; transition: transform .6s var(--ease); }
.photo:hover img { transform: scale(1.04); }
.photo::after { content: ""; position: absolute; inset: 0; z-index: 3; background: linear-gradient(0deg, rgba(58,66,49,.16), transparent 40%); opacity: 0; transition: opacity .3s; }
.photo:hover::after { opacity: 1; }
.photo-tall { min-height: 460px; aspect-ratio: 4/5; }
.photo-hero { aspect-ratio: 16/9; min-height: 280px; margin-bottom: 14px; }

/* ============================================================ LE MAS */
.le-mas { background: linear-gradient(180deg, var(--paper), var(--paper-2)); }
.col-text h2 { margin-bottom: 1.2rem; }
.col-text p { color: var(--ink-soft); }
.col-text p + p { margin-top: 1rem; }
.feature-list { list-style: none; margin-top: 1.8rem; display: grid; gap: .7rem; }
.feature-list li { position: relative; padding-left: 1.8rem; color: var(--ink-soft); }
.feature-list li::before { content: ""; position: absolute; left: 0; top: .5em; width: 9px; height: 9px; border-radius: 50%; background: var(--terra); box-shadow: 0 0 0 4px rgba(192,114,79,.14); }

/* ============================================================ CHAMBRES — cartes (1 photo → page) */
.chambres { background: var(--paper-2); }
.rooms { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: clamp(22px, 3vw, 32px); }
a.room-card { display: flex; flex-direction: column; background: var(--cloud); border: 1px solid var(--hairline); border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-md); transition: transform .4s var(--ease), box-shadow .4s var(--ease); }
a.room-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); }
.room-card .photo { border-radius: 0; box-shadow: none; aspect-ratio: 4/3; min-height: 220px; cursor: pointer; }
.room-card-body { padding: 1.4rem 1.5rem 1.6rem; display: flex; flex-direction: column; gap: .45rem; flex: 1; }
.room-eyebrow { text-transform: uppercase; letter-spacing: .2em; font-size: .68rem; font-weight: 700; color: var(--olive-500); }
.room-card h3 { font-size: 1.5rem; }
.room-card p { color: var(--ink-soft); font-size: .95rem; flex: 1; }
.room-link { margin-top: .5rem; font-weight: 700; font-size: .92rem; color: var(--terra-dk); display: inline-flex; align-items: center; gap: .4rem; transition: gap .3s var(--ease); }
a.room-card:hover .room-link { gap: .75rem; }
.fine { font-size: .86rem; color: var(--muted); }
.fine.center { margin-top: clamp(36px, 5vw, 56px); }

/* ============================================================ PISCINE (clair) */
.piscine { background: linear-gradient(180deg, var(--paper-2) 0%, #eaf2f4 50%, var(--paper) 100%); }
.pool-strip { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin-top: 14px; }
.pool-strip .photo { aspect-ratio: 3/4; min-height: 240px; }

/* ============================================================ GALERIE */
.galerie { background: var(--paper); }
.gallery-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.gallery-grid .photo { aspect-ratio: 4/3; min-height: 200px; }
.gallery-grid .photo:nth-child(1) { grid-column: span 2; grid-row: span 2; }

/* ============================================================ ANDUZE */
.anduze { background: linear-gradient(180deg, var(--paper), var(--paper-2)); }
.anduze-story { display: grid; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); gap: clamp(18px, 3vw, 28px); margin-bottom: clamp(40px, 6vw, 64px); }
.story-card { background: var(--cloud); border: 1px solid var(--hairline); border-radius: var(--radius); padding: 1.7rem 1.5rem; box-shadow: var(--shadow-sm); transition: transform .4s var(--ease), box-shadow .4s var(--ease); }
.story-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.story-card .ico { font-size: 1.7rem; display: block; margin-bottom: .7rem; }
.story-card h3 { font-size: 1.2rem; margin-bottom: .5rem; }
.story-card p { font-size: .92rem; color: var(--ink-soft); }
.situation { display: grid; grid-template-columns: 1.1fr 1fr; gap: clamp(28px, 5vw, 60px); align-items: center; padding: clamp(28px, 4vw, 48px); background: var(--cloud); border: 1px solid var(--hairline); border-radius: var(--radius); box-shadow: var(--shadow-md); }
.situation h3 { font-size: clamp(1.5rem, 3vw, 2rem); margin-bottom: 1rem; }
.situation p { color: var(--ink-soft); }
.situation p + p { margin-top: .9rem; }
.situation-aside { background: linear-gradient(160deg, var(--olive-100), var(--mist)); border-radius: var(--radius-sm); padding: 1.6rem; }
.situation-aside h4 { font-family: var(--sans); text-transform: uppercase; letter-spacing: .14em; font-size: .74rem; color: var(--olive-600); margin-bottom: 1rem; }
.dist-list { list-style: none; display: grid; gap: .7rem; }
.dist-list li { display: flex; align-items: baseline; justify-content: space-between; gap: 1rem; font-size: .92rem; padding-bottom: .7rem; border-bottom: 1px solid var(--hairline); }
.dist-list li:last-child { border-bottom: none; padding-bottom: 0; }
.dist-list b { font-weight: 600; color: var(--ink); }
.dist-list span { color: var(--olive-600); font-weight: 700; white-space: nowrap; }

/* ============================================================ AVIS */
.avis { background: var(--paper-2); }
.reviews { display: grid; grid-template-columns: repeat(auto-fit, minmax(270px, 1fr)); gap: clamp(18px, 3vw, 28px); }
.review { background: var(--cloud); border: 1px solid var(--hairline); border-radius: var(--radius); padding: 2.4rem 1.7rem 1.8rem; font-family: var(--serif); font-size: 1.16rem; font-style: italic; line-height: 1.45; color: var(--ink); box-shadow: var(--shadow-sm); position: relative; }
.review::before { content: "\201C"; font-family: var(--serif); font-size: 3.4rem; color: var(--olive-300); position: absolute; top: .2rem; left: 1rem; line-height: 1; }
.review cite { display: block; font-family: var(--sans); font-style: normal; font-size: .85rem; font-weight: 700; color: var(--olive-600); margin-top: 1rem; }

/* ============================================================ INFOS */
.infos { background: var(--paper); }
.info-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.2rem 1.6rem; margin-top: 1.6rem; }
.info-grid h4 { font-family: var(--sans); text-transform: uppercase; letter-spacing: .12em; font-size: .72rem; color: var(--terra-dk); margin-bottom: .25rem; }
.info-grid p { color: var(--ink); font-weight: 600; }
.map-frame { border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-md); border: 1px solid var(--hairline); aspect-ratio: 4/3; }
.map-frame iframe { width: 100%; height: 100%; border: 0; display: block; filter: saturate(.92) contrast(.98); }
.addr { margin-top: 1rem; font-weight: 700; color: var(--ink); }
.addr small { display: block; font-weight: 400; color: var(--muted); margin-top: .2rem; }

/* ============================================================ RÉSERVER */
.reserver { position: relative; text-align: center; overflow: hidden; background: radial-gradient(110% 90% at 50% -10%, #fff, transparent 60%), linear-gradient(180deg, #e8f1f4, var(--paper-2)); }
.reserver-sky { position: absolute; inset: 0; z-index: 0; }
.reserver-inner { position: relative; z-index: 1; max-width: 42rem; margin-inline: auto; }
.olive-divider { width: 120px; height: 24px; margin: 0 auto 1.6rem; }
.reserver h2 { margin-bottom: 1rem; }
.reserver p { color: var(--ink-soft); margin-bottom: 2rem; }
.reserver-actions { display: flex; gap: .9rem; justify-content: center; flex-wrap: wrap; }
.contact-line { margin-top: 2rem; font-weight: 600; color: var(--ink); }
.todo { color: #8a6d2a; background: #fbf3dd; border: 1px dashed #e3c879; border-radius: 6px; padding: .05rem .4rem; font-weight: 600; font-size: .9em; }

/* ============================================================ FOOTER */
.site-footer { background: var(--olive-800); color: #e6ead9; padding: clamp(44px, 6vw, 66px) 0 2rem; }
.footer-inner { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 2rem; padding-bottom: 2.2rem; border-bottom: 1px solid rgba(255,255,255,.12); }
.foot-brand .brand-name { color: #fff; font-size: 1.5rem; }
.foot-brand p { font-size: .9rem; margin-top: .4rem; color: #c2caaf; }
.foot-nav { display: flex; flex-wrap: wrap; gap: 1.2rem; align-items: center; }
.foot-nav a { font-size: .92rem; color: #e6ead9; transition: color .25s; }
.foot-nav a:hover { color: #fff; }
.copyright { text-align: center; font-size: .8rem; color: #9aa585; margin-top: 1.6rem; }

/* ============================================================ PAGE CHAMBRE (sous-page) */
.roompage { padding: calc(80px + clamp(28px, 5vw, 56px)) 0 clamp(56px, 9vw, 110px); background: var(--paper); min-height: 100vh; }
.back-link { display: inline-flex; align-items: center; gap: .45rem; font-weight: 700; color: var(--olive-700); margin-bottom: 1.6rem; transition: gap .3s var(--ease), color .25s; }
.back-link:hover { color: var(--terra-dk); gap: .7rem; }
.roompage-head { max-width: 64ch; }
.roompage-title { font-size: clamp(2.4rem, 6vw, 4rem); margin-bottom: .8rem; }
.roompage-lede { font-size: 1.12rem; color: var(--ink-soft); margin-bottom: 1.2rem; }
.roompage .tags { margin-bottom: 2.2rem; }
.tags { list-style: none; display: flex; flex-wrap: wrap; gap: .5rem; }
.tags li { font-size: .8rem; font-weight: 600; color: var(--olive-700); background: var(--olive-100); border: 1px solid var(--olive-200); padding: .34rem .8rem; border-radius: 999px; }
.roompage-gallery { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; }
.roompage-gallery .photo { aspect-ratio: 4/3; min-height: 240px; }
.roompage-gallery .photo:first-child { grid-column: span 2; aspect-ratio: 16/9; }
.roompage-cta { display: flex; gap: .9rem; flex-wrap: wrap; margin-top: 2.6rem; }

/* ============================================================ LIGHTBOX */
.lightbox { position: fixed; inset: 0; z-index: 100; display: none; place-items: center; padding: 4vw; background: rgba(40, 46, 35, .88); backdrop-filter: blur(6px); }
.lightbox.open { display: grid; }
.lb-figure { margin: 0; max-width: min(1100px, 92vw); max-height: 86vh; display: flex; flex-direction: column; align-items: center; gap: .8rem; }
.lb-figure img { max-width: 100%; max-height: 78vh; width: auto; height: auto; border-radius: 10px; box-shadow: 0 30px 80px -20px rgba(0,0,0,.6); object-fit: contain; }
.lb-figure figcaption { color: #eef2e6; font-size: .92rem; text-align: center; }
.lb-close { position: fixed; top: 18px; right: 24px; font-size: 2.4rem; line-height: 1; color: #fff; opacity: .85; }
.lb-close:hover { opacity: 1; }
.lb-nav { position: fixed; top: 50%; transform: translateY(-50%); width: 56px; height: 56px; border-radius: 50%; background: rgba(255,255,255,.14); color: #fff; font-size: 2rem; display: grid; place-items: center; transition: background .25s; }
.lb-nav:hover { background: rgba(255,255,255,.28); }
.lb-prev { left: 18px; } .lb-next { right: 18px; }

/* ============================================================ REVEAL */
.reveal { opacity: 0; transform: translateY(26px); transition: opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { *, *::before, *::after { animation: none !important; scroll-behavior: auto !important; } .reveal { opacity: 1; transform: none; transition: none; } }

/* ============================================================ RESPONSIVE */
@media (max-width: 900px) {
  .nav { position: fixed; inset: 0 0 0 auto; width: min(78vw, 320px); flex-direction: column; align-items: flex-start; justify-content: center; gap: 1.4rem; padding: 2rem 2.2rem; background: var(--glass-strong); backdrop-filter: blur(18px) saturate(1.3); box-shadow: -20px 0 60px -30px rgba(63,74,55,.5); transform: translateX(100%); transition: transform .45s var(--ease); }
  .nav.open { transform: none; }
  .nav a { font-size: 1.1rem; }
  .burger { display: flex; }
  .two-col, .two-col.reverse { grid-template-columns: 1fr; }
  .two-col.reverse .col-media { order: -1; }
  .situation { grid-template-columns: 1fr; }
  .hero-grove { opacity: .9; }
  .sun { top: 9%; left: 6%; width: 70px; height: 70px; }
}
@media (max-width: 560px) {
  .hero h1 { font-size: clamp(2rem, 7.5vw, 2.6rem); }
  .info-grid { grid-template-columns: 1fr; }
  .footer-inner { flex-direction: column; }
  .pool-strip { grid-template-columns: 1fr 1fr; }
  .gallery-grid { grid-template-columns: 1fr 1fr; }
  .gallery-grid .photo:nth-child(1) { grid-column: span 2; }
  .roompage-gallery { grid-template-columns: 1fr 1fr; }
  .roompage-gallery .photo:first-child { grid-column: span 2; }
}

/* ============================================================
   FOND CLAIR FIXE DERRIÈRE TOUT LE SITE
   (en descendant : ciel + soleil + branche + nuage restent derrière, jamais de blanc plat)
   ============================================================ */
html { background: var(--paper); }
body { background: transparent; }
.hero { background: transparent; }
/* sections en voile clair translucide — le ciel & la branche restent visibles derrière */
.section { background: rgba(251, 252, 248, .66) !important; -webkit-backdrop-filter: blur(7px) saturate(1.03); backdrop-filter: blur(7px) saturate(1.03); }
.piscine { background: rgba(240, 246, 243, .62) !important; }
.site-footer { background: rgba(45, 53, 40, .9) !important; -webkit-backdrop-filter: blur(7px); backdrop-filter: blur(7px); }
.section, .site-footer { position: relative; z-index: 1; }
@media (prefers-reduced-motion: reduce) { .sky-sun, .sky-cloud, .sky-olive { animation: none !important; } .section, .site-footer { -webkit-backdrop-filter: none; backdrop-filter: none; } }

/* ===== Hero = scène piscine animée (par-dessus le fond ciel fixe) ===== */
.oliviers-scene { position: absolute; inset: 0; z-index: 1; overflow: hidden; background: #cfe0ea; font-family: var(--sans); }
.scene-scrim { position: absolute; inset: 0; z-index: 5; pointer-events: none; background: linear-gradient(90deg, rgba(16,32,36,.52) 0%, rgba(16,32,36,.18) 34%, rgba(16,32,36,0) 58%); }
.hero { align-items: flex-start; }
.hero-content { margin-top: clamp(92px, 15vh, 180px); z-index: 6; }
.hero .hero-eyebrow { color: #e8845a; text-shadow: 0 1px 8px rgba(14,30,34,.4); }
.hero h1 { color: #fff; text-shadow: 0 2px 26px rgba(14,30,34,.5); }
.hero-tag { color: #eef4ec; text-shadow: 0 1px 14px rgba(14,30,34,.45); }
.hero-score { background: rgba(255,255,255,.85); }
.hero .btn-ghost { background: rgba(255,255,255,.8); }
.scroll-cue { border-color: rgba(255,255,255,.7); }
.scroll-cue span { background: #fff; }
.site-header:not(.scrolled) .brand-name,
.site-header:not(.scrolled) .brand-sprig,
.site-header:not(.scrolled) .nav a:not(.nav-cta) { color: #fff; }
.site-header:not(.scrolled) .burger span { background: #fff; }
