/* ================================================================
   BOUDOIR VALLARTA — shared design system v3
   - light/dark theming via [data-theme]
   - stronger nav (always-on backdrop bar; no mix-blend gimmicks)
   - longer/denser marquee
   - cinematic motion utilities (split-line lift, draw-in lines, parallax)
   - tightened section spacing
   - MOBILE NAV: hamburger + slide-in drawer (v4 addition)
================================================================ */

/* ---------- THEME TOKENS ---------- */
:root,
[data-theme="light"] {
  --parchment:   #EAE0D0;
  --parchment-2: #DDD2BE;
  --parchment-3: #F4EFE6;
  --umber:       #2A1F18;
  --umber-soft:  #5C4A3D;
  --umber-deep:  #15100C;
  --terracotta:  #B5664E;
  --gold:        #C9A961;
  --line:        rgba(42,31,24,.18);
  --bg:          var(--parchment);
  --bg-2:        var(--parchment-2);
  --text:        var(--umber);
  --text-soft:   var(--umber-soft);
  --accent:      var(--terracotta);
  --highlight:   var(--gold);
  --grain-blend: multiply;
  --grain-opacity: .07;
}

[data-theme="dark"] {
  --bg:          #15100C;
  --bg-2:        #1F1812;
  --text:        #EAE0D0;
  --text-soft:   #A89A88;
  --accent:      #D58467;   /* slightly brighter terracotta on dark */
  --highlight:   #DDB97A;   /* slightly warmer gold on dark */
  --line:        rgba(235,227,213,.13);
  --grain-blend: screen;
  --grain-opacity: .04;
}

/* ---------- RESET ---------- */
*{box-sizing:border-box;margin:0;padding:0}
html{
  scroll-behavior:smooth;
  background:var(--bg);color:var(--text);
  transition:background-color .8s ease, color .6s ease;
}
body{
  font-family:'Inter',system-ui,sans-serif;font-weight:300;
  background:var(--bg);color:var(--text);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;position:relative;
  transition:background-color .8s ease, color .6s ease;
}
::selection{background:var(--accent);color:var(--bg)}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}

/* ---------- TYPE HELPERS ---------- */
.display{font-family:'Playfair Display',serif;letter-spacing:.04em;font-weight:400}
.serif{font-family:'Playfair Display',serif;font-weight:300}
.it{font-style:italic}
.luxe{
  font-size:10px;letter-spacing:.36em;text-transform:uppercase;
  color:var(--text-soft);font-weight:400;
  font-variant-numeric:tabular-nums;
}
.num,.num *{
  font-family:'Playfair Display',serif !important;
  font-style:italic !important;
  font-feature-settings:"lnum" 1, "tnum" 1;
}
.tabnum{font-variant-numeric:tabular-nums lining-nums}

/* ---------- FILM GRAIN ---------- */
.grain{
  position:fixed;inset:0;pointer-events:none;z-index:100;
  opacity:var(--grain-opacity);mix-blend-mode:var(--grain-blend);
  width:100%;height:100%;
}

/* ---------- LAYOUT ---------- */
.wrap{max-width:1440px;margin:0 auto;padding:0 24px;box-sizing:border-box}
@media(min-width:768px){.wrap{padding:0 48px}}
@media(min-width:1200px){.wrap{padding:0 64px}}
section{position:relative}
.section-pad{padding:80px 0}
@media(min-width:768px){.section-pad{padding:140px 0}}

