/* ==========================================================================
   Apps 4 That LLC — Landing site
   Build what matters.

   Design tokens + reusable components, faithful to the Apps 4 That Brand Book
   v1.0 (palette, Inter type scale, four-tile collision mark, spark/doodle
   accents, dark hero field, rounded app cards, sticky-note moments).

   Structure
   1.  Design tokens (CSS custom properties)
   2.  Reset + base
   3.  Typography
   4.  Layout helpers (container, section, eyebrow)
   5.  Buttons
   6.  Decorative motifs (spark burst, squiggle, sticky note, doodle)
   7.  Site header + nav
   8.  Hero
   9.  Pillars strip
   10. App lab cards
   11. How it works (steps)
   12. Studio + service cards
   13. Lead magnet
   14. Brand story
   15. CTA bands + forms
   16. Footer
   17. Reveal-on-scroll + motion
   18. Responsive
   ========================================================================== */

/* 1. Design tokens ------------------------------------------------------- */
:root {
  /* Core palette (Brand Book p.15) */
  --midnight:      #1F2A44; /* trust, depth, structure   */
  --navy-dark:     #071426; /* hero field                */
  --coral:         #FF6B57; /* action, spark, momentum   */
  --coral-deep:    #E8543F;
  --mustard:       #F4B942; /* optimism, ideas, warmth   */
  --teal:          #3DB7A3; /* approachability, growth   */
  --teal-soft:     #9EEBD8;
  --cloud:         #F7F8FA; /* breathing room            */
  --ink:           #111827;
  --muted:         #5B6577;
  --purple:        #7B61FF; /* Apps 4 That Studio accent */
  --purple-soft:   #EDE9FF;

  /* Canon subbrand accents (one toy box, distinct tools) */
  --roundready:     #0F3D2E;
  --parenttravelpal:#1E6CF1;
  --fairwayaway:    #1FA463;
  --goodcatch:      #FF6B5B;
  --yardable:       #1F5E3A;
  --ideasweetspot:  #7C5CFF;

  /* Legacy aliases for non-product decorative accents */
  --golf:     var(--roundready);
  --family:   var(--parenttravelpal);
  --wellness: var(--yardable);
  --focus:    var(--coral);
  --budget:   var(--mustard);
  --travel:   var(--fairwayaway);

  /* Sticky-note paper colors */
  --note-yellow: #FFE08A;
  --note-mint:   #DFF7F2;
  --note-coral:  #FFD7D0;
  --note-lilac:  #E8E2FF;

  /* Surfaces */
  --surface:        #ffffff;
  --surface-cloud:  var(--cloud);
  --border:         #E5E8EF;
  --border-strong:  #D4D9E3;

  /* Type */
  --font-sans: "Inter", ui-sans-serif, system-ui, -apple-system, "Segoe UI",
               Roboto, Arial, sans-serif;

  /* Fluid type scale (Brand Book p.18) */
  --fs-display: clamp(2.75rem, 1.4rem + 6.6vw, 6.5rem); /* hero H1 */
  --fs-h1:      clamp(2.25rem, 1.4rem + 3.8vw, 3.75rem);
  --fs-h2:      clamp(1.9rem, 1.4rem + 2.2vw, 2.85rem);
  --fs-h3:      clamp(1.3rem, 1.1rem + 0.7vw, 1.6rem);
  --fs-lede:    clamp(1.1rem, 1rem + 0.5vw, 1.5rem);
  --fs-body:    1.0625rem;
  --fs-caption: 0.8125rem;

  /* Spacing scale */
  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-5: 1.5rem;
  --space-6: 2rem;
  --space-7: 3rem;
  --space-8: 4.5rem;
  --space-9: 6.5rem;

  /* Radii — generous, app-store rounded */
  --r-sm: 10px;
  --r-md: 16px;
  --r-lg: 24px;
  --r-xl: 32px;
  --r-pill: 999px;

  /* Elevation */
  --shadow-sm: 0 4px 16px rgba(31, 42, 68, 0.06);
  --shadow-md: 0 18px 48px rgba(31, 42, 68, 0.10);
  --shadow-lg: 0 30px 80px rgba(7, 20, 38, 0.22);
  --shadow-note: 0 16px 34px rgba(7, 20, 38, 0.22);

  /* Layout */
  --container: 1180px;
  --gutter: clamp(1.25rem, 5vw, 4rem);

  --ease: cubic-bezier(0.22, 1, 0.36, 1);
  --t-fast: 150ms var(--ease);
  --t: 280ms var(--ease);
}

