/* =========================================================================
   Seaside Labs — Brand System v2
   Inspired by Sway (swaythefuture.com): warm cream + one electric accent +
   contemporary serif paired with geometric sans. Confident, modern, alive.
   ========================================================================= */

@import url("https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,500;0,9..144,600;0,9..144,700;0,9..144,800;1,9..144,400;1,9..144,500&family=Inter:wght@400;500;600;700;800&display=swap");

:root {
  /* --- Cape Cod beach palette — saturated, alive, sun-drenched --- */
  --cream:          #fef6e4;   /* warm sand-white body */
  --cream-warm:     #fbe8c2;   /* sun-warmed sand */
  --shell:          #fffaf0;   /* foam white */
  --sand:           #f0c987;   /* wet sand / summer gold */
  --sand-deep:      #d9a55a;
  --ink:            #0a3142;   /* deep-water ink — like looking down into Buzzards Bay */
  --ink-soft:       rgba(10, 49, 66, 0.80);
  --ink-mute:       rgba(10, 49, 66, 0.70);  /* WCAG AA compliant on cream + sand surfaces */

  /* --- Ocean blues: brighter, more saturated, beach-actual not corporate --- */
  --tide:           #13a4c4;   /* turquoise — Swifts Beach at noon */
  --tide-deep:      #0a6783;   /* deep water */
  --tide-bright:    #2dd4bf;   /* sparkle / highlight */
  --tide-soft:      #bfeaf0;   /* shallow foam */
  --sky:            #7cc7e8;   /* clear-day sky */

  /* --- Warm accents — sunset moments --- */
  --sun:            #f3944b;   /* warm sunset orange */
  --sun-deep:       #db6e2c;
  --sun-soft:       #ffd9b5;
  --coral:          #e85d4f;   /* hot coral — CTA pop */
  --coral-soft:     #ffc8c0;

  /* --- Nature --- */
  --moss:           #3d8a6b;   /* dune grass / marsh green */
  --moss-soft:      #c1e4d1;

  /* --- Kelp (reserved) --- */
  --kelp:           #2b7a7f;
  --kelp-deep:      #124247;
  --kelp-soft:      #c4dfe1;

  /* --- Navy (TideClaw — deep ocean monitoring, distinct from Connect cyan) --- */
  --navy:           #1a3a5c;
  --navy-deep:      #0a1e36;
  --navy-soft:      #cdd7e4;

  /* --- Gold (Consulting — sunny happy yellow, distinct from ClaimClaw rust) --- */
  --gold:           #e8b933;
  --gold-deep:      #a8831a;
  --gold-soft:      #fae8a6;

  /* --- Per-division accent (override via body class) --- */
  --accent:         var(--tide);
  --accent-soft:    var(--tide-soft);
  --accent-deep:    var(--tide-deep);

  /* --- Type --- */
  --display: "Fraunces", "Recoleta", Georgia, serif;
  --body:    "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;

  /* --- Radii --- */
  --r-sm: 10px;
  --r-md: 18px;
  --r-lg: 28px;
  --r-pill: 999px;

  /* --- Shadow --- */
  --shadow-soft: 0 12px 28px rgba(14, 43, 51, 0.08);
  --shadow-card: 0 22px 48px rgba(14, 43, 51, 0.12);
  --shadow-hover: 0 30px 60px rgba(14, 43, 51, 0.18);

  /* --- Rhythm --- */
  --s-1: 0.5rem;
  --s-2: 1rem;
  --s-3: 1.5rem;
  --s-4: 2.5rem;
  --s-5: 4rem;
  --s-6: 6rem;
}

