/* ========================================================
   Pure Spa — Shared Stylesheet
   ======================================================== */

:root{
  --ink:#0e0e0e;
  --ink-soft:#2a2724;
  --ivory:#f7f3ec;
  --ivory-pure:#fbfaf6;
  --paper:#efe9de;
  --champagne:#b89968;
  --champagne-deep:#9c7e4f;
  --champagne-soft:#d4b88a;
  --sage:#6b7363;
  --line:rgba(184,153,104,.35);
  --line-soft:rgba(14,14,14,.08);
  --shadow:0 30px 80px -40px rgba(14,14,14,.35);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',sans-serif;
  font-weight:300;
  color:var(--ink-soft);
  background:var(--ivory);
  line-height:1.7;
  font-size:15px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

/* Typography ---------------------------------------------- */
.display{font-family:'Cormorant Garamond',serif;font-weight:400;color:var(--ink);letter-spacing:.005em}
.eyebrow{
  font-family:'Inter',sans-serif;
  font-size:11px;font-weight:500;letter-spacing:.32em;
  text-transform:uppercase;color:var(--champagne-deep);
  display:inline-flex;align-items:center;gap:14px;
}
.eyebrow::before{content:"";display:inline-block;width:30px;height:1px;background:var(--champagne)}
h1.display{font-size:clamp(48px,7vw,96px);line-height:1.05;font-weight:300}
h2.display{font-size:clamp(34px,4.5vw,58px);line-height:1.1;font-weight:300}
h3.display{font-size:clamp(22px,2.4vw,30px);line-height:1.2}
p.lead{font-size:17px;line-height:1.85;font-weight:300;color:var(--ink-soft)}

a{color:inherit;text-decoration:none;transition:color .3s}
a:hover{color:var(--champagne-deep)}
em.gold{font-style:italic;color:var(--champagne-deep);font-weight:300}

.container{max-width:1280px;margin:0 auto;padding:0 32px}
@media(max-width:680px){.container{padding:0 22px}}

/* Nav ----------------------------------------------------- */
nav.site{
  position:fixed;top:0;left:0;right:0;z-index:50;
  padding:22px 0;
  background:rgba(247,243,236,.78);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;
  transition:border-color .4s,padding .4s,background .4s;
}
nav.site.scrolled{border-color:var(--line-soft);padding:16px 0}
nav.site.dark{background:rgba(14,14,14,.78)}
nav.site.dark .brand,nav.site.dark .nav-links a{color:var(--ivory-pure)}
nav.site.dark .brand span{color:var(--champagne-soft)}
nav.site.dark .nav-cta{border-color:var(--ivory-pure);color:var(--ivory-pure)}
nav.site.dark .nav-cta:hover{background:var(--ivory-pure);color:var(--ink)}
nav.site .container{display:flex;align-items:center;justify-content:space-between;gap:32px}
.brand{
  font-family:'Cormorant Garamond',serif;
  font-size:24px;font-weight:500;letter-spacing:.18em;color:var(--ink);
}
.brand span{color:var(--champagne-deep);transition:color .4s}
.nav-links{display:flex;gap:32px;align-items:center}
.nav-links a{
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:400;
  color:var(--ink-soft);position:relative;
}
.nav-links a.active{color:var(--champagne-deep)}
.nav-links a.active::after{
  content:"";position:absolute;left:0;right:0;bottom:-6px;height:1px;background:var(--champagne);
}
.nav-cta{
  padding:11px 22px;border:1px solid var(--ink);border-radius:999px;
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  transition:all .35s;
}
.nav-cta:hover{background:var(--ink);color:var(--ivory)}
.nav-cta.active::after{display:none}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;font-size:22px;color:var(--ink);padding:6px 10px;line-height:1}
nav.site.dark .nav-toggle{color:var(--ivory-pure)}
@media(max-width:980px){
  .nav-links{
    position:fixed;top:0;right:0;bottom:0;width:min(86vw,360px);
    background:var(--ivory-pure);
    flex-direction:column;align-items:flex-start;justify-content:flex-start;
    padding:96px 38px 38px;gap:24px;
    transform:translateX(100%);transition:transform .4s cubic-bezier(.2,.7,.2,1);
    box-shadow:var(--shadow);
    z-index:55;
  }
  .nav-links.open{transform:translateX(0)}

  /* Always dark text on the cream panel — overrides dark-nav inheritance */
  .nav-links a,
  nav.site.dark .nav-links a{
    color:var(--ink-soft);
    font-size:14px;letter-spacing:.2em;
    width:100%;padding:6px 0;
    border-bottom:1px solid var(--line-soft);
  }
  .nav-links a:last-of-type{border-bottom:none}
  .nav-links a.active,
  nav.site.dark .nav-links a.active{color:var(--champagne-deep)}
  .nav-links a.active::after{display:none}

  /* CTA pill inside the panel */
  .nav-links .nav-cta,
  nav.site.dark .nav-links .nav-cta{
    color:var(--ink);border-color:var(--ink);
    margin-top:8px;border-bottom:1px solid var(--ink);
    text-align:center;justify-content:center;
  }
  .nav-links .nav-cta:hover,
  nav.site.dark .nav-links .nav-cta:hover{background:var(--ink);color:var(--ivory)}

  /* Toggle button: dark on cream nav, light on dark nav, dark again when menu is open */
  .nav-toggle{display:block;z-index:60;position:relative}
  nav.site.menu-open .nav-toggle,
  nav.site.dark.menu-open .nav-toggle{color:var(--ink)}
}

