/* =========================================================
   Yaz & Mir Massage — site styles
   Palette: deep teal · warm gold · cream · ink
   ========================================================= */

:root{
  --teal-900:#062b29;
  --teal-800:#0a3f3c;
  --teal-700:#155854;
  --teal-600:#1b8a85;
  --teal-500:#2da8a2;
  --teal-300:#7dcdc9;
  --teal-100:#d8efed;

  --gold-900:#6b5530;
  --gold-700:#8a6f3e;
  --gold-500:#b89968;
  --gold-300:#d4b785;
  --gold-100:#f0e3c4;

  --ink-900:#0a1413;
  --ink-700:#19302d;
  --ink-500:#3a5654;
  --ink-300:#7a8c8a;

  --paper:#fbf8f1;
  --cream:#f3ead6;
  --white:#ffffff;

  --shadow-card: 0 30px 80px -30px rgba(6,43,41,.45), 0 8px 24px -12px rgba(6,43,41,.25);
  --shadow-soft: 0 10px 30px -12px rgba(6,43,41,.35);
  --radius-card: 18px;
  --radius-pill: 999px;

  --display: 'Sora', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --body: 'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif;

  --container: min(1200px, 100% - 2.5rem);
  --container-narrow: min(900px, 100% - 2.5rem);

  --nav-h: 72px;
  --status-h: 36px;

  --t-fast: 220ms cubic-bezier(.2,.7,.2,1);
  --t-med: 480ms cubic-bezier(.2,.7,.2,1);
  --t-slow: 1100ms cubic-bezier(.2,.7,.2,1);
}

/* ---- reset & base ---- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;text-size-adjust:100%;}
html.lenis{height:auto;}
.lenis.lenis-smooth{scroll-behavior:auto !important;}
.lenis.lenis-smooth [data-lenis-prevent]{overscroll-behavior:contain;}
.lenis.lenis-stopped{overflow:hidden;}

body{
  font-family:var(--body);
  font-size:16px;
  line-height:1.6;
  color:var(--ink-700);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

img,picture,svg,video,iframe{display:block;max-width:100%;height:auto;}
img{height:auto;}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer;}
a{color:inherit;text-decoration:none;transition:color var(--t-fast);}
a:hover{color:var(--gold-500);}

ul,ol{list-style:none;}

/* lang visibility — drives the bilingual toggle */
html[lang="es"] [lang="en"]{display:none !important;}
html[lang="en"] [lang="es"]{display:none !important;}

.container{width:var(--container);margin-inline:auto;}
.container-narrow{width:var(--container-narrow);margin-inline:auto;}

/* ===========================================================
   Multi-layered fixed background stage (the scroll cross-fade)
   =========================================================== */
.bg-stage{
  position:fixed;
  inset:0;
  z-index:-2;
  pointer-events:none;
  background:var(--teal-900);
}
.bg-slide{
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center;
  opacity:0;
  transform:scale(1.05);
  transition:opacity var(--t-slow), transform 12s linear;
  will-change:opacity,transform;
}
.bg-slide.is-active{
  opacity:1;
  transform:scale(1);
}
.bg-veil{
  position:absolute;
  inset:0;
  background:
    radial-gradient(140% 90% at 70% 30%, rgba(184,153,104,.18), rgba(6,43,41,0) 55%),
    radial-gradient(120% 90% at 25% 25%, rgba(6,43,41,.20), rgba(6,43,41,.55) 85%),
    linear-gradient(180deg, rgba(10,20,19,.10), rgba(10,20,19,.55));
}

/* ===========================================================
   Top status ribbon (open/closed) — desktop only
   =========================================================== */
.status-bar{
  position:fixed;top:0;left:0;right:0;
  z-index:51;
  height:var(--status-h);
  background:var(--ink-900);
  color:var(--cream);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--display);
  font-size:.74rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  border-bottom:1px solid rgba(212,183,133,.16);
  transition:background var(--t-fast), color var(--t-fast);
}
.status-bar[hidden]{display:none;}
.status-bar__inner{display:inline-flex;align-items:center;gap:.7rem;}
.status-bar .dot{
  width:7px;height:7px;border-radius:50%;
  background:var(--ink-300);
  transition:background var(--t-fast), box-shadow var(--t-fast);
}
.status-bar[data-status="open"]{color:var(--teal-100);}
.status-bar[data-status="open"] .dot{
  background:#9ce4a3;
  box-shadow:0 0 0 3px rgba(156,228,163,.18);
  animation:pulse 2.4s ease-in-out infinite;
}
.status-bar[data-status="closed"]{color:var(--gold-100);}
.status-bar[data-status="closed"] .dot{background:var(--gold-500);}

/* ===========================================================
   Navigation
   =========================================================== */
.site-nav{
  position:fixed;top:var(--status-h);left:0;right:0;z-index:50;
  height:var(--nav-h);
  display:flex;align-items:center;
  padding-inline:clamp(1rem, 3vw, 2.25rem);
  color:var(--cream);
  background:linear-gradient(180deg, rgba(6,43,41,.55), rgba(6,43,41,0));
  transition:background var(--t-med), backdrop-filter var(--t-med), box-shadow var(--t-med);
}
.site-nav.is-scrolled{
  background:rgba(6,43,41,.78);
  backdrop-filter:saturate(160%) blur(14px);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  box-shadow:0 6px 22px -10px rgba(0,0,0,.35);
}

