/* =========================================================
   SUNRISE COVE — Lake of Bays
   Palette: deep pine/lake teal + warm cedar/gold + soft cream
   ========================================================= */

:root, [data-theme="light"] {
  /* Surfaces — warm soft cream/linen */
  --color-bg: #f6f3ec;
  --color-surface: #fbf9f3;
  --color-surface-2: #ffffff;
  --color-surface-offset: #eee9de;
  --color-divider: #e0dac d;
  --color-divider: #e0dacd;
  --color-border: #d6cfbf;

  /* Text — deep forest ink */
  --color-text: #20302c;
  --color-text-muted: #5c6660;
  --color-text-faint: #9aa39c;
  --color-text-inverse: #f6f3ec;

  /* Primary — deep lake/pine teal */
  --color-primary: #0f3a3d;
  --color-primary-hover: #0b2c2e;
  --color-primary-active: #082022;
  --color-primary-soft: #d8e2de;

  /* Accent — warm cedar gold (sunrise) */
  --color-accent: #c08a3e;
  --color-accent-hover: #a8762f;
  --color-accent-soft: #efe2cb;

  --shadow-sm: 0 1px 2px rgba(32,48,44,.06);
  --shadow-md: 0 6px 22px rgba(32,48,44,.10);
  --shadow-lg: 0 18px 50px rgba(32,48,44,.16);

  --radius-sm: .5rem;
  --radius-md: .85rem;
  --radius-lg: 1.25rem;
  --radius-xl: 1.75rem;
  --radius-full: 9999px;

  --transition-interactive: 200ms cubic-bezier(.16,1,.3,1);

  --content-narrow: 680px;
  --content-default: 1020px;
  --content-wide: 1280px;

  --font-display: 'Boska', Georgia, serif;
  --font-body: 'Satoshi', system-ui, sans-serif;

  /* type scale */
  --text-xs: clamp(.75rem,.7rem + .2vw,.82rem);
  --text-sm: clamp(.875rem,.82rem + .25vw,.95rem);
  --text-base: clamp(1rem,.96rem + .2vw,1.075rem);
  --text-lg: clamp(1.15rem,1rem + .6vw,1.4rem);
  --text-xl: clamp(1.5rem,1.2rem + 1.3vw,2.2rem);
  --text-2xl: clamp(2rem,1.3rem + 2.6vw,3.4rem);
  --text-hero: clamp(2.8rem,1.4rem + 6vw,6.2rem);

  --space-1:.25rem; --space-2:.5rem; --space-3:.75rem; --space-4:1rem;
  --space-5:1.25rem; --space-6:1.5rem; --space-8:2rem; --space-10:2.5rem;
  --space-12:3rem; --space-16:4rem; --space-20:5rem; --space-24:6rem; --space-32:8rem;
}

[data-theme="dark"] {
  --color-bg: #11201d;
  --color-surface: #16282492;
  --color-surface: #162824;
  --color-surface-2: #1c302b;
  --color-surface-offset: #1a2d29;
  --color-divider: #28403a;
  --color-border: #2f4842;

  --color-text: #e6e3d8;
  --color-text-muted: #9fb0a8;
  --color-text-faint: #6b7d75;
  --color-text-inverse: #11201d;

  --color-primary: #6cc0b3;
  --color-primary-hover: #84d0c3;
  --color-primary-active: #9adcd0;
  --color-primary-soft: #1f3a35;

  --color-accent: #e0a85a;
  --color-accent-hover: #ecba73;
  --color-accent-soft: #3a2f1d;

  --shadow-sm: 0 1px 2px rgba(0,0,0,.4);
  --shadow-md: 0 6px 22px rgba(0,0,0,.5);
  --shadow-lg: 0 18px 50px rgba(0,0,0,.6);
}

@media (prefers-color-scheme: dark) {
  :root:not([data-theme]) {
    --color-bg:#11201d; --color-surface:#162824; --color-surface-2:#1c302b;
    --color-surface-offset:#1a2d29; --color-divider:#28403a; --color-border:#2f4842;
    --color-text:#e6e3d8; --color-text-muted:#9fb0a8; --color-text-faint:#6b7d75;
    --color-text-inverse:#11201d; --color-primary:#6cc0b3; --color-primary-hover:#84d0c3;
    --color-primary-active:#9adcd0; --color-primary-soft:#1f3a35; --color-accent:#e0a85a;
    --color-accent-hover:#ecba73; --color-accent-soft:#3a2f1d;
  }
}

