/* ============================================================
   OPULENCE BEAUTY — Inner page styles
   ============================================================ */

/* ---- Page hero ---- */
.page-hero{ position:relative; min-height:62vh; display:flex; align-items:flex-end; overflow:hidden; padding-top:clamp(108px,14vh,150px); padding-bottom:clamp(40px,6vw,72px); }
.page-hero.tall{ min-height:78vh; }
.page-hero-media{ position:absolute; inset:0; z-index:0; }
.page-hero-media img{ width:100%; height:118%; object-fit:cover; position:absolute; top:-9%; }
.page-hero-veil{ position:absolute; inset:0; z-index:1; background:
  linear-gradient(180deg, rgba(10,9,8,0.62) 0%, rgba(10,9,8,0.30) 38%, rgba(10,9,8,0.78) 82%, var(--ink) 100%),
  linear-gradient(95deg, rgba(10,9,8,0.55), transparent 60%); }
.page-hero .wrap{ position:relative; z-index:2; }
.page-hero .eyebrow{ margin-bottom:22px; }
.page-hero h1{ margin:0 0 18px; }
.page-hero .lead{ max-width:52ch; }
.crumb{ font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; color:var(--cream-mute); margin-bottom:30px; }
.crumb a:hover{ color:var(--gold); }
.crumb span{ color:var(--gold); }

/* ---- Section heads ---- */
.shead{ max-width:680px; margin-bottom:clamp(40px,6vw,72px); }
.shead.center{ margin-inline:auto; text-align:center; }
.shead .eyebrow{ margin-bottom:20px; }
.shead h2{ margin-bottom:18px; }

/* ---- Intro split ---- */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,7vw,96px); align-items:center; }
.split.lean{ grid-template-columns:1.1fr 0.9fr; }
.split .media{ aspect-ratio:4/5; }
.split .media.wide{ aspect-ratio:4/3; }
.split .body h2{ margin-bottom:22px; }
.split .body .lead{ margin-bottom:20px; }
.split.flip .media{ order:2; }

/* ---- Pricing menu ---- */
.menu-group{ margin-bottom:clamp(46px,6vw,72px); }
.menu-group:last-child{ margin-bottom:0; }
.menu-group-head{ display:flex; align-items:baseline; gap:18px; margin-bottom:30px; padding-bottom:18px; border-bottom:1px solid var(--line); }
.menu-group-head h3{ font-size:clamp(1.5rem,3vw,2.1rem); }
.menu-group-head .gh-meta{ font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color:var(--cream-mute); margin-left:auto; white-space:nowrap; }
.menu-row{ display:grid; grid-template-columns:1fr auto; gap:14px 24px; align-items:baseline; padding:16px 0; border-bottom:1px solid var(--line-soft); }
.menu-row:last-child{ border-bottom:none; }
.menu-row .mr-name{ font-family:var(--font-display); font-size:1.45rem; color:var(--cream); line-height:1.2; }
.menu-row .mr-desc{ font-size:.92rem; color:var(--cream-mute); margin-top:3px; max-width:52ch; }
.menu-row .mr-price{ font-family:var(--font-display); font-size:1.5rem; color:var(--gold); white-space:nowrap; text-align:right; }
.menu-row .mr-time{ display:block; font-family:var(--font-sans); font-size:.66rem; letter-spacing:.16em; text-transform:uppercase; color:var(--cream-faint); margin-top:4px; }

/* tier cards grid */
.tier-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:22px; }
.tier .t-top{ display:flex; justify-content:space-between; align-items:flex-start; gap:16px; margin-bottom:14px; }
.tier .t-price-wrap{ text-align:right; }
.tier .t-desc{ color:var(--cream-dim); font-size:.96rem; margin:14px 0 0; }
.tier .t-tag{ display:inline-block; white-space:nowrap; font-size:.64rem; letter-spacing:.22em; text-transform:uppercase; color:var(--gold); border:1px solid var(--line); border-radius:100px; padding:5px 12px; margin-bottom:18px; }
.tier .t-list{ list-style:none; padding:0; margin:18px 0 0; }
.tier .t-list li{ display:flex; gap:10px; align-items:flex-start; padding:7px 0; font-size:.92rem; color:var(--cream-dim); border-top:1px solid var(--line-soft); }
.tier .t-list li:first-child{ border-top:none; }
.tier .t-list li::before{ content:""; width:5px; height:5px; border-radius:50%; background:var(--gold); margin-top:9px; flex:none; }