/* ============================================================
   NAV
============================================================ */
header.nav{
  position:fixed;inset:0 0 auto 0;z-index:50;
  padding:14px 0;
  transition:all .55s ease;
  color:var(--parchment);
  background:rgba(20,15,10,.55);
  backdrop-filter:blur(14px) saturate(1.1);
  -webkit-backdrop-filter:blur(14px) saturate(1.1);
  border-bottom:1px solid rgba(244,239,230,.1);
}
header.nav.solid{
  background:rgba(235,227,213,.94);
  color:var(--umber);
  border-bottom-color:rgba(42,31,24,.12);
}
[data-theme="dark"] header.nav.solid{
  background:rgba(20,15,10,.94);
  color:var(--parchment);
  border-bottom-color:rgba(244,239,230,.1);
}
header.nav.dark-route{
  background:rgba(235,227,213,.94);
  color:var(--umber);
  border-bottom-color:rgba(42,31,24,.12);
}
[data-theme="dark"] header.nav.dark-route{
  background:rgba(20,15,10,.94);
  color:var(--parchment);
}
header.nav .row{display:flex;align-items:center;justify-content:space-between;position:relative}
.logo{
  font-family:'Playfair Display',serif;font-size:22px;letter-spacing:.06em;
}
.logo em{
  font-family:'Playfair Display',serif;font-style:italic;
  color:var(--accent);
}
header.nav nav ul{display:none;gap:38px;align-items:center}
@media(min-width:900px){header.nav nav ul{display:flex}}
header.nav nav a{
  font-size:11px;letter-spacing:.36em;text-transform:uppercase;
  font-weight:500;
  opacity:.92;transition:opacity .3s,color .3s;
}
header.nav nav a:hover,header.nav nav a.active{opacity:1;color:var(--accent)}
header.nav .book{
  font-size:11px;letter-spacing:.36em;text-transform:uppercase;
  font-weight:500;
  border-bottom:1px solid currentColor;padding-bottom:3px;
}

/* theme toggle */
.theme-toggle{
  display:flex;align-items:center;gap:8px;
  font-size:10px;letter-spacing:.32em;text-transform:uppercase;
  opacity:.75;cursor:pointer;background:none;border:0;color:inherit;
  font-family:inherit;padding:0;
}
.theme-toggle:hover{opacity:1}
.theme-toggle .dot{width:6px;height:6px;border-radius:50%;background:currentColor;display:inline-block}

/* ============================================================
   MOBILE NAV — Hamburger + slide-in drawer
============================================================ */

/* Hamburger button */
.nav-toggle {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 36px;
  height: 36px;
  padding: 4px;
  background: none;
  border: 0;
  cursor: pointer;
  color: inherit;
  z-index: 60;
  flex-shrink: 0;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
}
.nav-toggle span {
  display: block;
  width: 22px;
  height: 1px;
  background: currentColor;
  transition: transform .35s cubic-bezier(.7,0,.2,1),
              opacity .25s ease,
              width .35s cubic-bezier(.7,0,.2,1);
  transform-origin: center;
}
.nav-toggle.open span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.nav-toggle.open span:nth-child(2) { opacity: 0; width: 0; }
.nav-toggle.open span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }
@media (min-width: 900px) { .nav-toggle { display: none; } }

/* Slide-in drawer — hidden off-screen by default (also has inline style="display:none") */
.mobile-nav {
  position: fixed;
  inset: 0 0 0 auto;
  width: min(300px, 86vw);
  background: var(--bg-2);
  border-left: 1px solid var(--line);
  z-index: 55;
  padding: 100px 36px 48px;
  display: flex;
  flex-direction: column;
  transform: translateX(110%);
  transition: transform .5s cubic-bezier(.7,0,.2,1);
  pointer-events: none;
}
.mobile-nav.open {
  transform: translateX(0);
  pointer-events: all;
}
.mobile-nav ul { display: flex; flex-direction: column; gap: 0; }
.mobile-nav ul li { border-bottom: 1px solid var(--line); }
.mobile-nav ul a {
  display: block;
  padding: 18px 0;
  font-family: 'Playfair Display', serif;
  font-size: 26px;
  letter-spacing: .04em;
  color: var(--text);
  transition: color .25s, padding-left .3s cubic-bezier(.7,0,.2,1);
}
.mobile-nav ul a:hover,
.mobile-nav ul a.active { color: var(--accent); padding-left: 6px; }
.mobile-nav .mob-actions {
  margin-top: 36px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.mobile-nav .mob-book {
  font-size: 11px;
  letter-spacing: .36em;
  text-transform: uppercase;
  font-weight: 500;
  border-bottom: 1px solid var(--accent);
  padding-bottom: 3px;
  color: var(--accent);
  display: inline-block;
}
.mobile-nav .mob-theme {
  font-size: 10px;
  letter-spacing: .32em;
  text-transform: uppercase;
  opacity: .65;
  cursor: pointer;
  background: none;
  border: 0;
  color: inherit;
  font-family: inherit;
  padding: 0;
  display: flex;
  align-items: center;
  gap: 8px;
}
.mobile-nav .mob-theme .dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: currentColor;
  display: inline-block;
}