.brand{
  display:flex;align-items:center;gap:.6rem;
  color:var(--gold-300);
  flex-shrink:0;
}
.brand:hover{color:var(--gold-500);}
.brand-mark{width:34px;height:34px;}
.brand-word{
  font-family:var(--display);
  font-weight:600;
  letter-spacing:.18em;
  font-size:.78rem;
  line-height:1;
  display:flex;flex-direction:column;gap:.18rem;
  color:var(--cream);
}
.brand-word small{
  font-weight:300;
  letter-spacing:.34em;
  font-size:.55rem;
  color:var(--gold-300);
}

.primary-nav{
  display:flex;gap:clamp(.6rem, 2vw, 1.8rem);
  margin-inline:auto;
  font-family:var(--display);
  font-weight:400;
  font-size:.86rem;
  letter-spacing:.08em;
}
.primary-nav a{
  position:relative;
  padding:.5rem .25rem;
  color:var(--cream);
}
.primary-nav a::after{
  content:"";position:absolute;left:.25rem;right:.25rem;bottom:.2rem;
  height:1px;background:var(--gold-500);
  transform:scaleX(0);transform-origin:left center;
  transition:transform var(--t-fast);
}
.primary-nav a:hover{color:var(--gold-300);}
.primary-nav a:hover::after,
.primary-nav a.is-current::after{transform:scaleX(1);}

.nav-actions{display:flex;align-items:center;gap:.6rem;flex-shrink:0;}
.lang-toggle{
  font-family:var(--display);font-weight:500;font-size:.78rem;letter-spacing:.18em;
  color:var(--cream);
  border:1px solid rgba(212,183,133,.45);
  border-radius:var(--radius-pill);
  padding:.45rem .8rem;
  transition:all var(--t-fast);
}
.lang-toggle:hover{
  background:var(--gold-500);color:var(--ink-900);
  border-color:var(--gold-500);
}
.menu-toggle{
  display:none;
  flex-direction:column;gap:5px;
  width:36px;height:36px;align-items:center;justify-content:center;
}
.menu-toggle span{display:block;width:22px;height:1.5px;background:var(--cream);transition:transform var(--t-fast),opacity var(--t-fast);}
.menu-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(6.5px) rotate(45deg);}
.menu-toggle[aria-expanded="true"] span:nth-child(2){opacity:0;}
.menu-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg);}

/* ===========================================================
   Type system
   =========================================================== */
.display-h{
  font-family:var(--display);
  font-weight:300;
  font-size:clamp(2rem, 5vw, 3.6rem);
  line-height:1.05;
  letter-spacing:-.01em;
  color:var(--ink-900);
}
.eyebrow{
  font-family:var(--display);
  font-weight:500;
  font-size:.74rem;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--teal-600);
  display:inline-block;
  margin-bottom:.85rem;
}
.section-head{margin-bottom:clamp(2rem,4vw,3.5rem);max-width:60ch;}
.section-head--center{text-align:center;margin-inline:auto;}
.section-lede{
  margin-top:1rem;
  color:var(--ink-500);
  font-size:1.05rem;
  max-width:55ch;
}
.section-head--center .section-lede{margin-inline:auto;}

/* Section heads that sit on the dimmed background (no card behind them)
   need light type. Inside .card they already get the dark-on-cream treatment. */
.section > .container > .section-head .display-h{
  color:var(--cream);
}
.section > .container > .section-head .eyebrow{
  color:var(--gold-300);
}
.section > .container > .section-head .section-lede{
  color:rgba(245,239,228,.78);
}
.section > .container > .section-head .display-h em{
  color:var(--gold-300);
}

/* ===========================================================
   Hero
   =========================================================== */
.hero{
  position:relative;
  min-height:100vh;
  min-height:100svh;
  padding-top:calc(var(--nav-h) + var(--status-h) + 4vh);
  padding-bottom:14vh;
  display:flex;align-items:center;
  color:var(--cream);
  overflow:hidden;
  isolation:isolate;
}
.hero-scrim{
  position:absolute;inset:0;z-index:-1;
  background:
    linear-gradient(180deg, rgba(6,43,41,.0) 0%, rgba(6,43,41,.10) 55%, rgba(6,43,41,.70) 100%),
    radial-gradient(70% 60% at 22% 35%, rgba(0,0,0,.35) 0%, rgba(0,0,0,0) 70%);
}
.hero-title,
.hero-lede,
.hero-eyebrow{
  text-shadow:0 2px 24px rgba(6,43,41,.55), 0 1px 3px rgba(6,43,41,.45);
}
.hero-content{
  width:var(--container);
  margin-inline:auto;
  max-width:780px;
  padding-block:2rem;
}
.hero-eyebrow{
  font-family:var(--display);
  font-size:.78rem;letter-spacing:.36em;text-transform:uppercase;
  color:var(--gold-300);
  margin-bottom:1.5rem;
}
.hero-title{
  font-family:var(--display);
  font-weight:200;
  font-size:clamp(2.6rem, 7vw, 5.4rem);
  line-height:1.02;
  letter-spacing:-.02em;
  color:var(--white);
  margin-bottom:1.6rem;
}
.hero-title em{
  font-style:italic;
  font-weight:300;
  color:var(--gold-300);
  font-family:'Cormorant Garamond', Georgia, serif;
}
.hero-lede{
  font-size:clamp(1rem, 1.6vw, 1.2rem);
  max-width:48ch;
  color:rgba(245,239,228,.9);
  margin-bottom:2.2rem;
}
.hero-lede strong{color:var(--gold-300);font-weight:500;}

