/* ============================================================
   RELAX MASSAGE & WELLNESS - "Tidal Release"
   Matte black · bone · deep Atlantic blue · sea-glass teal
   ============================================================ */

/* ───────── self-hosted fonts (latin subsets, swap) ───────── */
@font-face{font-family:'Fraunces';font-style:italic;font-weight:300;font-display:swap;src:url('../fonts/fraunces-italic-300.woff2') format('woff2')}
@font-face{font-family:'Fraunces';font-style:italic;font-weight:400;font-display:swap;src:url('../fonts/fraunces-italic-400.woff2') format('woff2')}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:300;font-display:swap;src:url('../fonts/fraunces-normal-300.woff2') format('woff2')}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/fraunces-normal-400.woff2') format('woff2')}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/fraunces-normal-500.woff2') format('woff2')}
@font-face{font-family:'Manrope';font-style:normal;font-weight:300;font-display:swap;src:url('../fonts/manrope-normal-300.woff2') format('woff2')}
@font-face{font-family:'Manrope';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/manrope-normal-400.woff2') format('woff2')}
@font-face{font-family:'Manrope';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/manrope-normal-500.woff2') format('woff2')}
@font-face{font-family:'Manrope';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/manrope-normal-600.woff2') format('woff2')}
@font-face{font-family:'Manrope';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/manrope-normal-700.woff2') format('woff2')}

:root{
  --ink:#05070A;          /* matte black background          */
  --ink-2:#080C13;        /* raised panel                    */
  --ink-3:#0B111B;        /* card surface                    */
  --bone:#E9EDEC;         /* pearl / bone text               */
  --bone-soft:rgba(233,237,236,.66);
  --bone-faint:rgba(233,237,236,.40);
  --atlantic:#102E4C;     /* deep Atlantic blue              */
  --atlantic-lo:#0A1B2E;
  --teal:#5FC9C0;         /* sea-glass teal                  */
  --teal-deep:#2E8C86;
  --cyan:#BFF3F2;         /* pale cyan highlight             */
  --line:rgba(233,237,236,.12);
  --line-soft:rgba(233,237,236,.07);

  --serif:"Fraunces",Georgia,serif;
  --sans:"Manrope",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;

  --ease:cubic-bezier(.22,1,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);

  --pad:clamp(1.25rem,5vw,6rem);
  --maxw:1320px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
.lenis.lenis-stopped{overflow:hidden}

body{
  font-family:var(--sans);
  background:var(--ink);
  color:var(--bone);
  font-weight:400;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
body[data-loading]{overflow:hidden;height:100vh}

::selection{background:var(--teal);color:var(--ink)}

a{color:inherit;text-decoration:none}
img,svg,canvas{display:block}
em{font-style:italic}
.sr-only{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* keyboard focus is part of the design, not an afterthought */
:focus-visible{outline:2px solid var(--teal);outline-offset:3px;border-radius:4px}
.skip{position:fixed;top:.8rem;left:.8rem;z-index:1100;background:var(--teal);color:var(--ink);
  font-weight:600;font-size:.82rem;padding:.7em 1.2em;border-radius:100px;
  transform:translateY(-300%);transition:transform .3s var(--ease)}
.skip:focus-visible{transform:none}

/* anchored sections land clear of the fixed nav */
[id]{scroll-margin-top:5.5rem}

/* thin page progress line under the nav */
.progress{position:fixed;top:0;left:0;width:100%;height:2px;z-index:600;pointer-events:none;
  background:linear-gradient(90deg,var(--teal),var(--cyan));
  transform:scaleX(0);transform-origin:left center}

/* static fallback if the animation stack ever fails to load */
.no-anim .preloader{display:none}
.no-anim .reveal-fade,.no-anim .reveal-title{opacity:1;transform:none}

/* ───────── shared type ───────── */
.eyebrow{
  font-size:.74rem;letter-spacing:.28em;text-transform:uppercase;
  color:var(--teal);font-weight:600;
  display:flex;align-items:center;gap:.7em;margin-bottom:1.6rem;
}
.eyebrow span{overflow:hidden;display:inline-block}
.eyebrow::before{content:"";width:2.2rem;height:1px;background:var(--teal);opacity:.55;flex:none}
.eyebrow--center{justify-content:center}

.section{padding:clamp(5rem,12vh,11rem) var(--pad);position:relative}
.section__head{max-width:var(--maxw);margin:0 auto 3.5rem}
.section__head--center{text-align:center}
.section__head--center .eyebrow{justify-content:center}
.section__title{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(2.4rem,6vw,5rem);line-height:1.02;letter-spacing:-.01em;
}
.section__title em{color:var(--teal);font-style:italic}
.section__sub{
  margin-top:1.4rem;max-width:42ch;color:var(--bone-soft);
  font-size:clamp(1rem,1.4vw,1.18rem);font-weight:300;
}
.section__head--center .section__sub{margin-left:auto;margin-right:auto}

/* ============================================================
   PRELOADER
   ============================================================ */
.preloader{
  position:fixed;inset:0;z-index:1000;background:var(--ink);
  display:flex;align-items:center;justify-content:center;
}
.preloader__inner{display:flex;flex-direction:column;align-items:center;gap:1.4rem;width:min(78vw,360px)}
.preloader__word{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:clamp(1.6rem,4vw,2.2rem);color:var(--bone);letter-spacing:.01em;
}
.preloader__bar{display:block;width:100%;height:1px;background:var(--line);overflow:hidden}
.preloader__bar i{display:block;height:100%;width:0%;background:linear-gradient(90deg,var(--teal),var(--cyan))}
.preloader__count{font-size:.74rem;letter-spacing:.25em;color:var(--bone-faint);font-variant-numeric:tabular-nums}
.preloader__count small{opacity:.6}
body:not([data-loading]) .preloader{opacity:0;visibility:hidden;transition:opacity .7s var(--ease),visibility .7s}

/* ============================================================
   CURSOR
   ============================================================ */
.cursor{
  position:fixed;top:0;left:0;z-index:900;pointer-events:none;
  width:9px;height:9px;border-radius:50%;background:var(--teal);
  transform:translate(-50%,-50%);mix-blend-mode:screen;
  transition:width .35s var(--ease),height .35s var(--ease),background .35s;
}
.cursor.is-hover{width:64px;height:64px;background:rgba(95,201,192,.14);border:1px solid rgba(95,201,192,.5)}
.cursor__label{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--cyan);
  opacity:0;transition:opacity .3s;white-space:nowrap;
}
.cursor.is-hover .cursor__label{opacity:1}
@media (pointer:coarse){.cursor{display:none}}

/* ============================================================
   NAV
   ============================================================ */
.nav{position:fixed;top:0;left:0;width:100%;z-index:500;padding:1.1rem var(--pad);
  transition:background .5s var(--ease),padding .5s var(--ease),border-color .5s;
  border-bottom:1px solid transparent;}
.nav.is-scrolled{
  background:rgba(5,7,10,.72);backdrop-filter:blur(16px) saturate(1.2);
  -webkit-backdrop-filter:blur(16px) saturate(1.2);
  border-bottom:1px solid var(--line-soft);padding-top:.8rem;padding-bottom:.8rem;
}
.nav__inner{max-width:1500px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:2rem}
.nav__logo{display:flex;align-items:center}
.nav__logo img{height:42px;width:auto;transition:height .5s var(--ease)}
.nav.is-scrolled .nav__logo img{height:36px}
.nav__links{display:flex;gap:2.1rem}
.nav__links a{font-size:.82rem;font-weight:500;letter-spacing:.02em;color:var(--bone-soft);position:relative;transition:color .3s}
.nav__links a::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:1px;background:var(--teal);transition:width .4s var(--ease)}
.nav__links a:hover,.nav__links a.is-active{color:var(--bone)}
.nav__links a:hover::after,.nav__links a.is-active::after{width:100%}
.nav__actions{display:flex;align-items:center;gap:1rem}

/* ───────── buttons ───────── */
.btn{
  --bg:transparent;--fg:var(--bone);--bd:var(--line);
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-family:var(--sans);font-size:.86rem;font-weight:600;letter-spacing:.02em;
  padding:.92em 1.7em;border-radius:100px;border:1px solid var(--bd);
  background:var(--bg);color:var(--fg);cursor:pointer;position:relative;overflow:hidden;
  transition:color .4s var(--ease),border-color .4s var(--ease),transform .5s var(--ease);
  white-space:nowrap;
}
.btn::before{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(120deg,var(--teal),var(--cyan));
  transform:translateY(101%);transition:transform .55s var(--ease)}
.btn:hover::before{transform:translateY(0)}
.btn--solid{--bg:var(--bone);--fg:var(--ink);--bd:var(--bone)}
.btn--solid:hover{--fg:var(--ink);border-color:var(--cyan)}
.btn--ghost{--bg:transparent;--fg:var(--bone);--bd:var(--line)}
.btn--ghost:hover{--fg:var(--ink);border-color:transparent}
.btn--small{padding:.62em 1.15em;font-size:.78rem}
.btn--light{--bg:var(--bone);--fg:var(--ink);--bd:var(--bone)}
.btn--big{padding:1.1em 2.2em;font-size:.95rem}

/* ───────── mobile menu / burger ───────── */
.nav__burger{display:none;width:42px;height:42px;border:1px solid var(--line);border-radius:50%;
  background:transparent;cursor:pointer;position:relative}
.nav__burger span{position:absolute;left:50%;top:50%;width:16px;height:1.5px;background:var(--bone);
  transform:translate(-50%,-50%) translateY(-3px);transition:.4s var(--ease)}
.nav__burger span:last-child{transform:translate(-50%,-50%) translateY(3px)}
.nav.is-open .nav__burger span{transform:translate(-50%,-50%) rotate(45deg)}
.nav.is-open .nav__burger span:last-child{transform:translate(-50%,-50%) rotate(-45deg)}

.menu{position:fixed;inset:0;z-index:480;background:var(--ink-2);
  display:flex;flex-direction:column;justify-content:center;padding:6rem var(--pad) 2.5rem;
  opacity:0;visibility:hidden;transform:translateY(-2%);
  transition:opacity .5s var(--ease),visibility .5s,transform .6s var(--ease)}
.menu.is-open{opacity:1;visibility:visible;transform:none}
.menu__links{display:flex;flex-direction:column;gap:.2rem}
.menu__links a{font-family:var(--serif);font-weight:300;font-size:clamp(2rem,9vw,3.2rem);
  display:flex;align-items:baseline;gap:1rem;padding:.4rem 0;border-bottom:1px solid var(--line-soft);color:var(--bone)}
.menu__links a small{font-family:var(--sans);font-size:.8rem;color:var(--teal);font-weight:600}
.menu__foot{margin-top:2.4rem;display:flex;flex-direction:column;gap:1rem;align-items:flex-start}
.menu__foot p{font-size:.86rem;color:var(--bone-soft);line-height:1.7}

/* ============================================================
   STORY - pinned WebGL "Tidal Release"
   ============================================================ */
.story{position:relative;background:var(--ink)}
.story__stage{position:relative;height:100svh;width:100%;overflow:hidden}
.story__canvas{position:absolute;inset:0;width:100%;height:100%;display:block}
.story__stage.no-webgl{background:
  radial-gradient(60% 50% at 50% 42%, rgba(95,201,192,.18), transparent 60%),
  radial-gradient(80% 70% at 50% 46%, rgba(16,46,76,.55), transparent 70%), var(--ink)}
.story__stage.no-webgl .story__canvas{display:none}
.story__stage.no-webgl .story__rail,.story__stage.no-webgl .story__hint{display:none}
.story__veil{position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(120% 80% at 50% 38%, transparent 38%, rgba(5,7,10,.55) 78%, rgba(5,7,10,.92) 100%),
    linear-gradient(180deg, rgba(5,7,10,.6) 0%, transparent 22%, transparent 60%, rgba(5,7,10,.85) 100%);
}
.story__grain{display:none}

/* captions */
.story__caps{position:absolute;inset:0;pointer-events:none}
.cap{position:absolute;will-change:opacity,transform}
.cap--open{
  left:var(--pad);right:var(--pad);bottom:clamp(5rem,16vh,11rem);
  max-width:min(92vw,720px);
}
.cap__eyebrow{font-size:.74rem;letter-spacing:.26em;text-transform:uppercase;color:var(--teal);font-weight:600;margin-bottom:1.5rem}
.cap__title{font-family:var(--serif);font-weight:300;line-height:1.0;letter-spacing:-.015em;
  font-size:clamp(2.7rem,8.5vw,7rem)}
.cap__title em{color:var(--cyan);font-style:italic}
.cap__title .l{display:block;overflow:hidden}
.cap__title .l>span{display:block;will-change:transform}
.cap__lede{margin-top:1.7rem;max-width:46ch;color:var(--bone-soft);font-weight:300;
  font-size:clamp(1.02rem,1.6vw,1.3rem);line-height:1.55}
.cap__cta{margin-top:2.2rem;display:flex;flex-wrap:wrap;gap:.9rem}

.cap--step{
  left:var(--pad);right:var(--pad);bottom:clamp(5rem,18vh,12rem);
  max-width:min(92vw,640px);opacity:0;
}
.cap__index{font-size:.74rem;letter-spacing:.24em;text-transform:uppercase;color:var(--teal);font-weight:600;display:block;margin-bottom:1.2rem}
.cap--release .cap__index,.cap--release .cap__line em{color:var(--cyan)}
.cap__line{font-family:var(--serif);font-weight:300;font-style:normal;
  font-size:clamp(1.7rem,4.4vw,3.1rem);line-height:1.16;letter-spacing:-.01em;color:var(--bone)}
.cap__line em{color:var(--teal)}
.cap--resolve .cap__line+.btn{margin-top:1.8rem;pointer-events:auto}
.cap--resolve{pointer-events:none}

/* phase rail */
.story__rail{position:absolute;right:var(--pad);top:50%;transform:translateY(-50%);
  display:flex;flex-direction:column;align-items:center;gap:.9rem;height:34vh}
.story__rail-label{writing-mode:vertical-rl;font-size:.68rem;letter-spacing:.24em;
  text-transform:uppercase;color:var(--bone-faint);transition:color .5s}
.story__rail-track{position:relative;flex:1;width:1px;background:var(--line)}
.story__rail-track i{position:absolute;left:0;top:0;width:100%;height:0%;
  background:linear-gradient(180deg,var(--teal),var(--cyan));box-shadow:0 0 8px rgba(95,201,192,.6)}

/* scroll hint */
.story__hint{position:absolute;left:var(--pad);bottom:1.6rem;display:flex;align-items:center;gap:.7rem;
  font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--bone-faint)}
.story__hint i{width:1px;height:30px;background:linear-gradient(var(--teal),transparent);
  position:relative;overflow:hidden}
.story__hint i::after{content:"";position:absolute;top:0;left:0;width:100%;height:40%;
  background:var(--cyan);animation:scrolldrop 2.4s var(--ease) infinite}
@keyframes scrolldrop{0%{transform:translateY(-100%)}60%,100%{transform:translateY(260%)}}

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee{overflow:hidden;border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);
  padding:1.5rem 0;background:var(--ink)}
.marquee__track{display:flex;white-space:nowrap;will-change:transform}
.marquee__track span{font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:clamp(1.4rem,3vw,2.3rem);color:var(--bone-soft);padding-right:.2em}

/* ============================================================
   METHOD
   ============================================================ */
.method{background:var(--ink)}
.method__inner{max-width:var(--maxw);margin:0 auto}
.method__statement{font-family:var(--serif);font-weight:300;letter-spacing:-.01em;
  font-size:clamp(1.9rem,4.6vw,3.6rem);line-height:1.18;max-width:20ch;margin-bottom:3.5rem}
.method__row{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,6vw,6rem);align-items:start}
.method__copy{color:var(--bone-soft);font-weight:300;font-size:clamp(1rem,1.4vw,1.16rem);max-width:48ch}
.method__stats{display:flex;flex-direction:column;gap:1.6rem}
.stat{display:flex;align-items:baseline;gap:.5rem;border-bottom:1px solid var(--line-soft);padding-bottom:1.4rem}
.stat__num{font-family:var(--serif);font-weight:300;font-size:clamp(2.6rem,5vw,3.6rem);line-height:1;color:var(--bone);font-variant-numeric:tabular-nums}
.stat__suffix{font-family:var(--serif);font-size:1.6rem;color:var(--teal)}
.stat__label{margin-left:auto;text-align:right;font-size:.82rem;color:var(--bone-faint);letter-spacing:.02em;max-width:14ch}

/* ============================================================
   BENEFITS
   ============================================================ */
.benefits__grid{max-width:var(--maxw);margin:0 auto;display:grid;
  grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line-soft);border:1px solid var(--line-soft)}
.card{background:var(--ink);padding:clamp(1.8rem,3vw,2.8rem);min-height:300px;
  display:flex;flex-direction:column;position:relative;overflow:hidden;transition:background .5s var(--ease)}
.card::after{content:"";position:absolute;inset:0;
  background:radial-gradient(120% 100% at 50% 120%,rgba(95,201,192,.16),transparent 65%);
  opacity:0;transition:opacity .55s var(--ease)}
.card:hover{background:var(--ink-3)}
.card:hover::after{opacity:1}
.card__num{font-size:.74rem;letter-spacing:.2em;color:var(--bone-faint);font-weight:600}
.card__glyph{width:44px;height:44px;color:var(--teal);margin:1.6rem 0 auto;transition:transform .6s var(--ease)}
.card:hover .card__glyph{transform:translateY(-4px) scale(1.06)}
.card h3{font-family:var(--serif);font-weight:400;font-size:clamp(1.3rem,2vw,1.7rem);margin:1.5rem 0 .7rem}
.card p{color:var(--bone-soft);font-weight:300;font-size:.96rem;line-height:1.6;max-width:34ch}
.card__tag{margin-top:1.4rem;font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--teal);
  border:1px solid var(--line);border-radius:100px;padding:.4em .9em;align-self:flex-start}

