/* ==========================================================================
   Normal People Coalition — stylesheet
   A dark, institutional "frontier-research" design system:
   near-black canvas, a single red accent, generated mesh artwork,
   Space Grotesk display + Inter text.
   ========================================================================== */

:root {
  /* surfaces */
  --bg:        #0a0c11;   /* page canvas — near-black, faint cool */
  --bg-elev:   #0e1118;   /* elevated section */
  --bg-top:    #14120f;   /* top utility strip — faint warm */
  --surface:   rgba(255,255,255,.022);
  --surface-2: rgba(255,255,255,.05);

  /* hairlines */
  --line:      rgba(255,255,255,.10);
  --line-2:    rgba(255,255,255,.18);

  /* ink */
  --ink:       #f4f6fa;
  --ink-2:     #b4bbc8;
  --ink-3:     #7b8493;

  /* accent — a single, deliberate blue (ties into the mesh artwork) */
  --accent:       #2563eb;
  --accent-bright:#3b82f6;
  --accent-ink:   #7cb0ff;

  /* artwork gradient (used only in the generated mesh) */
  --cyan:      #22d3ee;
  --violet:    #8b5cf6;

  /* type */
  --display: "Space Grotesk", "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;
  --sans:    "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;

  /* layout */
  --maxw:        1240px;
  --maxw-measure: 44rem;
  --radius:    14px;
  --radius-sm: 9px;
  --radius-pill: 999px;
  --space: clamp(4.5rem, 9vw, 8.5rem);

  --shadow:    0 1px 0 rgba(255,255,255,.03), 0 20px 50px -24px rgba(0,0,0,.7);
  --ring: 0 0 0 3px rgba(37,99,235,.45);
}

/* ---------- reset ---------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; overflow-x: clip; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }

/* grid/flex children must be allowed to shrink below content width */
.intro-grid > *, .join-grid > *, .footer-grid > *, .principle > *, .nav > *, .cta-body { min-width: 0; }