.cta-row{
  display:flex;flex-wrap:wrap;gap:.85rem;
  margin-bottom:2rem;
}
.btn{
  display:inline-flex;align-items:center;gap:.55rem;
  padding:.85rem 1.4rem;
  font-family:var(--display);
  font-weight:500;
  font-size:.92rem;
  letter-spacing:.04em;
  border-radius:var(--radius-pill);
  border:1px solid transparent;
  transition:all var(--t-fast);
  cursor:pointer;
  white-space:nowrap;
}
.btn-primary{
  background:var(--gold-500);
  color:var(--ink-900);
}
.btn-primary:hover{
  background:var(--gold-300);color:var(--ink-900);
  transform:translateY(-1px);
  box-shadow:0 14px 30px -12px rgba(184,153,104,.55);
}
.btn-ghost{
  border-color:rgba(245,239,228,.45);
  color:var(--cream);
}
.btn-ghost:hover{
  border-color:var(--gold-300);
  color:var(--gold-300);
  background:rgba(245,239,228,.04);
}

.hero-meta{
  display:flex;flex-wrap:wrap;align-items:center;gap:1rem 1.5rem;
  font-size:.85rem;color:rgba(245,239,228,.78);
}
.status-pill{
  display:inline-flex;align-items:center;gap:.55rem;
  padding:.35rem .85rem;
  border-radius:var(--radius-pill);
  background:rgba(245,239,228,.08);
  border:1px solid rgba(245,239,228,.18);
  font-family:var(--display);font-size:.78rem;letter-spacing:.06em;
}
.status-pill .dot{
  width:8px;height:8px;border-radius:50%;background:var(--ink-300);
  box-shadow:0 0 0 0 currentColor;
}
.status-pill[data-status="open"]{
  background:rgba(45,168,162,.18);
  border-color:rgba(125,205,201,.45);
  color:var(--teal-100);
}
.status-pill[data-status="open"] .dot{
  background:#9ce4a3;
  animation:pulse 2.4s ease-in-out infinite;
}
.status-pill[data-status="closed"]{
  background:rgba(184,153,104,.12);
  border-color:rgba(212,183,133,.4);
  color:var(--gold-100);
}
.status-pill[data-status="closed"] .dot{background:var(--gold-500);}
@keyframes pulse{
  0%,100%{box-shadow:0 0 0 0 rgba(156,228,163,.6);}
  50%{box-shadow:0 0 0 6px rgba(156,228,163,0);}
}
.hero-loc{display:inline-flex;align-items:center;gap:.4rem;color:rgba(245,239,228,.78);}
.hero-loc:hover{color:var(--gold-300);}

.scroll-cue{
  position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);
  width:30px;height:48px;
  border:1px solid rgba(245,239,228,.4);
  border-radius:var(--radius-pill);
  display:flex;justify-content:center;
  padding-top:8px;
}
.scroll-cue span{
  width:2px;height:8px;background:var(--gold-300);border-radius:2px;
  animation:scrollDot 1.8s ease-in-out infinite;
}
@keyframes scrollDot{
  0%{transform:translateY(0);opacity:1;}
  100%{transform:translateY(20px);opacity:0;}
}

/* floating gold blobs */
.float{
  position:absolute;border-radius:50%;
  pointer-events:none;
  filter:blur(40px);
  opacity:.55;
  z-index:-1;
  will-change:transform;
}
.float-1{
  width:360px;height:360px;top:8%;right:-6%;
  background:radial-gradient(circle, rgba(212,183,133,.55), rgba(212,183,133,0) 65%);
}
.float-2{
  width:260px;height:260px;bottom:18%;left:-5%;
  background:radial-gradient(circle, rgba(125,205,201,.5), rgba(125,205,201,0) 65%);
  filter:blur(30px);
}
.float-3{
  width:180px;height:180px;top:55%;right:25%;
  background:radial-gradient(circle, rgba(240,227,196,.4), rgba(240,227,196,0) 65%);
  filter:blur(28px);
  opacity:.4;
}

/* ===========================================================
   Section frame (cards floating on dimmed background)
   =========================================================== */
.section{
  position:relative;
  padding-block:clamp(5rem, 10vh, 9rem);
  isolation:isolate;
}
.card{
  background:var(--paper);
  border-radius:var(--radius-card);
  padding:clamp(1.5rem, 4vw, 3rem);
  box-shadow:var(--shadow-card);
  border:1px solid rgba(184,153,104,.08);
}
.card--flush{padding:0;overflow:hidden;}