/* 2. Reset + base -------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
}

body {
  margin: 0;
  font-family: var(--font-sans);
  font-size: var(--fs-body);
  line-height: 1.6;
  color: var(--ink);
  background: var(--cloud);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

img, svg { display: block; max-width: 100%; }
a { color: inherit; }
button { font: inherit; cursor: pointer; }

/* Skip link */
.skip-link {
  position: absolute;
  left: var(--space-4);
  top: -120px;
  z-index: 200;
  background: var(--coral);
  color: #fff;
  padding: 12px 18px;
  border-radius: var(--r-sm);
  font-weight: 800;
  transition: top var(--t-fast);
}
.skip-link:focus { top: var(--space-4); }

/* Accessible focus */
:focus-visible {
  outline: 3px solid var(--mustard);
  outline-offset: 2px;
  border-radius: 4px;
}

.visually-hidden {
  position: absolute !important;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0 0 0 0);
  white-space: nowrap; border: 0;
}

/* 3. Typography ---------------------------------------------------------- */
h1, h2, h3, h4 {
  font-weight: 800;
  line-height: 1.02;
  letter-spacing: -0.03em;
  color: var(--midnight);
  margin: 0 0 var(--space-4);
}
h2 { font-size: var(--fs-h2); }
h3 { font-size: var(--fs-h3); letter-spacing: -0.02em; line-height: 1.15; }
p { margin: 0 0 var(--space-4); }
p:last-child { margin-bottom: 0; }
strong { font-weight: 800; }

.lede {
  font-size: var(--fs-lede);
  line-height: 1.45;
  color: var(--muted);
}

/* 4. Layout helpers ------------------------------------------------------ */
.container {
  width: 100%;
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: var(--gutter);
}

.section { padding-block: clamp(3.5rem, 7vw, var(--space-9)); position: relative; }
.section--tight { padding-block: clamp(2.5rem, 5vw, 4rem); }

.section-head { max-width: 56ch; margin-bottom: var(--space-7); }
.section-head.is-center { margin-inline: auto; text-align: center; }
.section-head .lede { margin-top: var(--space-4); }

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 0.5em;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-weight: 800;
  font-size: var(--fs-caption);
  color: var(--teal);
  margin: 0 0 var(--space-3);
}
.eyebrow::before {
  content: "";
  width: 22px; height: 2px;
  background: currentColor;
  border-radius: 2px;
}
.eyebrow.is-purple { color: var(--purple); }
.eyebrow.is-coral  { color: var(--coral); }
.eyebrow.is-light  { color: var(--teal-soft); }

