/* ============================================================
   P-REJUVENATE AESTHETICS — Nurse-led medical aesthetics, Barry
   Luxury single-page site
   ============================================================ */

:root{
  --cream:#F4EEE4;
  --cream-soft:#EDE5D8;
  --paper:#FFFDF8;
  --ink:#3D3328;
  --ink-soft:#7B6E5D;
  --ink-faint:#A89A87;
  --rose:#C49C84;
  --rose-deep:#9E6F50;
  --blush:#E7D5C3;
  --blush-soft:#F2E7DB;
  --gold:#B7945F;
  --gold-soft:#D8BE92;
  --line:rgba(61,51,40,.14);
  --line-soft:rgba(61,51,40,.07);
  --shadow-sm:0 6px 24px rgba(61,51,40,.09);
  --shadow-md:0 18px 50px rgba(61,51,40,.14);
  --shadow-lg:0 40px 90px rgba(61,51,40,.22);
  --serif:"Cormorant Garamond",Georgia,"Times New Roman",serif;
  --sans:"Jost","Helvetica Neue",Arial,sans-serif;
  --ease:cubic-bezier(.22,.61,.36,1);
  --nav-h:78px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  background:var(--cream);
  color:var(--ink);
  font-weight:300;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:var(--rose);color:#fff}

/* ---------- typographic helpers ---------- */
.serif{font-family:var(--serif)}
.label{
  font-family:var(--sans);
  text-transform:uppercase;
  letter-spacing:.32em;
  font-size:.72rem;
  font-weight:500;
  color:var(--rose-deep);
}
.eyebrow{
  display:inline-flex;align-items:center;gap:.7em;
  text-transform:uppercase;letter-spacing:.3em;font-size:.72rem;font-weight:500;
  color:var(--rose-deep);
}
.eyebrow::before{content:"";width:34px;height:1px;background:var(--gold)}
.eyebrow.center::after{content:"";width:34px;height:1px;background:var(--gold)}
.eyebrow.center{justify-content:center}

h1,h2,h3{font-family:var(--serif);font-weight:500;line-height:1.04;letter-spacing:-.01em}
h2{font-size:clamp(2.2rem,5vw,3.9rem);color:var(--ink)}
h2 em{font-style:italic;background:linear-gradient(100deg,var(--rose-deep) 0%,var(--gold) 48%,var(--rose-deep) 100%);background-size:220% auto;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;animation:shimmer 7s linear infinite}
@keyframes shimmer{to{background-position:-220% center}}
p{color:var(--ink-soft)}
.lead{font-size:1.12rem;color:var(--ink-soft)}

.wrap{width:min(1240px,92vw);margin-inline:auto}
section{position:relative}
.sec-pad{padding:clamp(50px,6.5vw,92px) 0}

/* ---------- buttons ---------- */
/* ---- liquid glass buttons (Apple-Tahoe style: frosted lens + specular bevel) ---- */
.btn{
  position:relative;display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  padding:1.02em 2.1em;border-radius:100px;
  font-family:var(--sans);font-weight:500;font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;
  color:#fff;border:none;cursor:pointer;isolation:isolate;overflow:hidden;
  background:color-mix(in srgb, var(--ink) 58%, transparent);
  -webkit-backdrop-filter:blur(11px) saturate(155%);
  backdrop-filter:blur(11px) saturate(155%);
  text-shadow:0 1px 2px rgba(20,24,16,.3);
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb,#fff 16%,transparent),
    inset 1.8px 3px 0 -2px color-mix(in srgb,#fff 82%,transparent),
    inset -2px -2px 0 -2px color-mix(in srgb,#fff 55%,transparent),
    inset -3px -8px 1px -6px color-mix(in srgb,#fff 45%,transparent),
    inset 0 3px 5px -2px color-mix(in srgb,#000 22%,transparent),
    inset 2px -6.5px 1px -4px color-mix(in srgb,#000 12%,transparent),
    0 1px 5px 0 color-mix(in srgb,#000 12%,transparent),
    0 8px 22px -4px color-mix(in srgb,#000 22%,transparent);
  transition:transform .4s cubic-bezier(.2,.7,.3,1),box-shadow .45s var(--ease),background .4s var(--ease);
}
.btn>span{position:relative;z-index:2}
.btn::before{content:"";position:absolute;inset:0;z-index:1;border-radius:inherit;pointer-events:none;
  background:linear-gradient(115deg,transparent 28%,color-mix(in srgb,#fff 40%,transparent) 47%,transparent 62%);
  transform:translateX(-130%);transition:transform .85s var(--ease)}
.btn:hover::before{transform:translateX(130%)}
.btn:hover{transform:scale(1.035)}
.btn:active{transform:scale(.965)}
.btn--gold{background:color-mix(in srgb,var(--gold) 60%,transparent);color:#22301f;text-shadow:0 1px 1px rgba(255,255,255,.3)}
.btn--ghost{background:color-mix(in srgb,var(--paper) 12%,transparent);color:var(--ink);text-shadow:none}
.btn--light{background:color-mix(in srgb,var(--paper) 70%,transparent);color:var(--ink);text-shadow:none}
.btn--on-dark{color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.45)}
.btn--on-dark.btn--ghost{background:color-mix(in srgb,#fff 14%,transparent)}
.btn .arr{transition:transform .5s var(--ease)}
.btn:hover .arr{transform:translateX(4px)}

/* ============================================================
   ANNOUNCEMENT BAR
   ============================================================ */
.topbar{
  background:var(--ink);color:#efe4d8;
  font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;font-weight:400;
}
.topbar .wrap{display:flex;align-items:center;justify-content:center;gap:1.4em;
  padding:.55em 0;text-align:center;flex-wrap:wrap}
.topbar .dot{color:var(--gold)}
.topbar a{color:#fff;border-bottom:1px solid rgba(255,255,255,.4);padding-bottom:1px}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:sticky;top:0;z-index:100;
  height:var(--nav-h);
  display:flex;align-items:center;
  transition:background .5s var(--ease),box-shadow .5s var(--ease),height .4s var(--ease);
}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;width:min(1320px,94vw)}
.nav.scrolled{background:rgba(244,238,228,.86);backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--line-soft);height:66px}
.brand{display:flex;align-items:center;gap:.7em;line-height:1}
.brand .mark{width:38px;height:38px;flex:0 0 auto}
.brand .txt{display:flex;flex-direction:column;gap:.18em}
.brand .name{font-family:var(--serif);font-size:1.5rem;font-weight:600;letter-spacing:.16em;color:var(--ink)}
.brand .sub{font-size:.56rem;letter-spacing:.42em;text-transform:uppercase;color:var(--ink-soft);font-weight:400}
.nav-links{display:flex;align-items:center;gap:2.3em}
.nav-links a{font-size:.78rem;letter-spacing:.13em;text-transform:uppercase;color:var(--ink);position:relative;font-weight:400}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-7px;width:0;height:1px;background:var(--rose-deep);transition:width .4s var(--ease)}
.nav-links a:hover::after{width:100%}
.nav-links a.active{color:var(--rose-deep)}
.nav-links a.active::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:1.2em}
.nav-cta .btn{padding:.85em 1.6em}
.burger{display:none;width:30px;height:20px;position:relative;cursor:pointer;background:none;border:0}
.burger span{position:absolute;left:0;height:1.6px;width:100%;background:var(--ink);transition:.4s var(--ease)}
.burger span:nth-child(1){top:0}
.burger span:nth-child(2){top:9px}
.burger span:nth-child(3){top:18px}
.nav.open .burger span:nth-child(1){top:9px;transform:rotate(45deg)}
.nav.open .burger span:nth-child(2){opacity:0}
.nav.open .burger span:nth-child(3){top:9px;transform:rotate(-45deg)}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;min-height:94svh;
  margin-top:calc(-1 * var(--nav-h));
  padding:calc(var(--nav-h) + 1vh) 0 clamp(150px,21vh,220px);
  display:flex;align-items:center;overflow:hidden;
  background:var(--cream);
}
.hero__bg{position:absolute;inset:-24% 0 -8% 0;z-index:0;will-change:transform}
.hero__bg img{width:100%;height:100%;object-fit:cover;object-position:75% center;
  animation:heroZoom 24s ease-in-out infinite alternate;transform-origin:68% 48%}
.hero__content{will-change:transform,opacity}
.hero__scrim{position:absolute;inset:0;z-index:1;
  background:linear-gradient(100deg,rgba(244,238,228,.97) 0%,rgba(244,238,228,.86) 34%,rgba(244,238,228,.35) 55%,rgba(244,238,228,0) 78%);
}
.hero__scrim2{position:absolute;inset:0;z-index:1;background:linear-gradient(to top,rgba(244,238,228,.55),transparent 30%)}
.hero .wrap{position:relative;z-index:3;width:min(1240px,92vw)}
.hero__content{max-width:660px}
.hero__eyebrow{margin-bottom:1.6rem}
.hero h1{font-size:clamp(2.9rem,7.6vw,6rem);font-weight:500;color:var(--ink);letter-spacing:-.015em}
.hero h1 em{font-style:italic;background:linear-gradient(100deg,var(--rose-deep) 0%,var(--gold) 48%,var(--rose-deep) 100%);background-size:220% auto;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;animation:shimmer 7s linear infinite}
.hero h1 .thin{font-weight:300}
.hero__sub{margin:1.7rem 0 2.4rem;font-size:1.16rem;max-width:30em;color:var(--ink-soft)}
.hero__actions{display:flex;align-items:center;gap:1.2em;flex-wrap:wrap}
.hero__rating{display:flex;align-items:center;gap:.9em;margin-top:2.6rem}
.hero__rating .stars{color:var(--gold);letter-spacing:.15em;font-size:1.05rem}
.hero__rating .txt{font-size:.82rem;color:var(--ink-soft);letter-spacing:.04em}
.hero__rating .txt b{color:var(--ink);font-weight:500}

/* floating glass card */
.float-card{
  position:absolute;z-index:3;background:rgba(255,253,250,.72);
  backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.6);
  border-radius:18px;padding:1.1em 1.3em;box-shadow:var(--shadow-md);
}
.float-card.fc1{right:6%;top:24%;animation:floaty 7s ease-in-out infinite}
.float-card.fc2{right:13%;bottom:15%;animation:floaty 8s ease-in-out infinite .6s}
.float-card .big{font-family:var(--serif);font-size:1.9rem;font-weight:600;color:var(--ink);line-height:1}
.float-card .small{font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);margin-top:.4em}
.float-card .stars{color:var(--gold);font-size:.85rem;letter-spacing:.1em}

.scroll-cue{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:3;
  display:flex;flex-direction:column;align-items:center;gap:.7em;color:var(--ink-soft)}
.scroll-cue span{font-size:.6rem;letter-spacing:.3em;text-transform:uppercase}
.scroll-cue .line{width:1px;height:46px;background:linear-gradient(var(--rose-deep),transparent);position:relative;overflow:hidden}
.scroll-cue .line::after{content:"";position:absolute;top:-50%;left:0;width:100%;height:50%;background:var(--ink);animation:scrolldot 2.2s var(--ease) infinite}

/* hero staggered entrance */
.anim-up{opacity:0;transform:translateY(34px);transition:opacity 1.1s var(--ease),transform 1.1s var(--ease)}
.hero.loaded .anim-up{opacity:1;transform:none}
.anim-up.d1{transition-delay:.12s}
.anim-up.d2{transition-delay:.24s}
.anim-up.d3{transition-delay:.36s}
.anim-up.d4{transition-delay:.48s}
.anim-up.d5{transition-delay:.6s}
.float-card{opacity:0;transition:opacity 1.2s var(--ease) .7s}
.hero.loaded .float-card{opacity:1}
.scroll-cue{opacity:0;transition:opacity 1.2s var(--ease) 1s}
.hero.loaded .scroll-cue{opacity:1}

@keyframes heroZoom{0%{transform:scale(1.04) translate(0,0)}100%{transform:scale(1.14) translate(-1.5%,-1%)}}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}
@keyframes scrolldot{0%{top:-50%}100%{top:100%}}

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee{background:var(--ink);color:var(--cream);overflow:hidden;padding:1.15em 0;border-top:1px solid rgba(255,255,255,.06)}
.marquee__track{display:flex;width:max-content;animation:marq 38s linear infinite}
.marquee:hover .marquee__track{animation-play-state:paused}
.marquee__track span{font-family:var(--serif);font-style:italic;font-size:1.6rem;padding:0 1.1em;display:inline-flex;align-items:center;gap:1.2em;white-space:nowrap;color:#efe4d8}
.marquee__track span::after{content:"✦";font-style:normal;font-size:.7rem;color:var(--gold)}
@keyframes marq{to{transform:translateX(-50%)}}

/* ============================================================
   STATS
   ============================================================ */
.stats{background:var(--cream-soft)}
.stats .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line-soft);
  border:1px solid var(--line-soft);border-radius:20px;overflow:hidden}
.stat{background:var(--cream-soft);padding:1.9em 1.2em;text-align:center}
.stat .num{font-family:var(--serif);font-size:clamp(2.4rem,5vw,3.4rem);font-weight:600;color:var(--ink);line-height:1}
.stat .num .suf{color:var(--rose-deep)}
.stat .cap{margin-top:.6em;font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft)}

/* ============================================================
   ABOUT
   ============================================================ */
.about .grid{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(1.6rem,4vw,4rem);align-items:center}
.about__media{position:relative}
.about__media .frame{border-radius:220px 220px 24px 24px;overflow:hidden;box-shadow:var(--shadow-md);aspect-ratio:4/5}
.about__media .frame img{width:100%;height:100%;object-fit:cover}
.about__media .badge{
  position:absolute;left:-26px;bottom:34px;background:var(--paper);
  border-radius:50%;width:128px;height:128px;display:grid;place-items:center;text-align:center;
  box-shadow:var(--shadow-md);border:1px solid var(--line-soft);animation:spin 26s linear infinite}
.about__media .badge .inner{font-family:var(--serif);font-style:italic;font-size:1rem;color:var(--rose-deep);line-height:1.1}
.about__media .badge .est{font-family:var(--sans);font-size:.55rem;letter-spacing:.25em;text-transform:uppercase;color:var(--ink-soft);margin-top:.3em}
@keyframes spin{to{transform:rotate(360deg)}}
.about__body h2{margin:1.1rem 0 1.4rem}
.about__body .lead{margin-bottom:1.3rem}
.about__body p+p{margin-top:1rem}
.sign{margin-top:2rem;font-family:var(--serif);font-style:italic;font-size:1.7rem;color:var(--ink)}
.sign small{display:block;font-family:var(--sans);font-style:normal;font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);margin-top:.4em}
.about__list{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:.8em 1.6em;margin:1.8rem 0 2rem}
.about__list li{display:flex;align-items:center;gap:.7em;font-size:.92rem;color:var(--ink)}
.about__list li::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--gold);flex:0 0 auto}

