/* ===========================================================
 * legal-page.css
 * Shared styling for long-form policy & legal pages
 * (Privacy Policy, Terms, NPP, Medical Disclaimer,
 *  Accessibility, Good Faith Estimate)
 * Builds on colors_and_type.css (v3 design system).
 * =========================================================== */

html, body { margin: 0; padding: 0; }
body.lp-bg {
  font-family: var(--font-sans);
  color: var(--navy-500);
  background: var(--grad-page-v3) no-repeat;
  background-attachment: fixed;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; display: block; }
a { color: inherit; }

/* ─── Top nav (matches hub) ─── */
.nav { position: sticky; top: 0; z-index: 50; background: rgba(255,255,255,0.96); backdrop-filter: saturate(140%) blur(8px); border-bottom: 1px solid var(--gray-100); }
.nav__inner { max-width: 1320px; margin: 0 auto; padding: 14px 32px; display: flex; align-items: center; gap: 32px; }
.nav__logo { display: flex; align-items: center; gap: 12px; text-decoration: none; color: var(--navy-700); flex-shrink: 0; }
.nav__logo img { width: 44px; height: 44px; }
.nav__brand { font-family: var(--font-accent); font-weight: 800; font-size: 16px; letter-spacing: 0.04em; line-height: 1.05; text-transform: uppercase; color: var(--pink-500); }
.nav__brand small { display: block; font-family: var(--font-sans); font-weight: 500; font-size: 11px; letter-spacing: 0.06em; color: var(--navy-400); text-transform: uppercase; margin-top: 2px; }
.nav__links { display: flex; align-items: center; gap: 28px; margin-left: auto; font-family: var(--font-sans); font-weight: 600; font-size: 14px; }
.nav__links a { text-decoration: none; color: var(--navy-500); }
.nav__links a:hover { color: var(--pink-500); }
.nav .btn { height: 44px; padding: 0 22px; font-size: 12px; }
@media (max-width: 980px) { .nav__links { display: none; } }

/* ─── Layout ─── */
.lp-section { padding: clamp(40px, 6vw, 72px) 32px; }
.lp-section--hero { padding-top: clamp(64px, 9vw, 112px); padding-bottom: clamp(20px, 3vw, 40px); }
.lp-inner { max-width: 920px; margin: 0 auto; }
.lp-inner--narrow { max-width: 760px; margin: 0 auto; }

/* ─── Breadcrumb ─── */
.lp-crumbs { font-family: var(--font-sans); font-size: 13px; font-weight: 600; color: var(--navy-700); margin-bottom: 22px; letter-spacing: 0.02em; }
.lp-crumbs a { color: var(--pink-600); text-decoration: none; }
.lp-crumbs a:hover { text-decoration: underline; text-underline-offset: 3px; }
.lp-crumbs span[aria-hidden] { color: var(--navy-300); margin: 0 8px; }

/* ─── Hero ─── */
.lp-eyebrow {
  font-family: var(--font-accent); font-weight: 700; font-size: 13px;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--pink-500); margin: 0 0 18px;
}
.lp-h1 {
  font-family: var(--font-display); font-weight: 800;
  font-size: clamp(36px, 4.6vw, 56px);
  line-height: 1.04; letter-spacing: -0.025em;
  color: var(--pink-500);
  margin: 0 0 18px; text-wrap: balance;
}
.lp-lede {
  font-size: clamp(16px, 1.25vw, 19px); line-height: 1.6;
  color: var(--navy-700); margin: 0; max-width: 60ch;
  text-wrap: pretty;
}