/* Tinted section backgrounds */
.bg-cloud { background: var(--cloud); }
.bg-white { background: var(--surface); }
.bg-dark  { background: var(--navy-dark); color: #E8EEF8; }
.bg-midnight { background: var(--midnight); color: #E8EEF8; }
.bg-dark h2, .bg-midnight h2,
.bg-dark h3, .bg-midnight h3 { color: #fff; }

/* 5. Buttons ------------------------------------------------------------- */
.btn {
  --btn-bg: var(--coral);
  --btn-fg: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.55em;
  min-height: 52px;            /* >= 44px tap target */
  padding: 0.85em 1.5em;
  border: 2px solid transparent;
  border-radius: var(--r-md);
  background: var(--btn-bg);
  color: var(--btn-fg);
  font-weight: 800;
  font-size: 1rem;
  letter-spacing: -0.01em;
  text-decoration: none;
  text-align: center;
  transition: transform var(--t-fast), box-shadow var(--t),
              background var(--t-fast), border-color var(--t-fast);
  box-shadow: var(--shadow-sm);
}
.btn:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.btn:active { transform: translateY(0); }
.btn .btn__icon { width: 1.1em; height: 1.1em; }

.btn--coral  { --btn-bg: var(--coral); }
.btn--coral:hover { background: var(--coral-deep); }
.btn--teal   { --btn-bg: var(--teal); }
.btn--purple { --btn-bg: var(--purple); }
.btn--mustard { --btn-bg: var(--mustard); --btn-fg: var(--midnight); }

.btn--ghost {
  --btn-bg: transparent;
  --btn-fg: var(--midnight);
  border-color: var(--border-strong);
  box-shadow: none;
}
.btn--ghost:hover { border-color: var(--midnight); background: #fff; }

/* On dark fields */
.btn--outline-light {
  --btn-bg: transparent;
  --btn-fg: #fff;
  border-color: rgba(255,255,255,0.35);
  box-shadow: none;
}
.btn--outline-light:hover { border-color: #fff; background: rgba(255,255,255,0.08); }

.btn--block { width: 100%; }

/* Text link with arrow */
.link-arrow {
  display: inline-flex;
  align-items: center;
  gap: 0.4em;
  font-weight: 800;
  text-decoration: none;
  color: var(--coral);
}
.link-arrow svg { transition: transform var(--t-fast); }
.link-arrow:hover svg { transform: translateX(4px); }

/* 6. Decorative motifs --------------------------------------------------- */
.deco { position: absolute; pointer-events: none; z-index: 0; }

/* Spark burst (8-point) — sized via --size, colored via currentColor */
.spark {
  display: inline-block;
  width: var(--size, 40px);
  height: var(--size, 40px);
  color: var(--mustard);
  flex: none;
}
.spark svg { width: 100%; height: 100%; }

/* Hand-drawn underline swoosh under an accent word */
.swoosh { position: relative; white-space: nowrap; color: var(--coral); }
.swoosh::after {
  content: "";
  position: absolute;
  left: 0; right: 0;
  bottom: -0.16em;
  height: 0.34em;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='14' viewBox='0 0 200 14' fill='none'%3E%3Cpath d='M3 9C40 3 90 3 130 6c25 2 45 3 67 1' stroke='%23F4B942' stroke-width='5' stroke-linecap='round'/%3E%3C/svg%3E") center/100% 100% no-repeat;
}

/* Sticky note */
.note {
  position: relative;
  background: var(--note-yellow);
  color: var(--ink);
  padding: var(--space-5);
  border-radius: 6px 6px 10px 6px;
  box-shadow: var(--shadow-note);
  font-weight: 700;
  line-height: 1.4;
  max-width: 240px;
}
.note--mint  { background: var(--note-mint); }
.note--coral { background: var(--note-coral); }
.note--lilac { background: var(--note-lilac); }
.note__tape {
  position: absolute;
  top: -10px; left: 50%;
  width: 64px; height: 20px;
  transform: translateX(-50%) rotate(-3deg);
  background: rgba(255,255,255,0.45);
  border: 1px dashed rgba(7,20,38,0.18);
  border-radius: 3px;
}

/* 7. Site header --------------------------------------------------------- */
.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(7, 20, 38, 0.72);
  backdrop-filter: saturate(140%) blur(14px);
  -webkit-backdrop-filter: saturate(140%) blur(14px);
  border-bottom: 1px solid rgba(255,255,255,0.06);
  transition: background var(--t), box-shadow var(--t);
}
.site-header.is-scrolled {
  background: rgba(7, 20, 38, 0.95);
  box-shadow: 0 10px 30px rgba(0,0,0,0.25);
}
.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-5);
  min-height: 76px;
}
.brand-logo { display: inline-flex; align-items: center; }
.brand-logo img { height: 40px; width: auto; }

.primary-nav { display: flex; align-items: center; gap: var(--space-6); }
.primary-nav__links { display: flex; align-items: center; gap: var(--space-6); }
.primary-nav a {
  color: rgba(255,255,255,0.86);
  text-decoration: none;
  font-weight: 700;
  font-size: 0.95rem;
  transition: color var(--t-fast);
}
.primary-nav a:hover { color: #fff; }

.nav-toggle {
  display: none;
  flex-direction: column;
  gap: 5px;
  width: 46px; height: 46px;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: var(--r-sm);
}
.nav-toggle span {
  width: 22px; height: 2px; background: #fff; border-radius: 2px;
  transition: transform var(--t-fast), opacity var(--t-fast);
}
.nav-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* 8. Hero ---------------------------------------------------------------- */
.hero {
  position: relative;
  background:
    radial-gradient(1100px 600px at 85% -10%, rgba(123,97,255,0.20), transparent 60%),
    radial-gradient(900px 500px at 10% 110%, rgba(61,183,163,0.16), transparent 55%),
    linear-gradient(160deg, #071426 0%, #0c1d33 55%, #102542 100%);
  color: #fff;
  overflow: hidden;
}
.hero__grid {
  display: grid;
  grid-template-columns: 1.08fr 0.92fr;
  gap: clamp(2rem, 4vw, 4rem);
  align-items: center;
  padding-block: clamp(3.5rem, 8vw, 7rem);
}
.hero__copy { position: relative; z-index: 2; }
.hero h1 {
  color: #fff;
  font-size: var(--fs-display);
  font-weight: 800;
  letter-spacing: -0.045em;
  line-height: 0.95;
  margin-bottom: var(--space-5);
}
.hero h1 .accent { color: var(--coral); }
.hero .lede { color: #DCE6F4; max-width: 34ch; }
.hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  margin-top: var(--space-6);
}
.hero__trust {
  margin-top: var(--space-6);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2) var(--space-5);
  color: #9FB2CC;
  font-size: 0.9rem;
  font-weight: 600;
}
.hero__trust span { display: inline-flex; align-items: center; gap: 0.45em; }
.hero__trust .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--teal); }

/* Hero collage board */
.hero__board {
  position: relative;
  min-height: clamp(360px, 42vw, 480px);
  z-index: 1;
}
.hero__mark {
  position: absolute;
  top: 50%; left: 50%;
  width: clamp(180px, 24vw, 280px);
  transform: translate(-50%, -50%);
  filter: drop-shadow(0 24px 50px rgba(0,0,0,0.45));
  animation: float 7s var(--ease) infinite;
}
.hero__note {
  position: absolute;
  z-index: 3;
  font-size: 0.95rem;
  max-width: 200px;
}
.hero__note--1 { top: 4%;  left: -2%;  transform: rotate(-6deg); }
.hero__note--2 { bottom: 2%; right: -3%; transform: rotate(5deg); }
.hero__spark {
  position: absolute;
  color: var(--mustard);
}
.hero__spark--1 { top: 8%;  right: 16%; --size: 56px; animation: spin 18s linear infinite; }
.hero__spark--2 { bottom: 14%; left: 6%; --size: 34px; color: var(--teal); animation: pulse 4s var(--ease) infinite; }

@keyframes float { 0%,100% { transform: translate(-50%,-50%); } 50% { transform: translate(-50%, calc(-50% - 14px)); } }
@keyframes spin  { to { transform: rotate(360deg); } }
@keyframes pulse { 0%,100% { transform: scale(1); opacity: .9; } 50% { transform: scale(1.18); opacity: 1; } }

/* Marquee of category chips under hero */
.hero__rail {
  border-top: 1px solid rgba(255,255,255,0.08);
  background: rgba(7,20,38,0.5);
}
.hero__rail .container {
  display: flex; flex-wrap: wrap; gap: var(--space-3);
  padding-block: var(--space-4);
  align-items: center;
}
.hero__rail .label {
  color: #8EA1BC; font-size: 0.8rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.12em; margin-right: var(--space-2);
}
.chip {
  display: inline-flex; align-items: center; gap: 0.5em;
  padding: 0.45em 0.9em;
  border-radius: var(--r-pill);
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.12);
  color: #E8EEF8;
  font-size: 0.85rem; font-weight: 700;
}
.chip .dot { width: 8px; height: 8px; border-radius: 50%; }

