/* ================================================================
   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
================================================================ */

/* ---------- THEME TOKENS ---------- */
:root,
[data-theme="light"] {
  --parchment:        #EBE3D5;
  --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:             #EBE3D5;
  --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:'Manrope',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:'Italiana',serif;letter-spacing:.04em;font-weight:400}
.serif{font-family:'Cormorant Garamond',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:'Cormorant Garamond',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:1700px;margin:0 auto;padding:0 24px}
@media(min-width:768px){.wrap{padding:0 56px}}
section{position:relative}
.section-pad{padding:80px 0}
@media(min-width:768px){.section-pad{padding:140px 0}}

/* ============================================================
   NAV — solid umber bar always (subtle when over photos), so it
   never has legibility problems. On dark theme it's a soft cream.
============================================================ */
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:'Italiana',serif;font-size:22px;letter-spacing:.06em;
}
.logo em{
  font-family:'Cormorant Garamond',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}

/* ============================================================
   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:'Cormorant Garamond',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:'Italiana',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:'Cormorant Garamond',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:'Cormorant Garamond',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:'Italiana',serif;font-style:normal;letter-spacing:.04em;font-weight:400;display:inline}
.hero h1 .gold{color:var(--gold)}

/* ============================================================
   MARQUEE — long track, no empty gap on wide screens
============================================================ */
.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:'Italiana',serif;font-size:22px;letter-spacing:.18em;
  color:var(--text-soft);text-transform:uppercase;
}
.marquee-track em{
  color:var(--accent);font-family:'Cormorant Garamond',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:'Cormorant Garamond',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)}
/* use the standalone scale property (not transform:scale) so it composes
   with the inline transform that the parallax JS sets every frame. */
.reveal-img img{scale:1.10;transition:scale 2s cubic-bezier(.2,.7,.2,1)}
.reveal-img.in img{scale:1}

/* split-line headline lift — wraps each .ln in inline-block, content slides up sequentially */
.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 — animated horizontal line that scales in from left */
.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 — image must oversize its parent so translation doesn't expose bg.
   Apply .parallax-slow / .parallax-fast directly on the <img>. The parent
   should be `overflow:hidden` (figures already are). */
.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;
  /* center vertically so initial transform=0 shows the middle band */
  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 — image starts at 1.12 and scales to 1 as it enters viewport.
   Adds cinematic feeling. Intersection-observed; once .in is added, scale to 1. */
.scroll-scale{
  transform:scale(1.12);
  transition:transform 1.6s cubic-bezier(.2,.7,.2,1);
}
.scroll-scale.in{transform:scale(1)}

/* ============================================================
   COMMON COMPONENTS (sections, buttons)
============================================================ */
h2.head{
  font-family:'Italiana',serif;font-weight:400;
  font-size:clamp(34px,4.8vw,80px);line-height:1;letter-spacing:-.005em;
  padding-bottom:.06em;
}
h2.head em{
  font-family:'Cormorant Garamond',serif;font-style:italic;
  color:var(--accent);letter-spacing:-.01em;
}
h3.sub{
  font-family:'Cormorant Garamond',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:'Cormorant Garamond',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:'Italiana',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:'Cormorant Garamond',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)}
/* clean hover overlay — just a subtle dim, no arrow icon */
.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:'Cormorant Garamond',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:'Cormorant Garamond',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:'Italiana',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:'Cormorant Garamond',serif;font-style:italic;font-weight:300;
  color:var(--accent);letter-spacing:-.01em;
}
.cta .btn{
  display:inline-block;margin-top:48px;
  font-family:'Cormorant Garamond',serif;font-style:italic;font-size:24px;
  color:var(--accent);border-bottom:2px solid var(--accent);padding-bottom:8px;
  transition:opacity .3s;
}
.cta .btn:hover{opacity:.7}

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