/* ============================================================
   TREATMENTS
   ============================================================ */
.treat{background:var(--cream-soft)}
.sec-head{text-align:center;max-width:680px;margin:0 auto clamp(1.7rem,3vw,2.6rem)}
.sec-head h2{margin:1.1rem 0 1rem}
.sec-head p{font-size:1.05rem}
.treat__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem}
.tcard{position:relative;border-radius:18px;overflow:hidden;background:var(--ink);box-shadow:var(--shadow-sm);
  transition:transform .6s var(--ease),box-shadow .6s var(--ease);min-height:430px;display:flex}
.tcard img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease),filter .6s var(--ease)}
.tcard::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(38,30,22,.86) 6%,rgba(38,30,22,.18) 55%,rgba(38,30,22,.05))}
.tcard__body{position:relative;z-index:2;margin-top:auto;padding:1.7em 1.6em 1.8em;color:#fff}
.tcard__num{font-family:var(--serif);font-style:italic;font-size:.95rem;color:var(--gold-soft);opacity:.9}
.tcard h3{font-size:1.6rem;color:#fff;margin:.25em 0 .5em;font-weight:500}
.tcard p{font-size:.86rem;color:rgba(255,255,255,.78);line-height:1.55;max-height:0;opacity:0;overflow:hidden;transition:max-height .6s var(--ease),opacity .5s var(--ease),margin .6s var(--ease)}
.tcard .from{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-soft);margin-top:.9em;display:inline-block}
.tcard:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.tcard:hover img{transform:scale(1.08)}
.tcard:hover p{max-height:120px;opacity:1;margin-top:.2em}

/* ============================================================
   EXPERIENCE / WHY (parallax band)
   ============================================================ */
.why{position:relative;color:#fff;overflow:hidden}
.why__bg{position:absolute;inset:-12% 0;z-index:0}
.why__bg img{width:100%;height:100%;object-fit:cover}
.why::before{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(110deg,rgba(38,30,22,.9),rgba(38,30,22,.55) 60%,rgba(38,30,22,.78))}
.why .wrap{position:relative;z-index:2}
.why__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.6rem,4vw,4rem);align-items:center}
.why h2{color:#fff}
.why h2 em{color:var(--gold-soft)}
.why p.lead{color:rgba(255,255,255,.8)}
.why__feats{list-style:none;display:grid;gap:1.1em;margin-top:.5rem}
.why__feats li{display:flex;gap:1.1em;padding:1.1em 1.3em;border:1px solid rgba(255,255,255,.14);border-radius:14px;background:rgba(255,255,255,.04);backdrop-filter:blur(4px)}
.why__feats .ic{flex:0 0 auto;width:40px;height:40px;border-radius:50%;display:grid;place-items:center;background:rgba(217,188,140,.16);color:var(--gold-soft)}
.why__feats h4{font-family:var(--sans);font-weight:500;font-size:.95rem;letter-spacing:.02em;color:#fff;margin-bottom:.2em}
.why__feats p{font-size:.82rem;color:rgba(255,255,255,.7);margin:0}

/* ============================================================
   PRICING
   ============================================================ */
.pricing .price-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.4rem,3vw,2.6rem) clamp(2.2rem,5vw,4.5rem)}
.price-col h3{font-size:1.05rem;font-family:var(--sans);font-weight:500;letter-spacing:.22em;text-transform:uppercase;
  color:var(--rose-deep);padding-bottom:1em;margin-bottom:1.1em;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:.7em}