/* Division class hooks */
body.div-connect    { --accent: var(--tide);      --accent-soft: var(--tide-soft);    --accent-deep: var(--tide-deep); }
body.div-tideclaw   { --accent: var(--navy);      --accent-soft: var(--navy-soft);    --accent-deep: var(--navy-deep); }
body.div-consulting { --accent: var(--gold);      --accent-soft: var(--gold-soft);    --accent-deep: var(--gold-deep); }
body.div-gardens    { --accent: var(--moss);      --accent-soft: var(--moss-soft);    --accent-deep: #2b5f47; }
body.div-claimclaw  { --accent: var(--sun-deep);  --accent-soft: var(--sun-soft);     --accent-deep: #a84f17; }
body.div-reefpay    { --accent: var(--coral);     --accent-soft: var(--coral-soft);   --accent-deep: #b8463a; }

/* =========================================================================
   Base
   ========================================================================= */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
  color: var(--ink);
  /* Default body background — clean Cape Cod cream. No gradients while scrolling.
     Trust-focused divisions (Connect, TideClaw) override below to cool paper. */
  background: var(--cream);
  background-attachment: fixed;
  font-family: var(--body);
  font-weight: 400;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  min-height: 100vh;
  overflow-x: hidden;
}

/* Trust-focused divisions get a cool, paper-white surface that reads
   "infrastructure" instead of "beach hospitality". Connect serves municipal
   and tribal RFP buyers; TideClaw serves harbormasters and conservation
   officers — both want sober, not sun-drenched. */
body.div-connect,
body.div-tideclaw {
  background:
    radial-gradient(ellipse at 50% 110%, color-mix(in srgb, var(--tide-soft) 45%, transparent) 0%, transparent 55%),
    #f7f9fb;
}
img, svg { display: block; max-width: 100%; }
a { color: var(--accent); text-decoration: none; transition: color 180ms; }
a:hover { color: var(--accent-deep); }
::selection { background: var(--sun-soft); color: var(--ink); }

/* =========================================================================
   Typography
   ========================================================================= */
.display {
  font-family: var(--display);
  font-weight: 500;
  letter-spacing: -0.025em;
  line-height: 1.02;
  color: var(--ink);
  font-variation-settings: "opsz" 144;
}
.h1 { font-size: clamp(3rem, 8vw, 7rem); }
.h2 { font-size: clamp(2.25rem, 5vw, 4rem); }
.h3 { font-size: clamp(1.5rem, 2.4vw, 2rem); font-variation-settings: "opsz" 72; }
.h4 { font-size: clamp(1.2rem, 1.8vw, 1.4rem); font-variation-settings: "opsz" 48; }

/* Mobile: tighten optical size and bump weight so headlines don't look fragile.
   Fraunces opsz 144 is meant for billboard-size display; at ~36px on phones it
   reads thin. Drop to opsz 72 + weight 600 below 720px. */
@media (max-width: 720px) {
  .display { font-weight: 600; font-variation-settings: "opsz" 72; }
  .h1, .h2 { font-variation-settings: "opsz" 96; }
  .hero-headline { font-weight: 600; }
}

.display em {
  font-style: italic;
  font-family: var(--display);
  font-weight: 400;
  color: var(--accent);
}

.eyebrow {
  display: inline-flex; align-items: center; gap: 0.5rem;
  font-family: var(--body);
  font-weight: 600;
  font-size: 0.78rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent-deep);
}
.eyebrow::before {
  content: ""; width: 24px; height: 1.5px; background: var(--accent);
}

.lead {
  font-family: var(--body);
  font-size: clamp(1.05rem, 1.4vw, 1.25rem);
  line-height: 1.55;
  color: var(--ink-soft);
  max-width: 46rem;
}

.body-text { color: var(--ink-soft); font-size: 1rem; line-height: 1.7; }
.muted { color: var(--ink-mute); }
.small { font-size: 0.9rem; color: var(--ink-mute); }

/* =========================================================================
   Layout
   ========================================================================= */
.container { max-width: 1240px; margin: 0 auto; padding: 0 var(--s-3); }
.container-narrow { max-width: 880px; margin: 0 auto; padding: 0 var(--s-3); }

section { padding: var(--s-6) 0; position: relative; }
@media (max-width: 720px) { section { padding: var(--s-5) 0; } }

.grid-2 { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: var(--s-3); }
.grid-3 { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--s-3); }
.grid-4 { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: var(--s-2); }
@media (max-width: 860px) { .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; } }

/* =========================================================================
   Nav — thin, confident, no backdrop-blur-gimmicks
   ========================================================================= */
.nav {
  position: sticky; top: 0; z-index: 50;
  background: color-mix(in srgb, var(--cream) 92%, transparent);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(14, 43, 51, 0.08);
}
.nav-inner {
  max-width: 1240px; margin: 0 auto;
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--s-2); padding: 1.1rem var(--s-3);
}
.nav-brand {
  display: inline-flex; align-items: center; gap: 0.65rem;
  color: var(--ink); font-weight: 700;
}
.nav-brand svg { width: 36px; height: auto; color: var(--accent); }
.nav-brand .mark-text {
  font-family: var(--display);
  font-weight: 500;
  font-size: 1.15rem;
  letter-spacing: -0.01em;
  color: var(--ink);
}
.nav-brand .mark-text em { color: var(--accent); font-style: italic; font-weight: 400; }

