/* ═══════════════════════════════════════════════════════════
   Thai Silk Canary Wharf — Shared Design System
   ═══════════════════════════════════════════════════════════ */

/* ── TOKENS ── */
:root {
  /* Dark backgrounds — deep crimson/wine */
  --navy:          #120407;
  --royal:         #1E080C;
  --royal-mid:     #2C1018;
  --royal-light:   #3A1820;

  /* Light / pearl warm backgrounds */
  --cream:         #FDF3EE;
  --cream-mid:     #F5E2D8;
  --cream-deep:    #EDD0C0;
  --parchment:     #F0DDD0;

  /* Light Burgundy — primary accent */
  --gold:          #9B2D48;
  --gold-lt:       #C95070;
  --gold-pale:     #FAE8ED;
  --gold-deep:     #651828;
  --gold-glow:     rgba(155,45,72,0.36);
  --gold-soft:     rgba(155,45,72,0.10);
  --gold-border:   rgba(155,45,72,0.26);

  /* Whimsical accents */
  --orange:        #FF6B2C;
  --orange-lt:     #FF9052;
  --orange-glow:   rgba(255,107,44,0.30);
  --orange-soft:   rgba(255,107,44,0.10);

  --pink:          #FF1860;
  --pink-lt:       #FF6090;
  --pink-glow:     rgba(255,24,96,0.28);
  --pink-soft:     rgba(255,24,96,0.08);

  /* Silk Red — second accent */
  --cyan:          #C80030;
  --cyan-lt:       #F0004A;
  --cyan-glow:     rgba(200,0,48,0.28);
  --cyan-soft:     rgba(200,0,48,0.08);

  --red:           #FF1E4C;

  /* Text — on dark */
  --td:            #F5ECED;
  --md:            #A09098;
  --dd:            #5A4045;

  /* Text — on light */
  --tl:            #1A0A0E;
  --ml:            #6B3C42;
  --dl:            #B07880;

  /* Lines */
  --lined:         rgba(155,45,72,0.18);
  --lined-s:       rgba(155,45,72,0.32);
  --linel:         rgba(140,0,30,0.16);
  --linel-s:       rgba(140,0,30,0.28);

  /* Shadows */
  --shadow:        0 24px 64px rgba(0,0,0,0.65);
  --shadow-gold:   0 16px 48px rgba(155,45,72,0.22);
  --shadow-light:  0 8px 32px rgba(140,0,30,0.12);

  /* Layout */
  --radius:        16px;
  --content:       1200px;

  /* Fonts */
  --ffh:  'Raleway', system-ui, sans-serif;
  --ffs:  'Playfair Display', Georgia, serif;
  --ffb:  'Lato', system-ui, sans-serif;
}

/* ── RESET ── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0 }
html { scroll-behavior:smooth; overflow-x:hidden }
body {
  background:var(--navy);
  color:var(--td);
  font-family:var(--ffb);
  font-weight:400;
  line-height:1.7;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img { display:block; max-width:100% }
a  { color:inherit; text-decoration:none }
button { border:0; background:none; font:inherit; cursor:pointer; color:inherit }
ul { list-style:none }
::selection { background:var(--gold); color:var(--navy) }

/* ── MATERIAL ICONS ── */
.icon {
  font-family:'Material Symbols Rounded';
  font-variation-settings:'FILL' 0,'wght' 300,'GRAD' 0,'opsz' 24;
  font-weight:normal; font-style:normal;
  line-height:1; letter-spacing:normal; text-transform:none;
  white-space:nowrap; display:inline-block;
  -webkit-font-smoothing:antialiased; vertical-align:middle;
}
.icon.fill { font-variation-settings:'FILL' 1,'wght' 400,'GRAD' 0,'opsz' 24 }