/* ============================================================
   TREATMENTS
   ============================================================ */
.menu-list{max-width:var(--maxw);margin:0 auto;list-style:none;border-top:1px solid var(--line)}
.menu-list__row{border-bottom:1px solid var(--line)}
.menu-list__row a{display:grid;grid-template-columns:1fr auto auto 2.4rem;align-items:center;gap:1.4rem;
  padding:clamp(1.5rem,3.4vw,2.6rem) .4rem;position:relative;transition:padding-left .5s var(--ease)}
.menu-list__row a::before{content:"";position:absolute;left:0;bottom:-1px;width:0;height:1px;
  background:linear-gradient(90deg,var(--teal),var(--cyan));transition:width .6s var(--ease)}
.menu-list__row:hover a{padding-left:1.4rem}
.menu-list__row:hover a::before{width:100%}
.menu-list__name{font-family:var(--serif);font-weight:300;font-size:clamp(1.5rem,3.4vw,2.6rem);line-height:1.1}
.menu-list__name em{display:block;font-family:var(--sans);font-style:normal;font-weight:400;
  font-size:.8rem;letter-spacing:.04em;text-transform:uppercase;color:var(--bone-faint);margin-top:.55rem}
.menu-list__time{font-size:.9rem;color:var(--bone-soft);font-variant-numeric:tabular-nums}
.menu-list__price{font-family:var(--serif);font-size:clamp(1.4rem,2.4vw,1.9rem);color:var(--teal);font-variant-numeric:tabular-nums}
.menu-list__arrow{font-size:1.3rem;color:var(--bone-faint);transition:transform .5s var(--ease),color .5s}
.menu-list__row:hover .menu-list__arrow{transform:translateX(6px);color:var(--cyan)}
.treatments__note{max-width:var(--maxw);margin:2.4rem auto 0;color:var(--bone-faint);font-size:.92rem;font-weight:300}