.nav-links { display: flex; gap: 2rem; list-style: none; align-items: center; }
.nav-links a { color: var(--ink-soft); font-size: 0.92rem; font-weight: 500; border-radius: var(--r-sm); }
.nav-links a:hover { color: var(--accent); }
.nav-links a:focus-visible,
.nav-brand:focus-visible {
  outline: 3px solid var(--accent-deep);
  outline-offset: 4px;
}

.hamburger { display: none; cursor: pointer; background: none; border: none; padding: 0.5rem; flex-direction: column; gap: 5px; }
.hamburger span { display: block; width: 22px; height: 2px; background: var(--ink); transition: transform 0.3s, opacity 0.3s; }
.hamburger.active span:nth-child(1) { transform: rotate(45deg) translate(5px, 5px); }
.hamburger.active span:nth-child(2) { opacity: 0; }
.hamburger.active span:nth-child(3) { transform: rotate(-45deg) translate(5px, -5px); }

@media (max-width: 820px) {
  .hamburger { display: flex; }
  .nav-links {
    display: none; position: absolute; top: 100%; left: 0; right: 0;
    background: var(--cream); flex-direction: column;
    padding: 1rem 1.5rem; gap: 0.5rem; border-bottom: 1px solid rgba(14,43,51,0.08);
  }
  .nav-links.open { display: flex; }
  .nav-links a { padding: 0.7rem 0; font-size: 1rem; }
}

/* =========================================================================
   Buttons
   ========================================================================= */
