/* ============================================================
   ForgedOps.Ai — Interior landing pages (Locations · Services · Compare)
   WCS Enterprise Suite · Format Standard v3.0
   Inherits the full landing system, then adds interior components.
   ============================================================ */

@import url("./landing.css");

/* ---------- Surface-tone section (light rhythm break) ---------- */
.section--surface { background: var(--color-bg-surface); }

/* ---------- Breadcrumb strip (under nav) ---------- */
.crumbs { background: var(--wcs-navy); border-bottom: 1px solid var(--color-border-dark); }
.crumbs__inner { display: flex; align-items: center; gap: 10px; padding-block: var(--sp-3);
  font-family: var(--font-structural); font-size: var(--fs-caption); font-weight: 500;
  letter-spacing: var(--tracking-oswald); text-transform: uppercase; color: var(--wcs-silver); }
.crumbs__inner a { color: var(--wcs-silver); transition: color var(--dur-fast) var(--ease-out); }
.crumbs__inner a:hover { color: var(--wcs-forge-cyan); }
.crumbs__sep { color: var(--color-border-dark); }
.crumbs__here { color: var(--wcs-white); }

/* ============================================================
   COMPACT HERO — interior pages (copy + exhibit panel)
   ============================================================ */
.hero--compact { padding-block: clamp(48px, 7vw, 88px); }
.hero--compact .hero__inner { grid-template-columns: 1.1fr 0.9fr; align-items: stretch; }
@media (max-width: 920px) { .hero--compact .hero__inner { grid-template-columns: 1fr; } }
.hero--compact h1 { font-size: clamp(1.9rem, 4.2vw, 3rem); max-width: 16ch; }
.hero__locator { display: flex; align-items: center; gap: 10px; color: var(--wcs-silver);
  font-family: var(--font-structural); font-size: var(--fs-caption); letter-spacing: var(--tracking-oswald);
  text-transform: uppercase; margin-top: var(--sp-6); }
.hero__locator .rule { width: 24px; height: 1px; background: var(--wcs-forge-cyan); flex: none; }

/* ---------- Exhibit panel (legal-exhibit aesthetic) ---------- */
.exhibit { align-self: center; width: 100%; background: rgba(255,255,255,0.03);
  border: 1px solid var(--color-border-dark); border-left: 3px solid var(--wcs-forge-cyan);
  border-radius: var(--radius-md); padding: var(--sp-6); }
.exhibit__tag { display: flex; align-items: center; justify-content: space-between; gap: 12px;
  font-family: var(--font-mono); font-size: 0.6875rem; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--wcs-silver); padding-bottom: var(--sp-3); border-bottom: 1px solid var(--color-border-dark);
  margin-bottom: var(--sp-4); }
.exhibit__tag b { color: var(--wcs-forge-cyan); font-weight: 500; }
.exhibit__rows { display: flex; flex-direction: column; }
.exhibit__row { display: flex; align-items: baseline; justify-content: space-between; gap: var(--sp-4);
  padding: var(--sp-3) 0; border-bottom: 1px solid rgba(255,255,255,0.07); }
.exhibit__row:last-child { border-bottom: 0; }
.exhibit__val { font-family: var(--font-display); font-weight: 600; font-size: 1.625rem; line-height: 1;
  color: var(--wcs-white); flex: none; }
.exhibit__val em { font-style: italic; color: var(--wcs-forge-cyan); font-weight: 500; }
.exhibit__key { font-family: var(--font-structural); font-size: 0.6875rem; letter-spacing: var(--tracking-oswald);
  text-transform: uppercase; color: var(--color-text-on-dark-2); line-height: 1.45; text-align: right; }

/* ============================================================
   SECTION HEAD (centered & left variants) + intro
   ============================================================ */
.head { max-width: 760px; }
.head--center { margin-inline: auto; text-align: center; }
.head--center .section-title::after { margin-inline: auto; }
.head--center .eyebrow { border-bottom: 0; padding-bottom: 0; }
.head--center .eyebrow::after { content: ""; display: block; width: 100%; height: 1px; background: var(--wcs-forge-cyan); margin-top: var(--sp-2); }

/* ============================================================
   PROCESS STEPS (numeral indices)
   ============================================================ */
.steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--sp-5); margin-top: var(--sp-7); }
@media (max-width: 900px) { .steps { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px) { .steps { grid-template-columns: 1fr; } }
.step { position: relative; padding-top: var(--sp-5); border-top: 1px solid var(--color-border-subtle); }
.step__index { font-family: var(--font-display); font-weight: 600; font-size: 2.75rem; line-height: 1;
  color: var(--wcs-navy); margin-bottom: var(--sp-3); }
.step h3 { font-family: var(--font-structural); font-weight: 600; font-size: var(--fs-h3);
  text-transform: uppercase; letter-spacing: var(--tracking-oswald); line-height: var(--lh-snug);
  color: var(--wcs-navy); margin-bottom: var(--sp-3); }
.step p { color: var(--color-text-secondary); margin: 0; }
.section--dark .step { border-top-color: var(--color-border-dark); }
.section--dark .step__index { color: var(--wcs-forge-cyan); }
.section--dark .step h3 { color: var(--wcs-white); }
.section--dark .step p { color: var(--color-text-on-dark-2); }

/* ============================================================
   PROSE BLOCK (services "what it does" + location narrative)
   ============================================================ */
.prose { max-width: 64ch; }
.prose p { color: var(--color-text-secondary); margin: 0 0 var(--sp-4); }
.prose p:last-child { margin-bottom: 0; }
.prose strong { color: var(--wcs-navy); font-weight: 600; }
.prose em { font-family: var(--font-display); font-style: italic; color: var(--color-accent-deep); font-size: 1.05em; }

/* Two-column split: narrative + exhibit card on light */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(32px, 5vw, 72px); align-items: center; }
@media (max-width: 880px) { .split { grid-template-columns: 1fr; gap: 40px; } }

/* Light exhibit card (stat list on light surface) */
.statcard { background: var(--wcs-white); border: 1px solid var(--color-border-subtle);
  border-top: 3px solid var(--wcs-navy); border-radius: var(--radius-md); padding: var(--sp-6); box-shadow: var(--shadow-sm); }
.statcard__tag { font-family: var(--font-mono); font-size: 0.6875rem; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--wcs-silver); padding-bottom: var(--sp-3);
  border-bottom: 1px solid var(--color-border-subtle); margin-bottom: var(--sp-4); }
.statcard__row { display: flex; align-items: baseline; justify-content: space-between; gap: var(--sp-4);
  padding: var(--sp-3) 0; border-bottom: 1px solid var(--color-border-subtle); }
.statcard__row:last-child { border-bottom: 0; }
.statcard__val { font-family: var(--font-display); font-weight: 600; font-size: 1.75rem; line-height: 1;
  color: var(--wcs-forge-cyan); flex: none; }
.statcard__key { font-family: var(--font-structural); font-size: 0.6875rem; letter-spacing: var(--tracking-oswald);
  text-transform: uppercase; color: var(--color-text-secondary); text-align: right; line-height: 1.45; }

/* ============================================================
   SUBMARKETS / middot list
   ============================================================ */
.submarkets { display: flex; flex-wrap: wrap; gap: 10px 0; margin-top: var(--sp-6);
  font-family: var(--font-structural); font-size: 0.9375rem; letter-spacing: 0.08em; text-transform: uppercase; }
.submarkets span { color: var(--wcs-navy); }
.submarkets span::after { content: "·"; color: var(--wcs-forge-cyan); margin: 0 14px; }
.submarkets span:last-child::after { content: ""; margin: 0; }
.section--dark .submarkets span { color: var(--color-text-on-dark); }

/* ============================================================
   COMPARISON TABLE
   ============================================================ */
.compare { margin-top: var(--sp-7); border: 1px solid var(--color-border-subtle); border-radius: var(--radius-md);
  overflow: hidden; box-shadow: var(--shadow-sm); }
.compare__row { display: grid; grid-template-columns: 1.3fr 1fr 1fr; }
.compare__row + .compare__row { border-top: 1px solid var(--color-border-subtle); }
.compare__cell { padding: var(--sp-5) var(--sp-5); }
.compare__cell--feat { font-family: var(--font-structural); font-weight: 500; font-size: 0.8125rem;
  letter-spacing: 0.06em; text-transform: uppercase; color: var(--wcs-navy); display: flex; align-items: center; }
.compare__cell--us { background: var(--wcs-navy); color: var(--wcs-white); }
.compare__cell--them { color: var(--color-text-secondary); background: var(--wcs-white); }
.compare__head .compare__cell { padding-block: var(--sp-4); }
.compare__head .compare__cell--feat { background: var(--color-bg-surface); }
.compare__brand { font-family: var(--font-structural); font-weight: 600; font-size: 0.8125rem;
  letter-spacing: var(--tracking-oswald); text-transform: uppercase; }
