/* =========================================================================
   Aesura Health — Medical Spa Service Page Template
   Shared styles for all 10 service pages + Hair Restoration
   Pairs with: ../site.css (header, hero, footer, etc.)
   ========================================================================= */

/* ===== BREADCRUMB ===== */
.breadcrumb {
  background:var(--aes-cream-warm); border-bottom:1px solid var(--rule);
  padding:14px 56px; font-size:12px; color:var(--fg-3); letter-spacing:.04em;
}
.breadcrumb .container { max-width:1140px; margin:0 auto; }
.breadcrumb a { color:var(--fg-3); border-bottom:1px solid transparent; transition:color 200ms, border-color 200ms; }
.breadcrumb a:hover { color:var(--aes-forest); border-color:rgba(26,35,19,.3); }
.breadcrumb .sep { color:var(--rule); margin:0 10px; }
.breadcrumb .here { color:var(--fg-1); font-weight:500; }
@media (max-width: 600px) { .breadcrumb { padding:12px 20px; font-size:11.5px; } }

/* ===== SERVICE HERO — slimmer than homepage hero ===== */
.svc-hero {
  position:relative; padding:72px 56px 64px; color:var(--aes-cream);
  background:
    linear-gradient(180deg, rgba(26,35,19,.7) 0%, rgba(15,23,9,.94) 100%),
    radial-gradient(circle at 25% 35%, #2a3f2a 0%, #1A2313 45%, #0f1709 100%);
  overflow:hidden;
}
.svc-hero::after {
  content:""; position:absolute; right:-160px; top:50%; transform:translateY(-50%);
  width:540px; height:540px; border-radius:50%;
  background: radial-gradient(circle, rgba(212,178,74,.14) 0%, transparent 65%);
  pointer-events:none;
}
.svc-hero-inner {
  position:relative; max-width:1140px; margin:0 auto;
  display:grid; grid-template-columns: 1.4fr 1fr; gap:56px; align-items:end;
}
.svc-hero .eyebrow {
  font-size:11px; letter-spacing:.32em; text-transform:uppercase; color:#D4B24A;
  font-weight:600; margin:0 0 22px; display:flex; align-items:center; gap:14px;
}
.svc-hero .eyebrow::before { content:""; width:34px; height:1.5px; background:#D4B24A; }
.svc-hero h1 {
  font-family:var(--font-sans); font-weight:400; font-size:54px; line-height:1.06;
  color:#fff; margin:0 0 22px; letter-spacing:-.012em; text-wrap:balance;
}
.svc-hero h1 em { font-family:var(--font-serif); font-style:italic; font-weight:500; color:#D4B24A; }
.svc-hero .hero-sub { font-size:16px; line-height:1.7; color:#D8CFC4; max-width:540px; margin:0 0 28px; }
.svc-hero .hero-actions { display:flex; gap:14px; align-items:center; flex-wrap:wrap; }
.svc-hero .meta-row {
  display:grid; grid-template-columns: repeat(3, auto); gap:28px; margin-top:32px;
  padding-top:24px; border-top:1px solid rgba(212,178,74,.22);
  font-size:11.5px; letter-spacing:.18em; text-transform:uppercase; color:#BFB6AC;
}
.svc-hero .meta-row strong { display:block; font-family:var(--font-serif); font-style:italic; font-weight:500;
  font-size:22px; color:#D4B24A; letter-spacing:0; text-transform:none; margin-bottom:4px; }

/* Decorative side panel — abstract treatment "card" */
.svc-hero-card {
  background: linear-gradient(150deg, rgba(212,178,74,.16) 0%, rgba(212,178,74,.04) 60%, transparent 100%);
  border:1px solid rgba(212,178,74,.32);
  padding:32px 30px; backdrop-filter:blur(10px);
}
.svc-hero-card .card-eyebrow { font-size:10px; letter-spacing:.28em; text-transform:uppercase; color:#D4B24A; font-weight:600; margin-bottom:14px; }
.svc-hero-card h3 { font-family:var(--font-serif); font-style:italic; font-weight:400; font-size:22px; color:#fff; margin:0 0 18px; line-height:1.35; }
.svc-hero-card ul { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:11px; }
.svc-hero-card li { font-size:13.5px; line-height:1.55; color:#D8CFC4; padding-left:22px; position:relative; }
.svc-hero-card li::before { content:""; position:absolute; left:0; top:7px; width:9px; height:9px; border:1.5px solid #D4B24A; border-radius:50%; }

/* ===== AEO ANSWER BLOCK ===== */
.aeo {
  background:#fff; padding:64px 56px; border-bottom:1px solid var(--rule);
}
.aeo-inner { max-width:1080px; margin:0 auto; display:grid; grid-template-columns: 1fr 1.4fr; gap:56px; align-items:start; }
.aeo .eyebrow { font-size:11px; letter-spacing:.28em; text-transform:uppercase; color:#9C7C20; font-weight:600; margin-bottom:14px; }
.aeo h2 {
  font-family:var(--font-sans); font-weight:400; font-size:32px; line-height:1.22;
  color:var(--fg-1); margin:0; letter-spacing:-.005em;
}
.aeo h2 em { font-family:var(--font-serif); font-style:italic; color:var(--aes-forest); }
.aeo .answer-card {
  border-left:3px solid #D4B24A; padding:8px 0 8px 28px;
}
.aeo .answer-card p {
  font-size:18px; line-height:1.7; color:var(--fg-2); margin:0;
  font-family:var(--font-sans);
}
.aeo .answer-card p strong { color:var(--fg-1); font-weight:600; }
.aeo .answer-card .quick-facts {
  margin-top:20px; padding-top:18px; border-top:1px solid var(--rule);
  display:grid; grid-template-columns: repeat(3, 1fr); gap:18px;
}
.aeo .answer-card .quick-facts > div { font-size:12.5px; line-height:1.5; color:var(--fg-2); }
.aeo .answer-card .quick-facts strong { display:block; font-size:10.5px; letter-spacing:.22em; text-transform:uppercase; color:#9C7C20; font-weight:600; margin-bottom:4px; }

/* ===== BODY SECTIONS — flowing content ===== */
.svc-body { background:var(--aes-cream); padding:88px 56px 96px; }
.svc-body .container { max-width:880px; margin:0 auto; }
.svc-body h2 {
  font-family:var(--font-sans); font-weight:400; font-size:34px; line-height:1.2;
  color:var(--fg-1); margin:48px 0 16px; letter-spacing:-.005em;
}
.svc-body h2:first-child { margin-top:0; }
.svc-body h2 em { font-family:var(--font-serif); font-style:italic; color:#9C7C20; }
.svc-body h3 {
  font-family:var(--font-sans); font-weight:500; font-size:20px; color:var(--fg-1);
  margin:32px 0 12px; line-height:1.35;
}
.svc-body p { font-size:16.5px; line-height:1.75; color:var(--fg-2); margin:0 0 18px; }
.svc-body p strong { color:var(--fg-1); font-weight:600; }
.svc-body p a { color:var(--aes-forest); border-bottom:1px solid rgba(26,35,19,.3); }
.svc-body p a:hover { background:rgba(212,178,74,.12); border-bottom-color:#D4B24A; }
.svc-body ul { padding-left:0; list-style:none; margin:0 0 22px; }
.svc-body ul li { font-size:16px; line-height:1.7; color:var(--fg-2); padding-left:22px; position:relative; margin-bottom:8px; }
.svc-body ul li::before { content:"✦"; position:absolute; left:0; color:#9C7C20; font-size:11px; top:6px; }
.svc-body .lede { font-family:var(--font-serif); font-style:italic; font-size:21px; line-height:1.55; color:var(--fg-1); margin:0 0 36px; }

.svc-body .callout {
  background:#fff; border:1px solid var(--rule); border-left:3px solid #D4B24A;
  padding:24px 28px; margin:30px 0; font-family:var(--font-sans);
}
.svc-body .callout h4 { font-size:11px; letter-spacing:.28em; text-transform:uppercase; color:#9C7C20; font-weight:600; margin:0 0 10px; }
.svc-body .callout p { font-size:15.5px; margin:0; color:var(--fg-1); line-height:1.65; }

/* On-page anchor TOC */
.svc-toc {
  background:#fff; border:1px solid var(--rule); padding:24px 28px;
  margin-bottom:48px; display:flex; flex-wrap:wrap; gap:8px 16px; align-items:center;
}
.svc-toc h6 { font-size:10.5px; letter-spacing:.28em; text-transform:uppercase; color:#9C7C20; font-weight:600; margin:0 16px 0 0; padding-right:16px; border-right:1px solid var(--rule); }
.svc-toc a {
  font-size:12.5px; letter-spacing:.04em; color:var(--fg-2);
  padding:6px 0; border-bottom:1px dotted transparent; transition:color 200ms, border-color 200ms;
}
.svc-toc a:hover { color:var(--aes-forest); border-color:#D4B24A; }

/* ===== AREAS WE TREAT — pill grid ===== */
.areas-treat-grid {
  display:grid; grid-template-columns:repeat(2, 1fr); gap:10px 18px;
  background:var(--aes-cream-warm); padding:28px 32px; border-left:3px solid #D4B24A;
  margin:24px 0 36px;
}
.areas-treat-grid li { font-size:14.5px; padding-left:18px; }

/* ===== "WHO WE SERVE" / GEO BLOCK ===== */
.serve-block {
  background:#fff; border:1px solid var(--rule); padding:32px;
  margin:48px 0; display:grid; grid-template-columns: 1fr 1.3fr; gap:28px; align-items:start;
}
.serve-block h4 { font-size:11px; letter-spacing:.28em; text-transform:uppercase; color:#9C7C20; font-weight:600; margin:0 0 12px; }
.serve-block h3 { font-family:var(--font-sans); font-weight:400; font-size:22px; line-height:1.3; color:var(--fg-1); margin:0; letter-spacing:-.005em; }
.serve-block h3 em { font-family:var(--font-serif); font-style:italic; color:#9C7C20; }
.serve-block p { font-size:15px; line-height:1.7; color:var(--fg-2); margin:0; }
.serve-block strong { color:var(--fg-1); }

/* ===== FAQ accordion ===== */
.faq-section { background:#fff; padding:88px 56px; border-top:1px solid var(--rule); }
.faq-section .container { max-width:880px; margin:0 auto; }
.faq-section .eyebrow { font-size:11px; letter-spacing:.28em; text-transform:uppercase; color:#9C7C20; font-weight:600; margin:0 0 14px; text-align:center; }
.faq-section h2 { font-family:var(--font-sans); font-weight:400; font-size:42px; line-height:1.2; color:var(--fg-1); margin:0 0 12px; letter-spacing:-.005em; text-align:center; }
.faq-section h2 em { font-family:var(--font-serif); font-style:italic; color:#9C7C20; }
.faq-section .sub { font-size:14.5px; color:var(--fg-3); text-align:center; margin:0 0 56px; max-width:600px; margin-left:auto; margin-right:auto; line-height:1.6; }

details.faq-q {
  display:block !important;
  width:100%;
  border-top:1px solid var(--rule); padding:0; transition:background 200ms;
}
details.faq-q:last-of-type { border-bottom:1px solid var(--rule); }
details.faq-q summary {
  list-style:none; cursor:pointer; padding:24px 0;
  display:flex; align-items:flex-start; justify-content:space-between; gap:24px;
  width:100%; box-sizing:border-box;
  font-family:var(--font-sans); font-weight:500; font-size:18px; color:var(--fg-1); line-height:1.4;
}
details.faq-q summary::-webkit-details-marker { display:none; }
details.faq-q summary::after {
  content:""; flex-shrink:0; width:14px; height:14px;
  border-right:1.5px solid #9C7C20; border-bottom:1.5px solid #9C7C20;
  transform:rotate(45deg); transition: transform 240ms; margin-top:6px;
}
details.faq-q[open] summary::after { transform:rotate(-135deg); margin-top:10px; }
details.faq-q[open] summary { color:var(--aes-forest); }
details.faq-q .a {
  display:block; width:100%; box-sizing:border-box;
  font-size:15.5px; line-height:1.75; color:var(--fg-2); padding:0 0 28px; max-width:760px;
}
details.faq-q .a strong { color:var(--fg-1); font-weight:600; }

/* ===== RELATED / INTERNAL LINKS ===== */
.related {
  background:var(--aes-cream-warm); padding:80px 56px; border-top:1px solid var(--rule);
}
.related .container { max-width:1140px; margin:0 auto; }
.related .eyebrow { font-size:11px; letter-spacing:.28em; text-transform:uppercase; color:#9C7C20; font-weight:600; margin:0 0 14px; }
.related h2 { font-family:var(--font-sans); font-weight:400; font-size:36px; line-height:1.2; color:var(--fg-1); margin:0 0 36px; letter-spacing:-.005em; max-width:680px; }
.related h2 em { font-family:var(--font-serif); font-style:italic; color:#9C7C20; }
.related-grid { display:grid; grid-template-columns:repeat(3, 1fr); gap:18px; }
.related-card {
  background:#fff; border:1px solid var(--rule); padding:24px 26px; display:flex; flex-direction:column; gap:10px;
  transition: transform 240ms cubic-bezier(.22,1,.36,1), border-color 240ms;
}
.related-card:hover { border-color:#D4B24A; transform:translateY(-3px); }
.related-card .cat { font-size:10px; letter-spacing:.22em; text-transform:uppercase; color:#9C7C20; font-weight:600; }
.related-card h4 { font-family:var(--font-sans); font-weight:400; font-size:19px; line-height:1.3; color:var(--fg-1); margin:0; }
.related-card p { font-size:13.5px; line-height:1.55; color:var(--fg-2); margin:0; }
.related-card .more { margin-top:auto; font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--aes-forest); font-weight:600; padding-top:6px; }

/* ===== CINEMATIC BANNER — mirrored from weight-loss.html ===== */
/* Shared banner system used across all medical-spa-services pages. */
.wl-banner {
  width:100%;
  margin:0;
  padding:0;
  background:var(--aes-cream-warm);
  position:relative;
}
.wl-banner img {
  display:block;
  width:100%;
  height:auto;
  max-height:460px;
  object-fit:cover;
  object-position:center;
}
.wl-banner--captioned {
  padding:0 0 28px;
  background:var(--aes-cream-warm);
}
.wl-banner--captioned img { max-height:520px; }
.wl-banner-cap {
  text-align:center;
  margin:18px auto 0;
  max-width:720px;
  padding:0 24px;
  font-family:var(--font-serif);
  font-size:17px;
  line-height:1.45;
  color:#9C7C20;
  letter-spacing:.005em;
}
.wl-banner-cap em { font-style:italic; }
@media (max-width: 900px) {
  .wl-banner img { max-height:280px; }
  .wl-banner--captioned img { max-height:320px; }
  .wl-banner-cap { font-size:15px; margin-top:14px; padding:0 20px; }
  .wl-banner--captioned { padding-bottom:22px; }
}

/* ===== HUB PAGE — category tiers ===== */
.hub-categories { background:var(--aes-cream); padding:88px 56px; }
.hub-categories .container { max-width:1140px; margin:0 auto; }
.hub-cat { margin-bottom:64px; }
.hub-cat:last-child { margin-bottom:0; }
.hub-cat .cat-head { display:flex; align-items:flex-end; justify-content:space-between; gap:32px; margin-bottom:24px; flex-wrap:wrap; padding-bottom:16px; border-bottom:1px solid var(--rule); }
.hub-cat .cat-head h2 { font-family:var(--font-sans); font-weight:400; font-size:34px; line-height:1.2; color:var(--fg-1); margin:0; letter-spacing:-.005em; }
.hub-cat .cat-head h2 em { font-family:var(--font-serif); font-style:italic; color:#9C7C20; }
.hub-cat .cat-head p { font-size:14px; color:var(--fg-3); margin:0; max-width:380px; line-height:1.6; }
.hub-grid { display:grid; grid-template-columns:repeat(4, 1fr); gap:16px; }

/* ===== RESPONSIVE ===== */
@media (max-width: 1100px) {
  .svc-hero-inner, .aeo-inner, .serve-block { grid-template-columns: 1fr; gap:32px; }
  .svc-hero { padding:60px 32px 56px; }
  .svc-hero h1 { font-size:44px; }
  .aeo, .svc-body, .faq-section, .related { padding-left:32px; padding-right:32px; }
  .hub-grid { grid-template-columns:repeat(3, 1fr); }
  .related-grid { grid-template-columns:repeat(2, 1fr); }
}
@media (max-width: 768px) {
  .svc-hero { padding:48px 20px 44px; }
  .svc-hero h1 { font-size:34px; }
  .svc-hero .hero-sub { font-size:15px; }
  .svc-hero .meta-row { grid-template-columns: 1fr 1fr; gap:16px; padding-top:20px; }
  .aeo, .svc-body, .faq-section, .related, .hub-categories { padding-left:20px; padding-right:20px; padding-top:60px; padding-bottom:60px; }
  .aeo h2, .svc-body h2 { font-size:26px; }
  .aeo .answer-card p { font-size:16px; }
  .aeo .answer-card .quick-facts { grid-template-columns:1fr; gap:12px; }
  .areas-treat-grid { grid-template-columns: 1fr; }
  .faq-section h2, .related h2 { font-size:28px; }
  details.faq-q summary { font-size:16px; }
  .hub-grid { grid-template-columns:1fr; }
  .related-grid { grid-template-columns: 1fr; }
  .breadcrumb { padding:12px 20px; }
  .hub-cat .cat-head h2 { font-size:26px; }
}