.btn {
  display: inline-flex; align-items: center; gap: 0.5rem;
  padding: 0.95rem 1.75rem;
  border-radius: var(--r-pill);
  border: none;
  background: var(--ink);
  color: var(--cream);
  font-family: var(--body); font-weight: 600; font-size: 0.95rem;
  letter-spacing: 0.01em;
  text-decoration: none;
  transition: transform 180ms, background 180ms, color 180ms;
  cursor: pointer;
}
.btn:hover { background: var(--accent); color: var(--cream); transform: translateY(-1px); }
.btn:focus-visible {
  outline: 3px solid var(--accent-deep);
  outline-offset: 3px;
}
.btn.accent { background: var(--accent); color: var(--cream); }
.btn.accent:hover { background: var(--accent-deep); color: var(--cream); }
.btn.ghost {
  background: transparent;
  color: var(--ink);
  border: 1.5px solid var(--ink);
}
.btn.ghost:hover { background: var(--ink); color: var(--cream); }
.btn.warm { background: var(--sun); color: var(--cream); }
.btn.warm:hover { background: #c8532a; color: var(--cream); }
.btn .arrow { transition: transform 200ms; }
.btn:hover .arrow { transform: translateX(3px); }

/* =========================================================================
   Hero — asymmetric, big type, one big visual moment
   ========================================================================= */
.hero {
  padding: var(--s-5) 0 var(--s-6);
  position: relative;
  overflow: hidden;
}
.hero::before {
  content: ""; position: absolute; z-index: 0;
  top: -30%; right: -15%; width: 65%; aspect-ratio: 1;
  background: radial-gradient(circle, var(--sun) 0%, var(--sun-soft) 30%, transparent 70%);
  pointer-events: none; opacity: 0.4;
  filter: blur(20px);
}
.hero::after {
  content: ""; position: absolute; z-index: 0;
  bottom: -20%; left: -15%; width: 60%; aspect-ratio: 1;
  background: radial-gradient(circle, var(--tide-bright) 0%, var(--tide-soft) 40%, transparent 70%);
  pointer-events: none; opacity: 0.25;
  filter: blur(30px);
}
.hero-inner { position: relative; z-index: 1; }
.hero-headline { max-width: 16ch; }
.hero-sub { margin-top: var(--s-3); max-width: 34rem; }
.hero-cta { margin-top: var(--s-4); display: flex; gap: var(--s-2); flex-wrap: wrap; align-items: center; }
.hero-tagline {
  margin-top: var(--s-3);
  font-family: var(--display);
  font-style: italic;
  font-weight: 400;
  font-size: 1.1rem;
  color: var(--accent-deep);
}

.division-mark {
  --division-mark-accent: var(--accent);
  --division-mark-soft: var(--accent-soft);
  display: grid;
  justify-items: center;
  gap: 0.85rem;
  margin: 0 auto var(--s-4);
}

.division-mark-icon {
  width: clamp(96px, 11vw, 132px);
  height: clamp(96px, 11vw, 132px);
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: color-mix(in srgb, var(--division-mark-soft) 62%, var(--shell) 38%);
  color: var(--division-mark-accent);
  border: 1px solid color-mix(in srgb, var(--division-mark-accent) 18%, transparent);
  box-shadow: 0 20px 36px rgba(10, 49, 66, 0.12);
}

.division-mark-icon svg {
  width: 54%;
  height: 54%;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.division-mark-name {
  font-family: var(--display);
  font-weight: 500;
  font-size: clamp(1.7rem, 3vw, 2.35rem);
  letter-spacing: -0.02em;
  line-height: 1;
  color: var(--ink);
  font-variation-settings: "opsz" 72;
}

.division-mark-name em {
  color: var(--division-mark-accent);
  font-style: italic;
  font-weight: 400;
}

.division-mark.connect {
  --division-mark-accent: var(--tide);
  --division-mark-soft: var(--tide-soft);
}

.division-mark.claimclaw {
  --division-mark-accent: #a26835;
  --division-mark-soft: #f0dfc5;
}

.division-mark.tideclaw {
  --division-mark-accent: #0a5770;
  --division-mark-soft: #b2dde8;
}

/* =========================================================================
   Surfaces
   ========================================================================= */
.card {
  background: var(--shell);
  border: 1px solid rgba(14, 43, 51, 0.08);
  border-radius: var(--r-lg);
  padding: var(--s-3);
  transition: transform 200ms ease, box-shadow 200ms ease, border-color 200ms;
}
.card:hover {
  transform: translateY(-3px);
  border-color: var(--accent);
  box-shadow: var(--shadow-hover);
}

.big-stat {
  display: grid; gap: 0.25rem;
}
.big-stat .num {
  font-family: var(--display); font-weight: 500;
  font-size: clamp(2.5rem, 5vw, 4rem);
  line-height: 1; color: var(--accent);
  letter-spacing: -0.03em;
  font-variation-settings: "opsz" 144;
}
.big-stat .lbl {
  font-family: var(--body); font-size: 0.82rem;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--ink-mute); font-weight: 600;
}

/* =========================================================================
   Division card — big editorial feel
   ========================================================================= */
.div-card {
  position: relative; display: block;
  padding: var(--s-4) var(--s-3) var(--s-3);
  background: var(--shell);
  border: 1px solid rgba(14, 43, 51, 0.08);
  border-radius: var(--r-lg);
  text-decoration: none; color: inherit;
  transition: transform 220ms, border-color 220ms, box-shadow 220ms;
  overflow: hidden;
  isolation: isolate;
}
.div-card::before {
  content: ""; position: absolute; inset: auto -20% -60% auto;
  width: 80%; aspect-ratio: 1; border-radius: 999px;
  background: var(--div-accent-soft, var(--tide-soft));
  opacity: 0.45; z-index: -1;
  transition: transform 400ms ease;
}
.div-card:hover {
  transform: translateY(-4px);
  border-color: var(--div-accent, var(--tide));
  box-shadow: var(--shadow-card);
  color: inherit;
}
.div-card:hover::before { transform: scale(1.15) translate(-5%, -5%); }
.div-card:focus-visible {
  outline: 3px solid var(--div-accent, var(--accent-deep));
  outline-offset: 4px;
}

.div-icon {
  width: 48px; height: 48px; margin-bottom: var(--s-2);
  display: grid; place-items: center;
  color: var(--div-accent, var(--tide));
}
.div-icon svg { width: 100%; height: 100%; stroke: currentColor; fill: none; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }

.div-card h3 {
  font-family: var(--display); font-weight: 500;
  font-size: clamp(1.6rem, 2.4vw, 2rem);
  letter-spacing: -0.015em; color: var(--ink);
  margin-bottom: 0.3rem;
  font-variation-settings: "opsz" 72;
}
.div-card p { color: var(--ink-soft); font-size: 1rem; line-height: 1.6; }
.div-card .div-tag {
  display: inline-flex; align-items: center; gap: 0.4rem;
  margin-top: var(--s-3);
  font-size: 0.75rem; font-weight: 700;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--div-accent, var(--tide));
}
.div-card .div-tag::before { content: ""; width: 6px; height: 6px; border-radius: 999px; background: currentColor; }