/* ---------- base ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
[hidden]{display:none!important}
html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;scroll-behavior:smooth;scroll-padding-top:5rem}
body{min-height:100dvh;line-height:1.65;font-family:var(--font-body);font-size:var(--text-base);color:var(--color-text);background:var(--color-bg);overflow-x:hidden}
img,svg,video{display:block;max-width:100%;height:auto}
h1,h2,h3,h4,h5{line-height:1.1;text-wrap:balance;font-weight:600}
p{text-wrap:pretty}
a{color:inherit;text-decoration:none}
button{cursor:pointer;background:none;border:none;color:inherit;font:inherit}
input,select,textarea{font:inherit;color:inherit}
ul{list-style:none}
::selection{background:var(--color-accent-soft);color:var(--color-text)}
:focus-visible{outline:2px solid var(--color-accent);outline-offset:3px;border-radius:var(--radius-sm)}
a,button,input,select,textarea{transition:color var(--transition-interactive),background var(--transition-interactive),border-color var(--transition-interactive),box-shadow var(--transition-interactive),transform var(--transition-interactive)}

.skip-link{position:absolute;left:-999px;top:0;background:var(--color-primary);color:#fff;padding:.6rem 1rem;z-index:200;border-radius:0 0 var(--radius-sm) 0}
.skip-link:focus{left:0}

/* ---------- typography helpers ---------- */
.display-md{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:600;letter-spacing:-.01em}
.display-sm{font-family:var(--font-display);font-size:var(--text-xl);font-weight:600;letter-spacing:-.01em}
.eyebrow{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.22em;font-weight:600;color:var(--color-accent);margin-bottom:var(--space-4)}
.eyebrow--light{color:var(--color-accent)}

/* ---------- layout ---------- */
.section{max-width:var(--content-wide);margin-inline:auto;padding-inline:var(--space-6);padding-block:clamp(var(--space-16),9vw,var(--space-32))}
.section--flush{padding-block:clamp(var(--space-12),7vw,var(--space-24))}
.section__head{max-width:680px;margin-bottom:var(--space-12)}
.section__lede{color:var(--color-text-muted);font-size:var(--text-lg);margin-top:var(--space-4)}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-weight:600;font-size:var(--text-sm);border-radius:var(--radius-full);padding:.75rem 1.5rem;line-height:1;white-space:nowrap}
.btn--lg{padding:1rem 2rem;font-size:var(--text-base)}
.btn--sm{padding:.6rem 1.2rem}
.btn--block{width:100%}
.btn--primary{background:var(--color-primary);color:#f6f3ec}
.btn--primary:hover{background:var(--color-primary-hover);transform:translateY(-2px);box-shadow:var(--shadow-md)}
[data-theme="dark"] .btn--primary{color:var(--color-text-inverse)}
.btn--ghost{background:rgba(255,255,255,.12);color:#fff;backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.35)}
.btn--ghost:hover{background:rgba(255,255,255,.22);transform:translateY(-2px)}
.link-arrow{display:inline-block;margin-top:var(--space-4);color:var(--color-primary);font-weight:600;font-size:var(--text-sm)}
[data-theme="dark"] .link-arrow{color:var(--color-primary)}
.link-arrow:hover{color:var(--color-accent);transform:translateX(3px)}

/* ---------- header ---------- */
.header{position:sticky;top:0;z-index:100;background:color-mix(in srgb,var(--color-bg) 82%,transparent);backdrop-filter:blur(14px);border-bottom:1px solid transparent;transition:border-color .3s,box-shadow .3s,background .3s}
.header.is-scrolled{border-bottom-color:var(--color-border);box-shadow:var(--shadow-sm)}
.header__inner{max-width:var(--content-wide);margin-inline:auto;padding:.85rem var(--space-6);display:flex;align-items:center;gap:var(--space-6)}
.brand{display:flex;align-items:center;gap:.7rem;color:var(--color-primary)}
[data-theme="dark"] .brand{color:var(--color-primary)}
.brand__mark{flex-shrink:0}
.brand__text{display:flex;flex-direction:column;line-height:1.1}
.brand__name{font-family:var(--font-display);font-size:1.25rem;font-weight:600;color:var(--color-text)}
.brand__sub{font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--color-text-muted)}
.nav{display:flex;gap:var(--space-6);margin-left:auto;font-size:var(--text-sm);font-weight:500}
.nav a{color:var(--color-text-muted);position:relative;padding:.25rem 0}
.nav a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--color-accent);transition:width var(--transition-interactive)}
.nav a:hover{color:var(--color-text)}
.nav a:hover::after{width:100%}
.header__actions{display:flex;align-items:center;gap:var(--space-3)}
.icon-btn{width:40px;height:40px;display:grid;place-items:center;border-radius:var(--radius-full);color:var(--color-text-muted);border:1px solid var(--color-border)}
.icon-btn:hover{color:var(--color-text);border-color:var(--color-text-muted)}