/* ===========================================================
   About / Nosotros
   =========================================================== */
.two-col{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:clamp(2rem, 5vw, 4rem);
  align-items:center;
}
.about-text .role{
  color:var(--gold-700);
  font-family:var(--display);font-weight:500;
  letter-spacing:.12em;font-size:.85rem;text-transform:uppercase;
  margin:.4rem 0 1.6rem;
}
.about-text p{margin-bottom:1.2rem;color:var(--ink-700);max-width:50ch;}

.brand-quote{
  position:relative;
  margin:2rem 0;
  padding:1.4rem 1.6rem 1.4rem 3rem;
  border-left:2px solid var(--gold-500);
  background:linear-gradient(90deg, rgba(184,153,104,.08), rgba(184,153,104,0));
  font-family:'Cormorant Garamond', Georgia, serif;
  font-style:italic;
  font-size:1.4rem;
  color:var(--teal-700);
  line-height:1.4;
  border-radius:0 8px 8px 0;
}
.brand-quote .quote-mark{
  position:absolute;top:-.4rem;left:.6rem;
  font-size:4rem;line-height:1;
  color:var(--gold-300);
  font-family:Georgia,serif;
}

.trust-row{
  display:flex;flex-wrap:wrap;gap:1.8rem;
  margin-top:2rem;padding-top:1.6rem;
  border-top:1px solid rgba(184,153,104,.2);
}
.trust-row li{
  display:flex;flex-direction:column;
  font-size:.78rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--ink-500);
}
.trust-row strong{
  font-family:var(--display);
  font-size:1.6rem;font-weight:300;
  color:var(--teal-700);
  letter-spacing:0;
  margin-bottom:.2rem;
}

.about-figure{
  position:relative;
  border-radius:var(--radius-card);
  overflow:hidden;
  box-shadow:var(--shadow-soft);
}
.about-figure img,
.about-figure video{
  width:100%;
  aspect-ratio:3/4;
  object-fit:cover;
  display:block;
  background:var(--ink-900);
}
.about-figure figcaption{
  position:absolute;left:1rem;bottom:1rem;right:1rem;
  font-family:var(--display);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--cream);
  background:rgba(6,43,41,.65);
  padding:.5rem .8rem;
  border-radius:6px;
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
}


/* ===========================================================
   Services
   =========================================================== */
.services-grid{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:clamp(1.2rem, 2.5vw, 2rem);
}
.service-card{
  background:var(--paper);
  border-radius:var(--radius-card);
  overflow:hidden;
  box-shadow:var(--shadow-card);
  border:1px solid rgba(184,153,104,.1);
  display:flex;flex-direction:column;
  transition:transform var(--t-med), box-shadow var(--t-med);
}
.service-card:hover{
  transform:translateY(-4px);
  box-shadow:0 36px 90px -28px rgba(6,43,41,.55), 0 12px 28px -12px rgba(6,43,41,.3);
}
.service-card__media{
  aspect-ratio:4/5;
  overflow:hidden;
  position:relative;
}
.service-card__media img{
  width:100%;height:100%;object-fit:cover;
  object-position:center 45%;
  transition:transform 1.5s ease;
}
.service-card[data-focus="upper"] .service-card__media img{object-position:center 30%;}
.service-card[data-focus="lower"] .service-card__media img{object-position:center 65%;}
.service-card:hover .service-card__media img{transform:scale(1.05);}
.service-card__media::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(6,43,41,0) 50%, rgba(6,43,41,.35));
}
.service-card__body{
  padding:clamp(1.5rem, 2.5vw, 2.2rem);
  display:flex;flex-direction:column;gap:1.2rem;
  flex:1;
}
.service-card__body h3{
  font-family:var(--display);
  font-weight:400;
  font-size:1.7rem;
  letter-spacing:-.005em;
  color:var(--teal-800);
}

.price-list{display:flex;flex-direction:column;}
.price-list li{
  display:grid;
  grid-template-columns:1fr auto;
  grid-template-areas:
    "name price"
    "meta price";
  column-gap:1rem;
  padding:.85rem 0;
  border-bottom:1px dotted rgba(58,86,84,.22);
}
.price-list li:last-child{border-bottom:none;}
.price-list li.is-highlight{
  background:linear-gradient(90deg, rgba(184,153,104,.1), rgba(184,153,104,0));
  margin-inline:-.6rem;padding-inline:.6rem;border-radius:6px;
}
.svc-name{
  grid-area:name;
  font-weight:500;color:var(--ink-900);
  font-size:.98rem;
}
.svc-meta{
  grid-area:meta;
  font-size:.78rem;color:var(--ink-500);
  letter-spacing:.06em;
}
.svc-price{
  grid-area:price;
  align-self:start;
  font-family:var(--display);font-weight:500;
  color:var(--teal-700);
  font-size:1.02rem;
  white-space:nowrap;
}
.svc-price .currency{
  font-size:.7rem;color:var(--ink-500);font-weight:400;letter-spacing:.08em;
}
.price-list li.note{
  display:block;
  border:none;
  padding-top:.6rem;
  font-size:.8rem;font-style:italic;color:var(--ink-500);
}