/* Scrim overlay — also has inline style="display:none" as default */
.nav-scrim {
  position: fixed;
  inset: 0;
  background: rgba(20,15,10,.55);
  z-index: 54;
  opacity: 0;
  pointer-events: none;
  transition: opacity .4s ease;
}
.nav-scrim.open {
  opacity: 1;
  pointer-events: all;
}

/* On mobile: hide the desktop theme+book buttons (they live in the drawer)
   BUT keep the hamburger toggle visible */
@media (max-width: 899px) {
  header.nav > .wrap > div[style] { display: none !important; }
  .nav-toggle { display: flex !important; }
}

/* On desktop: hide hamburger */
@media (min-width: 900px) {
  .nav-toggle { display: none !important; }
}

/* ============================================================
   BOUDOIR PAGE — fix hero .corner.r overlap on mobile
   "$450 · Two hours · A full gallery" sits at top:96px and
   collides with the nav bar on small screens. Price is already
   prominently displayed in the Investment section below.
============================================================ */
@media (max-width: 899px) {
  .hero .corner.r { display: none; }
}

/* ============================================================
   PINNED 3-SLIDE HERO
============================================================ */
.hero-pinned{position:relative;height:300vh}
.hero-pinned .stage{position:sticky;top:0;height:100vh;min-height:760px;overflow:hidden;color:var(--parchment)}
.hero-pinned .slide{position:absolute;inset:0;opacity:0;transition:opacity 1.1s cubic-bezier(.7,0,.2,1)}
.hero-pinned .slide.active{opacity:1}
.hero-pinned .slide .bg{position:absolute;inset:0;overflow:hidden}
.hero-pinned .slide .bg img{
  width:100%;height:100%;object-fit:cover;
  transform:scale(1.12);
  transition:transform 8s cubic-bezier(.2,.7,.2,1);
}
.hero-pinned .slide.active .bg img{transform:scale(1)}
.hero-pinned .slide .bg::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(42,31,24,.42) 0%,rgba(42,31,24,.05) 30%,rgba(42,31,24,0) 56%,rgba(42,31,24,.85) 100%);
}
.hero-pinned .slide .body{
  position:absolute;left:24px;right:24px;bottom:48px;
  opacity:0;transform:translateY(20px);
  transition:opacity 1s ease .3s, transform 1.1s cubic-bezier(.2,.7,.2,1) .3s;
}
.hero-pinned .slide.active .body{opacity:1;transform:translateY(0)}
@media(min-width:768px){.hero-pinned .slide .body{left:56px;right:56px;bottom:64px}}
.hero-pinned h1{
  font-family:'Playfair Display',serif;font-style:italic;font-weight:300;
  font-size:clamp(48px,8.5vw,148px);
  line-height:.94;letter-spacing:-.018em;
  max-width:14ch;padding-bottom:.08em;
  text-shadow:0 2px 28px rgba(0,0,0,.18);
}
.hero-pinned h1 .iv{font-family:'Playfair Display',serif;font-style:normal;letter-spacing:.04em;font-weight:400}
.hero-pinned h1 .gold{color:var(--gold)}
.hero-pinned .corner{
  position:absolute;top:78px;font-size:10px;letter-spacing:.36em;
  text-transform:uppercase;opacity:.85;left:24px;color:var(--parchment);
  z-index:3;text-shadow:0 1px 16px rgba(0,0,0,.6);
}
.hero-pinned .corner.r{left:auto;right:24px;text-align:right}
@media(min-width:768px){.hero-pinned .corner{top:96px;left:56px}.hero-pinned .corner.r{right:56px}}
.hero-pinned .counter{
  position:absolute;right:24px;top:50%;transform:translateY(-50%);z-index:4;
  color:var(--parchment);text-align:right;
  display:flex;flex-direction:column;align-items:flex-end;gap:8px;
}
@media(min-width:768px){.hero-pinned .counter{right:56px}}
.hero-pinned .counter .now{
  font-family:'Playfair Display',serif;font-style:italic;
  font-size:64px;line-height:1;color:var(--gold);
  font-feature-settings:"lnum" 1;
}
.hero-pinned .counter .of{
  font-size:10px;letter-spacing:.4em;text-transform:uppercase;opacity:.7;
  font-variant-numeric:tabular-nums lining-nums;
}
.hero-pinned .progress{
  position:absolute;left:24px;right:24px;bottom:18px;
  height:1px;background:rgba(244,239,230,.2);z-index:3;
}
@media(min-width:768px){.hero-pinned .progress{left:56px;right:56px}}
.hero-pinned .progress .fill{
  height:100%;background:var(--gold);
  transform-origin:left;transform:scaleX(0);
  transition:transform .15s linear;
}