.div-card.accent-connect   { --div-accent: var(--tide); --div-accent-soft: var(--tide-soft); }
.div-card.accent-tideclaw  { --div-accent: #0a5770;    --div-accent-soft: #b2dde8; }
.div-card.accent-gardens   { --div-accent: var(--moss); --div-accent-soft: var(--moss-soft); }
.div-card.accent-claimclaw { --div-accent: #a26835;    --div-accent-soft: #f0dfc5; }
.div-card.accent-reefpay   { --div-accent: #2d8a78;    --div-accent-soft: #c7e8de; }
.div-card.accent-consulting { --div-accent: #1e4e5f;   --div-accent-soft: #c6dde3; }

/* =========================================================================
   Marquee / place strip
   ========================================================================= */
.places {
  display: flex; justify-content: center; gap: var(--s-4); flex-wrap: wrap;
  font-family: var(--display); font-style: italic; font-weight: 400;
  font-size: clamp(1rem, 1.4vw, 1.2rem);
  color: var(--ink-soft);
  padding: var(--s-3) 0;
  border-top: 1px solid rgba(14, 43, 51, 0.08);
  border-bottom: 1px solid rgba(14, 43, 51, 0.08);
}
.places span { display: inline-flex; align-items: center; gap: var(--s-4); }
.places span + span::before { content: "✦"; color: var(--accent); font-style: normal; font-size: 0.7em; }

/* =========================================================================
   CTA band
   ========================================================================= */
.cta-band {
  padding: var(--s-5) 0;
  background: var(--ink);
  color: var(--cream);
  text-align: center;
}
.cta-band .h2 { color: var(--cream); }
.cta-band .lead { color: rgba(251, 244, 234, 0.75); margin: var(--s-3) auto 0; }
.cta-band .btn { background: var(--cream); color: var(--ink); margin-top: var(--s-4); }
.cta-band .btn:hover { background: var(--accent); color: var(--cream); }

/* =========================================================================
   Footer
   ========================================================================= */
footer {
  padding: var(--s-4) 0 var(--s-3);
  background: var(--cream);
  border-top: 1px solid rgba(14, 43, 51, 0.08);
}
.footer-inner {
  max-width: 1240px; margin: 0 auto; padding: 0 var(--s-3);
  display: flex; flex-wrap: wrap; justify-content: space-between; gap: var(--s-2);
  color: var(--ink-mute); font-size: 0.88rem;
}
.footer-inner a { color: var(--ink-soft); font-weight: 500; }
.footer-inner a:hover { color: var(--accent); }

/* =========================================================================
   Contact form — shared across /contact/ and embedded CTA bands
   ========================================================================= */
.form-card {
  background: color-mix(in srgb, var(--shell) 74%, var(--accent-soft) 26%);
  border: 1px solid rgba(14, 43, 51, 0.08);
  border-radius: var(--r-lg);
  padding: clamp(1.5rem, 4vw, 2.5rem);
  max-width: 640px;
  margin: 0 auto;
  box-shadow: var(--shadow-soft);
  text-align: left;
}
.form-card h2 {
  font-family: var(--display); font-weight: 500;
  font-size: clamp(1.5rem, 2.4vw, 1.9rem);
  color: var(--ink); margin-bottom: var(--s-2);
  font-variation-settings: "opsz" 72;
  text-wrap: balance;
}
.form-card .intro {
  color: var(--ink-soft);
  margin-bottom: var(--s-3);
  line-height: 1.6;
  text-wrap: pretty;
}

.field { display: flex; flex-direction: column; gap: 0.4rem; margin-bottom: var(--s-3); }
.field label {
  font-family: var(--body); font-weight: 600; font-size: 0.82rem;
  letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--ink);
}
.field label .required { color: var(--coral); margin-left: 0.2rem; font-weight: 700; }
.field input, .field textarea {
  font-family: var(--body); font-size: 1rem;
  color: var(--ink); background: var(--shell);
  border: 1px solid rgba(14, 43, 51, 0.16);
  border-radius: var(--r-sm);
  padding: 0.75rem 0.9rem;
  line-height: 1.5;
  transition: border-color 180ms, box-shadow 180ms;
  width: 100%;
}
.field textarea { min-height: 140px; resize: vertical; }
.field input:focus, .field textarea:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 30%, transparent);
}
.field input:focus-visible, .field textarea:focus-visible {
  outline: 2px solid var(--accent-deep);
  outline-offset: 1px;
}
.field input[aria-invalid="true"], .field textarea[aria-invalid="true"] {
  border-color: var(--coral);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--coral) 25%, transparent);
}
.field .hint { font-size: 0.85rem; color: var(--ink-soft); }
.field .field-error { font-size: 0.85rem; color: #a0352b; display: none; }
.field.has-error .field-error { display: block; }

.form-submit {
  display: inline-flex; align-items: center; gap: 0.55rem;
  background: var(--accent); color: var(--cream);
  border: none; cursor: pointer;
  font-family: var(--body); font-weight: 600; font-size: 1rem;
  padding: 0.85rem 1.5rem;
  border-radius: var(--r-pill);
  transition: background 180ms, transform 180ms, box-shadow 180ms;
  box-shadow: 0 6px 18px rgba(10, 49, 66, 0.18);
}
.form-submit:hover:not(:disabled) {
  background: var(--accent-deep);
  transform: translateY(-1px);
  box-shadow: 0 10px 24px rgba(10, 49, 66, 0.22);
}
.form-submit:focus-visible {
  outline: 3px solid var(--accent-deep);
  outline-offset: 3px;
}
.form-submit:disabled { opacity: 0.6; cursor: not-allowed; }

.form-status {
  margin-top: var(--s-3);
  padding: 0.9rem 1rem;
  border-radius: var(--r-md);
  font-size: 0.95rem;
  display: none;
}
.form-status.is-visible { display: block; }
.form-status.error {
  background: color-mix(in srgb, var(--coral) 14%, transparent);
  border: 1px solid color-mix(in srgb, var(--coral) 35%, transparent);
  color: #6b2a22;
}

.form-success { text-align: center; padding: var(--s-3) 0; }
.form-success h2 {
  font-family: var(--display); font-weight: 500;
  font-size: clamp(1.4rem, 2vw, 1.7rem);
  color: var(--ink); margin-bottom: var(--s-2);
  font-variation-settings: "opsz" 72;
  text-wrap: balance;
}
.form-success p { color: var(--ink-soft); line-height: 1.6; margin-bottom: var(--s-3); text-wrap: pretty; }
.form-success .check {
  width: 56px; height: 56px; margin: 0 auto var(--s-3);
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 18%, transparent);
  display: grid; place-items: center;
  color: var(--accent-deep);
}
.form-success .check svg { width: 28px; height: 28px; }
.form-success .next-actions {
  display: inline-flex; flex-wrap: wrap; gap: var(--s-2);
  justify-content: center;
}