/* ============================================================
   STORIES
   ============================================================ */
.stories{overflow:hidden}
.stories__viewport{margin-top:1rem;cursor:grab}
.stories__viewport:active{cursor:grabbing}
.stories__track{display:flex;gap:1.4rem;padding:0 var(--pad);will-change:transform}
.quote{flex:0 0 min(86vw,460px);background:var(--ink-3);border:1px solid var(--line-soft);
  border-radius:6px;padding:clamp(1.8rem,3vw,2.6rem);display:flex;flex-direction:column;justify-content:space-between;gap:2rem;min-height:240px;
  transition:border-color .5s var(--ease),transform .5s var(--ease)}
.quote:hover{border-color:rgba(95,201,192,.35);transform:translateY(-4px)}
.quote blockquote{font-family:var(--serif);font-weight:300;font-size:clamp(1.2rem,2vw,1.5rem);line-height:1.4;color:var(--bone)}
.quote figcaption{font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--teal)}
.stories__hint{text-align:center;margin-top:2.2rem;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--bone-faint)}

/* ============================================================
   FAQ
   ============================================================ */
.faq__list{max-width:920px;margin:0 auto}
.faq__item{border-bottom:1px solid var(--line)}
.faq__item summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;
  padding:1.7rem .2rem;font-family:var(--serif);font-weight:300;font-size:clamp(1.2rem,2.4vw,1.7rem);color:var(--bone);transition:color .3s}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary:hover{color:var(--teal)}