/* ---------- LEGACY single-image hero ---------- */
.hero{position:relative;height:100svh;min-height:760px;overflow:hidden}
.hero .bg{position:absolute;inset:0;overflow:hidden}
.hero .bg img{
  width:100%;height:100%;object-fit:cover;
  transform:scale(1.15);animation:burns 12s cubic-bezier(.2,.7,.2,1) forwards;
}
@keyframes burns{to{transform:scale(1)}}
.hero .bg::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(42,31,24,.42) 0%,rgba(42,31,24,.05) 30%,rgba(42,31,24,0) 56%,rgba(42,31,24,.78) 100%);
}
.hero .corner{
  position:absolute;top:96px;color:var(--parchment);
  font-size:10px;letter-spacing:.36em;text-transform:uppercase;
  opacity:.85;left:24px;text-shadow:0 1px 16px rgba(0,0,0,.6);
}
.hero .corner.r{left:auto;right:24px;text-align:right}
@media(min-width:768px){.hero .corner{top:96px;left:56px}.hero .corner.r{right:56px}}
.hero .body{
  position:absolute;left:24px;right:24px;bottom:48px;color:var(--parchment);
  opacity:0;transform:translateY(28px);
  animation:rise 1.4s cubic-bezier(.2,.7,.2,1) .35s forwards;
}
@media(min-width:768px){.hero .body{left:56px;right:56px;bottom:64px}}
@keyframes rise{to{opacity:1;transform:translateY(0)}}
.hero h1{
  font-family:'Playfair Display',serif;font-style:italic;font-weight:300;
  font-size:clamp(48px,8.5vw,140px);line-height:.94;letter-spacing:-.018em;
  max-width:14ch;padding-bottom:.08em;
  text-shadow:0 2px 28px rgba(0,0,0,.2);
}
.hero h1 .iv{font-family:'Playfair Display',serif;font-style:normal;letter-spacing:.04em;font-weight:400;display:inline}
.hero h1 .gold{color:var(--gold)}

/* ============================================================
   MARQUEE
============================================================ */
.marquee{
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:24px 0;overflow:hidden;white-space:nowrap;
  background:var(--bg);
}
.marquee-track{
  display:inline-flex;gap:48px;align-items:center;
  animation:scroll 56s linear infinite;
  font-family:'Playfair Display',serif;font-size:22px;letter-spacing:.18em;
  color:var(--text-soft);text-transform:uppercase;
}
.marquee-track em{
  color:var(--accent);font-family:'Playfair Display',serif;font-style:italic;
  letter-spacing:.04em;text-transform:none;
}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ============================================================
   DROP CAP
