/* ===========================================================
 * THE ROOT & SCALP SPA — Marketing site shared styles
 * Used by index, head-spa, hair-rejuvenation
 * =========================================================== */
:root{
  --gold:#B8954C; --gold-dark:#9A7A3C; --ink:#0A0A0A;
  --white:#FFFFFF; --gray-50:#FAFAFA; --gray-100:#F3F3F3;
  --muted:#6B6B6B; --bone:#F3EEE4;
  --serif:"Cormorant Garamond","Times New Roman",serif;
  --sans:"Inter","Helvetica Neue",Arial,sans-serif;
}
*{box-sizing:border-box; margin:0; padding:0;}
html{scroll-behavior:smooth;}
body{font-family:var(--sans); font-weight:300; background:var(--white); color:var(--ink); -webkit-font-smoothing:antialiased; line-height:1.5;}
img,svg{max-width:100%; display:block;}
h1,h2,h3,h4{font-family:var(--serif); font-weight:300; letter-spacing:.005em; line-height:1.08;}
h1{font-size:clamp(44px,7vw,84px);}
h2{font-size:clamp(32px,5vw,56px); line-height:1.1;}
h3{font-size:clamp(22px,2.8vw,30px); line-height:1.2;}
h4{font-size:clamp(17px,2vw,20px); line-height:1.3;}
.eyebrow{font-family:var(--sans); font-weight:600; font-size:12px; letter-spacing:.24em; text-transform:uppercase; color:var(--gold-dark);}
section.dark .eyebrow,
.page-hero .eyebrow,
section[class*="dark"] .eyebrow{color:var(--gold);}
.lead{font-family:var(--serif); font-style:italic; font-weight:300; font-size:clamp(17px,2.3vw,22px); color:var(--gold-dark); line-height:1.45;}
p{font-size:15.5px; line-height:1.7; color:var(--ink); font-weight:300;}
.small{font-size:12.5px; color:var(--muted); font-weight:300;}