.compare__cell--us .compare__brand .ai { color: var(--wcs-forge-cyan); }
.compare__head .compare__cell--them .compare__brand { color: var(--wcs-silver); }
.compare__val { font-size: 0.9375rem; line-height: 1.5; }
.compare__cell--us .compare__val { color: var(--wcs-white); }
.compare__yes { display: inline-flex; align-items: center; gap: 10px; }
.compare__yes::before { content: ""; width: 8px; height: 8px; background: var(--wcs-forge-cyan); border-radius: 1px; flex: none; }
.compare__no { display: inline-flex; align-items: center; gap: 10px; color: var(--wcs-silver); }
.compare__no::before { content: ""; width: 14px; height: 1px; background: var(--color-border-strong); flex: none; }
@media (max-width: 760px) {
  .compare__row { grid-template-columns: 1fr; }
  .compare__cell { padding: var(--sp-4); }
  .compare__cell--feat { border-bottom: 1px solid var(--color-border-dark); background: var(--color-bg-surface); }
  .compare__head { display: none; }
  .compare__cell--us::before { content: "FORGEDOPS.AI"; display: block; font-family: var(--font-structural);
    font-size: 0.625rem; letter-spacing: var(--tracking-oswald); color: var(--wcs-forge-cyan); margin-bottom: 6px; }
  .compare__cell--them::before { content: "OTHER PLATFORM"; display: block; font-family: var(--font-structural);
    font-size: 0.625rem; letter-spacing: var(--tracking-oswald); color: var(--wcs-silver); margin-bottom: 6px; }
}

/* ============================================================
   FAQ ACCORDION
   ============================================================ */
.faq { max-width: 820px; margin-top: var(--sp-7); }
.faq__item { border-top: 1px solid var(--color-border-subtle); }
.faq__item:last-child { border-bottom: 1px solid var(--color-border-subtle); }
.faq__q { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: var(--sp-4);
  padding: var(--sp-5) 0; text-align: left; font-family: var(--font-structural); font-weight: 500;
  font-size: 1.0625rem; letter-spacing: 0.04em; text-transform: uppercase; color: var(--wcs-navy); }
.faq__q:hover { color: var(--color-accent-deep); }
.faq__mark { width: 26px; height: 26px; flex: none; display: grid; place-items: center;
  border: 1px solid var(--color-border-strong); border-radius: var(--radius-sm);
  font-family: var(--font-display); font-style: italic; font-size: 1.125rem; color: var(--wcs-forge-cyan);
  transition: transform var(--dur-base) var(--ease-in-out), border-color var(--dur-base) var(--ease-out); }
.faq__item.is-open .faq__mark { transform: rotate(45deg); border-color: var(--wcs-forge-cyan); }
.faq__a { overflow: hidden; max-height: 0; transition: max-height var(--dur-slow) var(--ease-in-out); }
.faq__a p { color: var(--color-text-secondary); margin: 0 0 var(--sp-5); max-width: 70ch; }

/* ============================================================
   RELATED STRIP (cross-links between pages)
   ============================================================ */
.related { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-5); margin-top: var(--sp-7); }
@media (max-width: 760px) { .related { grid-template-columns: 1fr; } }
.related__card { display: block; padding: var(--sp-5); background: var(--wcs-white);
  border: 1px solid var(--color-border-subtle); border-top: 3px solid var(--wcs-navy); border-radius: var(--radius-md);
  transition: transform var(--dur-base) var(--ease-out), border-top-color var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out); }
.related__card:hover { transform: translateY(-3px); border-top-color: var(--wcs-forge-cyan); box-shadow: var(--shadow-md); }
.related__kicker { font-family: var(--font-structural); font-size: var(--fs-caption); font-weight: 500;
  letter-spacing: var(--tracking-oswald); text-transform: uppercase; color: var(--wcs-silver); margin-bottom: var(--sp-3); }
.related__title { font-family: var(--font-display); font-weight: 600; font-size: 1.375rem; color: var(--wcs-navy);
  line-height: var(--lh-snug); margin-bottom: var(--sp-3); }