.services-foot{
  text-align:center;
  margin-top:2.5rem;
  font-family:'Cormorant Garamond', Georgia, serif;
  font-size:1.2rem;
  font-style:italic;
  color:var(--cream);
  text-shadow:0 2px 12px rgba(0,0,0,.4);
}

/* ===========================================================
   Space gallery
   =========================================================== */
/* Z-stacked collage: Grid with explicit overlapping cells. Cells are sized
   to match each image's aspect (6 portrait + 2 square sources). */
.space-grid{
  display:grid;
  grid-template-columns:repeat(12, 1fr);
  grid-template-rows:repeat(19, 50px);
  gap:0;
  padding:50px 10px 60px;
  perspective:1800px;
}
.space-tile{
  position:relative;
  overflow:hidden;
  background:var(--teal-900);
  border:0;padding:0;
  display:block;
  border-radius:10px;
  box-shadow:
    0 18px 40px -12px rgba(6,43,41,.55),
    0 30px 70px -20px rgba(6,43,41,.4);
  transform:rotate(var(--rot,0deg));
  transform-origin:center center;
  transition:transform 700ms cubic-bezier(.2,.7,.2,1),
              box-shadow 500ms cubic-bezier(.2,.7,.2,1),
              filter 600ms ease;
  cursor:zoom-in;
  z-index:var(--z,1);
  will-change:transform;
}
.space-tile:hover{
  transform:rotate(0deg) scale(1.06) translateY(-6px);
  z-index:99 !important;
  box-shadow:
    0 30px 60px -10px rgba(6,43,41,.6),
    0 60px 120px -20px rgba(6,43,41,.45);
}
.space-tile img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1.6s ease, filter 600ms ease;
  display:block;
  filter:saturate(.92);
}
.space-tile:hover img{
  transform:scale(1.04);
  filter:saturate(1.05);
}
.space-tile::after{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(6,43,41,0) 50%, rgba(6,43,41,.6));
  opacity:.55;
  transition:opacity var(--t-med);
  pointer-events:none;
}
.space-tile:hover::after{opacity:.82;}
.space-tile__cap{
  position:absolute;left:1rem;right:1rem;bottom:.85rem;
  font-family:var(--display);
  font-weight:500;
  font-size:.72rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--cream);
  text-shadow:0 1px 6px rgba(0,0,0,.55);
  text-align:left;
  transform:translateY(6px);opacity:.85;
  transition:transform var(--t-fast), opacity var(--t-fast);
  z-index:1;
}
.space-tile:hover .space-tile__cap{transform:translateY(0);opacity:1;}

.space-tile::before{
  content:"";
  position:absolute;top:.85rem;right:.85rem;
  width:36px;height:36px;border-radius:50%;
  background:rgba(6,43,41,.7);
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24'><path fill='%23f3ead6' d='M15.5 14h-.79l-.28-.27A6.5 6.5 0 1 0 13 16.71l.27.28v.79l5 5 1.5-1.5-5-5Zm-6 0A4.5 4.5 0 1 1 14 9.5 4.5 4.5 0 0 1 9.5 14Z'/></svg>");
  background-repeat:no-repeat;background-position:center;
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
  opacity:0;transform:scale(.85);
  transition:opacity var(--t-fast), transform var(--t-fast);
  z-index:2;pointer-events:none;
}
.space-tile:hover::before{opacity:1;transform:scale(1);}

/* Cell shapes are matched to source-image aspect:
     T1 = Interior Pic   (square 1.00)
     T2 = interior 1     (portrait 0.75)
     T3 = Massage Room   (portrait 0.75)
     T4 = interior 2     (portrait 0.75)
     T5 = interior 3     (portrait 0.75)
     T6 = interior 5     (portrait 0.75)
     T7 = interior 6     (portrait 0.75)
     T8 = interior 8     (square 1.02)
   Cell width ≈ 92px/col, height = 50px/row. */
.space-tile:nth-child(1){grid-area: 1/1  / 10/6;   --rot:-1.5deg; --z:2;}  /* square feature, top-left */
.space-tile:nth-child(2){grid-area: 1/8  / 13/13;  --rot: 2.2deg; --z:3;}  /* tall portrait, top-right */
.space-tile:nth-child(3){grid-area: 5/5  / 15/9;   --rot:-2.5deg; --z:6;}  /* portrait, overlaps T1+T2 */
.space-tile:nth-child(4){grid-area: 8/10 / 15/13;  --rot: 1.8deg; --z:4;}  /* portrait, mid-right */
.space-tile:nth-child(5){grid-area:10/2  / 17/5;   --rot: 1.5deg; --z:5;}  /* portrait, mid-left */
.space-tile:nth-child(6){grid-area:11/9  / 18/12;  --rot:-1.8deg; --z:7;}  /* portrait, lower-right, overlaps T4 */
.space-tile:nth-child(7){grid-area:12/3  / 19/6;   --rot: 2.4deg; --z:8;}  /* portrait, lower-mid, overlaps T5+T3 */
.space-tile:nth-child(8){grid-area:14/10 / 20/13;  --rot:-1.2deg; --z:6;}  /* square, bottom-right, overlaps T6 */