/* Buttons ------------------------------------------------- */
.btn{
  display:inline-flex;align-items:center;gap:14px;
  padding:16px 30px;border-radius:999px;
  font-size:11px;letter-spacing:.28em;text-transform:uppercase;font-weight:500;
  transition:all .4s;cursor:pointer;border:1px solid transparent;
}
.btn-primary{background:var(--champagne);color:var(--ink);border-color:var(--champagne)}
.btn-primary:hover{background:var(--champagne-soft);border-color:var(--champagne-soft);color:var(--ink)}
.btn-ghost{border-color:rgba(251,250,246,.5);color:var(--ivory-pure)}
.btn-ghost:hover{border-color:var(--ivory-pure);background:rgba(251,250,246,.08);color:var(--ivory-pure)}
.btn-dark{background:var(--ink);color:var(--ivory)}
.btn-dark:hover{background:var(--ink-soft);color:var(--ivory)}
.btn-outline{border-color:var(--ink);color:var(--ink)}
.btn-outline:hover{background:var(--ink);color:var(--ivory)}
.btn .arrow{font-size:16px;line-height:1;transition:transform .35s}
.btn:hover .arrow{transform:translateX(4px)}

/* Hero ---------------------------------------------------- */
.hero{
  position:relative;height:100vh;min-height:680px;
  display:flex;align-items:center;overflow:hidden;background:var(--ink);
}
.hero-bg{
  position:absolute;inset:0;background-size:cover;background-position:center;
  filter:brightness(.55) saturate(.85);transform:scale(1.05);
}
.hero::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(14,14,14,.25) 0%,rgba(14,14,14,.55) 100%);
}
.hero .container{position:relative;z-index:2;color:var(--ivory-pure);width:100%}
.hero .eyebrow{color:var(--champagne-soft)}
.hero .eyebrow::before{background:var(--champagne-soft)}
.hero h1,.hero h2{color:var(--ivory-pure);max-width:920px;margin:24px 0 28px}
.hero h1 em,.hero h2 em{font-style:italic;color:var(--champagne-soft);font-weight:300}
.hero p{max-width:560px;color:rgba(251,250,246,.82);font-size:16px;font-weight:300;line-height:1.85}
.hero-actions{margin-top:42px;display:flex;gap:18px;flex-wrap:wrap}
.scroll-cue{
  position:absolute;bottom:36px;left:50%;transform:translateX(-50%);z-index:3;
  color:rgba(251,250,246,.55);font-size:10px;letter-spacing:.32em;text-transform:uppercase;
  display:flex;flex-direction:column;align-items:center;gap:14px;
}
.scroll-cue::after{
  content:"";width:1px;height:50px;background:rgba(251,250,246,.4);
  animation:scrollline 2s ease-in-out infinite;
}
@keyframes scrollline{0%,100%{transform:scaleY(.4);transform-origin:top}50%{transform:scaleY(1)}}

/* Page hero (subpages, shorter) --------------------------- */
.page-hero{
  position:relative;padding:200px 0 100px;background:var(--ink);overflow:hidden;
}
.page-hero .hero-bg{filter:brightness(.45) saturate(.7)}
.page-hero::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(14,14,14,.45) 0%,rgba(14,14,14,.6) 100%);
}
.page-hero .container{position:relative;z-index:2;color:var(--ivory-pure)}
.page-hero .eyebrow{color:var(--champagne-soft)}
.page-hero .eyebrow::before{background:var(--champagne-soft)}
.page-hero h1{color:var(--ivory-pure);font-size:clamp(40px,6vw,72px);font-weight:300;line-height:1.05;margin:22px 0 22px;font-family:'Cormorant Garamond',serif}
.page-hero h1 em{font-style:italic;color:var(--champagne-soft);font-weight:300}
.page-hero p{max-width:620px;color:rgba(251,250,246,.78);font-size:16px;line-height:1.85;font-weight:300}