.related__title em { font-style: italic; color: var(--wcs-forge-cyan); font-weight: 500; }
.related__more { font-family: var(--font-structural); font-size: var(--fs-caption); font-weight: 500;
  letter-spacing: var(--tracking-oswald); text-transform: uppercase; color: var(--color-accent-deep);
  display: inline-flex; align-items: center; gap: 8px; }
.related__more .arr { transition: transform var(--dur-base) var(--ease-out); }
.related__card:hover .related__more .arr { transform: translateX(3px); }

/* ============================================================
   LOCAL PROOF / pull-quote band
   ============================================================ */
.pull { max-width: 56ch; }
.pull__quote { font-family: var(--font-display); font-weight: 500; font-size: clamp(1.375rem, 2.4vw, 1.875rem);
  line-height: 1.3; color: var(--wcs-white); }
.pull__quote em { font-style: italic; color: var(--wcs-forge-cyan); }
.pull__attr { display: flex; align-items: center; gap: 12px; margin-top: var(--sp-5);
  font-family: var(--font-structural); font-size: var(--fs-caption); letter-spacing: var(--tracking-oswald);
  text-transform: uppercase; color: var(--wcs-silver); }
.pull__attr .rule { width: 32px; height: 1px; background: var(--wcs-forge-cyan); flex: none; }

/* ---------- Inline anchor accent (in prose / footers) ---------- */
.link-cyan { color: var(--color-accent-deep); border-bottom: 1px solid currentColor; transition: color var(--dur-fast) var(--ease-out); }
.link-cyan:hover { color: var(--wcs-forge-cyan); }
.section--dark .link-cyan { color: var(--wcs-forge-cyan); }

/* ============================================================
   PRODUCT / SERVICE PAGE HELPERS
   ============================================================ */
/* 3-up pricing grid (reuses .tier from landing.css) */
.tiers--3 { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 1000px) { .tiers--3 { grid-template-columns: 1fr; max-width: 460px; margin-inline: auto; } }

/* Status pill (forthcoming / limited deployment / powered-by) */
.status-pill { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-structural);
  font-size: 0.625rem; font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--wcs-forge-cyan); border: 1px solid var(--color-border-dark); border-radius: var(--radius-pill);
  padding: 6px 14px; margin-bottom: var(--sp-5); }
.status-pill::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: var(--wcs-forge-cyan); flex: none; }

/* Powered-by lockup line */
.powered { font-family: var(--font-structural); font-size: 0.625rem; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--wcs-silver); }
.powered b { color: var(--wcs-forge-cyan); font-weight: 600; }

/* Audit / capability checklist (2-col on light) */
.checklist { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--sp-4) var(--sp-6); margin-top: var(--sp-7); }
@media (max-width: 680px) { .checklist { grid-template-columns: 1fr; } }
.checklist__item { display: grid; grid-template-columns: auto 1fr; gap: 14px; padding-top: var(--sp-4); border-top: 1px solid var(--color-border-subtle); }
.checklist__mark { width: 9px; height: 9px; background: var(--wcs-forge-cyan); border-radius: 1px; margin-top: 7px; }
.checklist__item h4 { font-family: var(--font-structural); font-weight: 600; font-size: 0.875rem; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--wcs-navy); margin: 0 0 4px; }
.checklist__item p { margin: 0; color: var(--color-text-secondary); font-size: 0.875rem; }
.section--dark .checklist__item { border-top-color: var(--color-border-dark); }
.section--dark .checklist__item h4 { color: var(--wcs-white); }
.section--dark .checklist__item p { color: var(--color-text-on-dark-2); }

/* Disclaimer / note callout — cyan left rule, light surface */
.note { display: grid; grid-template-columns: auto 1fr; gap: var(--sp-5); align-items: start;
  margin-top: var(--sp-7); padding: var(--sp-5) var(--sp-6); background: var(--wcs-white);
  border: 1px solid var(--color-border-subtle); border-left: 3px solid var(--wcs-forge-cyan);
  border-radius: var(--radius-md); box-shadow: var(--shadow-sm); }
@media (max-width: 680px) { .note { grid-template-columns: 1fr; gap: var(--sp-3); } }
.note__label { font-family: var(--font-structural); font-weight: 600; font-size: var(--fs-caption);
  letter-spacing: var(--tracking-oswald); text-transform: uppercase; color: var(--color-accent-deep);
  white-space: nowrap; padding-top: 2px; }
.note__body { margin: 0; color: var(--color-text-secondary); font-size: 0.9375rem; line-height: var(--lh-loose); }
.note__body strong { color: var(--wcs-navy); font-weight: 600; }