============================================================ */
.dropcap p:first-of-type::first-letter{
  font-family:'Playfair Display',serif;font-style:italic;
  font-size:4.5em;float:left;line-height:.85;
  padding:6px 14px 0 0;color:var(--accent);
}

/* ============================================================
   REVEAL + CINEMATIC MOTION
============================================================ */
.reveal{
  opacity:0;transform:translateY(28px);
  transition:opacity 1s cubic-bezier(.2,.7,.2,1),transform 1.1s cubic-bezier(.2,.7,.2,1);
}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal-img{clip-path:inset(0 0 100% 0);transition:clip-path 1.6s cubic-bezier(.7,0,.2,1)}
.reveal-img.in{clip-path:inset(0 0 0 0)}
.reveal-img img{scale:1.10;transition:scale 2s cubic-bezier(.2,.7,.2,1)}
.reveal-img.in img{scale:1}
.split-line{display:block;overflow:hidden;line-height:.94}
.split-line > .ln{display:block;overflow:hidden}
.split-line > .ln > span{
  display:block;transform:translateY(110%);
  transition:transform 1.2s cubic-bezier(.7,0,.2,1);
}
.split-line.in > .ln:nth-child(1) > span{transition-delay:.05s;transform:translateY(0)}
.split-line.in > .ln:nth-child(2) > span{transition-delay:.18s;transform:translateY(0)}
.split-line.in > .ln:nth-child(3) > span{transition-delay:.32s;transform:translateY(0)}
.split-line.in > .ln:nth-child(4) > span{transition-delay:.44s;transform:translateY(0)}
.draw-line{
  height:1px;background:var(--accent);transform:scaleX(0);transform-origin:left;
  transition:transform 1.4s cubic-bezier(.7,0,.2,1);
}
.draw-line.in{transform:scaleX(1)}
.parallax-slow,.parallax-fast{will-change:transform}
figure.reveal-img > img.parallax-slow,
figure.reveal-img > img.parallax-fast,
.b-split figure > img.parallax-slow,
.b-split figure > img.parallax-fast,
.b-rooms figure .fr > img.parallax-slow,
.full-bleed .fr > img.parallax-slow,
.full-bleed .fr > img.parallax-fast,
.md-pin-images figure > img.parallax-slow,
.ig-grid figure .fr > img.parallax-slow{
  height:140%;
  width:100%;
  object-fit:cover;
  position:absolute;top:-20%;left:0;
}
figure.reveal-img,
.b-split figure,
.b-rooms figure .fr,
.full-bleed .fr,
.md-pin-images figure,
.ig-grid figure .fr{position:relative;overflow:hidden}
.scroll-scale{
  transform:scale(1.12);
  transition:transform 1.6s cubic-bezier(.2,.7,.2,1);
}
.scroll-scale.in{transform:scale(1)}

/* ============================================================
   COMMON COMPONENTS
============================================================ */
h2.head{
  font-family:'Playfair Display',serif;font-weight:400;
  font-size:clamp(40px,5.5vw,96px);line-height:1;letter-spacing:-.005em;
  padding-bottom:.06em;
}
h2.head em{
  font-family:'Playfair Display',serif;font-style:italic;
  color:var(--accent);letter-spacing:-.01em;
}
h3.sub{
  font-family:'Playfair Display',serif;font-style:italic;font-weight:300;
  font-size:clamp(22px,2.4vw,30px);line-height:1.3;letter-spacing:-.005em;
}
.body-text{font-size:15px;line-height:1.85;color:var(--text-soft)}
.body-text-lg{font-size:17px;line-height:1.95;color:var(--text)}
.grid12{display:grid;grid-template-columns:repeat(12,1fr);gap:20px}
@media(min-width:768px){.grid12{gap:32px}}

