/* =========================================================================
   HARRIGAN SYSTEMS — visual system matched to harrigancreative.com
   White · navy ink · blue signal · Inter + Instrument Serif italic
   ========================================================================= */

:root {
  /* Palette */
  --bg:        #FFFFFF;
  --bg-soft:   #F4F7FB;
  --bg-soft2:  #EEF3FA;
  --ink:       #0A1228;   /* navy headlines */
  --ink-grad:  #0A1F3D;   /* dark-section gradient end */
  --slate:     #3D4658;   /* body text */
  --muted:     #697086;   /* secondary text */
  --line:      #DDE2EC;   /* hairline border */
  --line-soft: #E7ECF3;
  --line-ink:  rgba(255,255,255,.12);
  --blue:      #2F6DF6;   /* primary accent */
  --blue-700:  #1F57D6;
  --blue-soft: #DDE8FF;
  --blue-soft2:#EAF1FF;
  --green:     #15803D;
  --mint:      #16C79A;
  --green-bg:  #DCFCE7;
  --on-ink:    #EAEEF6;
  --muted-ink: #93A0BB;

  /* Type */
  --sans: "Inter", system-ui, -apple-system, "Segoe UI", Helvetica, Arial, sans-serif;
  --serif: "Instrument Serif", Georgia, serif;

  --step--1: clamp(0.8rem, 0.77rem + 0.15vw, 0.875rem);
  --step-0:  clamp(1rem, 0.97rem + 0.15vw, 1.0625rem);
  --step-1:  clamp(1.125rem, 1.05rem + 0.4vw, 1.3rem);
  --step-2:  clamp(1.4rem, 1.2rem + 0.9vw, 1.9rem);
  --step-3:  clamp(1.9rem, 1.5rem + 1.8vw, 2.9rem);
  --step-4:  clamp(2.4rem, 1.8rem + 3vw, 4.2rem);
  --step-5:  clamp(2.9rem, 2rem + 4.4vw, 5.4rem);

  --gap: clamp(1rem, 0.8rem + 1vw, 1.5rem);
  --section-y: clamp(4rem, 3rem + 5vw, 8rem);
  --wrap: 1200px;

  --r: 14px;
  --r-lg: 20px;
  --r-xl: 26px;
  --r-pill: 999px;

  --shadow-sm: 0 1px 2px rgba(10,18,40,.05), 0 1px 1px rgba(10,18,40,.04);
  --shadow: 0 14px 34px -16px rgba(10,18,40,.20);
  --shadow-lg: 0 36px 70px -24px rgba(10,18,40,.28);
  --shadow-blue: 0 16px 40px -16px rgba(47,109,246,.45);
  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after { box-sizing: border-box; }
* { margin: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }
body {
  font-family: var(--sans);
  font-size: var(--step-0);
  line-height: 1.6;
  color: var(--slate);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img,svg { display:block; max-width:100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; cursor: pointer; background: none; border: 0; }
::selection { background: var(--blue); color: #fff; }

/* ---------- Layout ---------- */
.wrap { width: min(100% - 2.5rem, var(--wrap)); margin-inline: auto; position: relative; z-index: 1; }
.section { padding-block: var(--section-y); position: relative; }
section[id] { scroll-margin-top: 88px; }
.section--tight { padding-block: clamp(2.5rem, 1.8rem + 2vw, 4rem); }
.section--soft { background: var(--bg-soft); border-block: 1px solid var(--line); }

/* faint grid + glow helpers (apply to a section) */
.grid-bg { position: relative; overflow: clip; }
.grid-bg::before {
  content:""; position:absolute; inset:0; z-index:0; pointer-events:none;
  background-image:
    linear-gradient(to right, rgba(10,18,40,.04) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(10,18,40,.04) 1px, transparent 1px);
  background-size: 58px 58px;
  -webkit-mask-image: radial-gradient(ellipse 70% 60% at 30% 0%, #000 0%, transparent 75%);
  mask-image: radial-gradient(ellipse 70% 60% at 30% 0%, #000 0%, transparent 75%);
}
.glow {
  position:absolute; z-index:0; pointer-events:none; border-radius:50%;
  background: radial-gradient(circle at 50% 50%, var(--blue-soft) 0%, transparent 65%);
  filter: blur(10px); opacity:.7;
}

/* ---------- Section header ---------- */
.shead { max-width: 64ch; margin-bottom: clamp(2rem, 1.4rem + 1.6vw, 3rem); }
.shead--center { margin-inline:auto; text-align:center; }
.eyebrow {
  font-size: var(--step--1);
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--muted);
  display: inline-flex; align-items: center; gap: .6em;
  margin-bottom: 1.1rem;
}
.eyebrow::before { content:"—"; color: var(--blue); font-weight:700; letter-spacing:0; }
.eyebrow--plain::before { display:none; }
.section--dark .eyebrow { color: var(--muted-ink); }

/* ---------- Type ---------- */
h1,h2,h3,h4 { font-family: var(--sans); color: var(--ink); font-weight: 500; line-height: 1.02; letter-spacing: -.035em; }
.serif-em { font-family: var(--serif); font-style: italic; font-weight: 400; letter-spacing: -.01em; color: var(--ink); }
.display { font-size: var(--step-4); }
.h2 { font-size: var(--step-3); }
.h3 { font-size: var(--step-2); }
.h4 { font-size: var(--step-1); font-weight:600; letter-spacing:-.02em; }
.lede { font-size: var(--step-1); line-height: 1.5; color: var(--slate); max-width: 54ch; font-weight: 400; }
.muted { color: var(--muted); }
.accent { color: var(--blue); }
.measure { max-width: 60ch; }
strong { color: var(--ink); font-weight: 600; }

.section--dark { background: linear-gradient(160deg, var(--ink) 0%, var(--ink-grad) 100%); color: var(--on-ink); }
.section--dark h1,.section--dark h2,.section--dark h3,.section--dark h4,.section--dark .serif-em { color: #fff; }
.section--dark .lede { color: var(--muted-ink); }
.section--dark .muted { color: var(--muted-ink); }
.section--dark strong { color:#fff; }

/* ---------- Buttons ---------- */
.btn {
  --bg: var(--ink); --fg: #fff; --bd: var(--ink);
  display:inline-flex; align-items:center; gap:.55em;
  padding: .8em 1.35em; border-radius: var(--r-pill);
  background: var(--bg); color: var(--fg); border: 1px solid var(--bd);
  font-weight: 600; font-size: var(--step-0); letter-spacing:-.01em;
  transition: transform .3s var(--ease), background .25s, box-shadow .35s var(--ease), border-color .25s, color .25s;
}
.btn .arr { transition: transform .3s var(--ease); }
.btn:hover { transform: translateY(-2px); box-shadow: var(--shadow); }
.btn:hover .arr { transform: translateX(4px); }
.btn--primary { --bg: var(--blue); --fg:#fff; --bd: var(--blue); }
.btn--primary:hover { --bg: var(--blue-700); box-shadow: var(--shadow-blue); }
.btn--dark { --bg: var(--ink); --fg:#fff; --bd: var(--ink); }
.btn--ghost { --bg: #fff; --fg: var(--ink); --bd: var(--line); }
.btn--ghost:hover { --bd: var(--ink); }
.section--dark .btn--ghost { --bg: transparent; --fg:#fff; --bd: var(--line-ink); }
.section--dark .btn--ghost:hover { --bd:#fff; }
.btn--lg { padding: .95em 1.6em; font-size: var(--step-1); }

.iconbtn {
  width: 56px; height:56px; border-radius:50%; background: var(--blue); color:#fff;
  display:inline-grid; place-items:center; box-shadow: var(--shadow-blue);
  transition: transform .3s var(--ease), background .25s;
}
.iconbtn:hover { transform: translateY(-3px) rotate(8deg); background: var(--blue-700); }

.textlink {
  display:inline-flex; align-items:center; gap:.4em; font-weight:600; color: var(--blue);
  transition: gap .25s var(--ease);
}
.textlink:hover { gap:.7em; }

/* ---------- Pills / chips ---------- */
.chip {
  display:inline-flex; align-items:center; gap:.5em;
  font-size: var(--step--1); font-weight:500; color: var(--slate);
  background:#fff; border:1px solid var(--line); border-radius: var(--r-pill);
  padding:.4em .9em; box-shadow: var(--shadow-sm);
}
.chip--soft { background: var(--bg-soft); box-shadow:none; }
.section--dark .chip { background: rgba(255,255,255,.06); border-color: var(--line-ink); color: var(--on-ink); box-shadow:none; }
.dot { width:.55em;height:.55em;border-radius:50%;background:var(--mint); box-shadow:0 0 0 0 rgba(22,199,154,.5); animation:pulse 2.4s infinite; flex:none; }
@keyframes pulse {0%{box-shadow:0 0 0 0 rgba(22,199,154,.45)}70%{box-shadow:0 0 0 7px rgba(22,199,154,0)}100%{box-shadow:0 0 0 0 rgba(22,199,154,0)}}

/* ---------- Grids ---------- */
.grid { display:grid; gap: var(--gap); }
.grid-2 { grid-template-columns: repeat(2,1fr); }
.grid-3 { grid-template-columns: repeat(3,1fr); }
.grid-4 { grid-template-columns: repeat(4,1fr); }
@media (max-width: 920px){ .grid-3,.grid-4 { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 600px){ .grid-2,.grid-3,.grid-4 { grid-template-columns: 1fr; } }

/* ---------- Cards ---------- */
.card {
  background:#fff; border:1px solid var(--line); border-radius: var(--r-lg);
  padding: clamp(1.4rem, 1.1rem + 1vw, 2rem); position:relative;
  transition: transform .35s var(--ease), box-shadow .35s var(--ease), border-color .3s;
}
.card:hover { transform: translateY(-4px); box-shadow: var(--shadow); border-color: #C6D2EA; }
.card__num { position:absolute; top:1.3rem; right:1.4rem; font-size: var(--step--1); color: var(--muted); font-variant-numeric: tabular-nums; letter-spacing:.1em; }
.card__icon {
  width:48px;height:48px;border-radius:13px; display:grid;place-items:center;
  background: var(--blue-soft); color: var(--blue); margin-bottom:1.2rem;
}
.card h3 { font-size: var(--step-1); font-weight:600; letter-spacing:-.02em; margin-bottom:.5rem; }
.card p { color: var(--slate); font-size: var(--step-0); }
.section--dark .card { background: rgba(255,255,255,.04); border-color: var(--line-ink); }
.section--dark .card p { color: var(--muted-ink); }
.section--dark .card__icon { background: rgba(47,109,246,.18); color: #9CC0FF; }

/* ---------- Flow pill (lead → ... → review) ---------- */
.flowbar {
  display:flex; align-items:center; flex-wrap:wrap; gap:.4rem .9rem;
  background:#fff; border:1px solid var(--line); border-radius: var(--r-pill);
  padding: .9rem 1.4rem; box-shadow: var(--shadow-sm);
}
.flowbar .step { display:inline-flex; align-items:center; gap:.5rem; color: var(--slate); font-weight:500; font-size: var(--step--1); white-space:nowrap; }
.flowbar .arr { color: var(--muted); }
.flowbar .win { color: var(--green); font-weight:600; }
@media (max-width:560px){ .flowbar{ border-radius: var(--r-lg); } }

/* ---------- Stats ---------- */
.stat__num { font-size: var(--step-3); font-weight:600; letter-spacing:-.04em; color: var(--ink); line-height:1; }
.stat__num .unit { color: var(--blue); }
.section--dark .stat__num { color:#fff; } .section--dark .stat__num .unit { color:#9CC0FF; }
.stat__label { font-size: var(--step--1); color: var(--muted); margin-top:.55rem; }
.section--dark .stat__label { color: var(--muted-ink); }
.kpi-row { display:flex; gap: clamp(1.6rem,1rem + 3vw,4rem); flex-wrap:wrap; }

/* ---------- Nav ---------- */
.nav { position: sticky; top:0; z-index:50; transition: background .35s var(--ease), border-color .35s, box-shadow .35s; border-bottom:1px solid transparent; }
.nav.scrolled { background: rgba(255,255,255,.82); backdrop-filter: saturate(160%) blur(12px); border-color: var(--line); }
.nav__inner { display:flex; align-items:center; justify-content:space-between; gap:1rem; height:72px; }
.brand { display:flex; align-items:center; gap:.65rem; }
.brand__mark { width:34px;height:34px;border-radius:9px; background: var(--ink); display:grid;place-items:center; flex:none; }
.brand__mark svg { width:20px;height:20px; }
.brand__name { font-weight:700; letter-spacing:-.02em; font-size:1.05rem; color: var(--ink); line-height:1.05; }
.brand__name small { display:block; font-weight:600; font-size:.58rem; letter-spacing:.18em; color: var(--muted); text-transform:uppercase; margin-top:2px; }
.nav__links { display:flex; align-items:center; gap: clamp(1rem,.5rem + 1.4vw,2.2rem); }
.nav__links a { font-size:.94rem; font-weight:500; color: var(--slate); position:relative; padding:.3em 0; transition:color .2s; }
.nav__links a:hover { color: var(--ink); }
.nav__links a::after { content:""; position:absolute; left:0; bottom:-2px; height:2px; width:0; background:var(--blue); transition:width .28s var(--ease); border-radius:2px; }
.nav__links a:hover::after { width:100%; }
.nav__right { display:flex; align-items:center; gap:1rem; }
.nav__status { display:flex; align-items:center; gap:.5rem; font-size:.85rem; color: var(--muted); font-weight:500; }
.nav__toggle { display:none; width:42px;height:42px;border:1px solid var(--line); border-radius:11px; align-items:center;justify-content:center; background:#fff; }
.nav__toggle span,.nav__toggle span::before,.nav__toggle span::after { display:block; width:18px;height:2px;background:var(--ink); border-radius:2px; transition:.3s var(--ease); content:""; }
.nav__toggle span::before{ position:absolute; transform:translateY(-6px); } .nav__toggle span::after{ position:absolute; transform:translateY(6px); }
.nav__toggle span{ position:relative; }
body.menu-open .nav__toggle span { background:transparent; }
body.menu-open .nav__toggle span::before { transform:rotate(45deg); }
body.menu-open .nav__toggle span::after { transform:rotate(-45deg); }
.nav__menu { display:flex; align-items:center; gap: clamp(1rem,.5rem + 1.4vw,2.2rem); }

@media (max-width: 900px){
  .nav__status { display:none; }
  .nav__toggle { display:flex; }
  .nav__menu {
    position: fixed; inset: 72px 0 auto 0; background:#fff; border-bottom:1px solid var(--line);
    flex-direction:column; align-items:stretch; gap:0; padding: 1rem 1.25rem 1.5rem;
    transform: translateY(-120%); transition: transform .42s var(--ease); box-shadow: var(--shadow);
  }
  .nav__menu.open { transform: translateY(0); }
  .nav__links { flex-direction:column; align-items:stretch; gap:0; }
  .nav__links a { font-size:1.05rem; padding:.75em 0; border-bottom:1px solid var(--line-soft); }
  .nav__right { flex-direction:column; align-items:stretch; gap:.7rem; margin-top:1rem; }
  .nav__right .btn { justify-content:center; }
}

/* ---------- Hero ---------- */
.hero { padding-top: clamp(2.5rem, 1.5rem + 3vw, 4.5rem); padding-bottom: var(--section-y); }
.hero__grid { display:grid; grid-template-columns: 1.05fr .95fr; gap: clamp(2rem,1rem + 3vw,4rem); align-items:center; }
@media (max-width: 960px){ .hero__grid { grid-template-columns:1fr; } }
.hero h1 { font-size: var(--step-5); letter-spacing:-.04em; line-height:.96; }
.hero .lede { margin-top: 1.5rem; }
.hero__cta { display:flex; gap:.75rem; flex-wrap:wrap; margin-top:2rem; }
.hero__stats { display:flex; gap: clamp(1.6rem,1rem + 3vw,3.4rem); flex-wrap:wrap; margin-top:2.6rem; padding-top:1.8rem; border-top:1px solid var(--line); }

/* hero dashboard panel */
.panel {
  background:#fff; border:1px solid var(--line); border-radius: var(--r-xl);
  box-shadow: var(--shadow-lg); overflow:hidden;
}
.panel__bar { display:flex; align-items:center; gap:.6rem; padding:.95rem 1.2rem; border-bottom:1px solid var(--line-soft); }
.panel__bar .live { display:inline-flex; align-items:center; gap:.45rem; font-size:.72rem; font-weight:600; letter-spacing:.12em; text-transform:uppercase; color: var(--muted); }
.panel__bar .when { margin-left:auto; font-size:.72rem; color: var(--muted); }
.panel__body { padding: 1.2rem; }
.panel__tiles { display:grid; grid-template-columns:1fr 1fr; gap:.8rem; margin-bottom:1rem; }
.tile { border:1px solid var(--line); border-radius: var(--r); padding:.9rem 1rem; background: var(--bg-soft); }
.tile .k { font-size:.66rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color: var(--muted); }
.tile .v { font-size:1.5rem; font-weight:600; letter-spacing:-.03em; color: var(--ink); margin-top:.25rem; line-height:1; }
.tile .delta { font-size:.72rem; font-weight:600; margin-top:.35rem; display:inline-flex; align-items:center; gap:.25rem; }
.tile .delta.up { color: var(--green); }
.panel__flow { border:1px solid var(--line); border-radius: var(--r); background:#fff; padding:.85rem 1rem; display:flex; flex-direction:column; gap:.55rem; }
.panel__row { display:flex; align-items:center; gap:.6rem; font-size:.82rem; color: var(--slate); opacity:0; transform: translateY(6px); }
.panel__row .tag { color: var(--blue); font-weight:600; }
.panel__row .ok { margin-left:auto; color: var(--green); font-weight:600; font-size:.74rem; }
.panel__row .arr { color: var(--muted); }
.panel.run .panel__row { animation: rowin .5s var(--ease) forwards; }
.panel.run .panel__row:nth-child(1){animation-delay:.1s}
.panel.run .panel__row:nth-child(2){animation-delay:.4s}
.panel.run .panel__row:nth-child(3){animation-delay:.7s}
.panel.run .panel__row:nth-child(4){animation-delay:1s}
@keyframes rowin { to { opacity:1; transform:none; } }
.panel { animation: floaty 7s ease-in-out infinite; }
@keyframes floaty { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-8px)} }

/* ---------- Marquee (dark, italic serif) ---------- */
.band { background: var(--ink); color:#fff; padding-block: clamp(1rem, .8rem + .6vw, 1.4rem); overflow:hidden; }
.band .marquee { -webkit-mask-image: linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent); mask-image: linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent); }
.marquee__track { display:flex; gap:0; width:max-content; animation: scrollx 34s linear infinite; }
.band:hover .marquee__track { animation-play-state: paused; }
.marquee__track span { font-family: var(--serif); font-style:italic; font-size: clamp(1.2rem, 1rem + 1vw, 1.7rem); color:#fff; white-space:nowrap; display:inline-flex; align-items:center; }
.marquee__track span::after { content:"•"; color: var(--blue); font-style:normal; margin:0 1.4rem; font-size:.7em; opacity:.9; }
@keyframes scrollx { to { transform: translateX(-50%); } }

/* ---------- Steps ---------- */
.step { padding-top:1.6rem; border-top:2px solid var(--ink); }
.section--dark .step { border-color: var(--blue); }
.step__n { font-size: var(--step--1); font-weight:600; color: var(--blue); letter-spacing:.08em; }
.step h3 { font-size: var(--step-2); font-weight:500; margin:.7rem 0 .55rem; }
.step p { color: var(--slate); }
.section--dark .step p { color: var(--muted-ink); }
.step__meta { display:inline-flex; align-items:center; gap:.45rem; font-size: var(--step--1); color: var(--muted); margin-top:1rem; font-weight:500; }
.section--dark .step__meta { color: var(--muted-ink); }

/* ---------- Split ---------- */
.split { display:grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem,1rem + 3vw,4.5rem); align-items:center; }
@media (max-width:900px){ .split { grid-template-columns:1fr; } }
.checklist { display:grid; gap:.85rem; margin-top:1.4rem; padding:0; }
.checklist li { list-style:none; display:flex; gap:.7rem; align-items:flex-start; color: var(--slate); }
.checklist .tick { flex:none; width:22px;height:22px;border-radius:50%; background: var(--green-bg); color: var(--green); display:grid;place-items:center; margin-top:.12rem; }
.checklist .tick svg { width:13px;height:13px; }
.section--dark .checklist li { color: var(--on-ink); }

/* ---------- Quote ---------- */
.quote { font-family: var(--serif); font-style:italic; font-size: var(--step-2); line-height:1.25; color: var(--ink); }
.section--dark .quote { color:#fff; }
.byline { font-size: var(--step--1); color: var(--muted); margin-top:1.2rem; font-weight:500; }
.section--dark .byline { color: var(--muted-ink); }

/* ---------- FAQ ---------- */
.faq { border-top:1px solid var(--line); max-width: 820px; margin-inline:auto; }
.faq details { border-bottom:1px solid var(--line); }
.faq summary { list-style:none; cursor:pointer; padding:1.35rem 0; display:flex; align-items:center; gap:1rem; font-weight:600; font-size: var(--step-1); color: var(--ink); letter-spacing:-.02em; }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary .q { font-size: var(--step--1); color: var(--blue); font-weight:600; font-variant-numeric:tabular-nums; }
.faq summary .plus { margin-left:auto; width:22px;height:22px; position:relative; flex:none; color: var(--muted); }
.faq summary .plus::before,.faq summary .plus::after{ content:""; position:absolute; inset:50% 0 auto 0; height:2px; background:currentColor; transform:translateY(-50%); border-radius:2px; }
.faq summary .plus::after{ transform:translateY(-50%) rotate(90deg); transition:transform .3s var(--ease); }
.faq details[open] summary .plus::after{ transform:translateY(-50%) rotate(0); }
.faq details[open] summary .plus { color: var(--blue); }
.faq__a { color: var(--slate); padding:0 0 1.4rem; max-width:70ch; }

/* ---------- CTA band ---------- */
.cta-band { text-align:center; max-width:760px; margin-inline:auto; }
.cta-band h2 { font-size: var(--step-4); }
.cta-band .lede { margin:1.1rem auto 2rem; text-align:center; }

/* ---------- Footer ---------- */
.foot { background: var(--ink); color: var(--on-ink); padding-block: clamp(3rem, 2rem + 3vw, 4.5rem) 1.8rem; }
.foot a { color: var(--muted-ink); transition:color .2s; font-size:.92rem; }
.foot a:hover { color:#fff; }
.foot__grid { display:grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap:2rem; }
@media (max-width:780px){ .foot__grid { grid-template-columns:1fr 1fr; } }
@media (max-width:460px){ .foot__grid { grid-template-columns:1fr; } }
.foot__grid .brand__name { color:#fff; }
.foot h5 { font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color: var(--muted-ink); margin-bottom:1rem; font-weight:600; }
.foot__col ul { list-style:none; display:grid; gap:.65rem; padding:0; }
.foot__bottom { display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; margin-top:2.6rem; padding-top:1.5rem; border-top:1px solid var(--line-ink); font-size:.82rem; color: var(--muted-ink); }

/* ---------- Reveal ---------- */
.reveal { opacity:0; transform: translateY(20px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.is-visible { opacity:1; transform:none; }
.reveal[data-d="1"]{transition-delay:.07s}.reveal[data-d="2"]{transition-delay:.14s}.reveal[data-d="3"]{transition-delay:.21s}
.reveal[data-d="4"]{transition-delay:.28s}.reveal[data-d="5"]{transition-delay:.35s}.reveal[data-d="6"]{transition-delay:.42s}
@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1!important;transform:none!important}
  .panel__row{opacity:1!important;transform:none!important}
  .panel{animation:none}.dot{animation:none}.marquee__track{animation:none}
}

/* ---------- Utilities ---------- */
.flow > * + * { margin-top: 1rem; }
.mt-1{margin-top:1rem}.mt-2{margin-top:2rem}
.center{text-align:center}

/* ---------- Contact form ---------- */
.form { display:block; }
.field { display:grid; gap:.4rem; }
.field + .field, .form-row + .field, .field + .form-row, .form-row + .form-row { margin-top:1rem; }
.field label { font-size:.72rem; font-weight:600; letter-spacing:.06em; text-transform:uppercase; color:var(--muted); }
.field input, .field select, .field textarea {
  width:100%; background:#fff; color:var(--ink);
  border:1px solid #CDD6E3; border-radius:10px; padding:.72rem .85rem;
  font-family:var(--sans); font-size:.95rem; line-height:1.4;
  transition:border-color .2s var(--ease), box-shadow .2s var(--ease);
  -webkit-appearance:none; appearance:none;
}
.field textarea { resize:vertical; min-height:118px; }
.field select {
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23697086' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right .85rem center; padding-right:2.4rem; cursor:pointer;
}
.field input:focus, .field select:focus, .field textarea:focus {
  outline:none; border-color:var(--blue); box-shadow:0 0 0 3px rgba(47,109,246,.16);
}
.field input::placeholder, .field textarea::placeholder { color:#9AA3B4; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
@media (max-width:560px){ .form-row { grid-template-columns:1fr; } .form-row + .field, .field + .form-row { margin-top:1rem; } }
.form button[type="submit"] { width:100%; justify-content:center; margin-top:1.3rem; }
.form__note { font-size:.78rem; color:var(--muted); margin-top:.9rem; text-align:center; }
.form__note a { color:var(--blue); }
.honeypot { position:absolute !important; left:-9999px; top:auto; width:1px; height:1px; overflow:hidden; }
.form-ok { text-align:center; padding:1.4rem .5rem; }
.form-ok .check { width:56px; height:56px; border-radius:50%; background:var(--green-bg); color:var(--green); display:grid; place-items:center; margin:0 auto 1.1rem; }
.form-ok .check svg { width:26px; height:26px; }
.form-ok h3 { color:var(--ink); font-size:var(--step-1); font-weight:600; margin-bottom:.5rem; }
.form-ok p { color:var(--muted); font-size:.95rem; }
.form-card-head { color:var(--ink); font-size:var(--step-1); font-weight:600; letter-spacing:-.02em; margin-bottom:.4rem; }
.form-card-sub { color:var(--muted); font-size:.92rem; margin-bottom:1.4rem; }