/* 9. Pillars strip ------------------------------------------------------- */
.pillars { background: var(--surface); border-bottom: 1px solid var(--border); }
.pillars__grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--space-4);
  padding-block: var(--space-6);
}
.pillar {
  display: flex; flex-direction: column; gap: var(--space-2);
  padding: var(--space-3);
}
.pillar__icon {
  width: 44px; height: 44px;
  display: grid; place-items: center;
  border-radius: var(--r-md);
  background: var(--cloud);
  color: var(--coral);
}
.pillar__icon svg { width: 24px; height: 24px; }
.pillar h3 { font-size: 1.05rem; margin: 0; }
.pillar p { font-size: 0.9rem; color: var(--muted); margin: 0; line-height: 1.45; }

/* 10. App cards ---------------------------------------------------------- */
.app-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(1rem, 2vw, 1.5rem);
}
.app-card {
  --accent: var(--coral);
  position: relative;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--space-6);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  transition: transform var(--t), box-shadow var(--t), border-color var(--t);
}
.app-card::before {            /* accent top bar */
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 5px;
  background: var(--accent);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--t);
}
.app-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-md);
  border-color: color-mix(in srgb, var(--accent) 45%, var(--border));
}
.app-card:hover::before { transform: scaleX(1); }

.app-card__hero {
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 10;
  object-fit: contain;
  object-position: center;
  display: block;
  border-radius: 14px;
  border: 1px solid color-mix(in srgb, var(--accent) 18%, var(--border));
  box-shadow: 0 12px 28px rgba(31, 42, 68, 0.08);
  background: var(--cloud);
}
.app-card__top { display: flex; align-items: center; justify-content: space-between; }
.app-card__icon {
  width: 64px; height: 64px;
  border-radius: 18px;
  box-shadow: var(--shadow-sm);
}
.app-card__tag {
  font-size: 0.72rem; font-weight: 800;
  text-transform: uppercase; letter-spacing: 0.08em;
  color: var(--accent);
  background: color-mix(in srgb, var(--accent) 14%, #fff);
  padding: 0.35em 0.7em;
  border-radius: var(--r-pill);
}
.app-card h3 { margin: 0; }
.app-card h3 .muted-name { color: var(--muted); font-weight: 700; }
.app-card p { color: var(--muted); margin: 0; flex: 1; }
.app-card .link-arrow { color: var(--accent); margin-top: var(--space-2); }

/* accent modifiers */
.app-card.is-roundready     { --accent: var(--roundready); }
.app-card.is-parenttravelpal{ --accent: var(--parenttravelpal); }
.app-card.is-fairwayaway    { --accent: var(--fairwayaway); }
.app-card.is-goodcatch      { --accent: var(--goodcatch); }
.app-card.is-yardable       { --accent: var(--yardable); }
.app-card.is-ideasweetspot  { --accent: var(--ideasweetspot); }

/* 11. How it works ------------------------------------------------------- */
.steps {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(1rem, 2.4vw, 2rem);
  counter-reset: step;
}
.step { position: relative; }
.step__num {
  width: 56px; height: 56px;
  display: grid; place-items: center;
  border-radius: var(--r-md);
  background: var(--midnight);
  color: #fff;
  font-weight: 800;
  font-size: 1.25rem;
  margin-bottom: var(--space-4);
}
.step:nth-child(1) .step__num { background: var(--coral); }
.step:nth-child(2) .step__num { background: var(--mustard); color: var(--midnight); }
.step:nth-child(3) .step__num { background: var(--teal); }
.step:nth-child(4) .step__num { background: var(--purple); }
.step h3 { margin-bottom: var(--space-2); }
.step p { color: var(--muted); margin: 0; }
.step__arrow {
  position: absolute;
  top: 18px; right: -14%;
  width: 28%;
  color: var(--border-strong);
}
.step:last-child .step__arrow { display: none; }

/* 12. Studio ------------------------------------------------------------- */
.studio { position: relative; overflow: hidden; }
.studio__grid {
  display: grid;
  grid-template-columns: 0.95fr 1.05fr;
  gap: clamp(2rem, 4vw, 4rem);
  align-items: start;
}
.studio__intro .lede { color: #C9D4E6; margin-bottom: var(--space-6); }
.studio__intro .btn { margin-top: var(--space-2); }
.studio__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  align-items: center;
}
.studio__badge {
  display: inline-flex; align-items: center; gap: 0.6em;
  background: rgba(123,97,255,0.16);
  border: 1px solid rgba(123,97,255,0.4);
  color: #CFC4FF;
  padding: 0.5em 1em;
  border-radius: var(--r-pill);
  font-weight: 700; font-size: 0.85rem;
  margin-bottom: var(--space-5);
}
.service-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-4);
}
.service-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: var(--space-5);
  transition: transform var(--t), box-shadow var(--t);
}
.service-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.service-card__icon {
  width: 46px; height: 46px;
  display: grid; place-items: center;
  border-radius: var(--r-sm);
  background: var(--purple-soft);
  color: var(--purple);
  margin-bottom: var(--space-3);
}
.service-card__icon svg { width: 24px; height: 24px; }
.service-card h3 { font-size: 1.15rem; color: var(--midnight); margin-bottom: var(--space-2); }
.service-card p { color: var(--muted); margin: 0; font-size: 0.95rem; line-height: 1.5; }
.service-card.is-wide { grid-column: 1 / -1; }