/* ---------- PACKAGES ---------- */
.pkg-grid{display:grid;grid-template-columns:1fr;gap:1px;background:var(--line);border:1px solid var(--line)}
@media(min-width:900px){.pkg-grid{grid-template-columns:repeat(3,1fr)}}
.pkg{background:var(--bg);padding:48px 36px;display:flex;flex-direction:column;justify-content:space-between;min-height:440px}
@media(min-width:768px){.pkg{padding:56px 48px}}
.pkg .num{
  font-family:'Playfair Display',serif !important;font-style:italic !important;
  font-weight:300;font-size:14px;letter-spacing:.05em;text-transform:none;
  color:var(--accent);margin-bottom:24px;font-feature-settings:"lnum" 1;
}
.pkg h3{font-family:'Playfair Display',serif;font-size:28px;letter-spacing:.02em;font-weight:400}
.pkg .meta{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);margin-top:8px}
.pkg p{margin-top:20px;font-size:14px;line-height:1.85;color:var(--text-soft)}
.pkg .foot{margin-top:36px;display:flex;align-items:flex-end;justify-content:space-between}
.pkg .price{
  font-family:'Playfair Display',serif !important;font-style:italic !important;
  font-weight:400;font-size:46px;letter-spacing:-.01em;line-height:1;
  color:var(--text);font-feature-settings:"lnum" 1;
}
.pkg .reserve{font-size:11px;letter-spacing:.32em;text-transform:uppercase;border-bottom:1px solid currentColor;padding-bottom:3px}
.lnk{font-size:11px;letter-spacing:.32em;text-transform:uppercase;border-bottom:1px solid currentColor;padding-bottom:3px}
.lnk-gold{color:var(--accent);border-color:var(--accent)}

/* ---------- INSTAGRAM FEED ---------- */
.ig-section{padding:80px 0 100px;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
@media(min-width:768px){.ig-section{padding:120px 0 140px}}
.ig-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:32px;flex-wrap:wrap;gap:24px}
.ig-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
@media(min-width:768px){.ig-grid{gap:14px}}
.ig-grid figure{position:relative;overflow:hidden;background:var(--bg-2);cursor:pointer;margin:0}
.ig-grid figure .fr{position:relative;aspect-ratio:1/1;overflow:hidden}
.ig-grid figure img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s cubic-bezier(.2,.7,.2,1),filter .6s ease}
.ig-grid figure:hover img{transform:scale(1.06)}
.ig-grid figure::after{
  content:"";position:absolute;inset:0;
  background:rgba(42,31,24,0);transition:background .5s ease;
  pointer-events:none;
}
.ig-grid figure:hover::after{background:rgba(42,31,24,.18)}

/* ---------- FOOTER ---------- */
footer{border-top:1px solid var(--line);background:var(--bg-2);margin-top:0}
footer .row{padding:80px 0;display:grid;grid-template-columns:1fr;gap:40px}
@media(min-width:768px){footer .row{grid-template-columns:5fr 3fr 4fr}}
footer .tag{font-family:'Playfair Display',serif;font-style:italic;font-weight:300;font-size:24px;line-height:1.25;color:var(--text-soft);max-width:380px}
footer .col h4{margin-bottom:24px}
footer ul{display:flex;flex-direction:column;gap:12px;font-size:14px}
footer ul a:hover{color:var(--accent)}
footer .bot{border-top:1px solid var(--line);padding:24px 0;display:flex;flex-direction:column;align-items:center;gap:12px;font-size:10px;letter-spacing:.36em;text-transform:uppercase;color:var(--text-soft)}
@media(min-width:768px){footer .bot{flex-direction:row;justify-content:space-between}}
footer .bot .center{font-family:'Playfair Display',serif;font-style:italic;text-transform:none;letter-spacing:0;font-size:14px;color:var(--accent)}