.menu-toggle{display:none;flex-direction:column;gap:5px;width:42px;height:42px;align-items:center;justify-content:center}
.menu-toggle span{width:22px;height:2px;background:var(--color-text);border-radius:2px;transition:.3s}
.menu-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.menu-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-menu{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-4) var(--space-6) var(--space-8);border-top:1px solid var(--color-border);background:var(--color-surface)}
.mobile-menu a{padding:.85rem .5rem;font-size:var(--text-lg);font-family:var(--font-display);border-bottom:1px solid var(--color-divider)}
.mobile-menu .btn{margin-top:var(--space-3);justify-content:center}

/* ---------- hero ---------- */
.hero{position:relative;min-height:92vh;display:flex;align-items:flex-end;color:#fff;overflow:hidden}
.hero__media{position:absolute;inset:0;z-index:-1}
.hero__media img{width:100%;height:100%;object-fit:cover;animation:slowzoom 22s ease-out forwards}
@keyframes slowzoom{from{transform:scale(1.08)}to{transform:scale(1)}}
.hero__scrim{position:absolute;inset:0;background:linear-gradient(to top,rgba(8,24,22,.85) 0%,rgba(8,24,22,.35) 45%,rgba(8,24,22,.15) 100%)}
.hero__content{position:relative;max-width:var(--content-wide);width:100%;margin-inline:auto;padding:0 var(--space-6) clamp(var(--space-16),9vw,var(--space-32))}
.hero__eyebrow{font-size:var(--text-sm);text-transform:uppercase;letter-spacing:.24em;font-weight:600;color:#e7c389;margin-bottom:var(--space-5)}
.hero__title{font-family:var(--font-display);font-size:var(--text-hero);font-weight:500;line-height:.98;letter-spacing:-.02em;max-width:14ch}
.hero__title em{font-style:italic;color:#e7c389}
.hero__lede{font-size:var(--text-lg);max-width:48ch;margin-top:var(--space-6);color:rgba(255,255,255,.92)}
.hero__actions{display:flex;flex-wrap:wrap;gap:var(--space-4);margin-top:var(--space-8)}
.hero__rating{display:flex;align-items:center;gap:.6rem;margin-top:var(--space-8);font-size:var(--text-sm);color:rgba(255,255,255,.92)}
.stars{color:#e7c389;letter-spacing:.1em}
.stars--lg{font-size:1.3rem}
.hero__scroll{position:absolute;bottom:1.5rem;left:50%;transform:translateX(-50%);width:26px;height:42px;border:2px solid rgba(255,255,255,.5);border-radius:var(--radius-full);display:grid;place-items:start center;padding-top:7px}
.hero__scroll span{width:4px;height:8px;border-radius:2px;background:#fff;animation:scrolldot 1.8s infinite}
@keyframes scrolldot{0%{opacity:0;transform:translateY(0)}40%{opacity:1}80%{opacity:0;transform:translateY(12px)}}

/* ---------- stats ---------- */
.stats{background:var(--color-primary);color:#f6f3ec}
[data-theme="dark"] .stats{background:var(--color-surface);border-block:1px solid var(--color-border)}
.stats__inner{max-width:var(--content-wide);margin-inline:auto;padding:var(--space-10) var(--space-6);display:grid;grid-template-columns:repeat(5,1fr);gap:var(--space-6);text-align:center}
.stat{display:flex;flex-direction:column;gap:.3rem}
.stat__num{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:600;color:#e7c389}
.stat__label{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.18em;color:rgba(246,243,236,.75)}
[data-theme="dark"] .stat__label{color:var(--color-text-muted)}

/* ---------- intro ---------- */
.intro__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(var(--space-8),5vw,var(--space-20));align-items:center}
.intro__text p{color:var(--color-text-muted);margin-top:var(--space-4)}
.intro__text .display-md{margin-bottom:var(--space-2)}
.intro__media{position:relative}
.intro__media img{width:100%;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);aspect-ratio:4/3;object-fit:cover}
.intro__pull{position:absolute;bottom:-2rem;left:-1rem;max-width:300px;background:var(--color-surface-2);padding:var(--space-5) var(--space-6);border-radius:var(--radius-md);box-shadow:var(--shadow-md);border:1px solid var(--color-border)}
.intro__pull blockquote{font-family:var(--font-display);font-size:var(--text-base);font-style:italic;line-height:1.4}
.intro__pull figcaption{margin-top:var(--space-3);font-size:var(--text-xs);color:var(--color-text-muted);font-weight:600;letter-spacing:.04em}

/* ---------- features ---------- */
.features{display:flex;flex-direction:column;gap:0}
.feature{display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:clamp(var(--space-8),5vw,var(--space-20));max-width:var(--content-wide);margin-inline:auto;padding:clamp(var(--space-10),5vw,var(--space-16)) var(--space-6)}
.feature--reverse .feature__media{order:2}
.feature__media img{width:100%;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);aspect-ratio:3/2;object-fit:cover}
.feature__text p{color:var(--color-text-muted);margin-top:var(--space-4)}
.feature__text .display-sm{margin-bottom:var(--space-2)}

/* ---------- amenities ---------- */
.amenities{background:var(--color-surface)}
.amenities__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:var(--space-4)}
.amenity{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-3);padding:var(--space-6) var(--space-4);background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:transform var(--transition-interactive),border-color var(--transition-interactive),box-shadow var(--transition-interactive)}
.amenity:hover{transform:translateY(-4px);border-color:var(--color-accent);box-shadow:var(--shadow-md)}
.amenity svg{width:30px;height:30px;fill:none;stroke:var(--color-primary);stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
[data-theme="dark"] .amenity svg{stroke:var(--color-primary)}
.amenity h4{font-size:var(--text-sm);font-weight:600;font-family:var(--font-body)}

/* ---------- gallery ---------- */
.gallery__grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:var(--space-3)}
.gallery__item{position:relative;overflow:hidden;border-radius:var(--radius-md);cursor:pointer;background:var(--color-surface-offset)}
.gallery__item img{width:100%;height:100%;object-fit:cover;transition:transform .5s cubic-bezier(.16,1,.3,1)}
.gallery__item:hover img{transform:scale(1.06)}
.gallery__item::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 60%,rgba(8,24,22,.25));opacity:0;transition:opacity var(--transition-interactive)}
.gallery__item:hover::after{opacity:1}
.gallery__item--lg{grid-column:span 2;grid-row:span 2}
.gallery__item--wide{grid-column:span 2}