/* ─── Version banner (right under hero) ─── */
.lp-version {
  margin: 28px 0 0;
  padding: 14px 22px;
  display: flex; align-items: center; gap: 22px;
  flex-wrap: wrap;
  font-family: var(--font-sans); font-size: 13.5px;
  color: var(--navy-600);
  border-radius: var(--radius-md);
  background: rgba(255,255,255,0.55);
  border: 1px solid rgba(31, 45, 64, 0.07);
}
.lp-version__label {
  font-family: var(--font-accent); font-weight: 700; font-size: 11.5px;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--pink-600);
}
.lp-version__sep { color: var(--navy-200); }
.lp-version__pdf {
  margin-left: auto;
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 16px;
  background: var(--navy-700);
  color: #fff !important;
  border-radius: var(--radius-pill);
  text-decoration: none !important;
  font-family: var(--font-accent); font-weight: 700; font-size: 11.5px;
  letter-spacing: 0.12em; text-transform: uppercase;
  transition: background 0.18s ease, transform 0.18s ease;
}
.lp-version__pdf:hover { background: var(--pink-600); transform: translateY(-1px); }
.lp-version__pdf svg { width: 14px; height: 14px; flex: none; }

/* ─── Review notice (for drafted-from-scratch pages) ─── */
.lp-notice {
  margin: 24px 0 0;
  padding: 16px 22px;
  background: rgba(244, 173, 188, 0.12);
  border-left: 3px solid var(--pink-400);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  font-size: 14px; line-height: 1.6;
  color: var(--navy-700);
}
.lp-notice strong {
  font-family: var(--font-accent); font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.1em; font-size: 11.5px;
  color: var(--pink-700); display: block; margin-bottom: 4px;
}

/* ─── Prose container (main policy body) ─── */
.lp-prose {
  padding: clamp(32px, 5vw, 56px) clamp(24px, 5vw, 56px);
}
.lp-prose h2 {
  font-family: var(--font-display); font-weight: 800;
  font-size: clamp(22px, 2.4vw, 28px);
  line-height: 1.2; letter-spacing: -0.012em;
  color: var(--pink-500);
  margin: 40px 0 14px; text-wrap: balance;
  scroll-margin-top: 96px;
}
.lp-prose h2:first-child { margin-top: 0; }
.lp-prose h3 {
  font-family: var(--font-display); font-weight: 700;
  font-size: 17px;
  color: var(--navy-900);
  margin: 24px 0 8px;
  line-height: 1.3;
}
.lp-prose p, .lp-prose li {
  font-size: 16px;
  line-height: 1.65;
  color: var(--navy-700);
}
.lp-prose p { margin: 0 0 14px; }
.lp-prose ul, .lp-prose ol { margin: 0 0 16px; padding-left: 22px; }
.lp-prose li { margin-bottom: 6px; }
.lp-prose li::marker { color: var(--pink-400); }
.lp-prose strong { color: var(--navy-900); font-weight: 700; }
.lp-prose em { color: var(--navy-600); font-style: italic; }
.lp-prose a {
  color: var(--pink-600);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
}
.lp-prose a:hover { color: var(--pink-700); }
.lp-prose hr {
  border: 0;
  border-top: 1px solid var(--gray-200);
  margin: 36px 0;
}

/* Pull-quote / callout */
.lp-prose .lp-callout {
  margin: 20px 0;
  padding: 18px 22px;
  background: rgba(244, 173, 188, 0.10);
  border-left: 4px solid var(--pink-400);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
}
.lp-prose .lp-callout p:last-child { margin-bottom: 0; }
.lp-prose .lp-callout strong { color: var(--pink-700); }

/* Emergency callout — for medical disclaimer */
.lp-prose .lp-callout--alert {
  background: rgba(194, 99, 138, 0.10);
  border-left-color: var(--pink-600);
}
.lp-prose .lp-callout--alert strong { color: var(--pink-700); }

/* ─── Table of contents (jump links) ─── */
.lp-toc {
  margin: 32px 0;
  padding: 22px 26px;
  background: rgba(255,255,255,0.62);
  border-radius: var(--radius-lg);
  border: 1px solid rgba(31, 45, 64, 0.06);
}
.lp-toc__label {
  font-family: var(--font-accent); font-weight: 700; font-size: 11.5px;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--pink-600); margin: 0 0 10px;
}
.lp-toc ul { list-style: none; margin: 0; padding: 0; display: grid; grid-template-columns: 1fr 1fr; gap: 4px 24px; }
@media (max-width: 640px) { .lp-toc ul { grid-template-columns: 1fr; } }
.lp-toc li { margin: 0; }
.lp-toc li::marker { content: ''; }
.lp-toc a {
  color: var(--navy-700);
  text-decoration: none;
  font-size: 14.5px;
  line-height: 1.5;
  display: block;
  padding: 4px 0;
}
.lp-toc a:hover { color: var(--pink-600); }