/* Sections base ------------------------------------------- */
section{padding:120px 0;position:relative}
@media(max-width:680px){section{padding:80px 0}}
.section-head{max-width:760px;margin:0 auto 80px;text-align:center}
.section-head h2{margin:22px 0 18px}
.section-head p{color:var(--sage)}

/* Two-column ---------------------------------------------- */
.two-col{display:grid;grid-template-columns:1fr 1.1fr;gap:100px;align-items:center}
.two-col.flip{grid-template-columns:1.1fr 1fr}
.two-col-img{position:relative;aspect-ratio:4/5;overflow:hidden;border-radius:2px}
.two-col-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1.5s}
.two-col-img:hover img{transform:scale(1.04)}
.two-col-img::before{
  content:"";position:absolute;inset:18px;border:1px solid rgba(247,243,236,.45);z-index:2;pointer-events:none;
}
.two-col-text h2{margin:24px 0 28px}
.two-col-text p+p{margin-top:22px}
.signature{
  margin-top:38px;font-family:'Cormorant Garamond',serif;font-style:italic;
  font-size:22px;color:var(--champagne-deep);
}
@media(max-width:880px){
  .two-col,.two-col.flip{grid-template-columns:1fr;gap:50px}
}

/* Tier section -------------------------------------------- */
.tiers-bg{background:var(--ink);color:var(--ivory);position:relative}
.tiers-bg::before{
  content:"";position:absolute;inset:0;opacity:.05;pointer-events:none;
  background-image:url('https://images.unsplash.com/photo-1583416750470-965b2707b355?ixlib=rb-4.0.3&auto=format&fit=crop&w=1600&q=80');
  background-size:cover;background-position:center;
}
.tiers-bg .section-head h2{color:var(--ivory-pure)}
.tiers-bg .section-head p{color:rgba(247,243,236,.65)}
.tiers-bg .eyebrow{color:var(--champagne-soft)}
.tiers-bg .eyebrow::before{background:var(--champagne-soft)}

.tier-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;position:relative;z-index:2}
.tier{
  position:relative;padding:56px 40px 48px;
  border:1px solid rgba(212,184,138,.25);
  background:rgba(247,243,236,.025);
  backdrop-filter:blur(2px);
  transition:all .5s cubic-bezier(.2,.7,.2,1);
  display:flex;flex-direction:column;
}
.tier:hover{border-color:var(--champagne);background:rgba(184,153,104,.06);transform:translateY(-6px)}
.tier-mark{
  font-family:'Cormorant Garamond',serif;font-size:13px;letter-spacing:.4em;
  text-transform:uppercase;color:var(--champagne-soft);font-weight:500;
}
.tier-name{
  font-family:'Cormorant Garamond',serif;font-size:42px;line-height:1;font-weight:400;
  margin:18px 0 12px;color:var(--ivory-pure);letter-spacing:.04em;
}
.tier-tag{
  font-family:'Cormorant Garamond',serif;font-style:italic;
  font-size:18px;color:var(--champagne-soft);margin-bottom:34px;
}
.tier hr{border:none;height:1px;background:var(--line);margin:0 0 28px}
.tier ul{list-style:none}
.tier li{
  padding:14px 0;border-bottom:1px solid rgba(212,184,138,.12);
  font-size:14px;color:rgba(247,243,236,.85);
  display:flex;justify-content:space-between;gap:16px;align-items:baseline;
}
.tier li:last-child{border-bottom:none}
.tier li .duration{
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--champagne-soft);white-space:nowrap;
}
.tier-perks{
  margin-top:28px;padding-top:28px;border-top:1px solid rgba(212,184,138,.18);
  font-family:'Cormorant Garamond',serif;font-style:italic;font-size:15px;
  line-height:1.7;color:rgba(247,243,236,.7);
}
.tier-cta{margin-top:36px;padding-top:30px;border-top:1px solid rgba(212,184,138,.18)}
.tier-cta a{
  display:flex;justify-content:space-between;align-items:center;
  font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--champagne-soft);
}
.tier-cta a:hover{color:var(--ivory-pure)}
.tier-cta a:hover .arrow{transform:translateX(6px)}
.tier.featured{
  border-color:var(--champagne);
  background:linear-gradient(180deg,rgba(184,153,104,.12) 0%,rgba(184,153,104,.04) 100%);
}
.tier.featured::before{
  content:"Most Coveted";
  position:absolute;top:-1px;left:50%;transform:translate(-50%,-50%);
  background:var(--champagne);color:var(--ink);padding:8px 18px;
  font-size:10px;letter-spacing:.3em;text-transform:uppercase;font-weight:500;
}
.tier-foot{
  margin-top:80px;text-align:center;
  font-family:'Cormorant Garamond',serif;font-style:italic;
  color:rgba(247,243,236,.55);font-size:18px;
}
@media(max-width:980px){
  .tier-grid{grid-template-columns:1fr;gap:22px}
  .tier.featured::before{left:32px;transform:translateY(-50%)}
}