/* ---------- sleeping ---------- */
.sleeping__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-5)}
.bedcard{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;transition:transform var(--transition-interactive),box-shadow var(--transition-interactive)}
.bedcard:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.bedcard img{width:100%;aspect-ratio:4/3;object-fit:cover}
.bedcard__body{padding:var(--space-5)}
.bedcard__lvl{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.16em;color:var(--color-accent);font-weight:600}
.bedcard__body h4{font-family:var(--font-display);font-size:var(--text-lg);margin:.35rem 0 .25rem}
.bedcard__body p{font-size:var(--text-sm);color:var(--color-text-muted)}
.sleeping__note{margin-top:var(--space-8);text-align:center;color:var(--color-text-muted);max-width:60ch;margin-inline:auto}

/* ---------- location ---------- */
.location{background:var(--color-surface)}
.location__grid{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(var(--space-8),5vw,var(--space-20));align-items:center}
.location__media img{width:100%;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);aspect-ratio:4/3;object-fit:cover}
.location__text p{color:var(--color-text-muted);margin-top:var(--space-4)}
.location__list{margin-top:var(--space-6);display:flex;flex-direction:column;gap:var(--space-3)}
.location__list li{padding-left:1.6rem;position:relative;color:var(--color-text-muted)}
.location__list li::before{content:"";position:absolute;left:0;top:.5rem;width:8px;height:8px;border-radius:50%;background:var(--color-accent)}
.location__list strong{color:var(--color-text)}
.location__muted{font-size:var(--text-sm);color:var(--color-text-faint);margin-top:var(--space-6)}
.seasons{margin-top:clamp(var(--space-12),7vw,var(--space-20))}
.seasons .section__head{text-align:center;max-width:46rem;margin:0 auto var(--space-10)}
.seasons__lede{color:var(--color-text-muted);margin-top:var(--space-4)}
.seasons__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-6)}
.season-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);box-shadow:var(--shadow-sm);transition:transform .25s ease,box-shadow .25s ease}
.season-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.season-card__tag{display:inline-block;font-size:var(--text-xs);font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--color-accent);background:color-mix(in srgb,var(--color-accent) 12%,transparent);padding:.3rem .7rem;border-radius:var(--radius-full)}
.season-card h4{margin:var(--space-4) 0 var(--space-3);font-size:var(--text-lg)}
.season-card ul{display:flex;flex-direction:column;gap:var(--space-2)}
.season-card li{position:relative;padding-left:1.2rem;font-size:var(--text-sm);color:var(--color-text-muted);line-height:1.45}
.season-card li::before{content:"";position:absolute;left:0;top:.55rem;width:6px;height:6px;border-radius:50%;background:var(--color-accent)}
@media(max-width:980px){.seasons__grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.seasons__grid{grid-template-columns:1fr}}