/* ── KEYFRAMES ── */
@keyframes cyanFlow    { 0%{background-position:0% center} 100%{background-position:200% center} }
@keyframes kenBurns    { from{transform:scale(1)} to{transform:scale(1.08)} }
@keyframes aurora      { 0%,100%{opacity:.55;transform:scale(1) translate(0,0)} 50%{opacity:.85;transform:scale(1.04) translate(1%,-1%)} }
@keyframes floatOrb    { 0%,100%{transform:translateY(0) scale(1)} 50%{transform:translateY(-18px) scale(1.04)} }
@keyframes stripScroll { from{transform:translateX(0)} to{transform:translateX(-50%)} }
@keyframes pinPing     { 0%{transform:scale(1);opacity:.8} 80%,100%{transform:scale(2.5);opacity:0} }
@keyframes glowPulse   { 0%,100%{box-shadow:0 0 16px var(--gold-glow)} 50%{box-shadow:0 0 40px var(--gold-glow),0 0 80px rgba(155,45,72,0.12)} }
@keyframes shimmer     { 0%{background-position:-200% center} 100%{background-position:200% center} }
@keyframes sparkle     { 0%,100%{opacity:0;transform:scale(0)} 50%{opacity:.7;transform:scale(1)} }

/* ── LAYOUT ── */
.shell { width:min(var(--content),calc(100% - 3rem)); margin:0 auto; position:relative; z-index:1 }

/* ── REVEAL ── */
[data-reveal]   { opacity:0; transform:translateY(26px); transition:opacity .7s ease,transform .7s ease }
[data-reveal].vis { opacity:1; transform:none }
[data-reveal-l] { opacity:0; transform:translateX(-28px); transition:opacity .75s ease,transform .75s ease }
[data-reveal-l].vis { opacity:1; transform:none }
[data-reveal-r] { opacity:0; transform:translateX(28px); transition:opacity .75s ease,transform .75s ease }
[data-reveal-r].vis { opacity:1; transform:none }

/* ── CYAN GRADIENT TEXT ── */
.text-gold {
  background:linear-gradient(135deg,var(--gold-deep) 0%,var(--gold-lt) 40%,var(--gold) 60%,var(--gold-lt) 80%,var(--gold-deep) 100%);
  background-size:200% auto;
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  animation:cyanFlow 5s ease infinite;
}

/* ── SECTION DECORATORS ── */
.ornament {
  display:flex; align-items:center; gap:14px; margin-bottom:12px;
}
.ornament::before,.ornament::after {
  content:''; flex:1; height:1px;
  background:linear-gradient(90deg,transparent,var(--gold-border),transparent);
}
.ornament-text {
  font-family:var(--ffh); font-weight:700; text-transform:uppercase;
  letter-spacing:.22em; font-size:.72rem; white-space:nowrap; color:var(--gold);
}
.ornament.light .ornament-text { color:var(--gold-deep) }
.ornament.light::before,.ornament.light::after { background:linear-gradient(90deg,transparent,var(--linel-s),transparent) }

.kicker {
  display:block; font-family:var(--ffh); font-size:.78rem; font-weight:700;
  letter-spacing:.28em; text-transform:uppercase; color:var(--gold); margin-bottom:10px;
}
.kicker.dark-sec { color:var(--gold-deep) }
.kicker.accent-pink { color:var(--pink-lt) }
.kicker.accent-cyan { color:var(--cyan-lt) }
.kicker.accent-orange { color:var(--orange-lt) }