.faq__icon{position:relative;width:18px;height:18px;flex:none}
.faq__icon::before,.faq__icon::after{content:"";position:absolute;background:var(--teal);transition:transform .4s var(--ease)}
.faq__icon::before{left:0;top:50%;width:100%;height:1.5px;transform:translateY(-50%)}
.faq__icon::after{left:50%;top:0;width:1.5px;height:100%;transform:translateX(-50%)}
.faq__item[open] .faq__icon::after,.faq__item.is-open .faq__icon::after{transform:translateX(-50%) scaleY(0)}
/* height is animated by JS with a soft spring; native details behavior
   remains intact for no-JS and reduced-motion visitors */
.faq__answer{overflow:hidden}
.faq__answer p{padding:0 .2rem 1.8rem;max-width:62ch;color:var(--bone-soft);font-weight:300;font-size:1.02rem;line-height:1.7}
.faq__answer a{color:var(--teal);text-decoration:underline;text-underline-offset:3px}

/* ============================================================
   VISIT / CTA
   ============================================================ */
.visit{text-align:center;background:
  radial-gradient(120% 90% at 50% 0%, rgba(16,46,76,.5), transparent 55%), var(--ink)}
.visit__inner{max-width:var(--maxw);margin:0 auto}
.visit__title{font-family:var(--serif);font-weight:300;line-height:.98;letter-spacing:-.015em;
  font-size:clamp(3.4rem,12vw,9rem);margin:.4rem 0 0}