/* ---------- reviews ---------- */
.reviews__score{display:flex;align-items:center;gap:.6rem;margin-top:var(--space-5);font-size:var(--text-base);color:var(--color-text-muted)}
.reviews__score strong{color:var(--color-text)}
.reviews__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-5)}
.review{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-5)}
.review p{font-size:var(--text-base);line-height:1.6}
.review footer{display:flex;flex-direction:column;gap:.1rem;margin-top:auto}
.review__name{font-weight:600;font-family:var(--font-display);font-size:var(--text-lg)}
.review__meta{font-size:var(--text-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em}

/* ---------- book ---------- */
.book{background:var(--color-primary);color:#f6f3ec}
[data-theme="dark"] .book{background:var(--color-surface);border-block:1px solid var(--color-border)}
.book__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(var(--space-8),5vw,var(--space-16));align-items:start}
.book__pitch h2{color:#fff}
[data-theme="dark"] .book__pitch h2{color:var(--color-text)}
.book__pitch p{color:rgba(246,243,236,.85);margin-top:var(--space-4)}
[data-theme="dark"] .book__pitch p{color:var(--color-text-muted)}
.book__perks{margin-top:var(--space-6);display:flex;flex-direction:column;gap:var(--space-3)}
.book__perks li{padding-left:1.9rem;position:relative;color:rgba(246,243,236,.92)}
[data-theme="dark"] .book__perks li{color:var(--color-text-muted)}
.book__perks li::before{content:"✓";position:absolute;left:0;top:0;color:#e7c389;font-weight:700}
.book__note{margin-top:var(--space-8);font-size:var(--text-sm);color:rgba(246,243,236,.7)}
.book__note a{color:#e7c389;font-weight:600;text-decoration:underline;text-underline-offset:3px}
[data-theme="dark"] .book__note{color:var(--color-text-faint)}

.book__form-wrap{background:var(--color-surface-2);border-radius:var(--radius-lg);padding:clamp(var(--space-6),3vw,var(--space-10));box-shadow:var(--shadow-lg);color:var(--color-text)}
.book__form h3{font-family:var(--font-display);font-size:var(--text-xl);margin-bottom:var(--space-6)}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}
.field{display:flex;flex-direction:column;gap:.4rem;margin-bottom:var(--space-4)}
.field label{font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted)}
.field input,.field select,.field textarea{padding:.7rem .85rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text);font-size:var(--text-sm)}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--color-accent);outline:none;box-shadow:0 0 0 3px var(--color-accent-soft)}
.field textarea{resize:vertical}
.form-status{margin-top:var(--space-4);padding:.85rem 1rem;border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:500}
.form-status.is-ok{background:var(--color-primary-soft);color:var(--color-primary)}
.form-status.is-err{background:var(--color-accent-soft);color:var(--color-accent-hover)}
.book__privacy{margin-top:var(--space-4);font-size:var(--text-xs);color:var(--color-text-faint);text-align:center}

