/* ============================================================
   F13 APARTMENT — Pula, Istria · direct-booking microsite
   Brand: "ceramic door-plate" identity — Poppins type, Adriatic
   teal + ceramic cream + sand-gold (see F13 brand notes). Reuses
   the Villa template's layout language. Noindexed (see .htaccess).
   ============================================================ */

/* ── Poppins (self-hosted, weights 400/500/600/700 · latin + latin-ext) ── */
@font-face { font-family:'Poppins'; font-style:normal; font-weight:400; font-display:swap;
  src:url('/fonts/poppins_400_latin.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+20AC,U+2122,U+FEFF,U+FFFD; }
@font-face { font-family:'Poppins'; font-style:normal; font-weight:400; font-display:swap;
  src:url('/fonts/poppins_400_latin-ext.woff2') format('woff2');
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+2113,U+2C60-2C7F,U+A720-A7FF; }
@font-face { font-family:'Poppins'; font-style:normal; font-weight:500; font-display:swap;
  src:url('/fonts/poppins_500_latin.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+20AC,U+2122,U+FEFF,U+FFFD; }
@font-face { font-family:'Poppins'; font-style:normal; font-weight:500; font-display:swap;
  src:url('/fonts/poppins_500_latin-ext.woff2') format('woff2');
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+2113,U+2C60-2C7F,U+A720-A7FF; }
@font-face { font-family:'Poppins'; font-style:normal; font-weight:600; font-display:swap;
  src:url('/fonts/poppins_600_latin.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+20AC,U+2122,U+FEFF,U+FFFD; }
@font-face { font-family:'Poppins'; font-style:normal; font-weight:600; font-display:swap;
  src:url('/fonts/poppins_600_latin-ext.woff2') format('woff2');
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+2113,U+2C60-2C7F,U+A720-A7FF; }
@font-face { font-family:'Poppins'; font-style:normal; font-weight:700; font-display:swap;
  src:url('/fonts/poppins_700_latin.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+20AC,U+2122,U+FEFF,U+FFFD; }
@font-face { font-family:'Poppins'; font-style:normal; font-weight:700; font-display:swap;
  src:url('/fonts/poppins_700_latin-ext.woff2') format('woff2');
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+2113,U+2C60-2C7F,U+A720-A7FF; }

/* ── Design tokens — F13 brand palette ───────────────────────── */
:root {
  /* Ceramic cream backgrounds */
  --bg-0:#FBF8F1;          /* cards / paper */
  --bg-1:#F4EDDD;          /* page */
  --bg-2:#EEE4D0;          /* tinted sections */
  --bg-3:#E3D6BE;
  --cream:#F7F0E1;         /* reversed ink — text on teal */
  --tile:#F2E9D6;

  /* Adriatic teal — primary brand accent */
  --sea-50:#E7EFEE;        /* pale teal panel */
  --sea-500:#2A7C88;       /* sea teal (the wave) — secondary */
  --sea-600:#1A6B76;
  --sea-700:#15616D;       /* PRIMARY — buttons, links, logo ink */
  --sea-800:#114E58;       /* hover */
  --sea-900:#0E3D45;       /* footer */

  /* Istrian sand-gold — the "sun" accent */
  --gold-500:#E0A458;
  --gold-700:#C5863C;

  /* Text */
  --ink:#1C2B2C;           /* headings / strong — ~12:1 on cream */
  --body:#293938;          /* body — ~10:1 on cream */
  --muted:#4B6467;         /* labels / meta — AA at ~5:1 */

  --line:rgba(21,97,109,0.14);
  --line-strong:rgba(21,97,109,0.24);
  --shadow-md:0 6px 22px rgba(14,50,55,0.09);
  --shadow-lg:0 22px 50px rgba(14,50,55,0.13);

  --font-display:'Poppins',system-ui,-apple-system,sans-serif;
  --font-body:'Poppins',system-ui,-apple-system,sans-serif;

  --max-w:1240px;
  --nav-h:78px;
  --section-py:clamp(3.5rem,7vw,6rem);
  --ease:cubic-bezier(0.16,1,0.3,1);
}

/* ── Reset / base ────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  background:var(--bg-1);color:var(--body);
  font-family:var(--font-body);font-size:1rem;font-weight:400;line-height:1.65;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  overflow-x:clip;min-height:100dvh;
}
img,svg{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
button{background:none;border:none;cursor:pointer;font:inherit;color:inherit;}
ul{list-style:none;}
h1,h2,h3{font-family:var(--font-display);font-weight:600;line-height:1.14;letter-spacing:-0.02em;color:var(--ink);}
p{line-height:1.72;max-width:62ch;}
address{font-style:normal;}

.wrap{width:100%;max-width:var(--max-w);margin-inline:auto;padding-inline:clamp(1.25rem,5vw,2.5rem);}
.section{padding-block:var(--section-py);}
.section--tint{background:var(--bg-2);}

/* ── Typographic scale ───────────────────────────────────────── */
.heading-1{font-size:clamp(1.9rem,4.2vw,2.9rem);font-weight:700;letter-spacing:-0.03em;}
.heading-2{font-size:clamp(1.5rem,3.2vw,2.2rem);font-weight:600;letter-spacing:-0.025em;}
.heading-3{font-size:clamp(1.15rem,2.2vw,1.5rem);font-weight:600;letter-spacing:-0.015em;}
.eyebrow{
  font-family:var(--font-body);font-size:0.76rem;font-weight:600;
  letter-spacing:0.15em;text-transform:uppercase;color:var(--muted);
  margin-bottom:0.9rem;
}
.eyebrow--light{color:rgba(247,240,225,0.92);}

/* ── Buttons ─────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:0.5rem;
  font-family:var(--font-body);font-weight:600;font-size:0.95rem;letter-spacing:0.005em;
  padding:0.85rem 1.6rem;border-radius:999px;border:1.5px solid transparent;
  transition:transform .2s var(--ease),background .2s,color .2s,box-shadow .2s;white-space:nowrap;
}
.btn:hover{transform:translateY(-2px);}
.btn.is-disabled{opacity:0.4;pointer-events:none;box-shadow:none;transform:none;}
.btn--lg{padding:1rem 2rem;font-size:1rem;}
.btn--small{padding:0.55rem 1.15rem;font-size:0.86rem;}
.btn--primary{background:var(--sea-700);color:var(--cream);box-shadow:var(--shadow-md);}
.btn--primary:hover{background:var(--sea-800);}
.btn--gold{background:var(--gold-500);color:#3a2a12;box-shadow:var(--shadow-md);}
.btn--gold:hover{background:var(--gold-700);color:#fff;}
.btn--ghost{background:rgba(247,240,225,0.06);color:var(--cream);border-color:rgba(247,240,225,0.72);}
.btn--ghost:hover{background:var(--cream);color:var(--sea-800);border-color:var(--cream);}
.btn--ghost-dark{background:transparent;color:var(--sea-700);border-color:var(--sea-700);}
.btn--ghost-dark:hover{background:var(--sea-700);color:var(--cream);}

/* ── Header ──────────────────────────────────────────────────── */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:50;height:var(--nav-h);display:flex;align-items:center;
  transition:background .3s var(--ease),box-shadow .3s,border-color .3s;border-bottom:1px solid transparent;
}
.site-header__inner{display:flex;align-items:center;justify-content:space-between;width:100%;}
.site-header.is-solid{background:rgba(251,248,241,0.94);backdrop-filter:blur(10px);
  border-bottom-color:var(--line);box-shadow:0 2px 14px rgba(14,50,55,0.06);}

/* Brand lockup (no-tag): teal badge over the hero, transparent teal when solid. */
.brand-logo{display:inline-flex;align-items:center;}
.brand-logo__img{height:48px;width:auto;display:block;}
.brand-logo__img--dark{display:none;}
.site-header.is-solid .brand-logo__img--light{display:none;}
.site-header.is-solid .brand-logo__img--dark{display:block;}

.site-nav{display:flex;align-items:center;gap:1.5rem;}
.site-nav__link{font-size:0.9rem;font-weight:500;color:var(--cream);opacity:0.92;transition:opacity .2s;}
.site-nav__link:hover{opacity:1;}
.site-header.is-solid .site-nav__link{color:var(--body);}
.site-header:not(.is-solid) .site-nav__link{text-shadow:0 1px 10px rgba(8,24,26,0.5);}

/* ── Hero ────────────────────────────────────────────────────── */
.hero{position:relative;min-height:min(92vh,820px);display:flex;align-items:flex-end;overflow:hidden;}
.hero__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 42%;}
.hero__scrim{position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(11,30,36,0.46) 0%,rgba(11,30,36,0.10) 26%,rgba(11,30,36,0.16) 50%,rgba(11,30,36,0.46) 80%,rgba(11,30,36,0.16) 100%),
    linear-gradient(100deg,rgba(8,24,29,0.72) 0%,rgba(8,24,29,0.40) 30%,rgba(8,24,29,0) 64%);}
/* Soft, generous fade from the hero photo into the cream section below — sits entirely
   below the (raised) hero content so the buttons never wash out. */
.hero__fade{position:absolute;left:0;right:0;bottom:0;height:clamp(90px,15vh,170px);z-index:1;
  pointer-events:none;background:linear-gradient(to bottom,rgba(244,237,221,0) 0%,rgba(244,237,221,0.5) 58%,var(--bg-1) 100%);}
.hero__content{position:relative;z-index:2;padding-bottom:clamp(6rem,10vw,8.5rem);padding-top:calc(var(--nav-h) + 2rem);}
.hero__title{font-family:var(--font-display);font-weight:700;color:var(--cream);
  font-size:clamp(2.7rem,8vw,5rem);line-height:1.02;letter-spacing:-0.035em;margin-bottom:1.1rem;}
.hero__tagline{color:rgba(247,240,225,0.95);font-size:clamp(1.05rem,2vw,1.28rem);
  line-height:1.6;max-width:38ch;margin-bottom:1.4rem;font-weight:400;}
.hero__meta{display:flex;flex-wrap:wrap;align-items:center;gap:0.55rem;
  color:rgba(247,240,225,0.92);font-size:0.95rem;letter-spacing:0.01em;margin-bottom:2rem;font-weight:500;}
.hero__meta .dot{opacity:0.5;}
.hero__cta{display:flex;flex-wrap:wrap;gap:0.9rem;}
/* Dark halo so white hero text stays legible over bright parts of the photo (G2/G19). */
.hero__title,.hero__tagline,.hero__meta,.hero .eyebrow--light{
  text-shadow:0 1px 2px rgba(8,20,24,0.42),0 2px 22px rgba(8,20,24,0.40);}

/* ── Intro ───────────────────────────────────────────────────── */
.intro__grid{display:grid;grid-template-columns:0.85fr 1.15fr;gap:clamp(1.5rem,5vw,4rem);align-items:start;}
.intro__body p{font-size:1.06rem;line-height:1.78;color:var(--body);}
.intro__body p + p{margin-top:1.2rem;}

/* ── Stats + amenities ───────────────────────────────────────── */
.stat-row{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem;
  padding-bottom:clamp(2rem,5vw,3.2rem);margin-bottom:clamp(2rem,5vw,3.2rem);border-bottom:1px solid var(--line);}
.stat{display:flex;flex-direction:column;align-items:center;text-align:center;gap:0.35rem;}
.stat__num{font-family:var(--font-display);font-weight:700;font-size:clamp(2.2rem,5vw,3.1rem);
  line-height:1;color:var(--sea-700);letter-spacing:-0.03em;}
.stat__unit{font-size:0.45em;vertical-align:0.4em;margin-left:0.05em;color:var(--sea-600);font-weight:600;}
.stat__label{font-size:0.78rem;font-weight:600;letter-spacing:0.09em;text-transform:uppercase;color:var(--muted);}

.amenities__title{margin-bottom:1.5rem;}
.amenities__list{display:grid;grid-template-columns:repeat(3,1fr);gap:0.7rem 2rem;}
.amenities__list li{position:relative;padding-left:1.6rem;font-size:1rem;color:var(--body);line-height:1.5;}
.amenities__list li::before{content:"";position:absolute;left:0;top:0.45em;width:0.7rem;height:0.42rem;
  border-left:2.5px solid var(--sea-600);border-bottom:2.5px solid var(--sea-600);transform:rotate(-45deg);}
.facts__note{margin-top:1.8rem;font-size:0.92rem;color:var(--muted);letter-spacing:0.01em;}

/* ── Feature rows ────────────────────────────────────────────── */
.feature__row{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,5vw,4rem);align-items:center;}
.feature__row + .feature__row{margin-top:clamp(3rem,7vw,5.5rem);}
.feature__row--reverse .feature__media{order:2;}
.feature__media{margin:0;border-radius:14px;overflow:hidden;box-shadow:var(--shadow-lg);background:var(--bg-3);}
.feature__media img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3;}
.feature__media img[width="1086"]{aspect-ratio:3/4;max-height:560px;}
.feature__text h2{margin-bottom:1.1rem;}
.feature__text p{font-size:1.04rem;line-height:1.75;color:var(--body);}
.distance-list{margin-top:1.6rem;border-top:1px solid var(--line);}
.distance-list li{display:flex;justify-content:space-between;gap:1rem;padding:0.7rem 0;border-bottom:1px solid var(--line);font-size:0.98rem;}
.distance-list__km{color:var(--sea-700);font-weight:600;font-variant-numeric:tabular-nums;}
.location-map{margin-top:clamp(2.5rem,5vw,4rem);border-radius:14px;overflow:hidden;box-shadow:var(--shadow-lg);line-height:0;}
.location-map iframe{width:100%;height:clamp(300px,40vw,440px);border:0;display:block;}

/* ── Direct-booking band + availability calendar ─────────────── */
.direct{background:var(--sea-700);color:var(--cream);}
.direct .eyebrow{color:var(--gold-500);}
.direct h2{color:var(--cream);}
.direct__head{max-width:62ch;margin:0 auto clamp(2rem,4vw,3rem);text-align:center;}
.direct__head p{color:rgba(247,240,225,0.92);font-size:1.06rem;line-height:1.7;margin:0.9rem auto 0;max-width:54ch;}

.booking{display:grid;grid-template-columns:1.5fr 1fr;gap:clamp(1.2rem,2.5vw,2.2rem);
  background:var(--bg-0);color:var(--body);border-radius:18px;padding:clamp(1.2rem,2.5vw,2rem);box-shadow:var(--shadow-lg);}

/* calendar */
.cal-nav{display:flex;align-items:center;margin-bottom:0.7rem;}
.cal-nav__sp{flex:1;}
.cal-nav__btn{width:2.2rem;height:2.2rem;border-radius:999px;border:1px solid var(--line-strong);color:var(--sea-700);
  font-size:1.3rem;line-height:1;display:flex;align-items:center;justify-content:center;transition:background .2s;}
.cal-nav__btn:hover:not(:disabled){background:var(--sea-50);}
.cal-nav__btn:disabled{opacity:0.3;cursor:default;}
.cal-months{display:grid;grid-template-columns:1fr 1fr;gap:1.6rem;}
.cal-month__title{font-family:var(--font-display);font-weight:600;color:var(--ink);font-size:0.95rem;text-align:center;margin-bottom:0.5rem;}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;}
.cal-dow{font-size:0.64rem;font-weight:700;letter-spacing:0.04em;text-transform:uppercase;color:var(--muted);text-align:center;padding-bottom:0.3rem;}
.cal-cell{position:relative;aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;line-height:1;border-radius:7px;color:var(--body);border:none;background:none;}
.cal-cell__day{font-size:0.82rem;}
.cal-cell__price{font-size:0.52rem;font-weight:600;letter-spacing:-0.02em;color:var(--muted);}
.cal-cell.is-checkin .cal-cell__price,.cal-cell.is-checkout .cal-cell__price{color:rgba(247,240,225,0.9);}
.cal-cell--empty{visibility:hidden;}
.cal-cell.is-past{color:#cbc4b5;cursor:default;}
.cal-cell.is-booked{color:#b6ada0;text-decoration:line-through;cursor:not-allowed;
  background:repeating-linear-gradient(135deg,transparent,transparent 4px,rgba(21,97,109,0.08) 4px,rgba(21,97,109,0.08) 8px);}
/* free nights that can't fit a 4-night stay between bookings: greyed + a dot, no strike */
.cal-cell.is-unbookable{text-decoration:none;}
.cal-cell.is-unbookable .cal-cell__day{opacity:0.6;}
.cal-cell.is-unbookable::after{content:"";position:absolute;bottom:5px;left:50%;width:4px;height:4px;margin-left:-2px;border-radius:50%;background:var(--gold-700);opacity:0.75;}
/* a booking's first night: selectable as check-out, shown without a price */
.cal-cell.is-checkout-only{cursor:pointer;}
.cal-cell.is-free{cursor:pointer;font-weight:500;}
.cal-cell.is-free:hover{background:var(--sea-50);}
.cal-cell.is-inrange{background:var(--sea-50);border-radius:0;}
.cal-cell.is-checkin,.cal-cell.is-checkout{background:var(--sea-700);color:var(--cream);font-weight:600;}
.cal-cell.is-checkin{border-radius:7px 0 0 7px;}
.cal-cell.is-checkout{border-radius:0 7px 7px 0;}
.booking__legend{display:flex;align-items:center;gap:0.35rem;margin-top:1rem;font-size:0.8rem;color:var(--muted);}
.booking__legend .lg{display:inline-block;width:0.85rem;height:0.85rem;border-radius:3px;margin:0 0.25rem 0 0.9rem;}
.booking__legend .lg:first-child{margin-left:0;}
.booking__legend .lg--free{background:var(--sea-50);border:1px solid var(--line-strong);}
.booking__legend .lg--booked{background:repeating-linear-gradient(135deg,#ece6da,#ece6da 3px,#d9d1c2 3px,#d9d1c2 6px);}

/* panel */
.booking__panel{display:flex;flex-direction:column;}
.booking__panel h3{margin-bottom:1rem;}
.booking__dates{display:grid;grid-template-columns:1fr 1fr;gap:0.7rem;margin-bottom:0.8rem;}
.booking__total{font-family:var(--font-display);font-weight:700;color:var(--sea-700);font-size:1.2rem;letter-spacing:-0.02em;min-height:1.25em;margin-bottom:0.8rem;}
.booking__date{background:var(--bg-1);border-radius:10px;padding:0.65rem 0.85rem;}
.booking__lbl{display:block;font-size:0.68rem;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;color:var(--muted);margin-bottom:0.2rem;}
.booking__date strong{font-weight:600;color:var(--ink);font-size:0.95rem;}
.booking__guests{display:block;margin-bottom:1.1rem;}
.booking__guests select{width:100%;margin-top:0.25rem;padding:0.6rem 0.8rem;border:1px solid var(--line-strong);border-radius:10px;background:var(--bg-1);font:inherit;color:var(--ink);}
.booking__cta{width:100%;margin-bottom:0.6rem;}
.booking__cta.is-ready{box-shadow:0 6px 22px rgba(21,97,109,0.30);}
.booking__clear{align-self:center;font-size:0.84rem;color:var(--muted);text-decoration:underline;margin-bottom:0.3rem;}
.booking__note{font-size:0.85rem;color:var(--muted);min-height:1em;margin-bottom:0.4rem;}
.booking__note--warn{color:#9a3a12;background:rgba(224,164,88,0.16);border:1px solid rgba(224,164,88,0.55);border-radius:9px;padding:0.55rem 0.75rem;font-weight:600;}
.direct__ota{margin-top:auto;padding-top:1rem;border-top:1px solid var(--line);font-size:0.84rem;color:var(--muted);text-align:center;}
.direct__ota a{color:var(--sea-700);font-weight:600;border-bottom:1px solid var(--line-strong);}
.direct__ota a:hover{border-bottom-color:var(--sea-700);}
@media (max-width:780px){ .booking{grid-template-columns:1fr;} }
@media (max-width:560px){ .cal-months{grid-template-columns:1fr;gap:1.3rem;} }

/* ── Gallery ─────────────────────────────────────────────────── */
.gallery__title{margin-bottom:2rem;}
.gallery__grid{columns:3;column-gap:1rem;}
.gallery__cell{display:block;width:100%;margin-bottom:1rem;padding:0;border-radius:12px;overflow:hidden;
  break-inside:avoid;box-shadow:var(--shadow-md);background:var(--bg-3);cursor:zoom-in;}
.gallery__cell img{width:100%;height:auto;transition:transform .5s var(--ease);}
.gallery__cell:hover img{transform:scale(1.04);}

/* ── Reviews ─────────────────────────────────────────────────── */
.reviews__title{margin-bottom:0.4rem;}
.reviews__sub{color:var(--muted);font-size:1rem;margin-bottom:2.4rem;}
.reviews__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;}
.review{background:var(--bg-0);border:1px solid var(--line);border-radius:14px;padding:1.8rem;
  display:flex;flex-direction:column;gap:1.1rem;box-shadow:var(--shadow-md);}
.review p{font-size:1.04rem;line-height:1.6;color:var(--ink);max-width:none;}
.review cite{font-style:normal;font-size:0.8rem;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;color:var(--sea-700);margin-top:auto;}
.reviews__attr{margin-top:1.6rem;font-size:0.85rem;color:var(--muted);}

/* ── Closing CTA ─────────────────────────────────────────────── */
.cta-band{background:var(--sea-50);}
.cta-band__inner{text-align:center;display:flex;flex-direction:column;align-items:center;gap:1.1rem;}
.cta-band__inner h2{color:var(--ink);}
.cta-band__inner p{max-width:48ch;color:var(--body);font-size:1.06rem;}
.cta-band .hero__cta{justify-content:center;margin-top:0.8rem;}
.cta-band .hero__cta .btn{text-shadow:none;}

/* ── Footer ──────────────────────────────────────────────────── */
.site-footer{background:var(--sea-900);color:rgba(247,240,225,0.85);padding-block:3rem 2rem;}
.site-footer__inner{display:flex;flex-wrap:wrap;justify-content:space-between;gap:1.5rem 2rem;align-items:flex-start;
  padding-bottom:1.8rem;border-bottom:1px solid rgba(247,240,225,0.14);}
/* align-items:flex-start so the flex column does NOT stretch the logo to full width. */
.site-footer__brand{display:flex;flex-direction:column;gap:0.9rem;align-items:flex-start;}
.site-footer__logo{height:52px;width:auto;display:block;}
.site-footer__addr{font-size:0.92rem;color:rgba(247,240,225,0.72);}
.site-footer__links{display:flex;gap:1.5rem;flex-wrap:wrap;align-items:center;}
.site-footer__links a{font-size:0.92rem;color:rgba(247,240,225,0.92);border-bottom:1px solid transparent;transition:border-color .2s;}
.site-footer__links a:hover{border-bottom-color:var(--gold-500);}
.site-footer__legal{padding-top:1.4rem;}
.site-footer__legal p{font-size:0.82rem;color:rgba(247,240,225,0.6);max-width:none;}

/* ── Lightbox ────────────────────────────────────────────────── */
.lightbox{position:fixed;inset:0;z-index:100;display:none;align-items:center;justify-content:center;
  background:rgba(8,24,28,0.92);padding:clamp(1rem,4vw,3rem);}
.lightbox.is-open{display:flex;}
.lightbox__img{max-width:100%;max-height:100%;border-radius:8px;box-shadow:0 30px 80px rgba(0,0,0,0.5);}
.lightbox__close{position:absolute;top:1.2rem;right:1.6rem;font-size:2.4rem;line-height:1;color:var(--cream);opacity:0.85;width:3rem;height:3rem;}
.lightbox__close:hover{opacity:1;}

/* ── Responsive ──────────────────────────────────────────────── */
@media (max-width:900px){
  .intro__grid{grid-template-columns:1fr;gap:1.5rem;}
  .feature__row,.feature__row--reverse .feature__media{grid-template-columns:1fr;order:0;}
  .feature__row{gap:1.6rem;}
  .feature__media img[width="1086"]{aspect-ratio:4/3;max-height:none;}
  .direct__grid{grid-template-columns:1fr;gap:2rem;}
  .reviews__grid{grid-template-columns:1fr;}
  .gallery__grid{columns:2;}
}
@media (max-width:600px){
  .site-nav{gap:0.8rem;}
  .site-nav__link{display:none;}
  .brand-logo__img{height:40px;}
  .stat-row{grid-template-columns:repeat(2,1fr);gap:1.6rem 1rem;}
  .amenities__list{grid-template-columns:1fr;}
  .gallery__grid{columns:1;}
  .hero__cta .btn{flex:1 1 auto;}
}
@media (prefers-reduced-motion:reduce){
  *{scroll-behavior:auto !important;transition:none !important;}
  .btn:hover,.gallery__cell:hover img{transform:none;}
}