/* Layout-sample tiles (Custom AI Systems "offer our layouts") */
.layouts { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-5); margin-top: var(--sp-7); }
@media (max-width: 880px) { .layouts { grid-template-columns: 1fr; max-width: 460px; margin-inline: auto; } }
.layout-tile { background: var(--wcs-white); border: 1px solid var(--color-border-subtle); border-top: 3px solid var(--wcs-navy);
  border-radius: var(--radius-md); overflow: hidden; box-shadow: var(--shadow-sm);
  transition: transform var(--dur-base) var(--ease-out), border-top-color var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out); }
.layout-tile:hover { transform: translateY(-3px); border-top-color: var(--wcs-forge-cyan); box-shadow: var(--shadow-md); }
.layout-tile__preview { aspect-ratio: 16 / 10; background: var(--grad-navy); position: relative; overflow: hidden; border-bottom: 1px solid var(--color-border-subtle); }
.layout-tile__body { padding: var(--sp-5); }
.layout-tile__body h3 { font-family: var(--font-structural); font-weight: 600; font-size: 1rem; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--wcs-navy); margin: 0 0 var(--sp-2); }
.layout-tile__body p { margin: 0; color: var(--color-text-secondary); font-size: 0.875rem; }
/* mini wireframe inside preview, drawn with the brand rule motifs */
.wf { position: absolute; inset: 0; padding: 18px; display: flex; flex-direction: column; gap: 9px; }
.wf .bar { background: rgba(255,255,255,0.10); border-radius: 2px; }
.wf .cyan { background: var(--wcs-forge-cyan); }
.wf .row { display: flex; gap: 9px; }
.wf .grow { flex: 1; }
/* ============================================================
   LEGAL DOCUMENTS — Privacy Policy · Terms & Conditions
   Legal-exhibit aesthetic: numbered articles, sticky index
   ============================================================ */
/* Compact document masthead (navy) */
.legal-hero { background: var(--grad-navy); color: var(--color-text-on-dark); border-bottom: var(--rule-cyan-thick);
  padding-block: clamp(40px, 6vw, 72px); }
.legal-hero__inner { max-width: 860px; }
.legal-hero h1 { font-family: var(--font-display); font-weight: 600; font-size: clamp(2rem, 4.4vw, 3.25rem);
  line-height: var(--lh-tight); letter-spacing: var(--tracking-tight); color: var(--wcs-white); max-width: 18ch; }
.legal-hero h1 em { font-style: italic; color: var(--wcs-forge-cyan); font-weight: 500; }
.legal-hero p { color: var(--color-text-on-dark-2); max-width: 60ch; margin: var(--sp-5) 0 0; }
.legal-meta { display: flex; flex-wrap: wrap; gap: var(--sp-3) var(--sp-6); margin-top: var(--sp-6);
  padding-top: var(--sp-5); border-top: 1px solid var(--color-border-dark); }
.legal-meta__item { display: flex; flex-direction: column; gap: 4px; }
.legal-meta__k { font-family: var(--font-structural); font-size: 0.625rem; font-weight: 500; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--wcs-silver); }
.legal-meta__v { font-family: var(--font-mono); font-size: 0.8125rem; letter-spacing: 0.04em; color: var(--wcs-white); }
.legal-meta__v b { color: var(--wcs-forge-cyan); font-weight: 500; }

/* Body grid: sticky index + articles */
.legal-layout { display: grid; grid-template-columns: 232px 1fr; gap: clamp(40px, 6vw, 88px); align-items: start; }
@media (max-width: 920px) { .legal-layout { grid-template-columns: 1fr; gap: var(--sp-7); } }

.legal-toc { position: sticky; top: 96px; }
@media (max-width: 920px) { .legal-toc { position: static; padding-bottom: var(--sp-5); border-bottom: 1px solid var(--color-border-subtle); } }
.legal-toc__label { font-family: var(--font-structural); font-size: 0.625rem; font-weight: 600; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--wcs-silver); padding-bottom: var(--sp-3); margin-bottom: var(--sp-3);
  border-bottom: 1px solid var(--color-border-subtle); }