/* ===========================================================
   Lightbox
   =========================================================== */
.lightbox{
  position:fixed;inset:0;
  z-index:200;
  display:none;
  background:rgba(6,43,41,.96);
  padding:clamp(2rem, 5vw, 4rem);
  align-items:center;justify-content:center;
  animation:lbFade .25s ease-out;
}
.lightbox.is-open{display:flex;}
@keyframes lbFade{from{opacity:0;}to{opacity:1;}}
.lightbox__stage{
  display:flex;flex-direction:column;align-items:center;gap:1rem;
  max-width:min(1400px, 100%);
  max-height:100%;
  margin:0;
}
.lightbox__stage img{
  max-width:100%;
  max-height:calc(100vh - 8rem);
  object-fit:contain;
  border-radius:8px;
  box-shadow:0 40px 90px -20px rgba(0,0,0,.7);
  background:var(--ink-900);
}
.lightbox__stage figcaption{
  font-family:var(--display);
  font-size:.85rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--gold-300);
  text-align:center;
}
.lightbox__close,
.lightbox__nav{
  position:absolute;
  width:48px;height:48px;
  border-radius:50%;
  background:rgba(245,239,228,.08);
  border:1px solid rgba(245,239,228,.2);
  color:var(--cream);
  display:flex;align-items:center;justify-content:center;
  transition:all var(--t-fast);
  z-index:1;
}
.lightbox__close:hover,
.lightbox__nav:hover{
  background:var(--gold-500);
  color:var(--ink-900);
  border-color:var(--gold-500);
}
.lightbox__close{top:1.4rem;right:1.4rem;}
.lightbox__prev{left:1.4rem;top:50%;transform:translateY(-50%);}
.lightbox__next{right:1.4rem;top:50%;transform:translateY(-50%);}
@media (max-width: 600px){
  .lightbox__close{top:1rem;right:1rem;width:42px;height:42px;}
  .lightbox__nav{width:42px;height:42px;}
  .lightbox__prev{left:.6rem;}
  .lightbox__next{right:.6rem;}
}

/* ===========================================================
   Booking
   =========================================================== */
/* Three-way booking grid */
.book-ways{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  grid-template-rows:auto auto;
  gap:clamp(1rem, 2vw, 1.5rem);
}
.book-way{
  position:relative;
  background:var(--paper);
  border:1px solid rgba(184,153,104,.12);
  border-radius:var(--radius-card);
  padding:2rem 1.6rem;
  display:flex;flex-direction:column;gap:.55rem;
  text-align:left;
  color:inherit;
  box-shadow:var(--shadow-soft);
  transition:transform var(--t-med), box-shadow var(--t-med), border-color var(--t-med);
  overflow:hidden;
}
.book-way::before{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(135deg, rgba(184,153,104,0) 0%, rgba(184,153,104,.08) 100%);
  opacity:0;transition:opacity var(--t-med);
  pointer-events:none;
}
.book-way:hover{
  transform:translateY(-3px);
  box-shadow:0 30px 70px -25px rgba(6,43,41,.5), 0 8px 20px -10px rgba(6,43,41,.25);
  border-color:var(--gold-300);
}
.book-way:hover::before{opacity:1;}
.book-way__icon{
  width:54px;height:54px;
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:rgba(45,168,162,.14);
  color:var(--teal-700);
  margin-bottom:.4rem;
  transition:all var(--t-med);
}
.book-way:hover .book-way__icon{
  background:var(--gold-500);color:var(--ink-900);
}
.book-way__head{
  font-family:var(--display);
  font-weight:500;
  font-size:1.35rem;
  color:var(--ink-900);
  letter-spacing:-.005em;
}
.book-way__body{
  font-size:.95rem;
  color:var(--ink-500);
  line-height:1.5;
  margin-bottom:.6rem;
}
.book-way__cta,
.book-way__cta-2{
  font-family:var(--display);
  font-weight:500;
  color:var(--teal-700);
  font-size:1rem;
}
.book-way__cta-2{font-size:.92rem;color:var(--ink-500);}
.book-way--primary{
  background:linear-gradient(160deg, var(--teal-700), var(--teal-800));
  color:var(--cream);
  border-color:transparent;
  grid-column:span 1;
  box-shadow:0 30px 70px -25px rgba(6,43,41,.6);
}
.book-way--primary .book-way__icon{
  background:rgba(245,239,228,.14);color:var(--cream);
}
.book-way--primary:hover .book-way__icon{
  background:var(--gold-500);color:var(--ink-900);
}
.book-way--primary .book-way__head{color:var(--white);}
.book-way--primary .book-way__body{color:rgba(245,239,228,.78);}
.book-way--primary .book-way__cta{color:var(--gold-300);}
.book-way--primary::before{
  background:radial-gradient(80% 60% at 80% 0%, rgba(184,153,104,.3), rgba(184,153,104,0) 60%);
  opacity:1;
}

