*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth} img{display:block;width:100%;height:100%;object-fit:cover}
a{color:inherit;text-decoration:none} ul{list-style:none}
body{overflow-x:hidden;-webkit-font-smoothing:antialiased}
.nav.is-open .nav__panel{transform:translateX(0);opacity:1;visibility:visible}
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s cubic-bezier(.22,1,.36,1),transform .7s cubic-bezier(.22,1,.36,1)}
.reveal.is-visible{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

:root{
  --cream:#fbf9f6;
  --ink:#2c332b;
  --accent:#5c6b5a;
  --accent-rgb:92,107,90;
  --sage:#8b9a7e;
  --light-cream:#f3ede4;
  --border:#dcd6cb;
  --text-dark:#2c332b;
  --text-muted:#606a5d;
  --sans:'Outfit',system-ui,sans-serif;
  --display:'Cormorant Garamond',serif;
}
body{background:var(--cream);color:var(--text-dark);font-family:var(--sans);line-height:1.6}
h1,h2,h3{font-family:var(--display);font-weight:500;color:var(--text-dark)}
em{font-style:italic;font-weight:400;color:var(--accent)}

/* NAV */
.nav{display:flex;align-items:center;padding:1.25rem 5vw;background:rgba(251,249,246,0.96);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;backdrop-filter:blur(10px)}
.nav__logo{font-family:var(--display);font-size:1.6rem;letter-spacing:.05em;color:var(--text-dark);font-weight:700}
.nav__accent{color:var(--sage)}
.nav__burger{margin-left:auto;background:none;border:0;cursor:pointer}.nav__burger span{display:block;width:22px;height:2px;background:var(--text-dark);margin:5px 0}
.nav__panel{display:none;gap:1.5rem;align-items:center}.nav.is-open .nav__panel{display:flex;flex-wrap:wrap;width:100%;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border)}
.nav__panel a{font-size:.85rem;text-transform:uppercase;letter-spacing:.1em;font-weight:600;color:var(--text-muted)}
.nav__panel a:hover{color:var(--accent)}
.nav__cta{color:var(--accent)!important;font-weight:700;border:1px solid var(--accent);padding:0.4rem 1.2rem;border-radius:100px}
.nav__cta:hover{background:var(--accent);color:#fff!important}
@media(min-width:850px){.nav__burger{display:none}.nav__panel{display:flex!important;margin-left:auto;gap:2rem}}

/* HERO */
.hero--spa{position:relative;min-height:90svh;padding:5rem 5vw;display:flex;align-items:center;background:radial-gradient(circle at top right, rgba(139,154,126,0.08), transparent 50%)}
.hero__inner{max-width:1200px;margin:0 auto;width:100%;display:grid;grid-template-columns:1fr;gap:4rem;align-items:center}
@media(min-width:850px){.hero__inner{grid-template-columns:1.15fr .85fr}}
.hero__eyebrow{color:var(--sage);text-transform:uppercase;letter-spacing:.15em;font-size:.85rem;font-weight:700;margin-bottom:1rem}
.hero h1{font-size:clamp(2.5rem,6vw,4.5rem);line-height:1.05;margin-bottom:1.5rem;font-weight:400}
.hero__lead{font-size:1.15rem;color:var(--text-muted);margin-bottom:2.25rem;max-width:32rem}
.hero__actions{display:flex;flex-wrap:wrap;gap:1rem;align-items:center}
.btn-spa{display:inline-block;background:var(--accent);color:#fff;padding:1rem 2.2rem;font-weight:500;letter-spacing:.04em;text-transform:uppercase;font-family:var(--sans);transition:transform .2s,box-shadow .2s;border-radius:100px;border:0}
.btn-spa:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(var(--accent-rgb),.25)}
.btn-outline{display:inline-block;border:1px solid var(--border);color:var(--text-dark);padding:1rem 2.2rem;font-weight:500;letter-spacing:.04em;text-transform:uppercase;font-family:var(--sans);transition:background .2s,color .2s;border-radius:100px;background:#fff}
.btn-outline:hover{background:var(--text-dark);color:#fff;border-color:var(--text-dark)}

.hero__image-panel{position:relative;width:100%;max-width:24rem;justify-self:center}
.hero__frame{border:1px solid var(--border);padding:10px;background:#fff;box-shadow:0 20px 40px rgba(0,0,0,.03);border-radius:160px 160px 0 0;overflow:hidden}
.hero__frame img{aspect-ratio:4/5;width:100%;height:100%;object-fit:cover;border-radius:160px 160px 0 0}
.hero__badge{position:absolute;left:-1.25rem;bottom:2rem;background:var(--light-cream);color:var(--text-dark);padding:0.75rem 1.25rem;box-shadow:0 10px 20px rgba(0,0,0,.04);display:flex;flex-direction:column;line-height:1.2;font-family:var(--sans);border-radius:16px;border:1px solid var(--border)}
.badge__title{font-weight:700;font-size:1rem;color:var(--accent)}
.badge__text{font-size:0.7rem;opacity:0.9}

/* DUAL SPA */
.dual-spa{padding:7rem 5vw;background:#fff;border-block:1px solid var(--border)}
.dual-spa__grid{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr;gap:4rem;align-items:center}
@media(min-width:768px){.dual-spa__grid{grid-template-columns:1fr 1.2fr}}
.dual-spa__img-wrap{position:relative;width:95%;max-width:26rem;border-radius:140px 140px 0 0;overflow:hidden;border:1px solid var(--border);padding:8px;background:#fff}
.dual-spa__img-wrap img{aspect-ratio:4/5;width:100%;object-fit:cover;border-radius:140px 140px 0 0}
.section-tag{text-transform:uppercase;letter-spacing:0.2em;color:var(--sage);font-size:0.8rem;font-weight:700;margin-bottom:0.75rem;display:inline-block}
.dual-spa__content h2{font-size:clamp(2rem,4vw,3.2rem);margin-bottom:1.5rem;line-height:1.1;font-weight:400}
.dual-spa__description{font-size:1.05rem;color:var(--text-muted);margin-bottom:2rem}
.spa-features{display:grid;grid-template-columns:1fr;gap:1.5rem;border-top:1px solid var(--border);padding-top:2rem}
@media(min-width:600px){.spa-features{grid-template-columns:1fr 1fr}}
.spa-feature strong{color:var(--accent);font-family:var(--display);font-size:1.35rem;display:block;margin-bottom:0.25rem}
.spa-feature p{font-size:0.85rem;color:var(--text-muted)}

/* SERVICES SPA */
.services-spa{padding:7rem 5vw;background:var(--cream)}
.services-spa__inner{max-width:900px;margin:0 auto}
.services-spa__header{text-align:center;margin-bottom:4.5rem}
.services-spa__header h2{font-size:clamp(2.2rem,5vw,3.6rem);font-weight:400}
.spa-menu-list{display:flex;flex-direction:column;gap:2.5rem}
.spa-menu-item__head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:0.5rem}
.spa-menu-item__title{font-family:var(--display);font-size:1.45rem;color:var(--text-dark);font-weight:500}
.spa-menu-item__dots{flex-grow:1;border-bottom:1px dotted var(--border);margin:0 15px}
.spa-menu-item__price{font-family:var(--sans);color:var(--accent);font-weight:600;font-size:1.15rem}
.spa-menu-item__desc{font-size:0.9rem;color:var(--text-muted);max-width:70ch}

/* GALLERY SPA */
.gallery-spa{padding:6rem 5vw;background:#fff;border-block:1px solid var(--border)}
.gallery-spa__header{text-align:center;margin-bottom:3.5rem}
.gallery-spa__header h2{font-size:clamp(2.2rem,4vw,3.2rem);font-weight:400}
.gallery-spa__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;max-width:1200px;margin:0 auto}
@media(min-width:768px){.gallery-spa__grid{grid-template-columns:repeat(4,1fr)}}
.spa-frame{background:#fff;border:1px solid var(--border);padding:8px;border-radius:120px 120px 0 0;text-align:center}
.spa-frame img{aspect-ratio:3/4;width:100%;height:100%;object-fit:cover;margin-bottom:0.75rem;transition:transform .3s;border-radius:110px 110px 0 0}
.spa-frame:hover img{transform:scale(1.02)}
.spa-frame figcaption{font-size:0.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.05em}

/* CTA SPA */
.cta-spa{padding:7rem 5vw;background:var(--cream)}
.cta-spa__inner{max-width:1000px;margin:0 auto;background:#fff;border:1px solid var(--border);border-radius:120px 120px 0 0;display:grid;grid-template-columns:1fr;align-items:center;overflow:hidden}
@media(min-width:768px){.cta-spa__inner{grid-template-columns:1.1fr .9fr}}
.cta-spa__content{padding:4rem 3rem}
.cta-spa__content h2{font-size:clamp(2rem,4vw,2.8rem);margin-bottom:1rem;line-height:1.1;font-weight:400}
.cta-spa__content p{color:var(--text-muted);margin-bottom:2rem}
.cta-spa__inner .btn-spa{width:100%;text-align:center}
.cta-spa__image img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3}
@media(max-width:768px){.cta-spa__image{order:-1}}

.site-footer{text-align:center;padding:2.5rem 5vw;font-size:.8rem;opacity:.5;border-top:1px solid var(--border);background:#fff}