.section-title {
  font-family:var(--ffs); font-weight:700;
  font-size:clamp(2rem,4.5vw,3.4rem); line-height:1.06; letter-spacing:.01em;
  margin-bottom:1rem;
}
.section-title.on-dark { color:#fff }
.section-title.on-light {
  background:linear-gradient(135deg,var(--tl) 0%,#3A1820 100%);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.section-copy { font-size:1rem; line-height:1.9; max-width:600px }
.section-copy.on-dark { color:var(--md) }
.section-copy.on-light { color:var(--ml) }

/* ── WAVE DIVIDERS ── */
.wave-dtl,.wave-ltd { line-height:0; position:relative; z-index:2 }
.wave-dtl { background:var(--navy) }
.wave-ltd { background:var(--cream) }
.wave-dtl svg,.wave-ltd svg { width:100%; display:block }

/* ── BUTTONS ── */
.btn-gold {
  display:inline-flex; align-items:center; gap:8px; padding:13px 30px;
  background:linear-gradient(135deg,var(--gold-deep),var(--gold-lt),var(--gold));
  background-size:200% auto;
  color:var(--navy); font-family:var(--ffh); font-size:.74rem; font-weight:800;
  letter-spacing:.18em; text-transform:uppercase; border:none; cursor:pointer;
  border-radius:var(--radius); box-shadow:0 8px 24px var(--gold-glow);
  transition:transform .2s,box-shadow .2s,background-position .4s;
}
.btn-gold:hover { transform:translateY(-3px); background-position:right center; box-shadow:0 14px 40px var(--gold-glow) }

.btn-gold-outline {
  display:inline-flex; align-items:center; gap:8px; padding:12px 28px;
  background:transparent; color:var(--gold-lt);
  font-family:var(--ffh); font-size:.74rem; font-weight:700;
  letter-spacing:.18em; text-transform:uppercase;
  border:2px solid var(--gold-border); cursor:pointer; border-radius:var(--radius);
  transition:background .2s,color .2s,border-color .2s,box-shadow .2s;
}
.btn-gold-outline:hover { background:var(--gold-soft); border-color:var(--gold); box-shadow:0 8px 28px var(--gold-glow); color:var(--gold-lt) }

.btn-navy {
  display:inline-flex; align-items:center; gap:8px; padding:12px 28px;
  background:var(--navy); color:var(--gold-lt);
  font-family:var(--ffh); font-size:.74rem; font-weight:700;
  letter-spacing:.18em; text-transform:uppercase;
  border:2px solid var(--gold-border); cursor:pointer; border-radius:var(--radius);
  transition:background .2s,box-shadow .2s;
}
.btn-navy:hover { background:var(--royal); box-shadow:0 8px 28px var(--gold-glow) }

/* accent buttons */
.btn-pink {
  display:inline-flex; align-items:center; gap:8px; padding:12px 28px;
  background:transparent; color:var(--pink-lt);
  font-family:var(--ffh); font-size:.74rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase;
  border:2px solid var(--pink); cursor:pointer; border-radius:var(--radius);
  transition:background .2s,color .2s,box-shadow .2s;
}
.btn-pink:hover { background:var(--pink); color:#fff; box-shadow:0 8px 28px var(--pink-glow) }

.btn-cyan {
  display:inline-flex; align-items:center; gap:8px; padding:12px 28px;
  background:transparent; color:var(--cyan-lt);
  font-family:var(--ffh); font-size:.74rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase;
  border:2px solid var(--cyan); cursor:pointer; border-radius:var(--radius);
  transition:background .2s,color .2s,box-shadow .2s;
}
.btn-cyan:hover { background:var(--cyan); color:#fff; box-shadow:0 8px 28px var(--cyan-glow) }

/* ── STRIPE ── */
.stripe { height:5px; background:repeating-linear-gradient(90deg,var(--gold-deep) 0,var(--gold) 33%,var(--gold-lt) 66%,var(--gold-deep) 100%); background-size:36px 5px }

/* ── NAV ── */
#nav {
  position:fixed; top:0; left:0; right:0; z-index:1000; height:70px;
  background:rgba(18,4,7,.96); backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(155,45,72,0.14);
  display:flex; align-items:center;
  transition:box-shadow .3s,border-color .3s;
}
#nav.scrolled { box-shadow:0 4px 32px rgba(0,0,0,.7),0 0 0 1px rgba(155,45,72,.12); border-color:rgba(155,45,72,.28) }

.nav-in {
  display:flex; align-items:center; justify-content:space-between;
  width:min(var(--content),calc(100% - 3rem)); margin:0 auto;
}

.nav-logo { display:flex; align-items:center; gap:12px; text-decoration:none }
.nav-lotus {
  font-family:'Material Symbols Rounded';
  font-variation-settings:'FILL' 1,'wght' 400,'GRAD' 0,'opsz' 24;
  font-size:1.75rem; font-weight:normal; font-style:normal; line-height:1;
  letter-spacing:normal; text-transform:none; white-space:nowrap;
  -webkit-font-smoothing:antialiased;
  background:linear-gradient(135deg,var(--gold-deep),var(--gold-lt));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}

.nav-wordmark { line-height:1.1 }
.nav-brand {
  font-family:var(--ffs); font-style:italic; font-weight:600; font-size:1.22rem;
  letter-spacing:.03em;
  background:linear-gradient(135deg,var(--gold-deep) 0%,var(--gold-lt) 40%,var(--gold) 60%,var(--gold-lt) 80%,var(--gold-deep) 100%);
  background-size:200% auto;
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  animation:cyanFlow 6s ease infinite;
  display:block;
}
.nav-tagline {
  font-family:var(--ffh); font-size:.54rem; font-weight:700;
  letter-spacing:.22em; text-transform:uppercase;
  color:rgba(155,45,72,.48); display:block;
}
.nav-cw {
  color:var(--gold-lt);
  text-shadow:0 0 10px rgba(201,80,112,.85),0 0 22px rgba(155,45,72,.5),0 0 40px rgba(155,45,72,.25);
}

.nav-links { display:flex; align-items:center; gap:24px }
.nav-links a {
  font-family:var(--ffh); font-size:.7rem; font-weight:600;
  letter-spacing:.1em; text-transform:uppercase;
  color:rgba(245,236,237,.6); transition:color .2s;
}
.nav-links a:hover,
.nav-links a.active { color:var(--gold-lt) }

.nav-book {
  padding:9px 22px;
  background:linear-gradient(135deg,var(--gold-deep),var(--gold));
  color:var(--navy); font-family:var(--ffh); font-size:.7rem; font-weight:800;
  letter-spacing:.16em; text-transform:uppercase; border:none; border-radius:var(--radius);
  box-shadow:0 4px 16px var(--gold-glow); transition:transform .2s,box-shadow .2s; cursor:pointer;
}
.nav-book:hover { transform:translateY(-2px); box-shadow:0 8px 28px var(--gold-glow) }

.nav-burger { display:none; flex-direction:column; gap:5px; padding:6px; cursor:pointer }
.nav-burger span { width:22px; height:2px; background:var(--gold-lt); transition:all .25s; border-radius:2px }
@media(max-width:860px) { .nav-links{display:none} .nav-burger{display:flex} }

/* ── MOBILE MENU ── */
#mobileMenu {
  position:fixed; top:70px; left:0; right:0; z-index:999;
  background:rgba(18,4,7,.98); backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(155,45,72,.14);
  padding:24px; transform:translateY(-110%); transition:transform .3s ease;
  display:flex; flex-direction:column; gap:14px;
}
#mobileMenu.open { transform:none }
#mobileMenu a {
  font-family:var(--ffh); font-size:.88rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase;
  color:rgba(245,236,237,.75); padding:10px 0; border-bottom:1px solid rgba(155,45,72,.1);
}
#mobileMenu .nav-book { width:100%; justify-content:center; margin-top:8px; border-radius:var(--radius) }

/* ── PAGE HERO BANNER (sub-pages) ── */
.page-banner {
  position:relative; min-height:52vh; display:flex; align-items:flex-end;
  padding-top:70px; overflow:hidden;
}
.page-banner-bg { position:absolute; inset:0; z-index:0 }
.page-banner-bg img { width:100%; height:100%; object-fit:cover; filter:brightness(.22) saturate(.4) }
.page-banner-overlay {
  position:absolute; inset:0; z-index:1;
  background:linear-gradient(135deg,rgba(18,4,7,.94) 0%,rgba(18,4,7,.52) 55%,rgba(18,4,7,.88) 100%);
}
.page-banner-overlay::before {
  content:''; position:absolute; left:0; top:0; bottom:0; width:4px;
  background:linear-gradient(180deg,var(--gold-deep),var(--gold-lt),var(--gold-deep));
}
.page-banner-inner { position:relative; z-index:2; padding:4rem 0 3.5rem }
.page-banner-breadcrumb {
  display:flex; align-items:center; gap:8px;
  font-family:var(--ffh); font-size:.62rem; font-weight:600; letter-spacing:.18em;
  text-transform:uppercase; color:rgba(155,45,72,.48); margin-bottom:1.2rem;
}
.page-banner-breadcrumb a:hover { color:var(--gold-lt) }
.page-banner-breadcrumb span { color:rgba(155,45,72,.28) }
.page-banner-eyebrow {
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--ffh); font-size:.62rem; font-weight:700; letter-spacing:.3em;
  text-transform:uppercase; color:var(--gold-lt); margin-bottom:1rem;
}
.page-banner-eyebrow::before { content:''; width:28px; height:1px; background:currentColor; opacity:.5 }
.page-banner-title {
  font-family:var(--ffs); font-weight:700; font-size:clamp(2.4rem,6vw,5rem);
  line-height:1.0; letter-spacing:.01em; color:#fff; margin-bottom:.9rem;
}
.page-banner-title .t-gold { color:var(--gold-lt) }
.page-banner-sub { font-size:1rem; color:rgba(245,236,237,.65); max-width:580px; line-height:1.85 }

/* ── LIGHT SECTION ── */
.sec-light {
  background:var(--cream);
  position:relative; z-index:1;
}
.sec-light-warm {
  background:var(--cream-mid);
  position:relative; z-index:1;
}
.sec-light::before,
.sec-light-warm::before {
  content:''; position:absolute; inset:0; pointer-events:none;
  background:
    radial-gradient(ellipse 55% 40% at 100% 0%,  rgba(155,45,72,0.06) 0%,transparent 60%),
    radial-gradient(ellipse 40% 35% at 0%  100%, rgba(155,45,72,0.04) 0%,transparent 55%),
    radial-gradient(ellipse 65% 55% at 12% 20%,  rgba(255,107,44,0.22) 0%,transparent 65%),
    radial-gradient(ellipse 50% 45% at 88% 80%,  rgba(255,140,50,0.18) 0%,transparent 62%);
}
/* Decorative lotus corner */
.sec-light .lotus-corner,
.sec-light-warm .lotus-corner {
  position:absolute; opacity:.05; pointer-events:none; font-family:'Material Symbols Rounded';
  font-variation-settings:'FILL' 1,'wght' 300,'GRAD' 0,'opsz' 24;
  font-size:180px; line-height:1; color:var(--cyan);
  font-weight:normal; font-style:normal; white-space:nowrap;
  -webkit-font-smoothing:antialiased;
}
.sec-light .lotus-corner.tl { top:-30px; left:-20px }
.sec-light .lotus-corner.br { bottom:-30px; right:-20px; transform:rotate(180deg) }

/* ── DARK SECTION ── */
.sec-dark {
  background:var(--navy); position:relative; z-index:1;
}
.sec-dark::before {
  content:''; position:absolute; inset:0; pointer-events:none;
  background:
    radial-gradient(ellipse 50% 40% at 15% 20%,rgba(200,0,48,0.05) 0%,transparent 60%),
    radial-gradient(ellipse 45% 35% at 85% 80%,rgba(155,45,72,0.04) 0%,transparent 55%),
    radial-gradient(ellipse 35% 30% at 50% 50%,rgba(255,24,96,0.03) 0%,transparent 50%);
}

.sec-royal { background:var(--royal); position:relative; z-index:1 }
.sec-royal::before {
  content:''; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(ellipse 50% 40% at 50% 0%,rgba(155,45,72,0.06) 0%,transparent 60%);
}

/* ── CARD BASE ── */
.card-dark {
  background:linear-gradient(160deg,rgba(44,16,24,.6),rgba(18,4,7,.9));
  border:1px solid var(--lined); border-radius:var(--radius);
  transition:transform .25s,border-color .25s,box-shadow .25s;
}
.card-dark:hover { transform:translateY(-5px); border-color:var(--gold-border); box-shadow:var(--shadow-gold) }

.card-light {
  background:rgba(255,255,255,0.75);
  border:1px solid var(--linel); border-radius:var(--radius);
  box-shadow:var(--shadow-light);
  transition:transform .25s,border-color .25s,box-shadow .25s;
}
.card-light:hover { transform:translateY(-4px); border-color:rgba(155,45,72,.3); box-shadow:0 12px 40px rgba(155,45,72,.14) }

/* ── FOOTER ── */
#footer { padding:52px 0 28px; background:var(--royal); border-top:1px solid rgba(155,45,72,.1) }
.foot-in { display:grid; grid-template-columns:1.5fr 1fr 1fr; gap:3rem }
@media(max-width:680px){ .foot-in{grid-template-columns:1fr} }

.foot-logo-wrap { display:flex; align-items:center; gap:10px; margin-bottom:12px }
.foot-lotus {
  font-family:'Material Symbols Rounded'; font-variation-settings:'FILL' 1,'wght' 400,'GRAD' 0,'opsz' 24;
  font-size:1.5rem; font-weight:normal; font-style:normal; line-height:1;
  letter-spacing:normal; text-transform:none; white-space:nowrap; -webkit-font-smoothing:antialiased;
  background:linear-gradient(135deg,var(--gold-deep),var(--gold-lt));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.foot-name-brand {
  font-family:var(--ffs); font-style:italic; font-weight:600; font-size:1.05rem;
  background:linear-gradient(135deg,var(--gold-deep),var(--gold-lt),var(--gold));
  background-size:200% auto;
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  animation:cyanFlow 7s ease infinite;
}
.foot-desc { font-size:.8rem; color:rgba(245,236,237,.38); line-height:1.75; max-width:260px; margin-bottom:1rem }
.foot-socs { display:flex; gap:8px }
.fsoc {
  width:32px; height:32px; border:1px solid rgba(155,45,72,.18);
  display:flex; align-items:center; justify-content:center;
  color:rgba(155,45,72,.38); transition:all .2s; border-radius:6px;
}
.fsoc:hover { border-color:var(--gold); color:var(--gold-lt); box-shadow:0 0 12px var(--gold-glow) }

.foot-h { font-family:var(--ffh); font-size:.57rem; font-weight:700; letter-spacing:.24em; text-transform:uppercase; color:var(--gold); margin-bottom:1rem }
.foot-links { display:flex; flex-direction:column; gap:.6rem }
.foot-links a { font-size:.82rem; color:rgba(245,236,237,.42); transition:color .2s }
.foot-links a:hover { color:var(--gold-lt) }
.foot-bar {
  margin-top:3rem; padding-top:1.4rem; border-top:1px solid rgba(155,45,72,.08);
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:.5rem;
}
.foot-copy { font-size:.72rem; color:var(--dd) }

/* ── RESPONSIVE ── */
@media(max-width:860px) {
  .page-banner-title { font-size:clamp(2rem,7vw,3.4rem) }
}

/* ── STRAIGHT SECTION SEPARATOR ── */
.section-sep {
  height:2px; position:relative; z-index:2;
  background:linear-gradient(90deg,transparent 0%,var(--gold-soft) 15%,var(--gold-border) 50%,var(--gold-soft) 85%,transparent 100%);
}

/* ── BANNER SLIDESHOW ── */
.banner-slides { position:absolute; inset:0; z-index:0; overflow:hidden }
.banner-slide {
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  filter:brightness(.22) saturate(.4);
  opacity:0; transition:opacity 1.5s ease;
}
.banner-slide.active { opacity:1 }
.page-banner-logo-wrap { margin-bottom:1.4rem }
.page-banner-logo-img { max-height:180px; width:auto; display:block; }

/* ── HORIZONTAL TREATMENT CARDS ── */
.treat-hcard {
  display:flex; align-items:stretch;
  border-radius:var(--radius); overflow:hidden;
  margin-bottom:1.5rem;
  transition:box-shadow .25s,transform .2s;
}
.treat-hcard-light {
  background:rgba(255,255,255,0.82);
  border:1px solid var(--linel);
  box-shadow:var(--shadow-light);
}
.treat-hcard-light:hover { transform:translateY(-3px); box-shadow:0 16px 48px rgba(155,45,72,0.18) }
.treat-hcard-dark {
  background:linear-gradient(160deg,rgba(44,16,24,.6),rgba(18,4,7,.9));
  border:1px solid var(--lined);
}
.treat-hcard-dark:hover { transform:translateY(-3px); box-shadow:0 16px 48px rgba(155,45,72,0.28); border-color:var(--gold-border) }
.treat-hcard-img {
  width:300px; min-width:240px; flex-shrink:0; position:relative;
}
.treat-hcard-img img {
  width:100%; height:100%; object-fit:cover; display:block;
}
.treat-hcard-body {
  padding:2rem 2.2rem; flex:1; min-width:0;
  display:flex; flex-direction:column; justify-content:center;
}
@media(max-width:780px) {
  .treat-hcard { flex-direction:column }
  .treat-hcard-img { width:100%; height:220px; min-width:unset }
}

/* ── HORIZONTAL PRICING CARDS ── */
.pricing-hstack { display:flex; flex-direction:column; gap:1rem; max-width:860px; margin:0 auto }
.phcard {
  display:flex; align-items:center; gap:2rem;
  background:linear-gradient(160deg,rgba(44,16,24,.6),rgba(18,4,7,.9));
  border:1px solid var(--lined); border-radius:var(--radius);
  padding:1.6rem 2rem; position:relative; overflow:hidden;
  transition:transform .25s,box-shadow .25s,border-color .25s;
}
.phcard:hover { transform:translateX(4px); box-shadow:0 8px 32px var(--gold-glow); border-color:var(--gold-border) }
.phcard.pc-warm { border-color:rgba(200,0,48,.3) }
.phcard.pc-warm:hover { box-shadow:0 8px 32px var(--cyan-glow) }
.phcard.pc-glow { border-color:rgba(255,107,44,.25) }
.phcard.pc-glow:hover { box-shadow:0 8px 32px var(--orange-glow) }
.phcard.featured { border-color:rgba(155,45,72,.5); box-shadow:0 0 0 1px rgba(155,45,72,.15) }
.phcard .price-bg {
  position:absolute; inset:0; transform:scale(1.1);
  background-size:cover; background-position:center;
  filter:blur(8px) brightness(.45); z-index:0; pointer-events:none;
}
.phcard .price-overlay {
  position:absolute; inset:0;
  background:linear-gradient(90deg,rgba(18,4,7,.88),rgba(30,8,12,.6));
  z-index:1; pointer-events:none;
}
.phcard > *:not(.price-bg):not(.price-overlay) { position:relative; z-index:2 }
.phcard::before { content:''; position:absolute; top:0; left:0; bottom:0; width:4px; border-radius:var(--radius) 0 0 var(--radius); z-index:3 }
.phcard.pc-gold::before { background:linear-gradient(180deg,var(--gold-deep),var(--gold-lt),var(--gold-deep)) }
.phcard.pc-warm::before { background:linear-gradient(180deg,#8A001E,var(--cyan-lt),#8A001E) }
.phcard.pc-glow::before { background:linear-gradient(180deg,#B03010,var(--orange-lt),#B03010) }
.phcard-left { text-align:center; min-width:90px; flex-shrink:0 }
.phcard-mins { font-family:var(--ffs); font-size:3.2rem; font-weight:700; color:#fff; line-height:1 }
.phcard-unit { font-family:var(--ffh); font-size:.62rem; font-weight:600; letter-spacing:.18em; text-transform:uppercase; color:var(--md) }
.phcard-badge { display:inline-flex; align-items:center; gap:5px; padding:.3rem .75rem; border-radius:20px; margin-top:.5rem; font-family:var(--ffh); font-size:.68rem; font-weight:800; letter-spacing:.14em; text-transform:uppercase }
.phcard.pc-gold .phcard-badge { background:var(--gold-soft); color:var(--gold-lt); border:1px solid var(--gold-border) }
.phcard.pc-warm .phcard-badge { background:rgba(200,0,48,.15); color:var(--cyan-lt); border:1px solid rgba(200,0,48,.35) }
.phcard.pc-glow .phcard-badge { background:rgba(255,107,44,.12); color:var(--orange-lt); border:1px solid rgba(255,107,44,.32) }
.phcard-mid { flex:1; display:grid; grid-template-columns:1fr 1fr; gap:.6rem 1.5rem }
.phcard-price-item { display:flex; justify-content:space-between; align-items:center; padding:.5rem .8rem; background:rgba(255,255,255,.04); border:1px solid var(--lined); border-radius:8px }
.phcard-svc { font-size:.82rem; color:var(--md); display:flex; align-items:center; gap:5px }
.phcard-amt { font-family:var(--ffs); font-size:1.05rem; font-weight:600; color:var(--gold-lt) }
.phcard.pc-warm .phcard-amt { color:var(--cyan-lt) }
.phcard.pc-glow .phcard-amt { color:var(--orange-lt) }
.phcard-right { flex-shrink:0 }
.phcard .btn-gold { white-space:nowrap }
.phcard.pc-warm .btn-gold { background:linear-gradient(135deg,#8A001E,var(--cyan-lt),var(--cyan)); box-shadow:0 8px 24px var(--cyan-glow) }
.phcard.pc-glow .btn-gold { background:linear-gradient(135deg,#B03010,var(--orange-lt),var(--orange)); color:#fff; box-shadow:0 8px 24px var(--orange-glow) }
@media(max-width:680px) {
  .phcard { flex-direction:column; align-items:flex-start; gap:1rem }
  .phcard-left { display:flex; align-items:baseline; gap:.5rem; min-width:unset }
  .phcard-mid { grid-template-columns:1fr; width:100% }
  .phcard-right { width:100% }
  .phcard .btn-gold { width:100%; justify-content:center }
}