.book-hours{
  grid-column:span 3;
  background:var(--paper);
  border-radius:var(--radius-card);
  padding:clamp(1.5rem, 2.5vw, 2.2rem) clamp(1.5rem, 4vw, 3rem);
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  gap:1.1rem;
  max-width:780px;
  margin-inline:auto;
  width:100%;
  box-shadow:var(--shadow-soft);
  border:1px solid rgba(184,153,104,.12);
}
.book-hours h3{
  font-family:var(--display);
  font-weight:500;
  font-size:.95rem;
  letter-spacing:.24em;text-transform:uppercase;
  color:var(--teal-700);
}
.hours{
  display:flex;flex-wrap:wrap;
  justify-content:center;
  gap:.6rem 2rem;
}
.hours div{
  display:flex;align-items:baseline;gap:.6rem;
  font-size:.98rem;
}
.hours dt{font-weight:500;color:var(--ink-900);}
.hours dd{
  font-family:var(--display);font-weight:400;
  color:var(--teal-700);font-variant-numeric:tabular-nums;
}
.book-hours__note{
  font-style:italic;
  color:var(--ink-500);
  margin:.2rem 0 0;
  font-family:'Cormorant Garamond', Georgia, serif;
  font-size:1.1rem;
}

@media (max-width: 720px){
  .book-ways{grid-template-columns:1fr;}
  .book-way--primary,.book-hours{grid-column:span 1;}
  .book-hours{grid-template-columns:1fr;text-align:center;}
  .book-hours h3{text-align:center;}
  .hours{justify-content:center;}
}

/* ===========================================================
   Location
   =========================================================== */
.location-row{
  display:grid;
  grid-template-columns:1.5fr 1fr;
  gap:clamp(1.2rem, 2.5vw, 2rem);
  align-items:stretch;
}
.map-frame{
  min-height:420px;
  position:relative;
}
.map-frame iframe{
  width:100%;
  height:100%;
  min-height:420px;
  border:0;
}
.location-card{
  display:flex;flex-direction:column;justify-content:space-between;
  font-style:normal;
}
.location-card .addr-lines{
  font-size:1.1rem;
  color:var(--ink-900);
  line-height:1.7;
  margin-block:1rem 1.6rem;
  font-family:var(--display);
  font-weight:300;
}

/* ===========================================================
   Footer
   =========================================================== */
.site-foot{
  position:relative;
  padding:5rem 0 1.5rem;
  background:var(--teal-900);
  color:var(--cream);
  z-index:1;
}
.foot-grid{
  display:grid;
  grid-template-columns:1.4fr repeat(3, 1fr);
  gap:2rem;
  padding-bottom:3rem;
  border-bottom:1px solid rgba(212,183,133,.18);
}
.foot-brand{display:flex;gap:1rem;align-items:flex-start;}
.foot-brand .brand-mark{width:46px;height:46px;color:var(--gold-500);flex-shrink:0;}
.foot-brand p{font-family:var(--display);font-size:1.1rem;font-weight:400;line-height:1.4;}
.foot-brand small{font-size:.78rem;color:var(--gold-300);font-weight:300;letter-spacing:.06em;}
.foot-col h4{
  font-family:var(--display);
  font-size:.78rem;letter-spacing:.24em;text-transform:uppercase;
  font-weight:500;color:var(--gold-300);
  margin-bottom:.85rem;
}
.foot-col p{font-size:.92rem;line-height:1.8;color:rgba(245,239,228,.85);}
.foot-col a:hover{color:var(--gold-300);}
.foot-base{
  text-align:center;
  padding-top:1.5rem;
  font-size:.78rem;color:rgba(245,239,228,.6);
  letter-spacing:.06em;
}

/* ===========================================================
   WhatsApp float
   =========================================================== */
.wa-float{
  position:fixed;
  bottom:1.4rem;right:1.4rem;
  width:58px;height:58px;
  border-radius:50%;
  background:var(--teal-600);
  color:var(--white);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 14px 30px -8px rgba(6,43,41,.55), 0 0 0 0 rgba(45,168,162,.6);
  z-index:60;
  animation:waPulse 3s ease-in-out infinite;
  transition:background var(--t-fast), transform var(--t-fast);
}
.wa-float:hover{
  background:var(--gold-500);
  color:var(--ink-900);
  transform:scale(1.05);
}
@keyframes waPulse{
  0%,100%{box-shadow:0 14px 30px -8px rgba(6,43,41,.55), 0 0 0 0 rgba(45,168,162,.55);}
  50%{box-shadow:0 14px 30px -8px rgba(6,43,41,.55), 0 0 0 14px rgba(45,168,162,0);}
}

/* ===========================================================
   Reveal animations (used by IntersectionObserver in app.js)
   =========================================================== */