/* ---------- footer ---------- */
.footer{background:var(--color-surface);border-top:1px solid var(--color-border)}
.footer__inner{max-width:var(--content-wide);margin-inline:auto;padding:var(--space-12) var(--space-6);display:flex;justify-content:space-between;align-items:center;gap:var(--space-8);flex-wrap:wrap}
.footer__brand{display:flex;align-items:center;gap:.8rem;color:var(--color-primary)}
[data-theme="dark"] .footer__brand{color:var(--color-primary)}
.footer__name{font-family:var(--font-display);font-size:var(--text-lg);color:var(--color-text)}
.footer__loc{font-size:var(--text-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.12em}
.footer__nav{display:flex;gap:var(--space-6);flex-wrap:wrap;font-size:var(--text-sm)}
.footer__nav a{color:var(--color-text-muted)}
.footer__nav a:hover{color:var(--color-accent)}
.footer__bar{border-top:1px solid var(--color-divider);text-align:center;padding:var(--space-5);font-size:var(--text-xs);color:var(--color-text-faint)}

/* ---------- lightbox ---------- */
.lightbox{position:fixed;inset:0;z-index:300;background:rgba(8,18,16,.96);display:flex;align-items:center;justify-content:center;padding:var(--space-8)}
.lightbox__img{max-width:92vw;max-height:86vh;border-radius:var(--radius-md);object-fit:contain;box-shadow:var(--shadow-lg)}
.lightbox__close{position:absolute;top:1.2rem;right:1.5rem;font-size:2.5rem;line-height:1;color:#fff;width:48px;height:48px}
.lightbox__nav{position:absolute;top:50%;transform:translateY(-50%);font-size:3rem;color:#fff;width:60px;height:60px;display:grid;place-items:center;background:rgba(255,255,255,.08);border-radius:var(--radius-full)}
.lightbox__nav:hover{background:rgba(255,255,255,.2)}
.lightbox__nav--prev{left:1.5rem}
.lightbox__nav--next{right:1.5rem}
.lightbox__count{position:absolute;bottom:1.5rem;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.8);font-size:var(--text-sm);letter-spacing:.05em}

/* ---------- reveal animation ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
.reveal.is-visible{opacity:1;transform:none}

/* ---------- responsive ---------- */
@media(max-width:980px){
  .nav{display:none}
  .menu-toggle{display:flex}
  .header__actions .btn{display:none}
  .intro__grid,.feature,.feature--reverse,.location__grid,.book__grid{grid-template-columns:1fr}
  .feature--reverse .feature__media{order:0}
  .intro__pull{position:static;margin-top:var(--space-5);max-width:none}
  .reviews__grid{grid-template-columns:1fr 1fr}
  .sleeping__grid{grid-template-columns:1fr 1fr}
  .stats__inner{grid-template-columns:repeat(3,1fr);gap:var(--space-8)}
}
@media(max-width:640px){
  .reviews__grid,.sleeping__grid{grid-template-columns:1fr}
  .gallery__grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:150px}
  .gallery__item--lg{grid-column:span 2;grid-row:span 1}
  .field-row{grid-template-columns:1fr}
  .stats__inner{grid-template-columns:repeat(2,1fr)}
  .hero{min-height:88vh}
  .footer__inner{flex-direction:column;align-items:flex-start;gap:var(--space-6)}
  .lightbox__nav{width:46px;height:46px;font-size:2rem}
  .lightbox__nav--prev{left:.5rem}.lightbox__nav--next{right:.5rem}
}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
  .reveal{opacity:1;transform:none}
  .hero__media img{animation:none}
}