/* Service categories grid -------------------------------- */
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border-top:1px solid var(--line)}
.svc{
  padding:60px 50px;border-bottom:1px solid var(--line);border-right:1px solid var(--line);
  transition:background .5s;display:flex;gap:40px;align-items:flex-start;
}
.svc:nth-child(2n){border-right:none}
.svc:hover{background:var(--ivory-pure)}
.svc-num{
  font-family:'Cormorant Garamond',serif;font-style:italic;font-size:14px;
  color:var(--champagne-deep);letter-spacing:.1em;margin-top:10px;flex-shrink:0;
}
.svc-body{flex:1}
.svc-body h3{margin-bottom:14px}
.svc-body p{font-size:14px;color:var(--sage);line-height:1.8}
.svc-link{
  margin-top:22px;display:inline-flex;align-items:center;gap:12px;
  font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--ink);
}
.svc-link::after{content:"→";transition:transform .35s}
.svc-link:hover::after{transform:translateX(5px)}
@media(max-width:880px){
  .svc-grid{grid-template-columns:1fr}
  .svc{border-right:none;padding:46px 22px}
}

/* Service menu (with prices) ----------------------------- */
.menu-section{padding:100px 0;border-bottom:1px solid var(--line)}
.menu-section:last-child{border-bottom:none}
.menu-section .section-head{margin-bottom:60px}
.menu-list{max-width:880px;margin:0 auto}
.menu-item{
  padding:36px 0;border-bottom:1px solid var(--line-soft);
  display:grid;grid-template-columns:1fr auto;gap:30px;align-items:start;
}
.menu-item:last-child{border-bottom:none}
.menu-item-head{display:flex;align-items:baseline;gap:18px;flex-wrap:wrap;margin-bottom:10px}
.menu-item h3{
  font-family:'Cormorant Garamond',serif;font-weight:400;
  font-size:26px;color:var(--ink);line-height:1.2;
}
.menu-item-desc{font-size:14px;color:var(--sage);line-height:1.8;max-width:580px}
.menu-item-pricing{
  font-family:'Cormorant Garamond',serif;text-align:right;min-width:140px;
}
.menu-item-pricing .row{
  display:flex;justify-content:flex-end;gap:14px;align-items:baseline;
  font-size:18px;color:var(--ink);padding:4px 0;
}
.menu-item-pricing .row span:first-child{
  font-family:'Inter',sans-serif;font-size:11px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--champagne-deep);
}
.menu-item-pricing .row .price{font-weight:500}
.rate-note{
  display:inline-block;margin-left:8px;
  font-family:'Inter',sans-serif;font-style:italic;font-weight:400;
  font-size:11px;letter-spacing:.08em;color:var(--sage);
  vertical-align:middle;
}
.menu-note{
  margin-top:50px;padding:30px;background:var(--ivory-pure);
  border-left:3px solid var(--champagne);
  font-family:'Cormorant Garamond',serif;font-style:italic;
  font-size:17px;color:var(--ink-soft);text-align:center;
}
@media(max-width:680px){
  .menu-item{grid-template-columns:1fr;gap:14px}
  .menu-item-pricing{text-align:left}
  .menu-item-pricing .row{justify-content:flex-start}
}

/* Visit / Contact ---------------------------------------- */
.visit-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:stretch;border:1px solid var(--line)}
.visit-text{padding:80px 70px}
.visit-text h2{margin:24px 0 30px}
.visit-info{margin-top:46px;display:grid;gap:34px}
.visit-info dt{
  font-size:10px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--champagne-deep);font-weight:500;margin-bottom:8px;
}
.visit-info dd{
  font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:400;
  color:var(--ink);line-height:1.4;
}
.visit-info dd a{color:inherit}
.visit-info dd .meta{font-size:14px;color:var(--sage);font-style:italic;font-family:'Inter',sans-serif;display:block;margin-top:6px}
.visit-img{
  background-size:cover;background-position:center;min-height:520px;
}
.visit-cta{margin-top:50px;display:flex;gap:14px;flex-wrap:wrap}
@media(max-width:980px){
  .visit-grid{grid-template-columns:1fr}
  .visit-text{padding:54px 30px}
  .visit-img{min-height:340px}
}