/* Layout */
section{padding:clamp(64px,9vw,140px) clamp(20px,5vw,72px);}
section.dark{background:var(--ink); color:var(--white);}
section.dark .lead{color:var(--gold);}
section.dark p{color:#E5E5E5;}
section.dark .small{color:#A8A8A8;}
section.tint{background:var(--gray-50);}
.container{max-width:1200px; margin:0 auto; width:100%;}
.narrow{max-width:780px;}
.center{text-align:center; margin-left:auto; margin-right:auto;}
.rule{width:56px; height:1.5px; background:var(--gold); margin:0 0 18px;}
.rule.center{margin:0 auto 18px;}
.stack > * + *{margin-top:18px;}
.stack-sm > * + *{margin-top:10px;}

/* Buttons */
.btn{display:inline-flex; align-items:center; gap:10px; font-family:var(--sans); font-weight:500; font-size:11px; letter-spacing:.2em; text-transform:uppercase; padding:15px 28px; border:none; cursor:pointer; text-decoration:none; transition:all .2s; line-height:1;}
.btn .arrow{font-weight:300;}
.btn-primary{background:var(--ink); color:var(--gold);}
.btn-primary:hover{background:var(--gold); color:var(--ink);}
.btn-primary.dark{background:var(--gold); color:var(--ink);}
.btn-primary.dark:hover{background:var(--white); color:var(--ink);}
.btn-secondary{background:transparent; color:var(--gold); border:.5px solid var(--gold);}
.btn-secondary:hover{background:var(--gold); color:var(--ink);}
.btn-secondary.on-dark{color:var(--gold);}
.btn-ghost{background:transparent; padding:8px 0; border-bottom:.5px solid var(--gold); color:var(--ink); font-size:11px;}
.btn-ghost:hover{color:var(--gold);}

/* ============ NAV ============ */
nav.topnav{position:fixed; top:0; left:0; right:0; z-index:100; background:rgba(10,10,10,.85); backdrop-filter:blur(12px); padding:14px clamp(20px,5vw,72px); display:flex; justify-content:space-between; align-items:center; transition:background .3s;}
.topnav.scrolled{background:rgba(255,255,255,.95); border-bottom:.5px solid rgba(184,149,76,.25);}
.topnav.scrolled .nav-brand{color:var(--ink);}
.topnav.scrolled .nav-brand-tag{color:var(--gold-dark);}
.topnav.scrolled .nav-links a{color:var(--ink);}
.topnav.scrolled .nav-links a:hover{color:var(--gold);}
.topnav.scrolled .nav-links a.nav-cta{background:var(--ink); color:var(--gold);}
.topnav.scrolled .nav-links a.nav-cta:hover{background:var(--gold); color:var(--ink);}
.nav-brand{display:flex; align-items:center; gap:12px; color:var(--white); font-family:var(--serif); font-weight:400; font-size:14px; letter-spacing:.12em; text-decoration:none; transition:color .2s;}
.nav-brand-mark{width:22px; height:30px; object-fit:contain;}
.nav-mark-light{display:none;}
.topnav.scrolled .nav-mark-dark{display:none;}
.topnav.scrolled .nav-mark-light{display:inline-block;}
.nav-links{display:flex; align-items:center; gap:clamp(14px,2vw,28px); transition:gap .35s ease;}
.nav-links a{color:var(--white); font-size:11px; letter-spacing:.18em; text-transform:uppercase; text-decoration:none; font-weight:500; transition:color .2s, font-size .35s ease, letter-spacing .35s ease;}
.nav-links a:hover{color:var(--gold);}
.nav-cta{background:var(--gold); color:var(--ink); padding:10px 18px; font-size:10.5px; font-weight:500; letter-spacing:.2em; text-transform:uppercase; text-decoration:none; transition:opacity .35s ease, transform .35s cubic-bezier(.2,.8,.2,1), max-width .35s ease, padding .35s ease, margin .35s ease, background .2s, color .2s;}
.nav-cta:hover{background:var(--white); color:var(--ink);}

/* Hide top CTA on scroll — the floating button takes over */
.topnav.scrolled .nav-cta{
  opacity:0; pointer-events:none;
  transform:scale(.85) translateX(20px);
  max-width:0; padding:10px 0; margin:0;
  overflow:hidden; white-space:nowrap;
}
/* Make nav links larger when the top CTA is gone */
.topnav.scrolled .nav-links{gap:clamp(20px,2.6vw,38px);}
.topnav.scrolled .nav-links a:not(.nav-cta){
  font-size:13px; letter-spacing:.22em;
}

/* Persistent floating "Book a Consultation" button */
.floating-book{position:fixed; bottom:24px; right:24px; z-index:90; background:var(--gold); color:var(--ink); padding:14px 22px; font-family:var(--sans); font-size:11px; font-weight:600; letter-spacing:.22em; text-transform:uppercase; text-decoration:none; border-radius:999px; box-shadow:0 8px 24px rgba(184,149,76,.35), 0 2px 6px rgba(0,0,0,.2); opacity:0; pointer-events:none; transform:translateY(20px); transition:opacity .35s cubic-bezier(.2,.8,.2,1), transform .35s cubic-bezier(.2,.8,.2,1), background .25s, color .25s; display:inline-flex; align-items:center; gap:10px;}
.floating-book.show{opacity:1; pointer-events:auto; transform:translateY(0); animation:floatingBookGlow 2.8s ease-in-out infinite;}
.floating-book:hover{background:var(--ink); color:var(--gold); box-shadow:0 12px 32px rgba(0,0,0,.35); transform:translateY(-2px); animation:none;}
.floating-book .arrow{font-size:14px; line-height:1;}
/* Hide the floating Book button on the booking page itself (avoids self-link) */
body.book-page .floating-book{display:none !important;}
@keyframes floatingBookGlow{
  0%,100%{
    box-shadow:0 8px 24px rgba(184,149,76,.35),
               0 2px 6px rgba(0,0,0,.2),
               0 0 0 0 rgba(184,149,76,0);
  }
  50%{
    box-shadow:0 10px 30px rgba(184,149,76,.55),
               0 2px 6px rgba(0,0,0,.2),
               0 0 24px 6px rgba(184,149,76,.35);
  }
}

/* Mobile burger */
.nav-burger{display:none; background:none; border:0; padding:8px; margin-right:-8px; cursor:pointer; flex-direction:column; gap:5px; align-items:center;}
.nav-burger span{display:block; width:24px; height:2px; background:var(--gold); transition:transform .28s cubic-bezier(.2,.8,.2,1), opacity .2s; transform-origin:center;}
.topnav.scrolled .nav-burger span{background:var(--ink);}
.topnav.menu-open .nav-burger span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.topnav.menu-open .nav-burger span:nth-child(2){opacity:0;}
.topnav.menu-open .nav-burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

@media (max-width:760px){
  .nav-burger{display:flex;}
  .nav-links{position:absolute; top:100%; left:0; right:0; background:rgba(10,10,10,.96); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px); flex-direction:column; align-items:stretch; gap:0; padding:0; max-height:0; overflow:hidden; transition:max-height .35s cubic-bezier(.2,.8,.2,1); border-bottom:.5px solid rgba(184,149,76,.2);}
  .topnav.scrolled .nav-links{background:rgba(255,255,255,.97); border-bottom:.5px solid rgba(184,149,76,.25);}
  .topnav.menu-open .nav-links{max-height:480px;}
  .nav-links a{display:block !important; padding:16px 24px; border-bottom:.5px solid rgba(184,149,76,.1); font-size:13px;}
  .nav-links .nav-cta{margin:12px 24px 16px; text-align:center; border-bottom:0; border-radius:0;}
  .topnav.scrolled .nav-links .nav-cta{background:var(--ink);color:var(--gold);}
  section{padding:60px 20px !important;}
  section .container{padding:0;}
  h2{font-size:clamp(28px,7vw,38px) !important;}
  h4{font-size:18px !important;}
  .floating-book{bottom:14px; right:14px; padding:11px 16px; font-size:10px; letter-spacing:.18em;}
}

/* ============ Page hero (subpages) ============ */
.page-hero{background:var(--ink); color:var(--white); padding:160px clamp(20px,5vw,72px) 80px; position:relative; overflow:hidden;}
.page-hero .eyebrow{color:var(--gold);}
.page-hero h1{color:var(--white); margin-top:18px; font-size:clamp(44px,7vw,76px);}
.page-hero .lead{margin-top:22px; max-width:680px; font-size:clamp(18px,2.4vw,24px);}
.page-hero .actions{display:flex; flex-wrap:wrap; gap:14px; margin-top:36px;}

/* ============ FOOTER ============ */
footer{background:var(--ink); color:#A8A8A8; padding:64px clamp(20px,5vw,72px) 40px;}
.footer-grid{display:grid; gap:36px; grid-template-columns:1fr; max-width:1200px; margin:0 auto;}
@media (min-width:720px){.footer-grid{grid-template-columns:2fr 1fr 1fr 1.4fr;}}
.footer-brand{font-family:var(--serif); font-weight:400; color:var(--white); font-size:18px; letter-spacing:.08em;}
.footer-brand .tag{display:block; font-family:var(--sans); font-weight:500; font-size:10px; letter-spacing:.22em; text-transform:uppercase; color:var(--gold); margin-top:6px;}
footer h5{font-family:var(--sans); font-weight:500; font-size:10px; letter-spacing:.22em; text-transform:uppercase; color:var(--gold); margin-bottom:16px;}
footer ul{list-style:none; padding:0;}
footer li{padding:5px 0; font-size:13px;}
footer a{color:#A8A8A8; text-decoration:none; transition:color .15s;}
footer a:hover{color:var(--gold);}
.footer-rule{border-top:.5px solid rgba(184,149,76,.2); margin:40px 0 24px;}
.footer-bottom{display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:14px; max-width:1200px; margin:0 auto; font-size:11px; color:#666;}

/* ============ Diamond list (◆) ============ */
.dia-list{list-style:none; padding:0;}
.dia-list li{font-size:14.5px; padding:10px 0 10px 22px; position:relative; color:var(--ink); line-height:1.6;}
.dia-list li::before{content:"◆"; color:var(--gold); position:absolute; left:0; font-size:11px; top:13px;}

/* ============ Card grids — Services / Packages ============ */
.cards-grid{display:grid; gap:1px; background:rgba(184,149,76,.25); border:.5px solid rgba(184,149,76,.25);}
@media (min-width:720px){.cards-grid.cols-2{grid-template-columns:repeat(2,1fr);}}
@media (min-width:980px){.cards-grid.cols-3{grid-template-columns:repeat(3,1fr);}}
@media (min-width:1080px){.cards-grid.cols-4{grid-template-columns:repeat(4,1fr);}}

.svc-card{background:var(--white); padding:36px 28px; display:flex; flex-direction:column; justify-content:space-between; min-height:340px; transition:background .2s;}
.svc-card:hover{background:var(--gray-50);}
.svc-card .eye{font-size:10px; letter-spacing:.22em; text-transform:uppercase; color:var(--gold); font-weight:500;}
.svc-card .name{font-family:var(--serif); font-style:italic; font-weight:300; font-size:26px; color:var(--ink); margin:10px 0 4px; line-height:1.1;}
.svc-card .dur{font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); font-weight:500; margin-bottom:20px;}
.svc-card .desc{font-size:14px; color:var(--ink); line-height:1.55; flex:1; font-weight:300;}
.svc-card .footer-row{display:flex; justify-content:space-between; align-items:flex-end; margin-top:20px; padding-top:14px; border-top:.5px solid var(--bone); flex-wrap:wrap; gap:10px;}
.svc-card .price{font-family:var(--serif); font-weight:300; font-size:28px; color:var(--ink); line-height:1;}
.svc-card .price .strike{font-size:18px; color:var(--muted); text-decoration:line-through; margin-right:8px;}
.svc-card a.book{font-size:10.5px; letter-spacing:.2em; text-transform:uppercase; color:var(--gold-dark); font-weight:500; text-decoration:none; border-bottom:.5px solid var(--gold); padding-bottom:3px; transition:color .15s;}
.svc-card a.book:hover{color:var(--ink);}

.pkg-grid{display:grid; gap:clamp(20px,3vw,36px); grid-template-columns:1fr; margin-top:48px;}
@media (min-width:860px){.pkg-grid.cols-3{grid-template-columns:repeat(3,1fr);}}
@media (min-width:1080px){.pkg-grid.cols-4{grid-template-columns:repeat(2,1fr);}}
@media (min-width:1200px){.pkg-grid.cols-4{grid-template-columns:repeat(4,1fr);}}
.pkg{background:var(--white); padding:36px 30px; border:.5px solid rgba(184,149,76,.25); display:flex; flex-direction:column; transition:border-color .2s, transform .2s;}
.pkg:hover{border-color:var(--gold); transform:translateY(-2px);}
.pkg .eye{font-size:10px; letter-spacing:.22em; text-transform:uppercase; color:var(--gold); font-weight:500;}
.pkg .name{font-family:var(--serif); font-style:italic; font-weight:300; font-size:28px; color:var(--ink); margin:8px 0 12px; line-height:1.05;}
.pkg .desc{font-size:13.5px; color:var(--ink); line-height:1.6; margin-bottom:20px; flex:1; font-weight:300;}
.pkg ul{list-style:none; padding:0; margin-bottom:20px;}
.pkg li{font-size:12.5px; padding:7px 0 7px 20px; position:relative; border-top:.5px solid var(--bone); color:var(--ink); line-height:1.5;}
.pkg li:first-child{border-top:none;}
.pkg li::before{content:"◆"; color:var(--gold); position:absolute; left:0; font-size:9px; top:10px;}
.pkg .foot{padding-top:20px; border-top:.5px solid var(--gold);}
.pkg .totals{display:flex; justify-content:space-between; align-items:baseline; flex-wrap:wrap; gap:8px; margin-bottom:14px;}
.pkg .totals .k{font-size:10px; letter-spacing:.18em; text-transform:uppercase; color:var(--muted);}
.pkg .totals .v{font-family:var(--serif); font-weight:300; font-size:20px; color:var(--ink); font-variant-numeric:tabular-nums;}
.pkg .totals .v.gold{color:var(--gold);}
.pkg .totals .v.strike{color:var(--muted); text-decoration:line-through; font-size:16px;}
.pkg .save{display:inline-block; background:var(--gold); color:var(--ink); font-size:10px; letter-spacing:.22em; text-transform:uppercase; font-weight:600; padding:5px 10px; margin-bottom:14px;}
.pkg .by{font-family:var(--serif); font-style:italic; color:var(--gold-dark); font-size:13px;}
.pkg a.cta{display:inline-flex; align-items:center; gap:8px; font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--gold-dark); font-weight:500; text-decoration:none; border-bottom:.5px solid var(--gold); padding-bottom:3px; transition:color .15s; margin-top:6px;}
.pkg a.cta:hover{color:var(--ink);}

/* ============ Calendly embed wrapper ============ */
.calendly-wrap{background:#161616; padding:24px; border:.5px solid rgba(184,149,76,.3); margin-top:32px;}
.calendly-wrap .cal-head{display:flex; flex-wrap:wrap; gap:14px; align-items:baseline; margin-bottom:14px;}
.calendly-wrap .cal-head .who{font-family:var(--serif); font-style:italic; font-size:18px; color:var(--white);}
.calendly-wrap .cal-head .role{font-size:10px; letter-spacing:.22em; text-transform:uppercase; color:var(--gold); font-weight:500;}
.calendly-iframe{width:100%; min-height:680px; border:0; background:var(--white);}
.calendly-fallback{padding:36px 24px; background:var(--ink); border:.5px dashed var(--gold); text-align:center; color:#D5D5D5;}
.calendly-fallback strong{color:var(--gold); font-family:var(--sans); font-weight:500; font-size:10px; letter-spacing:.22em; text-transform:uppercase; display:block; margin-bottom:8px;}
.calendly-fallback code{background:rgba(184,149,76,.12); color:var(--gold); padding:3px 8px; font-family:Consolas,Menlo,monospace; font-size:12px;}
.calendly-pickers{display:grid; gap:14px; grid-template-columns:1fr; margin-top:18px;}
@media (min-width:760px){.calendly-pickers{grid-template-columns:1fr 1fr;}}
.calendly-tile{padding:24px; background:#161616; border:.5px solid rgba(184,149,76,.3); transition:border-color .2s;}
.calendly-tile:hover{border-color:var(--gold);}
.calendly-tile .who{font-family:var(--serif); font-style:italic; font-size:22px; color:var(--white); margin-bottom:6px;}
.calendly-tile .role{font-size:10px; letter-spacing:.22em; text-transform:uppercase; color:var(--gold); font-weight:500; margin-bottom:14px;}
.calendly-tile p{color:#C8C8C8; font-size:13px; line-height:1.6; margin-bottom:18px;}
.calendly-tile a.cta{display:inline-flex; align-items:center; gap:10px; padding:13px 22px; background:var(--gold); color:var(--ink); font-size:10.5px; font-weight:600; letter-spacing:.22em; text-transform:uppercase; text-decoration:none;}
.calendly-tile a.cta:hover{background:var(--white);}

/* ============ Two-path pathway choice ============ */
.path-grid{display:grid; gap:1px; background:rgba(184,149,76,.25); border:.5px solid rgba(184,149,76,.25); margin-top:48px;}
@media (min-width:860px){.path-grid{grid-template-columns:1fr 1fr;}}
.path{background:var(--white); padding:clamp(36px,5vw,56px) clamp(28px,4vw,44px); display:flex; flex-direction:column; min-height:420px; position:relative; transition:background .25s;}
.path:hover{background:var(--gray-50);}
.path .eye{font-size:10px; letter-spacing:.22em; text-transform:uppercase; color:var(--gold); font-weight:500; margin-bottom:14px;}
.path h3{font-family:var(--serif); font-weight:300; font-size:clamp(28px,4vw,40px); color:var(--ink); margin-bottom:18px; line-height:1.05;}
.path p{font-size:15px; line-height:1.65; color:var(--ink); margin-bottom:22px; flex:1;}
.path .meta{font-family:var(--serif); font-style:italic; font-size:14px; color:var(--gold-dark); margin-bottom:24px; padding-top:18px; border-top:.5px solid var(--bone);}
.path a.go{display:inline-flex; align-items:center; gap:12px; font-family:var(--sans); font-weight:500; font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:var(--ink); text-decoration:none; border-bottom:1.5px solid var(--gold); padding-bottom:5px; align-self:flex-start; transition:gap .25s;}
.path a.go:hover{gap:18px;}
.path a.go .arr{transition:transform .25s;}
.path a.go:hover .arr{transform:translateX(4px);}

/* ============ Pillars (What Sets Us Apart) ============ */
.pillars{display:grid; gap:clamp(28px,4vw,48px); grid-template-columns:1fr; margin-top:48px;}
@media (min-width:760px){.pillars{grid-template-columns:repeat(3,1fr);}}
.pillar{padding:36px 28px; background:var(--white); border:.5px solid rgba(184,149,76,.25); border-top:2px solid var(--gold);}
.pillar .num{font-family:var(--serif); font-weight:300; font-size:36px; color:var(--gold); line-height:1; margin-bottom:14px;}
.pillar h4{font-family:var(--serif); font-weight:400; font-style:italic; color:var(--ink); margin-bottom:10px;}
.pillar p{font-size:14px; color:var(--ink); line-height:1.65;}

/* ============ Location ============ */
.location-grid{display:grid; gap:40px; grid-template-columns:1fr; text-align:left; margin-top:40px;}
@media (min-width:760px){.location-grid{grid-template-columns:1fr 1fr;}}
@media (min-width:1000px){.location-grid{grid-template-columns:1fr 1fr 1fr;}}
.loc-block{padding:28px; background:var(--gray-50); border-left:2px solid var(--gold);}
.loc-block h4{font-family:var(--serif); font-style:italic; color:var(--ink); margin-bottom:10px;}
.loc-block .small{color:var(--muted); margin-top:6px;}

/* ============ Reveal animations ============ */
.reveal{opacity:0; transform:translateY(20px); transition:opacity .8s cubic-bezier(.22,.61,.36,1), transform .8s cubic-bezier(.22,.61,.36,1);}
.reveal.in{opacity:1; transform:none;}
@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1; transform:none; transition:none;}
}

/* ============================================================
 * UTILITY CLASSES — replaces scattered inline style="..." attrs
 * ============================================================ */

/* Top margins */
.mt-8  {margin-top:8px;}
.mt-10 {margin-top:10px;}
.mt-14 {margin-top:14px;}
.mt-18 {margin-top:18px;}
.mt-22 {margin-top:22px;}
.mt-24 {margin-top:24px;}
.mt-32 {margin-top:32px;}
.mt-36 {margin-top:36px;}
.mt-48 {margin-top:48px;}
.mt-72 {margin-top:72px;}

/* Bottom margins */
.mb-6  {margin-bottom:6px;}
.mb-10 {margin-bottom:10px;}
.mb-14 {margin-bottom:14px;}
.mb-36 {margin-bottom:36px;}

/* Max widths */
.mw-400 {max-width:400px;}
.mw-640 {max-width:640px;}
.mw-680 {max-width:680px;}
.mw-720 {max-width:720px;}

/* Text colors */
.text-white {color:var(--white);}
.text-ink   {color:var(--ink);}
.text-gold  {color:var(--gold);}
.text-gold-dark {color:var(--gold-dark);}
.text-muted {color:var(--muted);}
.text-soft  {color:#D5D5D5;}
.text-soft-2{color:#A8A8A8;}

/* Backgrounds */
.bg-card-dark   {background:#161616; color:var(--white);}
.bg-card-darker {background:#0f0f0f;}

/* Typography */
.fw-300 {font-weight:300;}
.fw-400 {font-weight:400;}
.fw-500 {font-weight:500;}
.italic {font-style:italic;}
.italic-gold {font-style:italic; color:var(--gold);}
.serif-italic {font-family:var(--serif); font-style:italic;}
.serif-italic-15 {font-family:var(--serif); font-style:italic; font-size:15px;}
.serif-italic-30 {font-family:var(--serif); font-weight:300; font-size:clamp(22px,3vw,30px); font-style:italic;}
.serif-light-32 {font-family:var(--serif); font-weight:300; font-size:clamp(24px,3vw,32px);}
.serif-regular-ink {font-family:var(--serif); font-weight:400; color:var(--ink);}

/* Layout helpers */
.no-underline {text-decoration:none;}
.inherit-color {color:inherit;}
.flex-baseline {display:inline-flex; align-items:baseline; gap:8px;}
.full-col {grid-column:1 / -1;}

/* Footer brand description */
.footer-tagline {margin-top:18px; color:#A8A8A8; font-size:13.5px; max-width:400px;}

/* Code-style chip (used in setup pages) */
.code-chip {background:rgba(184,149,76,.12); color:var(--gold); padding:2px 8px; font-family:Consolas,Menlo,monospace; font-size:12px;}

/* Form inputs (used in book + secure-package + gift-card) */
.form-label {font-size:10px; letter-spacing:.22em; text-transform:uppercase; color:var(--gold-dark); font-weight:500; display:block; margin-bottom:6px;}
.form-input {width:100%; padding:13px 14px; border:.5px solid rgba(184,149,76,.4); background:var(--white); font-family:var(--sans); font-weight:300; font-size:14px;}
.form-input:focus {outline:none; border-color:var(--gold);}

/* Calendly-style placeholder boxes */
.cal-embed {min-width:320px; height:680px;}

/* FDA disclaimer panel (used inside dark cards) */
.fda-panel {margin-top:18px; padding:14px 16px; background:#0f0f0f; color:#A8A8A8; font-size:11px; line-height:1.5; border-left:2px solid var(--gold);}
.fda-panel-label {color:var(--gold); font-family:var(--sans); font-size:9px; letter-spacing:.22em; text-transform:uppercase; display:block; margin-bottom:6px; font-weight:500;}

/* Inline link with gold underline */
.link-gold {color:var(--gold); border-bottom:.5px solid var(--gold); text-decoration:none;}
.link-gold:hover {color:var(--gold-dark);}

/* Section heading helpers */
.h2-on-dark {color:var(--white); margin-top:14px;}
.lead-narrow {margin-top:14px; max-width:680px;}
.lead-narrow-2 {margin-top:14px; max-width:640px;}

/* Body text variants */
.body-tight {font-size:14.5px; line-height:1.7; color:var(--ink);}
.body-tight + .body-tight {margin-top:14px;}
.lead-italic {font-style:italic;}
.text-center {text-align:center;}

/* Compact "Enhance any visit" strip on head-spa */
.enhance-strip{
  max-width:720px; margin:40px auto 0; padding:18px 22px;
  border:.5px solid rgba(184,149,76,.3);
  display:flex; flex-wrap:wrap; align-items:center; gap:14px 24px;
  background:var(--white);
}
.enhance-strip-eyebrow{
  font-size:10px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--gold-dark); font-weight:500; flex:0 0 auto;
}
.enhance-strip-items{
  display:flex; flex-wrap:wrap; gap:10px 24px;
  flex:1; font-size:13.5px; color:var(--ink);
}

/* Secure-package reservation form */
.secure-pkg-card{
  background:var(--gray-50); padding:36px clamp(20px,3vw,40px);
  margin-top:48px; border-left:2px solid var(--gold);
}
.pkg-form-grid{
  display:grid; grid-template-columns:1fr 1fr; gap:14px 20px;
  margin-top:24px; max-width:720px;
}
.pkg-form-grid .col-l{grid-column:1/2;}
.pkg-form-grid .col-r{grid-column:2/3;}
.pkg-form-grid .col-full{grid-column:1/-1; justify-self:flex-start; margin-top:8px;}
