:root {
  --navy: #042858;
  --navy-deep: #001d46;
  --gold: #bd8b2f;
  --gold-light: #d4a955;
  --ink: #102d59;
  --muted: #46556b;
  --cream: #faf8f4;
  --line: #e5ded1;
  --white: #fff;
  --shadow: 0 8px 24px rgba(12, 38, 73, .08);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  padding: 12px;
  overflow-x: hidden;
  color: var(--ink);
  background: #f7f7f6;
  font-family: "DM Sans", Arial, sans-serif;
  line-height: 1.45;
}
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
h1, h2 { font-family: "Playfair Display", Georgia, serif; font-weight: 500; line-height: 1.08; }
.site-shell { width: 100%; max-width: 1180px; min-width: 0; margin: auto; overflow: hidden; background: var(--white); border: 1px solid #ddd; box-shadow: 0 2px 12px rgba(0, 0, 0, .05); }
.wrap { width: min(1020px, calc(100% - 64px)); margin-inline: auto; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0; }

.site-header {
  position: relative;
  z-index: 20;
  height: 122px;
  padding: 8px 40px;
  display: grid;
  grid-template-columns: 330px 1fr auto;
  align-items: center;
  gap: 24px;
  background: rgba(255, 255, 255, .98);
}
.site-header > * { min-width: 0; }
.brand img { width: 310px; height: 110px; object-fit: contain; }
.main-nav { display: flex; justify-content: flex-end; gap: clamp(18px, 2vw, 31px); font-size: 13px; font-weight: 600; }
.main-nav a { position: relative; padding: 14px 0; white-space: nowrap; }
.main-nav a::after { content: ""; position: absolute; inset: auto 50% 6px; height: 2px; background: var(--gold); transition: .2s; }
.main-nav a:hover::after, .main-nav a.active::after { inset-inline: 0; }
.menu-toggle { display: none; }

.button {
  min-height: 47px;
  padding: 12px 21px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  color: var(--white);
  background: var(--navy);
  border: 1px solid var(--gold);
  border-radius: 5px;
  font-size: 14px;
  font-weight: 600;
  box-shadow: 0 3px 8px rgba(0, 37, 84, .12);
  transition: transform .2s, background .2s;
}
.button:hover { transform: translateY(-2px); background: #0a376f; }
.button-small { min-height: 44px; padding: 10px 16px; font-size: 12px; white-space: nowrap; }
.button-outline { color: var(--navy); background: var(--white); box-shadow: none; }
.button-outline:hover { color: var(--white); }
.calendar-icon, .calendar-large { position: relative; display: inline-block; width: 17px; height: 17px; border: 1.5px solid currentColor; border-radius: 2px; }
.calendar-icon::before, .calendar-large::before { content: ""; position: absolute; inset: 4px 2px auto; border-top: 1.5px solid currentColor; }

.hero { height: 382px; position: relative; overflow: hidden; background: #f3f0eb; }
.hero-image { position: absolute; inset: 0 0 0 41%; background: url("assets/consultation-hero.webp") 54% center/cover no-repeat; }
.hero::after { content: ""; position: absolute; z-index: 1; inset: 0 49% 0 0; background: linear-gradient(90deg, #fff 58%, rgba(255,255,255,.88) 82%, transparent); }
.hero-path { position: absolute; z-index: 2; inset: 0; pointer-events: none; }
.hero-path svg { width: 100%; height: 100%; overflow: visible; }
.hero-path-line {
  fill: none;
  stroke: rgba(189, 139, 47, .68);
  stroke-width: 2;
  stroke-linecap: round;
  stroke-dasharray: 1;
  stroke-dashoffset: 1;
  vector-effect: non-scaling-stroke;
  animation: hero-path-draw 1.65s cubic-bezier(.3, .7, .2, 1) .45s forwards;
}
.hero-path-star {
  fill: var(--gold);
  opacity: 0;
  transform-box: fill-box;
  transform-origin: center;
  animation: hero-star-arrive .55s cubic-bezier(.2, .9, .25, 1.35) 1.85s forwards;
}
.hero-copy { position: relative; z-index: 3; width: min(1020px, calc(100% - 64px)); margin: auto; padding: 57px 48% 40px 0; }
.homepage .hero-image { animation: hero-image-settle 1.6s ease-out both; }
.homepage .hero-copy h1,
.homepage .hero-copy > p,
.homepage .hero-copy .button-row {
  opacity: 0;
  transform: translateY(16px);
  animation: hero-copy-arrive .7s cubic-bezier(.2, .7, .2, 1) forwards;
}
.homepage .hero-copy h1 { animation-delay: .12s; }
.homepage .hero-copy > p { animation-delay: .5s; }
.homepage .hero-copy .button-row { animation-delay: .68s; }
.homepage .hero-copy .gold-rule { width: 0; animation: hero-rule-grow .55s ease-out .38s forwards; }
h1 { margin: 0; color: var(--navy-deep); font-size: 43px; letter-spacing: -.02em; }
.gold-rule { display: block; width: 72px; height: 3px; margin-top: 15px; background: var(--gold); border-radius: 3px; }
.hero-copy > p { max-width: 440px; margin: 18px 0 20px; color: #33445d; font-size: 13px; line-height: 1.5; }
.button-row { display: flex; flex-wrap: wrap; gap: 18px; }

.js .homepage [data-reveal],
.js .homepage [data-reveal-group] > * {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity .68s ease, transform .68s cubic-bezier(.2, .7, .2, 1);
  transition-delay: var(--reveal-delay, 0ms);
}
.js .homepage [data-reveal].is-visible,
.js .homepage [data-reveal-group] > *.is-visible {
  opacity: 1;
  transform: translateY(0);
}

@keyframes hero-image-settle {
  from { transform: scale(1.035); }
  to { transform: scale(1); }
}

@keyframes hero-copy-arrive {
  to { opacity: 1; transform: translateY(0); }
}

@keyframes hero-rule-grow {
  to { width: 72px; }
}

@keyframes hero-path-draw {
  to { stroke-dashoffset: 0; }
}

@keyframes hero-star-arrive {
  0% { opacity: 0; transform: scale(.2) rotate(-25deg); }
  70% { opacity: 1; transform: scale(1.18) rotate(5deg); }
  100% { opacity: 1; transform: scale(1) rotate(0); }
}

.trust-strip {
  position: relative;
  z-index: 3;
  margin-top: -1px;
  min-height: 78px;
  padding: 12px 25px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  align-items: center;
  background: rgba(255,255,255,.98);
  border: 1px solid #e9e7e2;
  border-radius: 10px;
  box-shadow: var(--shadow);
}
.trust-strip > div { min-height: 45px; padding: 0 22px; display: flex; align-items: center; justify-content: center; gap: 14px; text-align: center; font-size: 12px; }
.trust-strip > div + div { border-left: 1px solid rgba(189,139,47,.45); }
.line-icon { width: 38px; height: 38px; position: relative; display: block; flex: 0 0 auto; color: var(--navy); }
.shield-icon::before { content: "♢"; position: absolute; inset: -10px 0 0; color: var(--navy); font: 54px/1 Georgia, serif; transform: scaleX(.72); }
.shield-icon::after { content: ""; position: absolute; width: 8px; height: 14px; left: 14px; top: 8px; border: solid var(--gold); border-width: 0 3px 3px 0; transform: rotate(45deg); }
.person-icon::before { content: ""; position: absolute; width: 13px; height: 13px; left: 12px; top: 1px; border: 2px solid var(--navy); border-radius: 50%; }
.person-icon::after { content: ""; position: absolute; width: 29px; height: 15px; left: 4px; bottom: 2px; border: 2px solid var(--navy); border-radius: 50% 50% 45% 45%; }
.care-icon::before { content: "♡"; position: absolute; top: -12px; left: 7px; color: var(--navy); font: 39px Georgia, serif; }
.care-icon::after { content: "⌣"; position: absolute; left: 1px; bottom: -7px; width: 36px; color: var(--gold); font-size: 31px; text-align: center; }

.section { padding-block: 31px; }
.section-title { display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: 36px; margin-bottom: 22px; text-align: center; }
.section-title span { height: 1px; background: linear-gradient(90deg, transparent, var(--gold)); }
.section-title span:last-child { background: linear-gradient(90deg, var(--gold), transparent); }
.section-title h2 { margin: 0; color: var(--navy-deep); font-size: 31px; white-space: nowrap; }
.card { background: var(--white); border: 1px solid #e8e5df; border-radius: 8px; box-shadow: 0 5px 13px rgba(0, 37, 84, .065); }
.treatment-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 13px; }
.treatment-card { min-width: 0; min-height: 208px; padding: 16px 10px 12px; overflow: hidden; display: grid; grid-template-rows: 62px 42px 1fr; align-items: start; text-align: center; transition: transform .2s, box-shadow .2s; }
.treatment-card:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.treatment-card h3 { min-height: 0; margin: 0; padding: 0 2px; display: grid; place-items: center; align-self: stretch; overflow-wrap: anywhere; color: var(--navy); font-size: 14px; line-height: 1.15; }
.treatment-card p { margin: 5px 0 0; align-self: start; color: #425169; font-size: 11px; line-height: 1.42; }
.procedure-icon { width: 58px; height: 55px; position: relative; margin: 0 auto; align-self: center; color: var(--gold); }
.stomach-icon::before, .bypass-icon::before { content: ""; position: absolute; width: 32px; height: 40px; left: 12px; top: 8px; border: 3px solid var(--gold); border-top-color: transparent; border-radius: 35% 55% 45% 55%; transform: rotate(20deg); }
.stomach-icon::after, .bypass-icon::after { content: ""; position: absolute; width: 14px; height: 25px; left: 12px; top: 0; border-right: 3px solid var(--gold); border-radius: 50%; }
.bypass-icon::before { background: linear-gradient(135deg, transparent 48%, var(--gold) 49% 55%, transparent 56%); }
.balloon-icon { width: 48px; height: 48px; top: 3px; border: 2px solid var(--gold); border-radius: 50%; }
.balloon-icon::after { content: ""; position: absolute; right: 4px; top: 6px; width: 11px; height: 15px; border-right: 2px solid var(--gold); border-radius: 50%; }
.capsule-icon { width: 55px; height: 28px; top: 13px; border: 2px solid var(--gold); border-radius: 18px; transform: rotate(-45deg); }
.capsule-icon::after { content: ""; position: absolute; left: 25px; top: 0; height: 24px; border-left: 2px solid var(--gold); }
.band-icon { width: 57px; height: 27px; top: 13px; border: 2px solid var(--gold); border-radius: 50%; box-shadow: inset 0 0 0 5px #fff, inset 0 0 0 7px var(--gold); }
.band-icon::after { content: ""; position: absolute; width: 9px; height: 7px; left: 23px; bottom: -5px; border: 2px solid var(--gold); border-radius: 2px; background: #fff; }
.scope-icon::before { content: ""; position: absolute; width: 4px; height: 52px; left: 30px; top: 0; background: var(--gold); border-radius: 4px; transform: rotate(35deg); }
.scope-icon::after { content: "✣"; position: absolute; left: 27px; top: -7px; color: var(--navy); font-size: 18px; }

.journey-section { padding-top: 5px; background: #fff; }
.journey-grid { display: grid; grid-template-columns: repeat(4, 1fr); }
.journey-grid article { position: relative; padding: 0 24px; text-align: center; }
.journey-grid article:not(:last-child)::after { content: ""; position: absolute; z-index: 0; top: 16px; left: 65%; width: 70%; height: 1px; background: var(--gold); }
.journey-grid b { width: 34px; height: 34px; position: relative; z-index: 2; margin: auto; display: grid; place-items: center; color: var(--white); background: var(--navy); border-radius: 50%; font-size: 13px; }
.journey-icon { width: 50px; height: 48px; position: relative; margin: 10px auto 3px; color: var(--gold); }
.enquiry-icon::before, .plan-icon::before { content: ""; position: absolute; width: 30px; height: 39px; left: 8px; top: 3px; border: 2px solid var(--gold); border-radius: 3px; }
.enquiry-icon::after { content: "✓"; position: absolute; right: 1px; bottom: 0; font-size: 28px; }
.assessment-icon::before { content: ""; position: absolute; width: 15px; height: 15px; left: 17px; top: 2px; border: 2px solid var(--gold); border-radius: 50%; }
.assessment-icon::after { content: ""; position: absolute; width: 34px; height: 20px; left: 8px; bottom: 3px; border: 2px solid var(--gold); border-radius: 50% 50% 10px 10px; }
.plan-icon::after { content: "✓\A✓"; white-space: pre; position: absolute; left: 18px; top: 7px; font-size: 13px; line-height: 15px; }
.ongoing-icon::before { content: "♧"; position: absolute; inset: -11px 0 0; color: var(--gold); font: 62px Georgia, serif; transform: rotate(180deg); }
.journey-grid h3 { min-height: 38px; margin: 5px 0 3px; color: var(--navy); font-size: 13px; line-height: 1.15; }
.journey-grid p, .clinical-note { color: #425169; font-size: 11px; }
.journey-grid p { margin: 0; line-height: 1.45; }
.clinical-note { margin: 20px 0 0; text-align: center; }

.costs-section { padding-top: 14px; padding-bottom: 14px; }
.costs-section .section-title { margin-bottom: 16px; }
.costs-section .section-title h2 { font-size: 25px; }
.info-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; }
.info-card { min-height: 119px; padding: 13px; display: grid; grid-template-columns: 70px 1fr auto; align-items: center; gap: 10px; transition: transform .2s; }
.info-card:hover { transform: translateY(-3px); }
.info-card i { width: 59px; height: 59px; display: grid; place-items: center; color: var(--gold); background: #faf8f4; border: 2px solid var(--gold); border-radius: 50%; font: normal 27px Georgia, serif; box-shadow: 0 0 0 9px #f7f6f3; }
.info-card h3 { margin: 0 0 4px; font-family: Georgia, serif; font-size: 15px; }
.info-card p { margin: 0; color: #46546a; font-size: 10px; line-height: 1.35; }
.info-card b { align-self: end; color: var(--navy); font-size: 22px; font-weight: 400; }
.info-card i.chat-icon::before { content: ""; width: 31px; height: 24px; border: 2px solid var(--gold); border-radius: 50%; }

.contact-banner { position: relative; overflow: hidden; color: var(--white); background: linear-gradient(100deg, #002454, #002e67); }
.contact-banner::after { content: ""; position: absolute; width: 170px; height: 170px; right: -25px; bottom: -115px; border: 4px solid var(--gold); border-radius: 50%; opacity: .65; }
.contact-inner { min-height: 128px; display: grid; grid-template-columns: 120px 1fr auto; align-items: center; gap: 25px; }
.contact-symbol { width: 82px; height: 82px; display: grid; place-items: center; color: var(--gold-light); border: 2px solid var(--gold); border-radius: 50%; }
.calendar-large { width: 34px; height: 38px; border-width: 2px; }
.contact-inner h2 { margin: 0 0 7px; font-size: 30px; }
.contact-inner p { max-width: 560px; margin: 0; color: #e0e7ef; font-size: 12px; }
.button-gold-outline { min-width: 220px; background: transparent; border: 2px solid var(--gold); box-shadow: none; }

.site-footer { color: #40516a; background: #fff; }
.footer-grid { padding-block: 20px; display: grid; grid-template-columns: 1fr 1fr 1.3fr; gap: 35px; }
.footer-grid > div { padding-right: 25px; display: flex; flex-direction: column; gap: 5px; font-size: 11px; }
.footer-grid > div:not(:last-child) { border-right: 1px solid rgba(189,139,47,.65); }
.footer-grid strong { margin-bottom: 2px; color: var(--navy); font-family: Georgia, serif; font-size: 13px; }
.footer-grid a:hover { color: var(--gold); }
.footer-grid p { margin: 0 0 7px; }
.footer-bottom { padding: 10px 0; color: #fff; background: var(--navy-deep); font-size: 10px; }
.footer-bottom .wrap { display: flex; justify-content: space-between; align-items: center; gap: 20px; }
.legal-links { display: flex; gap: 16px; }
.legal-links a { color: #fff; text-decoration: underline; text-underline-offset: 3px; }
.legal-links a:hover { color: var(--gold-light); }

.eyebrow { margin: 0 0 8px; color: var(--gold); font-size: 11px; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; }
.page-hero { padding: 62px 0 58px; color: #fff; background: radial-gradient(circle at 85% 20%, rgba(189,139,47,.24), transparent 28%), linear-gradient(110deg, var(--navy-deep), #06376e); }
.page-hero-inner { max-width: 760px; margin-left: max(32px, calc((100% - 1020px) / 2)); }
.page-hero h1 { color: #fff; font-size: clamp(38px, 5vw, 56px); }
.page-hero p:last-child { max-width: 670px; margin: 18px 0 0; color: #dce6f1; font-size: 15px; }
.page-hero .eyebrow { color: var(--gold-light); }
.intro-grid { display: grid; grid-template-columns: .8fr 1.2fr; gap: 70px; align-items: start; }
.intro-grid h2, .decision-panel h2, .contact-details h2 { margin: 0; color: var(--navy-deep); font: 500 34px/1.12 "Playfair Display", Georgia, serif; }
.prose p { margin: 0 0 14px; color: var(--muted); font-size: 14px; line-height: 1.65; }
.soft-section { background: linear-gradient(180deg, #faf9f6, #fff); border-block: 1px solid #eeeae3; }
.procedure-list { display: grid; gap: 16px; }
.detail-card { scroll-margin-top: 20px; padding: 25px 30px; display: grid; grid-template-columns: 90px 1fr; gap: 26px; background: #fff; border: 1px solid #e7e2d9; border-radius: 9px; box-shadow: var(--shadow); }
.detail-card .procedure-icon { margin-top: 17px; transform: scale(1.18); }
.detail-card h2 { margin: 2px 0 9px; color: var(--navy-deep); font-size: 26px; }
.detail-card p { margin: 0; color: var(--muted); font-size: 13px; line-height: 1.55; }
.detail-card ul { margin: 13px 0 0; padding-left: 18px; display: flex; flex-wrap: wrap; gap: 6px 28px; color: #344760; font-size: 12px; }
.option-type { color: var(--gold); font-size: 10px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; }
.decision-panel { display: flex; align-items: center; justify-content: space-between; gap: 50px; }
.decision-panel > div { max-width: 700px; }
.decision-panel p:last-child { margin: 12px 0 0; color: var(--muted); font-size: 13px; }
.decision-panel .button { flex: 0 0 auto; }
.step-list { max-width: 840px; margin: auto; }
.step-list article { position: relative; padding: 5px 0 30px 100px; display: grid; grid-template-columns: 1fr; }
.step-list article:not(:last-child)::before { content: ""; position: absolute; left: 34px; top: 52px; bottom: 0; border-left: 1px solid var(--gold); }
.step-list b { width: 68px; height: 48px; position: absolute; left: 0; top: 0; display: grid; place-items: center; color: #fff; background: var(--navy); border-radius: 30px; font-size: 14px; letter-spacing: .05em; }
.step-list h2 { margin: 0 0 7px; color: var(--navy-deep); font-size: 24px; }
.step-list p { margin: 0; color: var(--muted); font-size: 13px; line-height: 1.6; }
.support-grid, .cost-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.support-grid > div, .cost-grid article { padding: 25px; background: #fff; border: 1px solid #e8e3db; border-radius: 8px; box-shadow: 0 5px 15px rgba(0,37,84,.05); }
.support-grid h2 { margin: 0 0 10px; color: var(--navy-deep); font-size: 22px; }
.support-grid p:last-child, .cost-grid p { margin: 0; color: var(--muted); font-size: 12px; line-height: 1.55; }
.cost-grid article { text-align: center; }
.cost-grid span { width: 38px; height: 38px; margin: 0 auto 12px; display: grid; place-items: center; color: #fff; background: var(--navy); border-radius: 50%; font-weight: 700; }
.cost-grid h3 { margin: 0 0 8px; color: var(--navy); font-size: 15px; }
.faq-section { scroll-margin-top: 20px; }
.faq-section details { border-bottom: 1px solid #ddd7cc; }
.faq-section summary { position: relative; padding: 20px 48px 20px 4px; color: var(--navy); font-weight: 600; cursor: pointer; list-style: none; }
.faq-section summary::-webkit-details-marker { display: none; }
.faq-section summary::after { content: "+"; position: absolute; right: 8px; top: 13px; color: var(--gold); font: 28px Georgia, serif; }
.faq-section details[open] summary::after { content: "−"; }
.faq-section details p { max-width: 820px; margin: -5px 0 20px 4px; color: var(--muted); font-size: 13px; line-height: 1.6; }
.contact-layout { display: grid; grid-template-columns: .8fr 1.2fr; gap: 55px; align-items: start; }
.contact-details > p { color: var(--muted); font-size: 13px; line-height: 1.6; }
.contact-details > a { margin-top: 18px; padding: 16px 0; display: flex; flex-direction: column; border-bottom: 1px solid #ddd7cc; }
.contact-details > a span { color: var(--gold); font-size: 10px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; }
.contact-details > a strong { margin-top: 3px; color: var(--navy); font-size: 17px; }
.contact-note { margin-top: 28px; padding: 18px; background: #f7f4ee; border-left: 3px solid var(--gold); }
.contact-note strong { color: var(--navy); }
.contact-note p { margin: 5px 0 0; color: var(--muted); font-size: 11px; line-height: 1.5; }
.contact-form { padding: 30px; }
.contact-form h2 { margin: 0; color: var(--navy-deep); font-size: 29px; }
.contact-form > p { margin: 5px 0 20px; color: var(--muted); font-size: 11px; }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 15px; }
.form-grid label { display: flex; flex-direction: column; gap: 6px; color: var(--navy); font-size: 11px; font-weight: 600; }
.form-grid input, .form-grid select, .form-grid textarea { width: 100%; padding: 11px 12px; color: #243b59; background: #fff; border: 1px solid #cfc8bd; border-radius: 4px; font: inherit; font-size: 13px; }
.form-grid input:focus, .form-grid select:focus, .form-grid textarea:focus { outline: 2px solid rgba(189,139,47,.28); border-color: var(--gold); }
.form-grid textarea { resize: vertical; }
.full-field { grid-column: 1 / -1; }
.consent { flex-direction: row !important; align-items: flex-start; font-weight: 400 !important; line-height: 1.45; }
.consent input { width: auto; margin: 2px 3px 0 0; }
.honeypot { position: absolute; left: -9999px; }
.form-submit { margin-top: 20px; border: 0; cursor: pointer; }
.form-submit:disabled { opacity: .65; cursor: wait; }
.form-status { min-height: 18px; margin: 12px 0 0 !important; font-size: 12px !important; font-weight: 600; }
.form-status.success { color: #21643b; }
.form-status.error { color: #a22828; }
.form-privacy { margin-bottom: 0 !important; }
.consent a, .collection-notice a, .policy-content a { color: var(--navy); text-decoration: underline; text-underline-offset: 2px; }
.collection-notice { margin-top: 18px; padding: 15px; color: var(--muted); background: #f8f6f1; border-left: 3px solid var(--gold); }
.collection-notice strong { color: var(--navy); font-size: 12px; }
.collection-notice p { margin: 5px 0 0; font-size: 10px; line-height: 1.5; }
.clinical-disclaimer { margin: 0 0 18px; padding: 16px 19px; color: #354760; background: #fff; border: 1px solid #e5ded2; border-left: 4px solid var(--gold); border-radius: 5px; font-size: 12px; line-height: 1.55; }
.policy-content { max-width: 850px; }
.policy-content h2 { margin: 32px 0 9px; color: var(--navy-deep); font-size: 24px; }
.policy-content h2:first-of-type { margin-top: 10px; }
.policy-content p, .policy-content li { color: var(--muted); font-size: 13px; line-height: 1.7; }
.policy-content p { margin: 0 0 14px; }
.policy-content ul { margin: 0 0 16px; padding-left: 22px; }
.policy-updated { color: var(--gold) !important; font-size: 11px !important; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }

@media (max-width: 1040px) {
  .site-header { grid-template-columns: 255px 1fr auto; padding-inline: 25px; }
  .brand img { width: 245px; }
  .main-nav { gap: 15px; font-size: 12px; }
  .hero-copy { padding-right: 52%; }
  h1 { font-size: 38px; }
  .treatment-grid { grid-template-columns: repeat(3, 1fr); }
  .treatment-card { min-height: 190px; }
  .page-hero-inner { margin-left: 32px; }
}

@media (max-width: 820px) {
  body { padding: 0; }
  .site-shell { width: 100vw; max-width: 100vw; border: 0; }
  .wrap { width: calc(100vw - 32px); max-width: 680px; }
  .site-header { height: 82px; grid-template-columns: 1fr auto; padding: 7px 18px; }
  .brand img { width: 190px; height: 66px; }
  .menu-toggle { width: 44px; height: 44px; display: grid; place-content: center; gap: 5px; background: transparent; border: 0; }
  .menu-toggle span:not(.sr-only) { width: 25px; height: 2px; display: block; background: var(--navy); }
  .main-nav { display: none; position: absolute; top: 82px; left: 0; right: 0; padding: 18px 24px 26px; flex-direction: column; align-items: center; background: #fff; box-shadow: var(--shadow); }
  .main-nav.open { display: flex; }
  .header-cta { display: none; }
  .hero { height: 680px; display: flex; align-items: flex-end; }
  .hero-path { display: none; }
  .hero-image { inset: 0 0 300px; background-position: 58% center; }
  .hero::after { inset: 33% 0 0; background: linear-gradient(0deg, #fff 57%, rgba(255,255,255,.9) 78%, transparent); }
  .hero-copy { width: calc(100vw - 32px); max-width: 680px; min-width: 0; padding: 360px 0 38px; }
  h1 { max-width: 100%; font-size: clamp(35px, 10vw, 42px); overflow-wrap: anywhere; }
  .hero-copy > p { font-size: 14px; }
  .trust-strip { margin-top: 0; grid-template-columns: 1fr; padding: 10px 22px; border-radius: 0; width: 100%; }
  .trust-strip > div { justify-content: flex-start; }
  .trust-strip > div + div { border: 0; border-top: 1px solid rgba(189,139,47,.3); }
  .section { padding-block: 48px; }
  .journey-grid { grid-template-columns: 1fr 1fr; gap: 42px 0; }
  .journey-grid article:nth-child(2)::after { display: none; }
  .info-grid { grid-template-columns: 1fr; }
  .contact-inner { padding-block: 30px; grid-template-columns: 82px 1fr; }
  .contact-symbol { width: 70px; height: 70px; }
  .contact-inner .button { grid-column: 2; justify-self: start; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .footer-grid > div:last-child { grid-column: 1 / -1; }
  .page-hero { padding-block: 48px; }
  .page-hero-inner { margin-inline: auto; }
  .intro-grid, .contact-layout { grid-template-columns: 1fr; gap: 30px; }
  .support-grid, .cost-grid { grid-template-columns: 1fr; }
  .decision-panel { align-items: flex-start; flex-direction: column; gap: 22px; }
}

@media (max-width: 560px) {
  .hero { height: 720px; }
  .hero-copy { padding-top: 340px; }
  .button-row .button { width: 100%; }
  .section-title { gap: 12px; }
  .section-title h2, .costs-section .section-title h2 { font-size: 25px; white-space: normal; }
  .treatment-grid { min-width: 0; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: 10px; }
  .treatment-card { min-height: 210px; }
  .journey-grid { grid-template-columns: 1fr; gap: 38px; }
  .journey-grid article::after { display: none; }
  .info-card { grid-template-columns: 66px 1fr; }
  .info-card b { display: none; }
  .contact-inner { grid-template-columns: 1fr; text-align: center; }
  .contact-symbol { margin: auto; }
  .contact-inner .button { grid-column: 1; justify-self: center; }
  .footer-grid { grid-template-columns: 1fr; }
  .footer-grid > div, .footer-grid > div:not(:last-child) { padding: 0 0 17px; border-right: 0; border-bottom: 1px solid rgba(189,139,47,.35); }
  .footer-grid > div:last-child { grid-column: auto; }
  .footer-bottom .wrap { flex-direction: column; align-items: center; text-align: center; gap: 8px; }
  .legal-links { gap: 12px; }
  .page-hero h1 { font-size: 37px; }
  .page-hero p:last-child { font-size: 13px; }
  .detail-card { padding: 22px 18px; grid-template-columns: 1fr; gap: 5px; }
  .detail-card .procedure-icon { margin: 5px auto 12px; }
  .detail-card ul { display: block; }
  .detail-card li + li { margin-top: 5px; }
  .step-list article { padding-left: 65px; }
  .step-list b { width: 48px; height: 40px; }
  .step-list article:not(:last-child)::before { left: 24px; top: 44px; }
  .form-grid { grid-template-columns: 1fr; }
  .full-field { grid-column: auto; }
  .contact-form { padding: 22px 17px; }
}

@media (prefers-reduced-motion: reduce) {
  .homepage .hero-image,
  .homepage .hero-copy h1,
  .homepage .hero-copy > p,
  .homepage .hero-copy .button-row,
  .homepage .hero-copy .gold-rule,
  .hero-path-line,
  .hero-path-star {
    animation: none !important;
  }

  .homepage .hero-copy h1,
  .homepage .hero-copy > p,
  .homepage .hero-copy .button-row,
  .js .homepage [data-reveal],
  .js .homepage [data-reveal-group] > * {
    opacity: 1;
    transform: none;
    transition: none;
  }

  .homepage .hero-copy .gold-rule { width: 72px; }
  .hero-path-line { stroke-dashoffset: 0; }
  .hero-path-star { opacity: 1; }
}