.reveal{
  opacity:0;
  transform:translateY(28px);
  transition:opacity 1s cubic-bezier(.2,.7,.2,1), transform 1s cubic-bezier(.2,.7,.2,1);
}
.reveal.is-in{opacity:1;transform:none;}
.reveal-stagger > *{
  opacity:0;
  transform:translateY(22px);
  transition:opacity .9s cubic-bezier(.2,.7,.2,1), transform .9s cubic-bezier(.2,.7,.2,1);
}
.reveal-stagger.is-in > *{opacity:1;transform:none;}
.reveal-stagger.is-in > *:nth-child(1){transition-delay:0ms;}
.reveal-stagger.is-in > *:nth-child(2){transition-delay:80ms;}
.reveal-stagger.is-in > *:nth-child(3){transition-delay:160ms;}
.reveal-stagger.is-in > *:nth-child(4){transition-delay:240ms;}
.reveal-stagger.is-in > *:nth-child(5){transition-delay:320ms;}
.reveal-stagger.is-in > *:nth-child(6){transition-delay:400ms;}
.reveal-stagger.is-in > *:nth-child(7){transition-delay:480ms;}
.reveal-stagger.is-in > *:nth-child(8){transition-delay:560ms;}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;}
  .reveal,.reveal-stagger > *{opacity:1;transform:none;}
  .bg-slide{transition:opacity .2s linear;transform:none;}
}

/* ===========================================================
   Responsive
   =========================================================== */
@media (max-width: 1024px){
  .booking-row,.location-row,.two-col{grid-template-columns:1fr;}
  .services-grid{grid-template-columns:1fr;}
  .foot-grid{grid-template-columns:1fr 1fr;}
  /* Tablet collage: 6-col flowing grid, no overlap, gentle rotation */
  .space-grid{
    grid-template-columns:repeat(6, 1fr);
    grid-template-rows:auto;
    grid-auto-rows:200px;
    gap:18px;
    padding:20px 0;
    perspective:none;
  }
  .space-tile{grid-area:auto;}
  .space-tile:nth-child(1){grid-column:span 6;grid-row:span 2;--rot:-1deg;--z:1;}
  .space-tile:nth-child(2){grid-column:span 3;--rot: 1.5deg;--z:1;}
  .space-tile:nth-child(3){grid-column:span 3;--rot:-1.5deg;--z:1;}
  .space-tile:nth-child(4){grid-column:span 2;--rot: 1.2deg;--z:1;}
  .space-tile:nth-child(5){grid-column:span 2;--rot:-1.5deg;--z:1;}
  .space-tile:nth-child(6){grid-column:span 2;--rot: 1.8deg;--z:1;}
  .space-tile:nth-child(7){grid-column:span 3;--rot:-1deg;--z:1;}
  .space-tile:nth-child(8){grid-column:span 3;--rot: 1deg;--z:1;}
}

@media (max-width: 720px){
  :root{--nav-h:64px;--status-h:32px;}
  .status-bar{
    font-size:.62rem;
    letter-spacing:.18em;
    padding:0 .8rem;
  }
  .menu-toggle{display:flex;}
  .primary-nav{
    position:fixed;
    top:var(--nav-h);left:0;right:0;
    flex-direction:column;align-items:flex-start;
    padding:1.5rem 1.5rem 2rem;
    background:rgba(6,43,41,.96);
    backdrop-filter:blur(16px);
    -webkit-backdrop-filter:blur(16px);
    transform:translateY(-120%);
    transition:transform var(--t-med);
    gap:.4rem;
    border-bottom:1px solid rgba(212,183,133,.18);
  }
  .primary-nav.is-open{transform:translateY(0);}
  .primary-nav a{font-size:1.05rem;padding:.7rem 0;width:100%;border-bottom:1px solid rgba(212,183,133,.08);}
  .primary-nav a::after{display:none;}

  .hero{padding-top:calc(var(--nav-h) + 2rem);}
  .hero-content{padding-block:1rem;}
  .hero-meta{gap:.6rem 1rem;}

  /* Mobile collage: simple 2-col flow, no rotation, no overlap */
  .space-grid{
    grid-template-columns:repeat(2, 1fr);
    grid-template-rows:auto;
    grid-auto-rows:170px;
    gap:10px;
    padding:6px 0;
    perspective:none;
  }
  .space-tile,
  .space-tile:nth-child(1),.space-tile:nth-child(2),.space-tile:nth-child(3),
  .space-tile:nth-child(4),.space-tile:nth-child(5),.space-tile:nth-child(6),
  .space-tile:nth-child(7),.space-tile:nth-child(8){
    --rot:0deg;
    --z:1;
    grid-area:auto;
    grid-column:span 1;
    grid-row:span 1;
  }
  .space-tile:nth-child(1){grid-column:span 2;grid-row:span 2;}
  .space-tile:hover{transform:translateY(-3px) scale(1.02);}

  .foot-grid{grid-template-columns:1fr;gap:1.6rem;}
  .booking-frame,.booking-frame iframe{min-height:560px;}

  .brand-word{font-size:.7rem;}
  .brand-word small{font-size:.5rem;}

  .wa-float{bottom:1rem;right:1rem;width:52px;height:52px;}
  .scroll-cue{display:none;}
}

@media (max-width: 460px){
  .cta-row .btn{flex:1;justify-content:center;}
  .trust-row{gap:1.2rem;}
  .trust-row strong{font-size:1.3rem;}
}