/* ---------- CTA ---------- */
.cta{padding:120px 0 160px;border-top:1px solid var(--line);text-align:center}
.cta .luxe{margin-bottom:32px}
.cta h2{
  font-family:'Playfair Display',serif;font-weight:400;
  font-size:clamp(44px,7.5vw,116px);
  line-height:1.12;letter-spacing:-.005em;
  padding-bottom:.18em;
}
.cta h2 em{
  font-family:'Playfair Display',serif;font-style:italic;font-weight:300;
  color:var(--accent);letter-spacing:-.01em;
}
.cta .btn{
  display:inline-block;margin-top:48px;
  font-family:\'Inter\',system-ui,sans-serif;font-style:normal;font-size:11px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;
  color:var(--accent);border-bottom:2px solid var(--accent);padding-bottom:8px;
  transition:opacity .3s;
}
.cta .btn:hover{opacity:.7}

/* ---------- LIGHTBOX ---------- */
#lightbox{
  display:none;position:fixed;inset:0;z-index:200;
  background:rgba(20,15,10,.92);
  align-items:center;justify-content:center;
  cursor:zoom-out;
}
#lightbox.open{display:flex}
#lightbox img{max-width:90vw;max-height:90vh;object-fit:contain}

/* ============================================================
   REDUCED MOTION
============================================================ */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms!important;transition-duration:.001ms!important}
}


/* ══ TYPOGRAPHY SYSTEM ══ */

/* Display — Playfair Display: headlines, hero text, section titles */
.head, h1, h2, h3, .logo, .cta h2 {
  font-family: 'Playfair Display', Georgia, serif;
  font-weight: 400;
  letter-spacing: -0.02em;
  line-height: 0.95;
}

/* Accent — Cormorant Garamond: italic highlights, labels, captions, section eyebrows */
.luxe, .tag, figcaption, .sub, em, .num, .counter-num,
.hero .corner, .bot .center, cite, blockquote {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-weight: 300;
  letter-spacing: 0.04em;
  font-style: italic;
}

/* UI — Inter: nav, body text, buttons, prices, descriptions */
body, p, .body-text, .body-text-lg, nav, button,
.book, .btn, .price, .pkg h3, input, textarea, select,
.pkg p, .filter-btn, #p-filters button {
  font-family: 'Inter', system-ui, sans-serif;
  font-weight: 300;
  letter-spacing: 0.01em;
}

/* Nav links — Inter slightly tracked */  
nav ul li a, .nav ul li a {
  font-family: 'Inter', system-ui, sans-serif;
  font-weight: 400;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-size: 11px;
}

/* Logo — Playfair Display */
.logo {
  font-family: 'Playfair Display', Georgia, serif;
  font-weight: 400;
}

/* Logo italic part — Cormorant */
.logo em {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic;
  font-weight: 300;
}

/* Buttons — Inter medium */
.book, .btn, button.theme-toggle {
  font-family: 'Inter', system-ui, sans-serif;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 11px;
}

/* 3. REFINED BACKGROUND PALETTE */
/* Keep parchment as primary, add alabaster for alternating sections */
:root {
  --alabaster: #F5F1EB;
  --espresso:  #1A1410;
}

/* Alternating section backgrounds for rhythm */
section.alt-bg {
  background: var(--alabaster);
}

/* Footer — deep espresso */
footer {
  background: var(--espresso) !important;
  color: #EAE0D0;
}

footer * {
  color: rgba(235,227,213,0.75);
}

footer a:hover {
  color: #EAE0D0;
}

footer .logo {
  color: #EAE0D0 !important;
}

footer .bot {
  border-top: 1px solid rgba(235,227,213,0.12);
  color: rgba(235,227,213,0.4);
}

/* CTA section — slightly deeper than parchment */
.cta {
  background: var(--umber-deep) !important;
  color: #EAE0D0;
}

.cta h2, .cta p, .cta .luxe {
  color: #EAE0D0 !important;
}