.visit__title em{color:var(--teal);font-style:italic}
.visit__title .l{display:block;overflow:hidden}
.visit__title .l>span{display:block;will-change:transform}
.visit__copy{max-width:46ch;margin:2rem auto 0;color:var(--bone-soft);font-weight:300;font-size:clamp(1.02rem,1.5vw,1.22rem)}
.visit__actions{margin-top:2.6rem;display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}
.visit__details{margin-top:5rem;display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;
  max-width:840px;margin-left:auto;margin-right:auto;text-align:left;border-top:1px solid var(--line);padding-top:3rem}
.visit__details h4{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--teal);margin-bottom:1rem;font-weight:600}
.visit__details p,.visit__details address{font-style:normal;color:var(--bone-soft);font-weight:300;line-height:1.8;font-size:.98rem}
.visit__details a{transition:color .3s}
.visit__details a:hover{color:var(--cyan)}

/* ============================================================
   KEY FACTS (crawlable quick-answers strip)
   ============================================================ */
.facts{padding:clamp(3rem,7vh,5.5rem) var(--pad);border-top:1px solid var(--line-soft);background:var(--ink-2)}
.facts__grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:2rem}
.facts__grid dt{font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--teal);font-weight:600;margin-bottom:.8rem}
.facts__grid dd{color:var(--bone-soft);font-weight:300;font-size:.94rem;line-height:1.75}
.facts__grid dd a{color:var(--bone);text-decoration:underline;text-underline-offset:3px;text-decoration-color:rgba(95,201,192,.5)}
.facts__grid dd a:hover{color:var(--cyan)}
@media (max-width:1080px){.facts__grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.facts__grid{grid-template-columns:1fr;gap:1.6rem}}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{padding:3rem var(--pad) 0;border-top:1px solid var(--line-soft);background:var(--ink)}
.footer__top{max-width:1500px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;
  gap:1.5rem;flex-wrap:wrap;font-size:.82rem;color:var(--bone-faint)}