/* ─── Contact block ─── */
.lp-contact {
  margin: 36px 0 0;
  padding: 24px 28px;
  background: rgba(255,255,255,0.6);
  border-radius: var(--radius-lg);
  border-left: 4px solid var(--pink-500);
}
.lp-contact__label {
  font-family: var(--font-accent); font-weight: 700; font-size: 11.5px;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--pink-600); margin: 0 0 10px;
}
.lp-contact p { margin: 0 0 4px; font-size: 15px; line-height: 1.55; color: var(--navy-700); }
.lp-contact p:last-child { margin-bottom: 0; }
.lp-contact strong { color: var(--navy-900); }
.lp-contact a { color: var(--pink-600); text-decoration: underline; text-underline-offset: 3px; }

/* ─── Cross-links to sibling policies ─── */
.lp-related {
  margin: 48px 0 0;
}
.lp-related__label {
  font-family: var(--font-accent); font-weight: 700; font-size: 11.5px;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--pink-600); margin: 0 0 14px;
  text-align: center;
}
.lp-related__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 14px;
}
.lp-related a {
  display: block;
  padding: 18px 20px;
  background: rgba(255,255,255,0.62);
  border-radius: var(--radius-lg);
  border: 1px solid rgba(31, 45, 64, 0.06);
  text-decoration: none;
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}
.lp-related a:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.lp-related__title {
  font-family: var(--font-display); font-weight: 700;
  font-size: 15.5px; color: var(--pink-600);
  margin: 0 0 4px;
  line-height: 1.3;
}
.lp-related__sub {
  font-size: 13px; color: var(--navy-500); margin: 0;
  line-height: 1.45;
}

/* ─── Final band (navy) ─── */
/* Final CTA → LIGHT frosted card + Case-A fade (enabled below). Was a navy gradient band. */
.lp-final {
  position: relative;
  max-width: 820px; width: calc(100% - 48px);
  margin: clamp(48px, 7vw, 80px) auto 0;
  padding: clamp(40px,5.5vw,60px) clamp(28px,4vw,48px);
  background: var(--card-lift-bg); backdrop-filter: var(--card-lift-blur); -webkit-backdrop-filter: var(--card-lift-blur);
  border: 1px solid rgba(255,255,255,0.6); border-radius: var(--radius-xl);
  box-shadow: 0 18px 50px -28px rgba(41,52,72,0.35);
  color: var(--navy-500);
  text-align: center;
}
.footer-ombre-blend { display: block; }
.lp-final__title {
  font-family: var(--font-display); font-weight: 800;
  font-size: clamp(26px, 3vw, 36px);
  line-height: 1.15; letter-spacing: -0.018em;
  margin: 0 0 14px; text-wrap: balance;
  color: var(--navy-700);
}
.lp-final__body {
  color: var(--navy-500);
  font-size: clamp(14.5px, 1.15vw, 16.5px);
  line-height: 1.6; max-width: 56ch; margin: 0 auto;
}
.lp-final__body a { color: var(--pink-600); text-decoration: underline; text-underline-offset: 3px; }
.lp-final__body a:hover { color: var(--pink-700); }

/* ─── Skip link (accessibility) ─── */
/* position: fixed (not absolute) so the off-screen -40px offset is
   relative to the viewport, not to whatever container GeneratePress
   wraps the page content in (.inside-article). With position:absolute,
   a positioned ancestor pulls the skip link back into the visible
   page flow. With position:fixed, the -40px reliably hides it above
   the top of the viewport until focused. */
.lp-skip {
  position: fixed;
  top: -40px;
  left: 8px;
  background: var(--navy-900);
  color: #fff;
  padding: 8px 16px;
  border-radius: var(--radius-sm);
  text-decoration: none;
  font-size: 13px;
  z-index: 100;
}
.lp-skip:focus { top: 8px; }