/* policy / addon panels */
.panel{ border:1px solid var(--line); border-radius:5px; background:linear-gradient(180deg,rgba(27,23,18,0.5),rgba(16,14,11,0.3)); padding:clamp(28px,4vw,44px); }
.panel h3{ font-size:1.5rem; margin-bottom:18px; }
.addon-list{ display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:14px 30px; list-style:none; padding:0; margin:0; }
.addon-list li{ display:flex; justify-content:space-between; gap:14px; padding:12px 0; border-bottom:1px solid var(--line-soft); font-size:.96rem; }
.addon-list li b{ color:var(--gold); font-weight:400; font-family:var(--font-display); font-size:1.2rem; }
.fineprint{ font-size:.82rem; color:var(--cream-mute); line-height:1.7; }
.fineprint b{ color:var(--gold-soft); font-weight:400; }

/* steps */
.steps{ display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:30px; }
.step{ position:relative; padding-top:28px; }
.step .s-num{ font-family:var(--font-display); font-size:1rem; letter-spacing:.2em; color:var(--gold); margin-bottom:14px; display:block; }
.step::before{ content:""; position:absolute; top:0; left:0; width:46px; height:1px; background:var(--gold); }
.step h4{ font-family:var(--font-display); font-size:1.4rem; font-weight:400; margin:0 0 10px; color:var(--cream); }
.step p{ font-size:.94rem; color:var(--cream-mute); margin:0; }

/* show-whole helper: never crops, mattes on black (seamless on dark site) */
.frame.whole img, .media.whole img{ object-fit:contain !important; background:var(--ink); transform:none !important; }
.split .media.whole{ aspect-ratio:auto; }

/* gallery strip */
.gallery{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.gallery .frame{ aspect-ratio:3/4; }
.gallery .frame img{ transition:transform 1s var(--ease-out); }
.gallery .frame:hover img{ transform:scale(1.06); }

/* before/after */
.ba{ position:relative; overflow:hidden; border-radius:4px; cursor:ew-resize; aspect-ratio:4/3; user-select:none; }
.ba img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.ba .ba-top{ z-index:2; clip-path:inset(0 50% 0 0); }
.ba .ba-handle{ position:absolute; top:0; bottom:0; left:50%; width:2px; background:var(--gold); z-index:3; transform:translateX(-1px); }
.ba .ba-handle::after{ content:"⟷"; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:42px; height:42px; border-radius:50%; background:var(--ink); border:1px solid var(--gold); color:var(--gold); display:flex; align-items:center; justify-content:center; font-size:.8rem; }
.ba .ba-tag{ position:absolute; bottom:14px; z-index:4; font-size:.6rem; letter-spacing:.2em; text-transform:uppercase; color:var(--cream); background:rgba(10,9,8,0.6); padding:5px 12px; border-radius:100px; backdrop-filter:blur(6px); }
.ba .ba-tag.l{ left:14px; } .ba .ba-tag.r{ right:14px; }

/* CTA band */
.cta-band{ position:relative; overflow:hidden; text-align:center; padding-block:clamp(80px,12vw,150px); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.cta-band .cta-orb{ position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:60vmin; height:60vmin; border-radius:50%; background:radial-gradient(circle,var(--gold-glow),transparent 62%); filter:blur(22px); z-index:0; }
.cta-band .wrap{ position:relative; z-index:2; }
.cta-band h2{ margin:18px 0 24px; }

@media (max-width:860px){
  .split, .split.lean{ grid-template-columns:1fr; gap:32px; }
  .split.flip .media{ order:-1; }
  .gallery{ grid-template-columns:repeat(2,1fr); }
  .menu-row{ grid-template-columns:1fr auto; }
}
@media (max-width:560px){
  .menu-group-head{ flex-wrap:wrap; gap:6px; }
  .menu-group-head .gh-meta{ margin-left:0; }
}