.price-col h3 .ic{color:var(--gold)}
.price-row{display:flex;align-items:baseline;gap:1em;padding:.85em 0;border-bottom:1px dashed var(--line-soft)}
.price-row .nm{font-family:var(--serif);font-size:1.28rem;color:var(--ink);font-weight:500}
.price-row .nm small{display:block;font-family:var(--sans);font-size:.72rem;letter-spacing:.04em;color:var(--ink-faint);font-weight:300;margin-top:.1em;text-transform:none}
.price-row .dots{flex:1;border-bottom:1px dotted var(--line);transform:translateY(-4px)}
.price-row .pr{font-family:var(--serif);font-size:1.3rem;color:var(--rose-deep);font-weight:600;white-space:nowrap}
.price-note{margin-top:2.6rem;text-align:center;font-size:.86rem;color:var(--ink-faint)}
.price-cta{margin-top:1.4rem;text-align:center}

/* ============================================================
   BOOKING
   ============================================================ */
.booking{position:relative;overflow:hidden;background:linear-gradient(165deg,var(--blush-soft) 0%,var(--cream-soft) 46%)}
.booking__glow{position:absolute;width:560px;height:560px;border-radius:50%;top:-220px;right:-140px;
  background:radial-gradient(circle,rgba(183,148,95,.26),transparent 65%);filter:blur(20px);z-index:0}