.footer__nav{display:flex;gap:1.6rem}
.footer__nav a{transition:color .3s}
.footer__nav a:hover{color:var(--teal)}
.footer__up{background:none;border:none;color:var(--bone-soft);cursor:pointer;font-size:.82rem;font-family:var(--sans);transition:color .3s}
.footer__up:hover{color:var(--teal)}
.footer__wordmark{text-align:center;overflow:hidden;line-height:.78;margin-top:1rem;will-change:transform}
.footer__wordmark span{font-family:var(--serif);font-weight:300;font-size:clamp(5rem,26vw,22rem);
  letter-spacing:-.02em;color:transparent;-webkit-text-stroke:1px var(--line);
  background:linear-gradient(180deg,rgba(95,201,192,.14),transparent 80%);-webkit-background-clip:text;background-clip:text;
  display:inline-block}

/* ============================================================
   REVEAL STATES (GSAP toggles)
   ============================================================ */
.reveal-line span,.reveal-words .w{display:inline-block}
.reveal-fade{opacity:0;transform:translateY(24px)}
.reveal-title{opacity:0;transform:translateY(28px)}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1080px){
  .benefits__grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:820px){
  .nav__links{display:none}
  .nav__burger{display:block}
  .nav__actions .btn--small{display:none}
  .method__row{grid-template-columns:1fr;gap:2.6rem}
  .visit__details{grid-template-columns:1fr;text-align:center;gap:2.4rem}
  .story__rail{display:none}
  .menu-list__row a{grid-template-columns:1fr auto;grid-template-areas:"name price" "meta arrow";row-gap:.4rem;column-gap:1rem}
  .menu-list__name{grid-area:name}
  .menu-list__price{grid-area:price;justify-self:end}
  .menu-list__time{grid-area:meta;align-self:center}
  .menu-list__arrow{grid-area:arrow;justify-self:end}
  .cap--open{bottom:clamp(6rem,20vh,10rem)}
}
@media (max-width:560px){
  .benefits__grid{grid-template-columns:1fr}
  .cap__cta{flex-direction:column;align-items:stretch}
  .cap__cta .btn{width:100%}
  .story__hint{display:none}
}

/* ============================================================
   REDUCED MOTION
   ============================================================ */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.001ms!important;scroll-behavior:auto!important}
  .reveal-fade,.reveal-title{opacity:1;transform:none}
  .story__hint i::after{display:none}
}