body {
  font-family: var(--sans);
  color: var(--ink-2);
  background: var(--bg);
  line-height: 1.7;
  font-size: 1.0625rem;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

/* faint ambient field behind the whole page */
body::before {
  content: "";
  position: fixed; inset: 0; z-index: -1; pointer-events: none;
  background:
    radial-gradient(60% 50% at 82% 0%, rgba(79,114,240,.08), transparent 60%),
    radial-gradient(50% 40% at 6% 2%, rgba(37,99,235,.05), transparent 60%);
}

img { max-width: 100%; display: block; height: auto; }
a { color: var(--ink); text-underline-offset: .2em; text-decoration-thickness: .06em; }
a:hover { color: #fff; }

h1, h2, h3, h4 {
  font-family: var(--display);
  font-weight: 500;
  line-height: 1.06;
  letter-spacing: -.02em;
  color: var(--ink);
}
h1 { font-size: clamp(2.5rem, 5.6vw, 4.7rem); }
h2 { font-size: clamp(1.75rem, 3.4vw, 2.65rem); }
h3 { font-size: clamp(1.3rem, 2vw, 1.55rem); font-weight: 600; letter-spacing: -.015em; }
p { color: var(--ink-2); }
strong { color: var(--ink); font-weight: 600; }

:focus-visible { outline: none; box-shadow: var(--ring); border-radius: 6px; }
::selection { background: rgba(37,99,235,.32); color: #fff; }

/* ---------- layout helpers ---------- */
.wrap { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: clamp(1.15rem, 4vw, 2.4rem); }
.narrow { max-width: 60rem; margin-inline: auto; }
.measure { max-width: var(--maxw-measure); }
.section { padding-block: var(--space); }
.section--top0 { padding-top: clamp(2.4rem, 5vw, 3.6rem); }
.band { padding-block: clamp(3rem, 6vw, 5rem); }
.bg-elev { background: var(--bg-elev); border-block: 1px solid var(--line); }
.center { text-align: center; }

/* labels */
.eyebrow, .kicker {
  display: inline-flex; align-items: center; gap: .6rem;
  font-family: var(--sans);
  font-size: .76rem; font-weight: 600; letter-spacing: .18em; text-transform: uppercase;
  color: var(--ink-3);
}
.eyebrow { color: var(--accent-ink); }
.kicker-dot, .note-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--accent); box-shadow: 0 0 12px rgba(37,99,235,.8); flex: none; }
.section-head { max-width: 40rem; margin-bottom: clamp(2.2rem, 4vw, 3.4rem); }
.section-head h2 { margin-top: 1rem; }
.section-head .eyebrow + h2 { margin-top: .9rem; }

.page-lede { font-size: clamp(1.15rem, 2vw, 1.35rem); color: var(--ink); line-height: 1.5; max-width: 42rem; margin-top: 1.4rem; font-weight: 400; }

/* ---------- buttons ---------- */
.btn {
  position: relative;
  display: inline-flex; align-items: center; justify-content: center; gap: .55rem;
  font-family: var(--sans); font-weight: 600; font-size: .98rem; line-height: 1;
  padding: .92rem 1.6rem; border-radius: var(--radius-pill); cursor: pointer;
  border: 1px solid transparent; text-decoration: none; white-space: nowrap;
  transition: transform .18s ease, background .2s ease, color .2s ease, border-color .2s ease, box-shadow .25s ease;
}
.btn--lg { padding: 1.05rem 1.9rem; font-size: 1.04rem; }
.btn--block { width: 100%; }
.btn .ico-arrow { transition: transform .2s ease; }
.btn:hover .ico-arrow { transform: translateX(3px); }

.btn--accent { background: var(--accent); color: #fff; box-shadow: 0 10px 30px -12px rgba(37,99,235,.9); }
.btn--accent:hover { background: var(--accent-bright); color: #fff; transform: translateY(-2px); box-shadow: 0 16px 38px -14px rgba(37,99,235,.95); }
.btn--accent:active { transform: translateY(0); }

.btn--ghost { background: transparent; color: var(--ink); border-color: var(--line-2); }
.btn--ghost:hover { background: var(--surface-2); color: #fff; border-color: rgba(255,255,255,.4); transform: translateY(-2px); }

.btn--outline { background: transparent; color: var(--ink); border-color: var(--line-2); padding: .72rem 1.25rem; font-size: .92rem; }
.btn--outline:hover { border-color: var(--accent); color: #fff; background: rgba(37,99,235,.08); }

.btn-row { display: flex; flex-wrap: wrap; gap: .85rem; }
.center .btn-row { justify-content: center; }

/* ---------- header / nav ---------- */
.site-header { position: sticky; top: 0; z-index: 60; background: rgba(10,12,17,.72); backdrop-filter: saturate(150%) blur(14px); -webkit-backdrop-filter: saturate(150%) blur(14px); border-bottom: 1px solid var(--line); transition: background .25s ease, border-color .25s ease; }
.site-header.is-elevated { background: rgba(9,11,15,.92); border-bottom-color: var(--line-2); }
.nav { display: flex; align-items: center; gap: 1.6rem; min-height: 76px; }

/* brand wordmark */
.brand { display: inline-flex; align-items: center; gap: .85rem; text-decoration: none; color: var(--ink); flex: none; }
.brand-mono { font-family: var(--display); font-weight: 700; font-size: 1.6rem; letter-spacing: -.04em; color: var(--ink); line-height: 1; }
.brand-mono-x { color: var(--accent-bright); }
.brand-rule { width: 1px; height: 30px; background: var(--line-2); }
.brand-name { font-family: var(--sans); font-weight: 600; font-size: .68rem; letter-spacing: .16em; text-transform: uppercase; line-height: 1.32; color: var(--ink-2); }
.brand:hover .brand-name { color: var(--ink); }

.nav-main { margin-left: auto; }
.nav-links { display: flex; align-items: center; gap: .3rem; list-style: none; padding: 0; }
.nav-links a { display: inline-block; padding: .5rem .9rem; border-radius: var(--radius-pill); color: var(--ink-2); text-decoration: none; font-weight: 500; font-size: .96rem; transition: color .15s ease, background .15s ease; }
.nav-links a:hover { color: #fff; background: var(--surface-2); }
.nav-links a.is-active { color: #fff; }
.nav-links a.is-active::after { content: ""; display: block; height: 2px; margin: .35rem .9rem 0; border-radius: 2px; background: var(--accent); }
.nav-cta { flex: none; }

.nav-toggle { display: none; width: 46px; height: 46px; align-items: center; justify-content: center; border: 1px solid var(--line-2); border-radius: 10px; background: var(--surface); color: var(--ink); cursor: pointer; flex: none; }
.nav-drawer { display: none; }

@media (max-width: 1040px) {
  .nav-main, .nav-cta { display: none; }
  .nav-toggle { display: inline-flex; margin-left: auto; }
  .nav-drawer {
    position: fixed; inset: 76px 0 auto 0; display: none; flex-direction: column; gap: .2rem;
    background: rgba(8,10,14,.98); backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
    border-bottom: 1px solid var(--line);
    padding: 1rem clamp(1.15rem,4vw,2.4rem) 1.6rem; box-shadow: var(--shadow);
  }
  .nav-drawer.open { display: flex; animation: drawer-in .22s ease; }
  @keyframes drawer-in { from { opacity: 0; transform: translateY(-8px); } to { opacity: 1; transform: none; } }
  .nav-drawer .nav-links { flex-direction: column; align-items: stretch; gap: .1rem; }
  .nav-drawer .nav-links a { padding: .85rem .9rem; font-size: 1.05rem; border-radius: 10px; }
  .nav-drawer .nav-links a.is-active::after { display: none; }
  .nav-drawer .btn { margin-top: .9rem; }
}
.nav-open body, body.nav-open { overflow: hidden; }

/* ---------- generated mesh artwork ---------- */
.flow { display: block; width: 100%; height: auto; }
.flow--faint { opacity: .55; }

/* ---------- hero ---------- */
.hero { position: relative; overflow: hidden; padding-top: clamp(3.5rem, 7vw, 6.5rem); padding-bottom: clamp(3rem, 5vw, 4.5rem); }
.hero-art {
  position: absolute; top: -12%; right: -8%; width: min(74%, 920px); z-index: 0; pointer-events: none;
  -webkit-mask-image: linear-gradient(100deg, transparent 0%, #000 34%, #000 100%);
  mask-image: linear-gradient(100deg, transparent 0%, #000 34%, #000 100%);
}
.hero-in { position: relative; z-index: 1; max-width: 47rem; }
.kicker { margin-bottom: 1.7rem; }
.hero-title { font-size: clamp(2.1rem, 6.4vw, 5rem); line-height: 1.05; max-width: 18ch; overflow-wrap: break-word; }
.hero-actions { margin-top: 2.4rem; }

.hero-rule { height: 1px; background: linear-gradient(90deg, var(--line-2), transparent); margin-top: clamp(3rem, 6vw, 5rem); }

/* editorial intro band (mirrors the institutional two-column lead) */
.intro-grid { position: relative; z-index: 1; display: grid; grid-template-columns: 1.05fr 1fr; gap: clamp(1.6rem, 5vw, 4.5rem); padding-top: clamp(2.4rem, 5vw, 3.6rem); }
.intro-statement { font-family: var(--display); font-weight: 500; font-size: clamp(1.5rem, 2.6vw, 2.1rem); line-height: 1.2; letter-spacing: -.02em; color: var(--ink); }
.intro-body { padding-top: .4rem; }
.intro-body p { font-size: 1.08rem; }
@media (max-width: 820px) { .intro-grid { grid-template-columns: 1fr; gap: 1.4rem; } }

/* ---------- principles (numbered editorial rows) ---------- */
.principles { display: grid; gap: 0; border-top: 1px solid var(--line); }
.principle { display: grid; grid-template-columns: auto 1fr; gap: clamp(1.2rem, 4vw, 3.5rem); padding-block: clamp(2.2rem, 4vw, 3.2rem); border-bottom: 1px solid var(--line); }
.principle-num { font-family: var(--display); font-weight: 500; font-size: 1rem; color: var(--accent-ink); letter-spacing: .05em; padding-top: .5rem; }
.principle-main { max-width: 52rem; }
.principle-main h3 { margin-bottom: 1rem; }
.principle-main p { font-size: 1.06rem; }
@media (max-width: 640px) { .principle { grid-template-columns: 1fr; gap: .6rem; } .principle-num { padding-top: 0; } }

.link-more { display: inline-flex; align-items: center; gap: .45rem; margin-top: 1.3rem; font-weight: 600; font-size: .96rem; color: var(--ink); text-decoration: none; }
.link-more .ico-arrow { transition: transform .2s ease; color: var(--accent-ink); }
.link-more:hover { color: #fff; }
.link-more:hover .ico-arrow { transform: translateX(4px); }

/* ---------- interior page hero ---------- */
.page-hero { position: relative; overflow: hidden; padding-top: clamp(3rem, 6vw, 5rem); padding-bottom: clamp(2.4rem, 4vw, 3.4rem); border-bottom: 1px solid var(--line); }
.page-hero-art { position: absolute; top: -30%; right: -6%; width: min(58%, 720px); z-index: 0; pointer-events: none;
  -webkit-mask-image: linear-gradient(100deg, transparent 0%, #000 45%);
  mask-image: linear-gradient(100deg, transparent 0%, #000 45%); }
.page-hero > .wrap { position: relative; z-index: 1; }
.breadcrumb { font-size: .85rem; color: var(--ink-3); margin-bottom: 1.3rem; letter-spacing: .02em; }
.breadcrumb a { color: var(--ink-3); text-decoration: none; }
.breadcrumb a:hover { color: var(--ink); }
.breadcrumb span { margin-inline: .5rem; color: var(--line-2); }

/* lists with ticks */
.bullet-lg { list-style: none; padding: 0; display: grid; gap: .9rem; margin-top: 1.8rem; }
.bullet-lg li { display: flex; align-items: center; gap: .85rem; font-family: var(--display); font-weight: 500; font-size: clamp(1.1rem, 1.9vw, 1.35rem); color: var(--ink); letter-spacing: -.01em; }
.tick { width: 28px; height: 28px; border-radius: 7px; flex: none; display: grid; place-items: center; background: rgba(37,99,235,.14); color: var(--accent-ink); border: 1px solid rgba(37,99,235,.3); }

/* ---------- long-form prose ---------- */
.prose { color: var(--ink-2); }
.prose > * + * { margin-top: 1.3rem; }
.prose p { font-size: 1.12rem; line-height: 1.78; }
.prose h2 { margin-top: 3rem; }
.prose h2 + p { margin-top: 1.2rem; }
.prose .eyebrow { margin-bottom: .4rem; }
.prose a { color: var(--accent-ink); text-decoration: underline; text-decoration-color: rgba(255,107,102,.4); }
.prose a:hover { color: #fff; text-decoration-color: #fff; }
.cta-sentence { color: var(--ink); }
.closing-line { font-family: var(--display); font-weight: 500; font-size: clamp(1.4rem, 2.6vw, 1.9rem); line-height: 1.3; letter-spacing: -.02em; color: var(--ink); margin-top: 2.8rem; padding-top: 1.8rem; border-top: 1px solid var(--line); }

/* ---------- team ---------- */
.team { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1.2rem, 2.5vw, 1.8rem); }
@media (max-width: 860px) { .team { grid-template-columns: 1fr; max-width: 30rem; } }
.member { background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; transition: transform .2s ease, border-color .2s ease, background .2s ease; }
.member:hover { transform: translateY(-4px); border-color: var(--line-2); background: var(--surface-2); }
.member-photo { aspect-ratio: 1; overflow: hidden; background: var(--bg-elev); border-bottom: 1px solid var(--line); }
.member-photo img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(.25) contrast(1.02); transition: filter .3s ease; }
.member:hover .member-photo img { filter: none; }
.member-body { padding: 1.3rem 1.4rem 1.6rem; }
.member-body h3 { font-size: 1.22rem; }
.member .role { color: var(--accent-ink); font-weight: 600; font-size: .82rem; letter-spacing: .1em; text-transform: uppercase; margin: .35rem 0 .9rem; }
.member-body p { font-size: .96rem; line-height: 1.65; }

.note-501 { display: inline-flex; align-items: center; gap: .7rem; margin-top: clamp(2rem, 4vw, 3rem); font-size: .92rem; color: var(--ink-3); }

/* ---------- CTA band ---------- */
.cta { position: relative; overflow: hidden; border: 1px solid var(--line); border-radius: clamp(16px, 3vw, 26px); background: linear-gradient(120deg, #11141c, #0b0d13); padding: clamp(2.4rem, 5vw, 4rem); }
.cta-art { position: absolute; inset: -30% -10% auto auto; width: min(62%, 640px); z-index: 0; opacity: .6; pointer-events: none;
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 55%); mask-image: linear-gradient(90deg, transparent, #000 55%); }
.cta-body { position: relative; z-index: 1; max-width: 40rem; }
.cta-lead { font-family: var(--display); font-weight: 500; font-size: clamp(1.4rem, 2.8vw, 2.05rem); line-height: 1.25; letter-spacing: -.02em; color: var(--ink); }
.cta .btn-row { margin-top: 2rem; }

/* ---------- join (split layout + form) ---------- */
.join-wrap { position: relative; overflow: hidden; padding-block: clamp(2.6rem, 6vw, 5rem); }
.join-art { position: absolute; inset: -20% -10% auto auto; width: min(60%, 720px); z-index: 0; pointer-events: none;
  -webkit-mask-image: linear-gradient(100deg, transparent 0%, #000 50%); mask-image: linear-gradient(100deg, transparent 0%, #000 50%); }
.join-grid { position: relative; z-index: 1; display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem, 5vw, 4.5rem); align-items: start; }
.join-intro { padding-top: 1rem; }
.join-intro h1 { font-size: clamp(2.1rem, 4.2vw, 3.3rem); margin-top: 1.4rem; max-width: 16ch; }
.join-intro .bullet-lg { margin-top: 2rem; }
@media (max-width: 880px) { .join-grid { grid-template-columns: 1fr; } .join-intro { max-width: 38rem; } }

.form-card { background: var(--surface); border: 1px solid var(--line-2); border-radius: var(--radius); box-shadow: var(--shadow); padding: clamp(1.5rem, 4vw, 2.4rem); }
.field { display: block; margin-bottom: 1.2rem; }
.field > label { display: block; font-weight: 500; font-size: .92rem; margin-bottom: .45rem; color: var(--ink); }
.field input { width: 100%; font-family: var(--sans); font-size: 1rem; color: var(--ink); background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.2); border-radius: var(--radius-sm); padding: .85rem 1rem; transition: border-color .15s ease, box-shadow .15s ease, background .15s ease; }
.field input::placeholder { color: var(--ink-3); }
.field input:hover { border-color: rgba(255,255,255,.3); }
.field input:focus { outline: none; border-color: var(--accent); background: rgba(255,255,255,.06); box-shadow: var(--ring); }
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 0 1rem; }
@media (max-width: 520px) { .grid-2 { grid-template-columns: 1fr; } }

.consent { display: flex; gap: .75rem; align-items: flex-start; background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius-sm); padding: .9rem 1rem; margin-bottom: 1.4rem; cursor: pointer; }
.consent input { margin-top: .15rem; width: 18px; height: 18px; accent-color: var(--accent); flex: none; }
.consent span { font-size: .9rem; color: var(--ink-2); line-height: 1.55; }

.form-status { display: none; border-radius: var(--radius-sm); padding: .9rem 1.1rem; font-weight: 500; margin-bottom: 1.1rem; font-size: .95rem; }
.form-status.show { display: block; }
.form-status.ok { background: rgba(34,211,238,.12); color: #bdeefa; border: 1px solid rgba(34,211,238,.35); }
.form-status.err { background: rgba(245,158,11,.12); color: #fcd9a0; border: 1px solid rgba(245,158,11,.4); }

.success-panel { display: none; text-align: center; padding: 1.5rem .5rem; }
.success-panel.show { display: block; animation: reveal .5s ease both; }
.success-panel .check { width: 64px; height: 64px; border-radius: 50%; background: rgba(34,211,238,.14); color: var(--cyan); display: grid; place-items: center; margin: 0 auto 1.2rem; border: 1px solid rgba(34,211,238,.4); }

/* ---------- news panel ---------- */
.news-panel { border: 1px solid var(--line); border-radius: var(--radius); background: var(--surface); padding: clamp(2.4rem, 5vw, 3.6rem); text-align: center; }
.news-icon { color: var(--accent-ink); display: inline-grid; place-items: center; margin-bottom: 1.3rem; }
.news-line { font-family: var(--display); font-weight: 500; font-size: clamp(1.25rem, 2.4vw, 1.6rem); line-height: 1.4; letter-spacing: -.015em; color: var(--ink); max-width: 34rem; margin: 0 auto; }

/* ---------- status pages (thanks / 404) ---------- */
.status-page { position: relative; overflow: hidden; padding-block: clamp(4.5rem, 12vw, 9rem); display: grid; place-items: center; min-height: 64vh; }
.status-art { position: absolute; inset: -10% -5% -10% auto; width: min(70%, 820px); z-index: 0; opacity: .5; pointer-events: none;
  -webkit-mask-image: radial-gradient(70% 70% at 60% 50%, #000, transparent 78%); mask-image: radial-gradient(70% 70% at 60% 50%, #000, transparent 78%); }
.status-page > .wrap { position: relative; z-index: 1; }
.status-code { font-family: var(--display); font-weight: 600; font-size: clamp(4rem, 14vw, 8rem); color: var(--ink); letter-spacing: -.04em; line-height: 1; }
.status-line { font-family: var(--display); font-weight: 500; font-size: clamp(1.4rem, 3vw, 2rem); line-height: 1.3; letter-spacing: -.02em; color: var(--ink); max-width: 30ch; margin: 1.4rem auto 2rem; }
.check--xl { width: 80px; height: 80px; border-radius: 50%; display: grid; place-items: center; margin: 0 auto; background: rgba(34,211,238,.12); color: var(--cyan); border: 1px solid rgba(34,211,238,.4); }

/* ---------- footer ---------- */
.site-footer { background: #07090d; border-top: 1px solid var(--line); padding-block: clamp(3rem, 6vw, 4.5rem) 2rem; }
.footer-grid { display: grid; grid-template-columns: 1.6fr 1fr; gap: 2.5rem 3rem; align-items: start; }
@media (max-width: 720px) { .footer-grid { grid-template-columns: 1fr; gap: 2rem; } }
.brand--footer .brand-mono { font-size: 1.5rem; }
.footer-about { max-width: 32ch; margin-top: 1.3rem; color: var(--ink-2); font-size: .98rem; }
.footer-501 { margin-top: .9rem; font-size: .9rem; color: var(--ink-3); }
.footer-h { font-size: .74rem; letter-spacing: .16em; text-transform: uppercase; color: var(--ink-3); margin-bottom: 1.1rem; font-weight: 600; }
.footer-col ul { list-style: none; padding: 0; display: grid; gap: .7rem; }
.footer-col a { color: var(--ink-2); text-decoration: none; font-size: .98rem; transition: color .15s ease; }
.footer-col a:hover { color: #fff; }
.footer-bottom { display: flex; align-items: center; justify-content: space-between; gap: 1rem; margin-top: clamp(2.4rem, 5vw, 3.4rem); padding-top: 1.5rem; border-top: 1px solid var(--line); font-size: .84rem; color: var(--ink-3); }
.footer-mono { font-family: var(--display); font-weight: 700; letter-spacing: .04em; color: var(--ink-3); }

/* ---------- misc ---------- */
.skip-link { position: absolute; left: -999px; top: 0; z-index: 100; background: var(--accent); color: #fff; padding: .7rem 1rem; border-radius: 0 0 8px 0; text-decoration: none; }
.skip-link:focus { left: 0; }

/* ---------- scroll-reveal ---------- */
.js .reveal { opacity: 0; transform: translateY(20px); transition: opacity .7s cubic-bezier(.22,.61,.36,1), transform .7s cubic-bezier(.22,.61,.36,1); will-change: opacity, transform; }
.js .reveal.in { opacity: 1; transform: none; }
@keyframes reveal { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: none; } }
@media (prefers-reduced-motion: reduce) {
  .js .reveal { opacity: 1 !important; transform: none !important; transition: none; }
}