.booking .wrap{position:relative;z-index:1}
.booking__grid{display:grid;grid-template-columns:1.02fr .98fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}

.booking__steps{list-style:none;display:grid;gap:1.1em}
.booking__steps li{display:flex;gap:1.1em;align-items:flex-start}
.booking__steps .n{flex:0 0 auto;width:42px;height:42px;border-radius:50%;display:grid;place-items:center;
  font-family:var(--serif);font-size:1.25rem;font-weight:600;color:#fff;background:linear-gradient(135deg,var(--rose),var(--gold));box-shadow:var(--shadow-sm)}
.booking__steps h4{font-family:var(--sans);font-weight:500;font-size:1.02rem;color:var(--ink);margin-bottom:.15em}
.booking__steps p{font-size:.9rem;margin:0}

.booking__tiles-lbl{display:block;margin:2.1rem 0 1rem;font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-soft)}
.booking__tiles{display:grid;grid-template-columns:1fr 1fr;gap:.9rem}
.bk-tile{display:flex;flex-direction:column;gap:.12em;padding:1.05em 1.2em;border-radius:14px;background:var(--paper);
  border:1px solid var(--line-soft);box-shadow:var(--shadow-sm);position:relative;transition:transform .45s var(--ease),box-shadow .45s var(--ease),border-color .45s}
.bk-tile__nm{font-family:var(--serif);font-size:1.32rem;font-weight:500;color:var(--ink)}
.bk-tile__sub{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--rose-deep)}
.bk-tile .arr{position:absolute;top:1.1em;right:1.2em;color:var(--ink-faint);transition:transform .45s var(--ease),color .45s}
.bk-tile:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--blush)}
.bk-tile:hover .arr{transform:translateX(4px);color:var(--rose-deep)}