/* 13. Lead magnet -------------------------------------------------------- */
.leadmagnet__grid {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: clamp(2rem, 4vw, 4rem);
  align-items: center;
}
.checklist-card {
  position: relative;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--space-6);
  box-shadow: var(--shadow-md);
}
.checklist-card h3 { font-size: 1.15rem; margin-bottom: var(--space-4); }
.checklist {
  list-style: none;
  margin: 0; padding: 0;
  display: grid; gap: var(--space-3);
}
.checklist li {
  display: flex; align-items: flex-start; gap: 0.7em;
  font-weight: 600; color: var(--midnight);
}
.checklist li svg { flex: none; width: 22px; height: 22px; color: var(--teal); margin-top: 1px; }
.checklist-card .spark {
  position: absolute; top: -18px; right: -10px; --size: 44px; color: var(--mustard);
}

/* 14. Brand story -------------------------------------------------------- */
.story { position: relative; overflow: hidden; }
.story__inner { max-width: 56ch; position: relative; z-index: 2; }
.story h2 { color: #fff; font-size: var(--fs-h1); }
.story p { color: #D6E0F0; font-size: var(--fs-lede); line-height: 1.5; }
.story__kicker {
  font-style: italic; color: var(--teal-soft);
  font-size: clamp(1.2rem, 1rem + 1vw, 1.7rem);
  font-weight: 700;
  margin-top: var(--space-5);
}
.story__deco { right: -60px; bottom: -60px; width: 320px; opacity: 0.12; }

/* 15. CTA bands + forms -------------------------------------------------- */
.cta {
  position: relative;
  background:
    radial-gradient(700px 360px at 80% 0%, rgba(244,185,66,0.20), transparent 60%),
    linear-gradient(135deg, #102542, #0a1c33);
  color: #fff;
  overflow: hidden;
}
.cta__inner { max-width: 640px; position: relative; z-index: 2; }
.cta h2 { color: #fff; }
.cta p { color: #D6E0F0; }

/* Inline email form */
.signup {
  display: flex;
  gap: var(--space-3);
  margin-top: var(--space-5);
  flex-wrap: wrap;
}
.signup .field { flex: 1 1 240px; }
.field { display: flex; flex-direction: column; gap: var(--space-2); }
.field > label { font-weight: 700; font-size: 0.9rem; }
.input, .textarea, .select {
  width: 100%;
  padding: 0.9em 1em;
  border: 1.5px solid var(--border-strong);
  border-radius: var(--r-md);
  background: #fff;
  color: var(--ink);
  font: inherit;
  transition: border-color var(--t-fast), box-shadow var(--t-fast);
}
.input:focus, .textarea:focus, .select:focus {
  outline: none;
  border-color: var(--teal);
  box-shadow: 0 0 0 4px rgba(61,183,163,0.18);
}
.textarea { min-height: 120px; resize: vertical; }
.form-hint { font-size: 0.82rem; color: var(--muted); margin-top: var(--space-2); }
.cta .form-hint { color: #9FB2CC; }

/* Studio intake form card */
.intake {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: clamp(1.5rem, 3vw, var(--space-6));
  box-shadow: var(--shadow-md);
}
.intake .grid-2 {
  display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4);
}
.intake .field { margin-bottom: var(--space-4); }
.intake .btn { margin-top: var(--space-2); }

/* Form success / status message */
.form-status {
  margin-top: var(--space-4);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--r-md);
  font-weight: 700;
  display: none;
}
.form-status.is-visible { display: block; }
.form-status.is-success { background: var(--note-mint); color: #14624f; }
.form-status.is-error { background: var(--note-coral); color: #8a2d1c; }

/* 16. Footer ------------------------------------------------------------- */
.site-footer {
  background: var(--navy-dark);
  color: #B7C4DA;
  padding-block: var(--space-8) var(--space-6);
}
.footer__top {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1.2fr;
  gap: var(--space-7);
  padding-bottom: var(--space-7);
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.footer__brand img { height: 42px; margin-bottom: var(--space-4); }
.footer__brand p { color: #93A3BE; max-width: 32ch; }
.footer__tagline { color: var(--teal-soft); font-style: italic; font-weight: 700; }
.footer__col h4 {
  color: #fff; font-size: 0.85rem; text-transform: uppercase;
  letter-spacing: 0.12em; margin-bottom: var(--space-4);
}
.footer__col ul { list-style: none; margin: 0; padding: 0; display: grid; gap: var(--space-3); }
.footer__col a { color: #B7C4DA; text-decoration: none; font-weight: 600; transition: color var(--t-fast); }
.footer__col a:hover { color: #fff; }
.footer__signup .input { background: rgba(255,255,255,0.06); border-color: rgba(255,255,255,0.16); color: #fff; }
.footer__signup .input::placeholder { color: #8195B0; }
.footer__signup .signup { margin-top: var(--space-3); }
.footer__bottom {
  display: flex; flex-wrap: wrap; gap: var(--space-4);
  align-items: center; justify-content: space-between;
  padding-top: var(--space-5);
  font-size: 0.85rem; color: #7E90AC;
}
.footer__bottom a { color: #9FB2CC; }

/* 17. Reveal on scroll --------------------------------------------------- *
   Only hide content when JS is available (html.js). With JS disabled the
   site renders fully — important for a static, crawlable, accessible build. */
.js .reveal {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity 0.6s var(--ease), transform 0.6s var(--ease);
  will-change: opacity, transform;
}
.js .reveal.is-in { opacity: 1; transform: none; }
.js .reveal[data-delay="1"] { transition-delay: 80ms; }
.js .reveal[data-delay="2"] { transition-delay: 160ms; }
.js .reveal[data-delay="3"] { transition-delay: 240ms; }
.js .reveal[data-delay="4"] { transition-delay: 320ms; }

@media (prefers-reduced-motion: reduce) {
  .js .reveal { opacity: 1; transform: none; transition: none; }
  .hero__mark, .hero__spark--1, .hero__spark--2 { animation: none; }
}

/* 18. Responsive --------------------------------------------------------- */
@media (max-width: 1024px) {
  .footer__top { grid-template-columns: 1fr 1fr; }
  .footer__brand { grid-column: 1 / -1; }
}

@media (max-width: 880px) {
  .pillars__grid { grid-template-columns: repeat(2, 1fr); }
  .app-grid { grid-template-columns: repeat(2, 1fr); }
  .steps { grid-template-columns: repeat(2, 1fr); }
  .step__arrow { display: none; }
  .studio__grid, .leadmagnet__grid { grid-template-columns: 1fr; }
  .hero__grid { grid-template-columns: 1fr; }
  .hero__board { min-height: 320px; order: -1; }

  /* Mobile nav */
  .nav-toggle { display: flex; }
  .primary-nav__links {
    position: absolute;
    top: 100%; left: 0; right: 0;
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    background: rgba(7,20,38,0.98);
    backdrop-filter: blur(14px);
    border-bottom: 1px solid rgba(255,255,255,0.1);
    padding: var(--space-3) var(--gutter) var(--space-5);
    transform: translateY(-12px);
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--t), transform var(--t);
  }
  .primary-nav__links a { padding: var(--space-4) 0; border-bottom: 1px solid rgba(255,255,255,0.07); }
  .primary-nav.is-open .primary-nav__links {
    transform: none; opacity: 1; pointer-events: auto;
  }
  .primary-nav__cta { display: none; }
  .primary-nav.is-open .primary-nav__cta { display: inline-flex; margin-top: var(--space-4); }
}

@media (max-width: 560px) {
  .app-grid { grid-template-columns: 1fr; }
  .steps { grid-template-columns: 1fr; }
  .pillars__grid { grid-template-columns: 1fr; }
  .intake .grid-2 { grid-template-columns: 1fr; }
  .footer__top { grid-template-columns: 1fr; }
  .btn { width: 100%; }
  .hero__actions .btn { width: 100%; }
}