.legal-toc ol { list-style: none; counter-reset: toc; margin: 0; padding: 0; display: flex; flex-direction: column; }
.legal-toc li { counter-increment: toc; }
.legal-toc a { display: grid; grid-template-columns: 26px 1fr; gap: 6px; align-items: baseline; padding: 7px 0;
  font-family: var(--font-structural); font-size: 0.75rem; font-weight: 500; letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--color-text-secondary); line-height: 1.3; transition: color var(--dur-fast) var(--ease-out); }
.legal-toc a::before { content: counter(toc, decimal-leading-zero); font-family: var(--font-mono); font-size: 0.6875rem;
  color: var(--wcs-silver); transition: color var(--dur-fast) var(--ease-out); }
.legal-toc a:hover { color: var(--wcs-navy); }
.legal-toc a:hover::before { color: var(--wcs-forge-cyan); }

/* Articles */
.legal-body { counter-reset: art; max-width: 72ch; }
.legal-art { padding-top: var(--sp-7); margin-top: var(--sp-7); border-top: 1px solid var(--color-border-subtle); scroll-margin-top: 88px; }
.legal-body > .legal-art:first-child { padding-top: 0; margin-top: 0; border-top: 0; }
.legal-art__head { counter-increment: art; display: grid; grid-template-columns: auto 1fr; gap: 16px; align-items: baseline; margin-bottom: var(--sp-5); }
.legal-art__num { font-family: var(--font-mono); font-size: 0.8125rem; letter-spacing: 0.08em; color: var(--wcs-forge-cyan); padding-top: 6px; }
.legal-art__num::before { content: counter(art, decimal-leading-zero); }
.legal-art h2 { font-family: var(--font-display); font-weight: 600; font-size: clamp(1.5rem, 2.6vw, 2rem); line-height: var(--lh-snug);
  letter-spacing: var(--tracking-tight); color: var(--wcs-navy); }
.legal-art h2 em { font-style: italic; color: var(--wcs-forge-cyan); font-weight: 500; }
.legal-art h3 { font-family: var(--font-structural); font-weight: 600; font-size: 0.9375rem; letter-spacing: 0.06em;
  text-transform: uppercase; color: var(--wcs-navy); margin: var(--sp-6) 0 var(--sp-3); }
.legal-art p { color: var(--color-text-secondary); margin: 0 0 var(--sp-4); line-height: var(--lh-loose); }
.legal-art p:last-child, .legal-art ul:last-child { margin-bottom: 0; }
.legal-art strong { color: var(--wcs-navy); font-weight: 600; }
.legal-art a { color: var(--color-accent-deep); border-bottom: 1px solid currentColor; transition: color var(--dur-fast) var(--ease-out); }
.legal-art a:hover { color: var(--wcs-forge-cyan); }
.legal-art ul { list-style: none; margin: 0 0 var(--sp-4); padding: 0; display: flex; flex-direction: column; gap: var(--sp-3); }
.legal-art li { position: relative; padding-left: 22px; color: var(--color-text-secondary); line-height: var(--lh-loose); }
.legal-art li::before { content: ""; position: absolute; left: 0; top: 11px; width: 7px; height: 7px; background: var(--wcs-forge-cyan); border-radius: 1px; }
.legal-art li strong { color: var(--wcs-navy); }

/* Definitions table inside Terms */
.legal-defs { display: flex; flex-direction: column; margin: var(--sp-2) 0 var(--sp-4); border-top: 1px solid var(--color-border-subtle); }
.legal-defs__row { display: grid; grid-template-columns: 180px 1fr; gap: var(--sp-5); padding: var(--sp-3) 0; border-bottom: 1px solid var(--color-border-subtle); }
@media (max-width: 560px) { .legal-defs__row { grid-template-columns: 1fr; gap: 4px; } }
.legal-defs__term { font-family: var(--font-structural); font-weight: 600; font-size: 0.8125rem; letter-spacing: 0.06em;
  text-transform: uppercase; color: var(--wcs-navy); }
.legal-defs__def { color: var(--color-text-secondary); font-size: 0.9375rem; line-height: var(--lh-loose); }

/* Closing contact card */
.legal-contact { margin-top: var(--sp-7); padding: var(--sp-6); background: var(--color-bg-surface);
  border: 1px solid var(--color-border-subtle); border-left: 3px solid var(--wcs-forge-cyan); border-radius: var(--radius-md); }
.legal-contact h3 { font-family: var(--font-structural); font-weight: 600; font-size: 0.9375rem; letter-spacing: 0.06em;
  text-transform: uppercase; color: var(--wcs-navy); margin: 0 0 var(--sp-3); }