.booking__card{background:var(--paper);border:1px solid var(--line-soft);border-radius:24px;padding:1.7em;box-shadow:var(--shadow-lg)}
.bk-card__top{display:flex;align-items:center;justify-content:space-between;gap:1em;padding-bottom:1.2em;border-bottom:1px solid var(--line-soft)}
.bk-card__brand{display:flex;align-items:center;gap:.7em}
.bk-card__brand .mark{width:42px;height:42px;flex:0 0 auto}
.bk-card__title{display:flex;flex-direction:column;line-height:1.25}
.bk-card__title strong{font-family:var(--serif);font-size:1.15rem;font-weight:600;color:var(--ink);letter-spacing:.02em}
.bk-card__title span{font-size:.72rem;color:var(--ink-soft)}
.bk-card__live{display:inline-flex;align-items:center;gap:.5em;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;
  color:#2f8f5b;background:rgba(52,168,83,.1);padding:.45em .8em;border-radius:100px;font-weight:500;white-space:nowrap}
.bk-card__live i{width:7px;height:7px;border-radius:50%;background:#34A853;animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(52,168,83,.5)}70%{box-shadow:0 0 0 7px rgba(52,168,83,0)}100%{box-shadow:0 0 0 0 rgba(52,168,83,0)}}

.bk-cal{margin:1.3em 0}
.bk-cal__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:.9em}
.bk-cal__head span{font-family:var(--serif);font-size:1.15rem;font-weight:600;color:var(--ink)}
.bk-cal__head button{width:30px;height:30px;border-radius:50%;border:1px solid var(--line);background:transparent;
  color:var(--ink);cursor:pointer;font-size:1.05rem;line-height:1;display:grid;place-items:center;transition:.3s var(--ease)}
.bk-cal__head button:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.bk-cal__dow{display:grid;grid-template-columns:repeat(7,1fr);gap:.3em;margin-bottom:.5em}
.bk-cal__dow span{text-align:center;font-size:.62rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint)}
.bk-cal__grid{display:grid;grid-template-columns:repeat(7,1fr);gap:.3em}
.bk-day{position:relative;aspect-ratio:1;display:grid;place-items:center;border-radius:9px;font-size:.86rem;color:var(--ink);cursor:pointer;
  transition:background .3s var(--ease),color .3s var(--ease);border:1px solid transparent}
.bk-day.is-empty{visibility:hidden;pointer-events:none}
.bk-day.is-past{color:var(--ink-faint);opacity:.4;cursor:default;pointer-events:none}
.bk-day.has-slot::after{content:"";position:absolute;bottom:5px;width:4px;height:4px;border-radius:50%;background:var(--gold)}
.bk-day:not(.is-past):not(.is-today):hover{background:var(--blush-soft);border-color:var(--blush)}
.bk-day.is-today{background:linear-gradient(135deg,var(--rose),var(--gold));color:#fff;font-weight:500}
.bk-day.is-today.has-slot::after{background:#fff}

.bk-slots{margin-bottom:1.3em}
.bk-slots__lbl{display:block;font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:.6em}
.bk-slots__row{display:flex;flex-wrap:wrap;gap:.5em}
.bk-slot{padding:.5em .9em;border-radius:100px;border:1px solid var(--line);font-size:.82rem;color:var(--ink);transition:.3s var(--ease)}
.bk-slot:hover{background:var(--ink);color:#fff;border-color:var(--ink);transform:translateY(-2px)}
.bk-card__cta{width:100%;justify-content:center;margin-bottom:1em}
.bk-card__note{display:flex;align-items:center;justify-content:center;gap:.5em;font-size:.74rem;color:var(--ink-faint);text-align:center}
.bk-card__note svg{color:var(--gold);flex:0 0 auto}

/* ============================================================
   GALLERY
   ============================================================ */
.gallery{background:var(--cream-soft)}
.gal-grid{display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:200px;gap:1rem}
.gal-grid figure{position:relative;overflow:hidden;border-radius:14px;background:var(--ink)}
.gal-grid img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease)}
.gal-grid figure::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(38,30,22,.4),transparent 50%);opacity:0;transition:opacity .5s}
.gal-grid figcaption{position:absolute;left:1.1em;bottom:.9em;z-index:2;color:#fff;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;
  opacity:0;transform:translateY(8px);transition:.5s var(--ease)}
.gal-grid figure:hover img{transform:scale(1.08)}
.gal-grid figure:hover::after{opacity:1}
.gal-grid figure:hover figcaption{opacity:1;transform:none}
.g-a{grid-column:span 2;grid-row:span 2}
.g-b{grid-column:span 2;grid-row:span 1}
.g-c{grid-column:span 2;grid-row:span 2}
.g-d{grid-column:span 2;grid-row:span 1}
.g-e{grid-column:span 3;grid-row:span 1}
.g-f{grid-column:span 3;grid-row:span 1}

/* ============================================================
   REVIEWS
   ============================================================ */
.reviews .rev-top{display:flex;align-items:flex-end;justify-content:space-between;gap:2rem;flex-wrap:wrap;margin-bottom:3rem}
.gbadge{display:flex;align-items:center;gap:1em;background:var(--paper);border:1px solid var(--line-soft);
  border-radius:16px;padding:1em 1.4em;box-shadow:var(--shadow-sm)}