/* Quote band --------------------------------------------- */
.quote{background:var(--ivory);text-align:center;padding:120px 32px}
.quote-mark{
  font-family:'Cormorant Garamond',serif;font-size:80px;line-height:1;
  color:var(--champagne);margin-bottom:24px;display:inline-block;
}
.quote blockquote{
  font-family:'Cormorant Garamond',serif;font-weight:300;
  font-size:clamp(24px,3.4vw,40px);line-height:1.4;color:var(--ink);
  max-width:920px;margin:0 auto;font-style:italic;
}
.quote cite{
  display:block;margin-top:36px;font-family:'Inter',sans-serif;font-style:normal;
  font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--champagne-deep);
}

/* Promotion cards ---------------------------------------- */
.promo-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:32px}
.promo{
  background:var(--ivory-pure);
  padding:60px 50px;border:1px solid var(--line);
  position:relative;display:flex;flex-direction:column;
}
.promo-mark{
  font-family:'Cormorant Garamond',serif;font-size:13px;letter-spacing:.4em;
  text-transform:uppercase;color:var(--champagne-deep);font-weight:500;
}
.promo h3{
  font-family:'Cormorant Garamond',serif;font-weight:400;font-size:34px;
  margin:18px 0 18px;color:var(--ink);line-height:1.2;
}
.promo .offer{
  font-family:'Cormorant Garamond',serif;font-style:italic;font-size:24px;
  color:var(--champagne-deep);margin-bottom:24px;line-height:1.4;
}
.promo dl{margin-top:auto;padding-top:30px;border-top:1px solid var(--line);display:grid;gap:18px}
.promo dt{
  font-size:10px;letter-spacing:.3em;text-transform:uppercase;
  color:var(--champagne-deep);font-weight:500;margin-bottom:4px;
}
.promo dd{font-size:14px;color:var(--ink-soft);line-height:1.7}
@media(max-width:880px){.promo-grid{grid-template-columns:1fr}.promo{padding:42px 28px}}

/* PureBrow special menu ---------------------------------- */
.brow-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.brow{
  padding:50px 36px;border:1px solid var(--line);
  background:var(--ivory-pure);transition:all .5s;
  display:flex;flex-direction:column;
}
.brow:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--champagne)}
.brow-num{
  font-family:'Cormorant Garamond',serif;font-style:italic;font-size:14px;
  color:var(--champagne-deep);letter-spacing:.14em;margin-bottom:20px;
}
.brow h3{
  font-family:'Cormorant Garamond',serif;font-weight:400;font-size:28px;
  margin-bottom:18px;color:var(--ink);line-height:1.2;
}
.brow p{font-size:14px;color:var(--sage);line-height:1.8;flex:1}
.brow-price{
  margin-top:28px;padding-top:24px;border-top:1px solid var(--line-soft);
  font-family:'Cormorant Garamond',serif;font-size:32px;font-weight:500;color:var(--champagne-deep);
}
@media(max-width:980px){.brow-grid{grid-template-columns:1fr;gap:22px}}

/* Footer -------------------------------------------------- */
footer{background:var(--ink);color:rgba(247,243,236,.6);padding:90px 0 40px;font-size:13px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:60px;margin-bottom:70px}
.foot-brand{
  font-family:'Cormorant Garamond',serif;font-size:28px;letter-spacing:.18em;
  color:var(--ivory-pure);font-weight:500;margin-bottom:18px;
}
.foot-brand span{color:var(--champagne)}
.foot-tag{
  font-family:'Cormorant Garamond',serif;font-style:italic;
  font-size:18px;color:var(--champagne-soft);line-height:1.6;max-width:280px;
}
.foot-grid h4{
  font-size:11px;letter-spacing:.3em;text-transform:uppercase;
  color:var(--ivory-pure);font-weight:500;margin-bottom:22px;
}
.foot-grid ul{list-style:none}
.foot-grid li{padding:6px 0}
.foot-grid a:hover{color:var(--champagne-soft)}
.foot-bottom{
  border-top:1px solid rgba(212,184,138,.15);padding-top:30px;
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:rgba(247,243,236,.4);
}
@media(max-width:880px){.foot-grid{grid-template-columns:1fr 1fr;gap:40px}}

/* Reveal animations -------------------------------------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity 1.1s,transform 1.1s}
.reveal.in{opacity:1;transform:none}