.legal-contact p { margin: 0; color: var(--color-text-secondary); line-height: var(--lh-loose); }
.legal-contact a { color: var(--color-accent-deep); }

/* Ordered lists inside an article (numbered sub-clauses) */
.legal-art ol { list-style: none; counter-reset: clause; margin: 0 0 var(--sp-4); padding: 0; display: flex; flex-direction: column; gap: var(--sp-3); }
.legal-art ol li { counter-increment: clause; position: relative; padding-left: 30px; }
.legal-art ol li::before { content: counter(clause) "."; position: absolute; left: 0; top: 2px; width: auto; height: auto; background: none; border-radius: 0;
  font-family: var(--font-mono); font-size: 0.8125rem; color: var(--wcs-forge-cyan); }

/* Plain-English summary card (sits atop the document body) */
.legal-tldr { background: var(--wcs-white); border: 1px solid var(--color-border-subtle); border-left: 4px solid var(--wcs-forge-cyan);
  border-radius: var(--radius-md); padding: var(--sp-6) var(--sp-6) var(--sp-5); box-shadow: var(--shadow-sm); margin-bottom: var(--sp-7); }
.legal-tldr__label { font-family: var(--font-structural); font-weight: 600; font-size: 0.6875rem; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--wcs-forge-cyan); }
.legal-tldr h2 { font-family: var(--font-display); font-weight: 600; font-size: clamp(1.5rem, 2.4vw, 1.875rem); line-height: var(--lh-snug);
  letter-spacing: var(--tracking-tight); color: var(--wcs-navy); margin: var(--sp-2) 0 var(--sp-2); }
.legal-tldr__sub { font-family: var(--font-body); font-style: italic; font-size: 0.9375rem; color: var(--color-text-secondary); margin: 0 0 var(--sp-4); max-width: 64ch; }
.legal-tldr ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: var(--sp-3); }
.legal-tldr li { position: relative; padding-left: 24px; color: var(--color-text-secondary); line-height: var(--lh-loose); font-size: 0.9375rem; }
.legal-tldr li::before { content: "\2192"; position: absolute; left: 0; top: 1px; color: var(--wcs-forge-cyan); font-weight: 700; }
.legal-tldr li strong { color: var(--wcs-navy); font-weight: 600; }

/* Dark callout (plain-English aside within an article) */
.legal-callout { background: var(--grad-navy); border-left: 4px solid var(--wcs-forge-cyan); border-radius: var(--radius-sm);
  padding: var(--sp-4) var(--sp-5); margin: var(--sp-5) 0; }
.legal-callout p { margin: 0; color: var(--color-text-on-dark); line-height: var(--lh-loose); }
.legal-callout strong { color: var(--wcs-white); }

/* Uppercase emphasis block (statutory disclaimers: warranty, liability, class waiver) */
.legal-emph { background: var(--color-bg-surface); border: 1px solid var(--color-border-subtle); border-left: 3px solid var(--wcs-navy);
  border-radius: var(--radius-sm); padding: var(--sp-5); margin: var(--sp-5) 0; }
.legal-emph p { margin: 0; color: var(--wcs-navy); font-size: 0.8125rem; line-height: var(--lh-loose);
  letter-spacing: 0.04em; text-transform: uppercase; }
.legal-emph p strong { color: var(--wcs-navy); }

/* Cookie / data table inside an article */
.legal-table { width: 100%; border-collapse: collapse; margin: var(--sp-4) 0; font-size: 0.875rem; }
.legal-table th, .legal-table td { border: 1px solid var(--color-border-subtle); padding: 12px 14px; text-align: left; vertical-align: top; line-height: var(--lh-loose); }
.legal-table th { background: var(--wcs-navy); color: var(--wcs-white); font-family: var(--font-structural); font-weight: 600;
  font-size: 0.6875rem; letter-spacing: 0.1em; text-transform: uppercase; }
.legal-table td { color: var(--color-text-secondary); }
.legal-table td strong { color: var(--wcs-navy); }
@media (max-width: 620px) { .legal-table, .legal-table tbody, .legal-table tr, .legal-table td, .legal-table th { display: block; width: 100%; }
  .legal-table tr { margin-bottom: var(--sp-3); border: 1px solid var(--color-border-subtle); }
  .legal-table td, .legal-table th { border: 0; border-bottom: 1px solid var(--color-border-subtle); } }