.gbadge .g{font-family:var(--serif);font-weight:700;font-size:1.5rem}
.gbadge .g .b{color:#4285F4}.gbadge .g .r{color:#EA4335}.gbadge .g .y{color:#FBBC05}.gbadge .g .g2{color:#34A853}
.gbadge .meta .stars{color:var(--gold);letter-spacing:.1em}
.gbadge .meta .sub{font-size:.74rem;color:var(--ink-soft);letter-spacing:.05em}
.gbadge .meta b{font-family:var(--serif);font-size:1.05rem;color:var(--ink)}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
.rcard{background:var(--paper);border:1px solid var(--line-soft);border-radius:18px;padding:2em 1.9em;box-shadow:var(--shadow-sm);
  display:flex;flex-direction:column;transition:transform .5s var(--ease),box-shadow .5s var(--ease)}
.rcard:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.rcard .stars{color:var(--gold);letter-spacing:.15em;font-size:.95rem}
.rcard .quote{font-family:var(--serif);font-size:1.28rem;line-height:1.45;color:var(--ink);margin:1em 0 1.4em;font-weight:500}
.rcard .who{display:flex;align-items:center;gap:.8em;margin-top:auto}
.rcard .av{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;font-family:var(--serif);font-weight:600;
  color:#fff;background:linear-gradient(135deg,var(--rose),var(--gold));font-size:1.05rem}
.rcard .who .nm{font-weight:500;font-size:.9rem;color:var(--ink)}
.rcard .who .src{font-size:.72rem;color:var(--ink-faint)}

/* ============================================================
   VISIT / CONTACT
   ============================================================ */
.visit{background:var(--ink);color:var(--cream)}
.visit h2{color:#fff}
.visit h2 em{color:var(--gold-soft)}
.visit .grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:stretch}
.visit .info .eyebrow{color:var(--gold-soft)}
.visit .info .eyebrow::before{background:var(--gold-soft)}
.info-list{list-style:none;margin-top:2.2rem;display:grid;gap:1.5em}
.info-list li{display:flex;gap:1.1em;padding-bottom:1.5em;border-bottom:1px solid rgba(255,255,255,.1)}
.info-list .ic{flex:0 0 auto;width:44px;height:44px;border-radius:12px;display:grid;place-items:center;
  background:rgba(217,188,140,.14);color:var(--gold-soft)}
.info-list .lbl{font-size:.68rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold-soft);margin-bottom:.3em}
.info-list .val{color:#fff;font-size:1rem;line-height:1.5}
.info-list .val a:hover{color:var(--gold-soft)}
.hours-line{display:flex;justify-content:space-between;gap:1.5em;max-width:320px;color:rgba(255,255,255,.85);font-size:.92rem;padding:.15em 0}
.visit__cta{display:flex;gap:1em;flex-wrap:wrap;margin-top:2.4rem}
.map-card{border-radius:20px;overflow:hidden;box-shadow:var(--shadow-lg);border:1px solid rgba(255,255,255,.1);min-height:420px;position:relative}
.map-card iframe{width:100%;height:100%;min-height:420px;border:0;filter:grayscale(.3) sepia(.12) saturate(1.05)}

/* ============================================================
   FINAL CTA
   ============================================================ */
.cta-band{position:relative;text-align:center;overflow:hidden;background:linear-gradient(120deg,var(--blush-soft),var(--cream) 60%,var(--blush))}
.cta-band .glow{position:absolute;width:520px;height:520px;border-radius:50%;
  background:radial-gradient(circle,rgba(183,148,95,.35),transparent 65%);filter:blur(20px)}
.cta-band .glow.a{top:-160px;left:-80px}
.cta-band .glow.b{bottom:-200px;right:-60px;background:radial-gradient(circle,rgba(200,156,124,.3),transparent 65%)}
.cta-band .wrap{position:relative;z-index:2}
.cta-band h2{font-size:clamp(2.4rem,6vw,4.6rem)}
.cta-band p{max-width:34em;margin:1.4rem auto 2.4rem;font-size:1.1rem}
.cta-band .actions{display:flex;gap:1.1em;justify-content:center;flex-wrap:wrap}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:#2A2118;color:#c4cbb2;padding:3.4rem 0 2rem}
.footer .grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:2.5rem;padding-bottom:3rem;border-bottom:1px solid rgba(255,255,255,.08)}
.footer .brand .name{color:#fff}
.footer .brand .sub{color:var(--gold-soft)}
.footer .fdesc{margin-top:1.3rem;font-size:.9rem;color:#a99d87;max-width:30ch}
.footer h5{font-family:var(--sans);font-weight:500;font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold-soft);margin-bottom:1.3rem}
.footer ul{list-style:none;display:grid;gap:.7em}
.footer ul a,.footer ul li{font-size:.9rem;color:#cabea9;transition:color .3s}
.footer ul a:hover{color:#fff}
.socials{display:flex;gap:.7em;margin-top:.3rem}
.socials a{width:40px;height:40px;border-radius:50%;border:1px solid rgba(255,255,255,.16);display:grid;place-items:center;color:#cbb9ab;transition:.4s var(--ease)}
.socials a:hover{background:var(--gold);color:#2A2118;border-color:var(--gold);transform:translateY(-3px)}
.foot-bot{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;padding-top:1.8rem;font-size:.78rem;color:#8f8473}
.foot-bot a{color:#cabea9}
.foot-bot a:hover{color:#fff}

/* ============================================================
   REVEAL ANIMATIONS
   ============================================================ */
.reveal{opacity:0;transform:translateY(38px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}
.reveal.d4{transition-delay:.32s}.reveal.d5{transition-delay:.4s}.reveal.d6{transition-delay:.48s}
.reveal-x{opacity:0;transform:translateX(-44px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal-x.in{opacity:1;transform:none}

/* progress + to-top */
.progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:200;
  background:linear-gradient(90deg,var(--rose-deep),var(--gold))}
.totop{position:fixed;right:24px;bottom:24px;z-index:120;width:48px;height:48px;border-radius:50%;
  background:var(--ink);color:#fff;display:grid;place-items:center;cursor:pointer;border:0;
  opacity:0;transform:translateY(20px) scale(.8);transition:.5s var(--ease);box-shadow:var(--shadow-md)}
.totop.show{opacity:1;transform:none}
.totop:hover{background:var(--rose-deep)}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1080px){
  .nav-links{display:none}
  .burger{display:block}
  .treat__grid{grid-template-columns:repeat(2,1fr)}
  .gal-grid{grid-template-columns:repeat(4,1fr)}
  .g-e,.g-f{grid-column:span 2}
}
@media (max-width:880px){
  :root{--nav-h:66px}
  .about .grid,.why__grid,.visit .grid,.booking__grid{grid-template-columns:1fr}
  .booking__card{max-width:460px;margin:0 auto;width:100%}
  .pricing .price-grid{grid-template-columns:1fr}
  .rev-grid{grid-template-columns:1fr}
  .stats .grid{grid-template-columns:repeat(2,1fr)}
  .float-card{display:none}
  .hero__scrim{background:linear-gradient(180deg,rgba(244,238,228,.7),rgba(244,238,228,.92) 60%,var(--cream))}
  .about__media{max-width:420px;margin:0 auto}
  .footer .grid{grid-template-columns:1fr 1fr}
  /* mobile menu panel */
  .nav-links.show{display:flex;position:absolute;top:var(--nav-h);left:0;right:0;flex-direction:column;
    background:var(--cream-soft);padding:1.6em 7vw 2em;gap:1.3em;box-shadow:var(--shadow-md);align-items:flex-start}
  .nav-links.show a{font-size:.95rem}
}
@media (max-width:560px){
  .topbar .wrap span:nth-child(n+4){display:none}
  .gal-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:150px}
  .g-a,.g-c{grid-row:span 2}
  .about__list{grid-template-columns:1fr}
  .footer .grid{grid-template-columns:1fr}
  .hero__actions .btn{width:100%;justify-content:center}
}

@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  .hero__bg img{animation:none}
  .reveal,.reveal-x{opacity:1;transform:none}
}

/* ============================================================
   HERO 3  (centered + darkened + bottom image reel)
   ============================================================ */
.hero__dark{position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(180deg, rgba(34,27,20,.60) 0%, rgba(34,27,20,.46) 36%, rgba(34,27,20,.64) 76%, rgba(38,30,22,.94) 100%),
    radial-gradient(120% 78% at 50% 28%, rgba(34,27,20,.22), rgba(34,27,20,.66));
}
.hero .wrap{position:relative;z-index:3;width:min(1100px,92vw)}
.hero__content{max-width:720px;margin:0 auto;text-align:center}
.hero h1{color:#fff;font-size:clamp(2.3rem,5.2vw,4.05rem);line-height:1.06}
.hero h1 .thin{color:rgba(255,255,255,.9)}
.hero__sub{color:rgba(255,255,255,.82);font-size:.98rem;line-height:1.6;margin:1.1rem auto 1.7rem;max-width:34em}
.hero__actions{justify-content:center}
.hero__pill{display:inline-flex;align-items:center;gap:.6em;margin-bottom:1.6rem;
  padding:.62em 1.25em;border-radius:100px;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;font-weight:500;
  color:rgba(255,255,255,.92);background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);
  -webkit-backdrop-filter:blur(10px) saturate(140%);backdrop-filter:blur(10px) saturate(140%)}
.hero__pill-stars{color:var(--gold-soft);letter-spacing:.1em}

.hero__reel{position:absolute;left:0;bottom:0;width:100%;height:min(25vh,205px);z-index:2;overflow:hidden;display:flex;align-items:flex-end;
  -webkit-mask-image:linear-gradient(to bottom,transparent,#000 30%,#000 86%,transparent),linear-gradient(to right,transparent,#000 7%,#000 93%,transparent);
  mask-image:linear-gradient(to bottom,transparent,#000 30%,#000 86%,transparent),linear-gradient(to right,transparent,#000 7%,#000 93%,transparent);
  -webkit-mask-composite:source-in;mask-composite:intersect}
.hero__reel-track{display:flex;gap:0;padding:0 0 1.5rem;width:max-content;animation:heroReel 46s linear infinite}
.hero:hover .hero__reel-track{animation-play-state:paused}
.hero__reel-track img{height:clamp(100px,14vh,160px);aspect-ratio:3/4;object-fit:cover;border-radius:14px;flex:0 0 auto;margin-right:1rem;
  box-shadow:0 16px 36px rgba(0,0,0,.42);border:1px solid rgba(255,255,255,.14)}
.hero__reel-track img:nth-child(odd){transform:rotate(-3deg)}
.hero__reel-track img:nth-child(even){transform:rotate(4deg) translateY(10px)}
@keyframes heroReel{to{transform:translateX(-50%)}}

/* nav legible over the dark hero (transparent state) */
.nav:not(.scrolled) .nav-links a{color:#fff}
.nav:not(.scrolled) .nav-links a::after{background:#fff}
.nav:not(.scrolled) .brand .name{color:#fff}
.nav:not(.scrolled) .brand .sub{color:rgba(255,255,255,.72)}
.nav:not(.scrolled) .burger span{background:#fff}

/* ============================================================
   SCROLL REEL TESTIMONIALS
   ============================================================ */
.reel{position:relative;display:flex;flex-direction:column;gap:0;overflow:hidden;border-radius:22px;
  border:1px solid var(--line-soft);background:var(--cream-soft);box-shadow:var(--shadow-md);min-height:330px}
@media(min-width:880px){.reel{flex-direction:row}}
.reel__viewport{position:relative;height:230px;width:100%;flex:0 0 auto;overflow:hidden}
@media(min-width:880px){.reel__viewport{height:auto;width:400px;align-self:stretch}}
.reel__viewport{
  -webkit-mask-image:linear-gradient(to right,transparent,#000 14%,#000 86%,transparent),linear-gradient(to bottom,transparent,#000 10%,#000 90%,transparent);
  mask-image:linear-gradient(to right,transparent,#000 14%,#000 86%,transparent),linear-gradient(to bottom,transparent,#000 10%,#000 90%,transparent);
  -webkit-mask-composite:source-in;mask-composite:intersect}
.reel__cols{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;gap:8px}
.reel__col{display:flex;flex-direction:column;gap:8px;flex:0 0 auto;will-change:transform;
  transition:transform 800ms cubic-bezier(.65,0,.35,1)}
.reel-cell{width:118px;height:118px;flex:0 0 auto;border-radius:14px;border:1px solid var(--line-soft);
  background:linear-gradient(to bottom,var(--blush-soft),var(--paper));filter:blur(1px);
  box-shadow:0 1px 2px rgba(44,51,38,.06),inset 0 2px 0 rgba(255,255,255,.9)}
.reel-feat{position:relative;width:118px;height:118px;flex:0 0 auto;border-radius:14px;overflow:hidden;background:var(--blush);
  box-shadow:0 10px 24px -6px rgba(44,51,38,.3),inset 0 1px 0 rgba(255,255,255,.7)}
.reel-feat img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 30%}
.reel-feat::after{content:"";position:absolute;inset:0;mix-blend-mode:overlay;filter:blur(6px);
  background:linear-gradient(220deg,rgba(200,156,124,0) 32%,rgba(200,156,124,.9) 42%,rgba(216,190,146,.9) 48%,rgba(183,148,95,.5) 55%,rgba(183,148,95,0) 66%)}
.reel__content{display:flex;flex:1;min-width:0;flex-direction:column;justify-content:space-between;padding:1.8em 1.6em 1.6em}
.reel__quoteicon{width:40px;height:40px;color:var(--gold);opacity:.45;margin-bottom:.4em}
.reel__stage{position:relative;min-height:130px}
.reel__quote{font-family:var(--serif);font-size:clamp(1.3rem,2vw,1.7rem);font-weight:500;line-height:1.32;color:var(--ink);margin:0 0 .6em}
.reel__author{font-size:.85rem;font-weight:500;color:var(--ink-soft);margin:0}
.reel__char{display:inline-block;opacity:0;transform:translateY(0.5em);animation:reelRise .5s var(--ease) forwards}
@keyframes reelRise{to{opacity:1;transform:none}}
.reel__stage.is-exiting .reel__quote,.reel__stage.is-exiting .reel__author{opacity:0;transform:translateY(-8px);transition:opacity .24s ease,transform .24s ease}
.reel__controls{display:flex;align-items:center;gap:.9em;margin-top:1.4em}
.reel__controls button{width:34px;height:34px;border-radius:50%;border:1px solid var(--line);background:transparent;color:var(--ink);
  cursor:pointer;display:grid;place-items:center;font-size:1rem;transition:.3s var(--ease)}
.reel__controls button:hover:not(:disabled){background:var(--ink);color:#fff;border-color:var(--ink);transform:scale(1.08)}
.reel__controls button:disabled{opacity:.35;cursor:default}
.reel__count{font-size:.8rem;letter-spacing:.1em;color:var(--ink-faint)}
.reel__count b{font-family:var(--serif);font-size:1rem;color:var(--ink)}

/* ============================================================
   CARD FAN CAROUSEL (gallery)
   ============================================================ */
.fan{position:relative;display:flex;flex-direction:column;align-items:center;gap:1rem}
.fan__layout{position:relative;width:100%;height:clamp(290px,33vw,395px);display:flex;align-items:center;justify-content:center}
.fan-card{position:absolute;top:50%;left:50%;width:clamp(190px,21vw,300px);aspect-ratio:3/4;border-radius:20px;overflow:hidden;
  margin:-0px 0 0 0;transform-origin:center bottom;cursor:grab;
  box-shadow:0 24px 50px -12px rgba(34,27,20,.45);border:3px solid #fff;
  transition:transform .6s cubic-bezier(.2,.8,.25,1.2),opacity .45s var(--ease)}
.fan-card img{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none}
.fan-card::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(34,27,20,.32),transparent 45%)}
.fan__controls{display:flex;align-items:center;gap:1.1em;z-index:5}
.fan__controls button{width:46px;height:46px;border-radius:50%;cursor:pointer;display:grid;place-items:center;color:var(--ink);
  border:1px solid var(--line);background:color-mix(in srgb,var(--paper) 40%,transparent);
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:.3s var(--ease);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.4),0 6px 16px rgba(34,27,20,.12)}
.fan__controls button:hover{transform:scale(1.08);color:#fff;background:var(--ink);border-color:var(--ink)}
.fan__dots{display:flex;gap:.5em}
.fan__dots span{width:8px;height:8px;border-radius:50%;background:var(--line);transition:.3s var(--ease)}
.fan__dots span.on{background:var(--rose-deep);transform:scale(1.35)}

/* pull gallery + reviews up (less top whitespace) */
.gallery{padding-top:clamp(12px,1.8vw,26px)}
.reviews{padding-top:clamp(12px,1.8vw,26px)}
.gallery .sec-head,.reviews .sec-head{margin-bottom:clamp(1rem,2vw,1.6rem)}