.source-pill {
  display: inline-flex; align-items: center; gap: 0.4rem;
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  color: var(--accent-deep);
  padding: 0.35rem 0.85rem;
  border-radius: var(--r-pill);
  font-size: 0.78rem; font-weight: 600;
  letter-spacing: 0.06em; text-transform: uppercase;
  margin-bottom: var(--s-2);
}

/* Dark-surface variant — when the form sits on a dark band (e.g. .cta-band) */
.cta-band .form-card {
  background: rgba(251, 244, 234, 0.96);
  box-shadow: 0 24px 56px rgba(0, 0, 0, 0.28);
  border-color: rgba(255, 255, 255, 0.14);
}

/* Skip link — visible on keyboard focus */
.skip-link {
  position: absolute; left: -999px; top: auto;
  width: 1px; height: 1px; overflow: hidden;
}
.skip-link:focus {
  position: static; width: auto; height: auto;
  display: inline-block;
  background: var(--ink); color: var(--cream);
  padding: 0.6rem 1rem; margin: 0.5rem;
  border-radius: var(--r-sm); font-weight: 600;
}

/* =========================================================================
   Utility
   ========================================================================= */
.text-center { text-align: center; }
.mt-1 { margin-top: var(--s-1); }
.mt-2 { margin-top: var(--s-2); }
.mt-3 { margin-top: var(--s-3); }
.mt-4 { margin-top: var(--s-4); }
.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; }

@media print {
  body { background: #fff; }
  .nav, .hamburger, footer { display: none; }
}