/* 4. TYPE SCALE — more dramatic size contrast */
@media(min-width:900px) {
  .head { font-size: clamp(56px, 6.5vw, 110px); }
  h2.head { font-size: clamp(44px, 5vw, 88px); }
}

/* Tighter letter-spacing on large display text */
h1 { letter-spacing: -0.03em; }

/* Body text refinement */
.body-text { 
  font-size: 15px; 
  line-height: 1.75; 
  font-weight: 300;
}

.body-text-lg { 
  font-size: 17px; 
  line-height: 1.8; 
  font-weight: 300;
}

/* Labels — Inter ALL CAPS, very tracked */
.luxe {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-style: normal !important;
  font-size: 10px !important;
  font-weight: 500 !important;
  letter-spacing: 0.28em !important;
  text-transform: uppercase !important;
}


/* ══ TARGETED TYPE FIXES ══ */

/* CTA headline — was 116px Italiana, now editorial but controlled */
.cta h2, .cta .head {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-size: clamp(44px, 5vw, 72px) !important;
  font-weight: 400 !important;
  line-height: 1.05 !important;
  letter-spacing: -0.02em !important;
  font-style: normal !important;
}

.cta h2 em, .cta .head em {
  font-family: 'Cormorant Garamond', Georgia, serif !important;
  font-style: italic !important;
  font-weight: 300 !important;
}

/* CTA subtitle "Start with a conversation" */
.cta .luxe {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 10px !important;
  font-weight: 500 !important;
  letter-spacing: 0.28em !important;
  text-transform: uppercase !important;
  font-style: normal !important;
  color: var(--text-soft) !important;
}

/* CTA button — NOT a giant serif, small Inter uppercase */
.cta a.btn, .cta .btn {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 11px !important;
  font-weight: 500 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  font-style: normal !important;
}

/* Logo — Playfair Display, larger */
.logo {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-size: 24px !important;
  font-weight: 400 !important;
  letter-spacing: -0.01em !important;
}

.logo em {
  font-family: 'Cormorant Garamond', Georgia, serif !important;
  font-style: italic !important;
  font-weight: 300 !important;
}

/* h3 / package titles — Playfair Display, controlled size */
h3, .pkg h3 {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-size: clamp(20px, 2.2vw, 32px) !important;
  font-weight: 400 !important;
  letter-spacing: -0.01em !important;
}

/* Price — Inter, not Cormorant */
.price {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-size: clamp(28px, 3vw, 42px) !important;
  font-weight: 400 !important;
  letter-spacing: -0.02em !important;
}

/* Body text — Inter light, proper line height */
.body-text {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 15px !important;
  line-height: 1.78 !important;
  font-weight: 300 !important;
  letter-spacing: 0.005em !important;
}

.body-text-lg {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 17px !important;
  line-height: 1.85 !important;
  font-weight: 300 !important;
}

/* Section labels — .luxe = Inter tracked uppercase */
.luxe {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 10px !important;
  font-weight: 500 !important;
  letter-spacing: 0.28em !important;
  text-transform: uppercase !important;
  font-style: normal !important;
}

/* Subheadings .sub — Cormorant italic, refined */
.sub {
  font-family: 'Cormorant Garamond', Georgia, serif !important;
  font-style: italic !important;
  font-weight: 300 !important;
  letter-spacing: 0.02em !important;
}

/* Nav links */
nav ul li a, header nav ul li a {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 11px !important;
  font-weight: 400 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
}

/* h1 hero — Playfair Display, dramatic */
h1 {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-weight: 400 !important;
  letter-spacing: -0.025em !important;
  line-height: 0.92 !important;
}

/* Footer deep espresso */
footer {
  background: #1A1410 !important;
}

[data-theme="dark"] footer,
body.dark footer {
  background: #0D0A08 !important;
}
/* 13" laptop fix */
@media (max-width: 1440px) {
  .logo { font-size: 16px !important; }
  footer .tag { font-size: 16px !important; }
}
