/* FastCart — Landing shared stylesheet
 * Scope: index.html + materials.html
 * Typography: Instrument Serif (display) + General Sans (body) + Geist Mono (accents)
 */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  /* Palette */
  --ink: #0D1F16;
  --ink-soft: #2A3A2F;
  --muted: #6A7A70;
  --paper: #F4EFE6;
  --paper-2: #EDE7DA;
  --line: rgba(13, 31, 22, 0.08);

  --accent: #FF6A3D;
  --accent-soft: #FFE9DE;
  --moss: #B6CDB4;
  --moss-dark: #3C6B4A;

  /* Mesh gradient stops (hero + final CTA only) */
  --mesh-1: #0D1F16;
  --mesh-2: #3C6B4A;
  --mesh-3: #FF6A3D;
  --mesh-4: #FFC5A5;

  /* Shape */
  --radius-card: 16px;
  --radius-hero: 22px;
  --radius-pill: 999px;
  --shadow-soft: 0 18px 40px rgba(13, 31, 22, 0.08);

  /* Font stacks */
  --font-display: "Instrument Serif", Georgia, "Times New Roman", serif;
  --font-sans: "General Sans", system-ui, -apple-system, "Helvetica Neue", sans-serif;
  --font-mono: "Geist Mono", ui-monospace, "SFMono-Regular", Menlo, monospace;
}

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

body {
  font-family: var(--font-sans);
  font-weight: 400;
  font-size: 16px;
  line-height: 1.6;
  color: var(--ink);
  background-color: var(--paper);
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.051 0 0 0 0 0.121 0 0 0 0 0.086 0 0 0 0.04 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  background-repeat: repeat;
  background-size: 220px 220px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

a { color: inherit; text-decoration: none; }

img, svg { display: block; max-width: 100%; }

button { font: inherit; cursor: pointer; border: none; background: none; color: inherit; }

:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 3px;
  border-radius: 4px;
}

/* ---------- Layout ---------- */

.container {
  width: min(1180px, calc(100% - 48px));
  margin: 0 auto;
  position: relative;
}

.section {
  position: relative;
  padding: clamp(72px, 10vw, 140px) 0;
}

.section--paper   { background: var(--paper); }
.section--paper-2 { background: var(--paper-2); }

.section-divider {
  position: relative;
  height: 1px;
  width: min(1180px, calc(100% - 48px));
  margin: 0 auto;
  transform: skewY(-0.6deg);
  transform-origin: left;
  background: linear-gradient(90deg, transparent 0%, var(--line) 18%, var(--line) 82%, transparent 100%);
}

.section-divider::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--accent);
  transform: translate(-50%, -50%);
  opacity: 0.5;
}

/* Giant decorative section numbers */
.section-number {
  position: absolute;
  top: 0;
  right: clamp(-20px, -2vw, -8px);
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(120px, 18vw, 240px);
  line-height: 0.9;
  letter-spacing: -0.04em;
  color: rgba(13, 31, 22, 0.06);
  pointer-events: none;
  user-select: none;
  z-index: 0;
}

.section > .container { position: relative; z-index: 1; }

/* ---------- Typography utilities ---------- */

.display-h1 {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(56px, 7.5vw, 112px);
  line-height: 0.96;
  letter-spacing: -0.04em;
  color: var(--ink);
}

.section-h2 {
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: clamp(36px, 4.5vw, 64px);
  line-height: 1.04;
  letter-spacing: -0.03em;
  color: var(--ink);
}

.section-h2--italic {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  letter-spacing: -0.02em;
}

.lead {
  font-size: clamp(18px, 1.6vw, 22px);
  line-height: 1.55;
  color: var(--ink-soft);
  max-width: 62ch;
}

.mono-label {
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}

.mono-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 7px 12px;
  border-radius: var(--radius-pill);
  background: rgba(255, 255, 255, 0.6);
  border: 1px solid var(--line);
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-soft);
}

.micro {
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}

/* ---------- Eyebrow ---------- */

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-soft);
}

.eyebrow-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--accent);
  flex-shrink: 0;
}

/* ---------- Sticky nav ---------- */

.sticky-nav {
  position: sticky;
  top: 0;
  z-index: 50;
  backdrop-filter: saturate(140%) blur(14px);
  -webkit-backdrop-filter: saturate(140%) blur(14px);
  background: rgba(244, 239, 230, 0.78);
  border-bottom: 1px solid var(--line);
}

.sticky-nav__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: 16px 0;
}

.nav-logo {
  display: inline-flex;
  align-items: baseline;
  gap: 10px;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 26px;
  letter-spacing: -0.02em;
  color: var(--ink);
}

.nav-logo__mark {
  display: inline-grid;
  place-items: center;
  width: 36px;
  height: 36px;
  border-radius: 10px;
  background: var(--ink);
  color: var(--paper);
  font-family: var(--font-sans);
  font-style: normal;
  font-weight: 600;
  font-size: 14px;
  letter-spacing: 0.02em;
  align-self: center;
}

.nav-links {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.nav-links a {
  padding: 10px 14px;
  font-size: 15px;
  font-weight: 500;
  color: var(--ink-soft);
  border-radius: 10px;
  transition: color 0.15s ease, background 0.15s ease;
}

.nav-links a:hover { color: var(--ink); background: rgba(13, 31, 22, 0.04); }

.nav-cta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 11px 18px;
  font-size: 15px;
  font-weight: 600;
  color: #fff !important;
  background: var(--accent);
  border-radius: 12px;
  transition: transform 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
}

.nav-cta:hover {
  background: var(--ink);
  transform: translateY(-1px);
  box-shadow: var(--shadow-soft);
}

/* ---------- Buttons ---------- */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 56px;
  padding: 0 24px;
  border-radius: 14px;
  font-family: var(--font-sans);
  font-size: 16px;
  font-weight: 600;
  letter-spacing: -0.01em;
  transition: transform 0.15s ease, box-shadow 0.15s ease, background 0.15s ease, color 0.15s ease;
  border: 1px solid transparent;
}

.btn--primary {
  background: var(--accent);
  color: #fff;
}

.btn--primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 32px rgba(255, 106, 61, 0.28);
  background: #ff5825;
}

.btn--ghost {
  background: transparent;
  color: var(--ink);
  border-color: transparent;
  padding: 0 4px;
  min-height: auto;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 6px;
  text-decoration-color: var(--line);
}

.btn--ghost:hover { color: var(--accent); text-decoration-color: var(--accent); }

.btn--on-mesh {
  background: var(--paper);
  color: var(--ink);
}

.btn--on-mesh:hover {
  background: var(--accent);
  color: #fff;
  transform: translateY(-2px);
}

/* ---------- Hero ---------- */

.hero {
  position: relative;
  padding: clamp(56px, 8vw, 120px) 0 clamp(72px, 10vw, 140px);
  background: var(--paper);
  overflow: hidden;
}

.hero__grid {
  display: grid;
  grid-template-columns: minmax(0, 7fr) minmax(0, 5fr);
  gap: clamp(24px, 4vw, 56px);
  align-items: center;
}

.hero__eyebrow { margin-bottom: 28px; }

.hero__title {
  margin: 0 0 24px;
}

.hero__title .word {
  display: inline-block;
  opacity: 1;
  transform: translateY(0);
}

.hero__title .word--spacer { width: 0.25em; }

.hero__subhead {
  max-width: 52ch;
  margin-bottom: 36px;
}

.hero__cta-row {
  display: inline-flex;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
  margin-bottom: 20px;
}

.hero__microcopy {
  margin-top: 4px;
}

.hero__visual {
  position: relative;
  margin-right: calc(-1 * clamp(16px, 2.5vw, 40px));
  border-radius: var(--radius-hero);
  aspect-ratio: 4 / 5;
  padding: clamp(20px, 2.4vw, 36px);
  background: radial-gradient(60% 70% at 30% 20%, var(--mesh-2), transparent 60%),
              radial-gradient(50% 60% at 80% 30%, var(--mesh-3), transparent 65%),
              radial-gradient(60% 60% at 70% 85%, var(--mesh-4), transparent 60%),
              var(--mesh-1);
  box-shadow: var(--shadow-soft);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: visible;
}

/* ---- Mockup card (Telegram chat) ---- */

.mockup {
  --mk-paper: #FBF7EE;
  --mk-paper-2: #F1ECE0;
  --mk-ink: #0D1F16;
  --mk-ink-soft: #2A3A2F;
  --mk-muted: #73847A;
  --mk-line: rgba(13, 31, 22, 0.08);
  --mk-accent: #FF6A3D;
  --mk-moss: #B6CDB4;
  --mk-moss-dark: #3C6B4A;

  position: relative;
  width: 100%;
  max-width: 380px;
  border-radius: 22px;
  background: var(--mk-paper);
  box-shadow: 0 30px 60px -20px rgba(13, 31, 22, 0.45), 0 8px 18px -10px rgba(13, 31, 22, 0.3);
  overflow: hidden;
  font-family: var(--font-sans);
  color: var(--mk-ink);
  transform: translateZ(0);
}

.mockup__chrome {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  padding: 12px 16px;
  border-bottom: 1px solid var(--mk-line);
  background: var(--mk-paper-2);
}

.mockup__dots { display: inline-flex; gap: 6px; }
.mockup__dots i {
  width: 9px; height: 9px; border-radius: 50%;
  background: rgba(13, 31, 22, 0.16);
}
.mockup__dots i:first-child { background: #FF6A5B; }
.mockup__dots i:nth-child(2) { background: #FFBE50; }
.mockup__dots i:nth-child(3) { background: #4CCC6E; }

.mockup__title {
  justify-self: center;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--mk-ink-soft);
}

.mockup__time {
  justify-self: end;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.06em;
  color: var(--mk-muted);
}

.mockup__body {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 20px 18px 22px;
  background: linear-gradient(180deg, var(--mk-paper) 0%, var(--mk-paper-2) 100%);
}

/* bubbles */
.bubble { display: flex; flex-direction: column; max-width: 86%; }
.bubble--user { align-self: flex-end; align-items: flex-end; }
.bubble--bot  { align-self: flex-start; width: 100%; max-width: 100%; }

/* user: recipe thumb */
.thumb {
  width: 168px;
  aspect-ratio: 4 / 5;
  border-radius: 16px;
  overflow: hidden;
  position: relative;
  background:
    radial-gradient(120% 80% at 20% 10%, rgba(255, 197, 165, 0.45), transparent 60%),
    radial-gradient(120% 100% at 90% 90%, rgba(60, 107, 74, 0.55), transparent 60%),
    linear-gradient(155deg, #3C2A20 0%, #6A3F2C 55%, #A0583C 100%);
  box-shadow: 0 10px 28px -14px rgba(13, 31, 22, 0.5);
  isolation: isolate;
}

.thumb::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(2px 2px at 20% 40%, rgba(255,255,255,0.15) 100%, transparent 101%),
    radial-gradient(3px 3px at 70% 22%, rgba(255,255,255,0.12) 100%, transparent 101%),
    radial-gradient(2px 2px at 55% 70%, rgba(255,255,255,0.1) 100%, transparent 101%);
  mix-blend-mode: overlay;
  pointer-events: none;
}

.thumb__badge {
  position: absolute;
  top: 10px; left: 10px;
  padding: 4px 8px;
  border-radius: 999px;
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.12em;
  color: #fff;
  background: rgba(13, 31, 22, 0.5);
  backdrop-filter: blur(6px);
}

.thumb__surface {
  position: absolute;
  inset: 40% 12% 26% 12%;
  border-radius: 60% 40% 55% 45% / 50% 60% 40% 50%;
  background: radial-gradient(60% 80% at 40% 30%, rgba(255, 220, 190, 0.7), transparent 70%),
              radial-gradient(60% 60% at 70% 70%, rgba(255, 140, 100, 0.5), transparent 70%);
  filter: blur(6px);
  opacity: 0.65;
}

.thumb__caption {
  position: absolute;
  left: 10px; right: 10px; bottom: 10px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 9px;
  border-radius: 10px;
  background: rgba(13, 31, 22, 0.55);
  backdrop-filter: blur(6px);
  font-size: 10.5px;
  font-weight: 500;
  color: #fff;
}

.thumb__dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--mk-accent);
  box-shadow: 0 0 0 2px rgba(255, 106, 61, 0.25);
}

.bubble__meta {
  margin-top: 6px;
  display: inline-flex;
  gap: 8px;
  align-items: baseline;
  font-size: 11px;
  color: var(--mk-muted);
}
.bubble__meta .mono {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.04em;
}

/* bot bubble */
.bubble--bot .bubble__head {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
}

.bubble__check {
  display: inline-grid;
  place-items: center;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--mk-moss-dark);
  color: #fff;
}

.bubble__title {
  font-size: 14px;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--mk-ink);
}

.bubble__time.mono {
  font-family: var(--font-mono);
  font-size: 10.5px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--mk-accent);
  margin-left: auto;
}
.bubble--bot .bubble__head { justify-content: flex-start; }
.bubble--bot .bubble__head .bubble__time { margin-left: auto; }

.bubble__items {
  list-style: none;
  padding: 10px 12px;
  margin: 0;
  background: var(--mk-paper);
  border: 1px solid var(--mk-line);
  border-radius: 14px;
  display: grid;
  gap: 2px;
}

.bubble__items li {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 10px;
  padding: 6px 4px;
  font-size: 12.5px;
  color: var(--mk-ink-soft);
  border-bottom: 1px dashed var(--mk-line);
}
.bubble__items li:last-child { border-bottom: none; }

.bubble__items li .mono {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.02em;
  color: var(--mk-muted);
}

.bubble__more {
  color: var(--mk-moss-dark) !important;
  font-weight: 600;
}

.bubble__cta {
  margin-top: 12px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  border-radius: 12px;
  background: var(--mk-ink);
  color: var(--mk-paper);
  font-size: 12.5px;
  font-weight: 600;
  letter-spacing: -0.01em;
  align-self: flex-start;
}

/* ---- floating card ---- */

.hero__floating-card {
  position: absolute;
  left: clamp(-12px, -1vw, 0px);
  bottom: clamp(24px, 4vw, 48px);
  padding: 12px 16px 12px 14px;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: 14px;
  box-shadow: var(--shadow-soft);
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink);
  white-space: nowrap;
  z-index: 2;
}

.hero__floating-icon {
  display: inline-grid;
  place-items: center;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--moss-dark);
  color: var(--paper);
}

/* ---------- Social proof strip ---------- */

.proof {
  padding: 28px 0;
  background: var(--paper);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}

.proof__row {
  display: flex;
  align-items: center;
  justify-content: space-around;
  gap: 16px;
  flex-wrap: wrap;
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-soft);
}

.proof__row span:not(.proof__sep) { white-space: nowrap; }

.proof__sep {
  color: var(--accent);
  font-weight: 600;
}

/* ---------- Pain / Relief split ---------- */

.split {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 20px;
  margin-top: 48px;
}

.split__card {
  padding: clamp(28px, 3vw, 40px);
  border-radius: var(--radius-card);
  border: 1px solid var(--line);
  position: relative;
}

.split__card--pain {
  background: var(--paper-2);
}

.split__card--relief {
  background: var(--moss);
}

.split__card h3 {
  font-family: var(--font-sans);
  font-size: 22px;
  font-weight: 600;
  letter-spacing: -0.02em;
  margin-bottom: 24px;
  color: var(--ink);
}

.split__list {
  list-style: none;
  display: grid;
  gap: 14px;
}

.split__list li {
  position: relative;
  padding-left: 28px;
  font-size: 17px;
  line-height: 1.5;
  color: var(--ink-soft);
}

.split__list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 10px;
  width: 14px;
  height: 1px;
  background: var(--ink-soft);
}

.split__card--relief .split__list li::before {
  background: var(--moss-dark);
  height: 2px;
}

/* ---------- Steps (how it works) ---------- */

.steps {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
  margin-top: 56px;
}

.step-card {
  padding: 32px;
  border-radius: var(--radius-card);
  border: 1px solid var(--line);
  background: var(--paper);
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.step-card__num {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 56px;
  line-height: 1;
  letter-spacing: -0.04em;
  color: var(--accent);
}

.step-card__title {
  font-family: var(--font-sans);
  font-size: 22px;
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--ink);
}

.step-card__desc {
  font-size: 16px;
  line-height: 1.55;
  color: var(--ink-soft);
}

.step-card__visual {
  margin-top: auto;
  aspect-ratio: 4 / 3;
  border-radius: 12px;
  overflow: hidden;
  background: var(--paper-2);
  border: 1px solid var(--line);
}

.step-card__visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Step visual compositions (CSS-only UI mockups) */

.step-visual {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  padding: 18px;
  gap: 12px;
  font-family: var(--font-sans);
  color: var(--ink);
}

/* ---- Step 01: send ---- */

.step-visual--send {
  background: linear-gradient(180deg, var(--paper) 0%, var(--paper-2) 100%);
  justify-content: space-between;
}

.sv-thumb {
  position: relative;
  flex: 1;
  border-radius: 12px;
  overflow: hidden;
  min-height: 80px;
  background:
    radial-gradient(120% 100% at 20% 10%, rgba(255, 197, 165, 0.45), transparent 60%),
    radial-gradient(120% 100% at 90% 90%, rgba(60, 107, 74, 0.55), transparent 60%),
    linear-gradient(155deg, #3C2A20 0%, #6A3F2C 55%, #A0583C 100%);
}

.sv-thumb__label {
  position: absolute;
  top: 10px; left: 10px;
  padding: 3px 8px;
  border-radius: 999px;
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.12em;
  color: #fff;
  background: rgba(13, 31, 22, 0.55);
  backdrop-filter: blur(4px);
}

.sv-thumb__surface {
  position: absolute;
  inset: 35% 15% 25% 15%;
  border-radius: 60% 40% 55% 45% / 50% 60% 40% 50%;
  background: radial-gradient(60% 80% at 40% 30%, rgba(255, 220, 190, 0.7), transparent 70%),
              radial-gradient(60% 60% at 70% 70%, rgba(255, 140, 100, 0.5), transparent 70%);
  filter: blur(5px);
  opacity: 0.7;
}

.sv-send-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: 12px;
}

.sv-send-row__file {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex: 1;
  min-width: 0;
}

.sv-send-row__ic {
  display: inline-grid; place-items: center;
  width: 22px; height: 22px;
  border-radius: 6px;
  background: var(--paper-2);
  color: var(--ink-soft);
}

.sv-send-row__name {
  font-size: 12px;
  font-weight: 500;
  color: var(--ink);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}

.sv-send-row__size {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.04em;
  color: var(--muted);
}

.sv-send-row__send {
  display: inline-grid; place-items: center;
  width: 28px; height: 28px;
  border-radius: 50%;
  background: var(--accent);
  color: #fff;
  flex-shrink: 0;
}

/* ---- Step 02: match ---- */

.step-visual--match {
  background: var(--paper);
  gap: 10px;
}

.sv-match {
  list-style: none;
  margin: 0; padding: 0;
  display: grid;
  gap: 8px;
  flex: 1;
}

.sv-match li {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 28px minmax(0, 1fr);
  align-items: center;
  gap: 4px;
  font-size: 11.5px;
}

.sv-match__ing {
  padding: 7px 10px;
  background: var(--paper-2);
  border-radius: 8px;
  font-weight: 500;
  color: var(--ink);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}

.sv-match__line {
  height: 2px;
  background: var(--moss-dark);
  border-radius: 2px;
  position: relative;
}

.sv-match__line::after {
  content: "";
  position: absolute;
  right: -3px; top: 50%;
  transform: translateY(-50%);
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--moss-dark);
}

.sv-match__line--pending {
  background: repeating-linear-gradient(90deg, var(--line) 0 4px, transparent 4px 8px);
}
.sv-match__line--pending::after { background: var(--muted); }

.sv-match__prod {
  padding: 7px 10px;
  background: var(--moss);
  border-radius: 8px;
  font-weight: 500;
  color: var(--moss-dark);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}

.sv-match__prod--pending {
  background: transparent;
  border: 1px dashed var(--line);
  color: var(--muted);
  font-style: italic;
}

.sv-match__footer {
  display: flex;
  justify-content: space-between;
  padding-top: 8px;
  border-top: 1px solid var(--line);
  font-family: var(--font-mono);
  font-size: 10.5px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}

.sv-match__footer span:last-child { color: var(--moss-dark); }

/* ---- Step 03: cart ---- */

.step-visual--cart {
  background: linear-gradient(180deg, var(--paper) 0%, var(--paper-2) 100%);
  gap: 10px;
}

.sv-cart__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.sv-cart__badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 10px;
  border-radius: 999px;
  background: var(--moss);
  color: var(--moss-dark);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: -0.01em;
}

.sv-cart__time {
  font-family: var(--font-mono);
  font-size: 10.5px;
  font-weight: 500;
  letter-spacing: 0.08em;
  color: var(--accent);
}

.sv-cart__items {
  list-style: none; margin: 0; padding: 0;
  display: grid; gap: 6px;
  flex: 1;
}

.sv-cart__items li {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: baseline;
  gap: 8px;
  padding: 10px 12px;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: 10px;
  font-size: 12px;
  color: var(--ink-soft);
}

.sv-cart__n {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 20px;
  line-height: 1;
  color: var(--ink);
  letter-spacing: -0.03em;
}

.sv-cart__items .mono {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.02em;
  color: var(--ink);
}

.sv-cart__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 10px 14px;
  border-radius: 10px;
  background: var(--ink);
  color: var(--paper);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: -0.01em;
}

/* ---------- Magic section ---------- */

.magic {
  background: var(--paper);
  position: relative;
}

.magic__body {
  display: grid;
  grid-template-columns: minmax(0, 5fr) minmax(0, 7fr);
  gap: clamp(24px, 4vw, 56px);
  align-items: center;
  margin-top: 40px;
}

.magic__copy p {
  font-size: clamp(18px, 1.6vw, 22px);
  line-height: 1.55;
  color: var(--ink-soft);
  max-width: 46ch;
}

.magic__visual {
  aspect-ratio: 16 / 10;
  border-radius: var(--radius-hero);
  overflow: hidden;
  background: radial-gradient(55% 70% at 25% 25%, var(--mesh-2), transparent 60%),
              radial-gradient(55% 55% at 75% 30%, var(--mesh-3), transparent 65%),
              radial-gradient(60% 60% at 65% 85%, var(--mesh-4), transparent 60%),
              var(--mesh-1);
  box-shadow: var(--shadow-soft);
  position: relative;
  padding: clamp(18px, 2vw, 28px);
}

/* ---- Morph (recipe → chips) ---- */

.morph {
  position: relative;
  width: 100%;
  height: 100%;
  border-radius: 16px;
  background: rgba(251, 247, 238, 0.94);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.5);
  overflow: hidden;
  padding: clamp(20px, 2.6vw, 36px);
}

.morph__layer {
  position: absolute;
  inset: clamp(20px, 2.6vw, 36px);
  display: flex;
  flex-direction: column;
  gap: 16px;
  transition: opacity 0.55s ease, transform 0.7s cubic-bezier(0.2, 0.8, 0.2, 1);
}

.morph__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 11px;
  color: var(--muted);
}

.morph__eyebrow::before {
  content: "";
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--accent);
}

.morph__layer--text p {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(22px, 2.4vw, 32px);
  line-height: 1.28;
  color: var(--ink);
  letter-spacing: -0.01em;
  max-width: 30ch;
}

.morph__layer--text em {
  font-style: italic;
  background: linear-gradient(180deg, transparent 62%, rgba(255, 106, 61, 0.22) 62%);
  padding: 0 2px;
}

.morph__layer--chips {
  opacity: 0;
  transform: translateY(14px);
}

.morph__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 4px;
}

.morph-chip {
  display: inline-flex;
  align-items: baseline;
  gap: 4px;
  padding: 8px 12px;
  border-radius: 999px;
  background: var(--paper);
  border: 1px solid rgba(13, 31, 22, 0.1);
  font-size: 12.5px;
  font-weight: 500;
  color: var(--ink);
  opacity: 0;
  transform: translateY(8px) scale(0.96);
  transition: opacity 0.4s ease, transform 0.4s cubic-bezier(0.2, 0.8, 0.2, 1);
  transition-delay: calc(var(--d, 0) * 70ms);
}

.morph-chip em {
  font-style: normal;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.02em;
  color: var(--muted);
}

/* Triggered state — when section scrolls into view */
.magic__visual.is-visible .morph__layer--text {
  opacity: 0;
  transform: translateY(-8px);
  transition-delay: 0.25s;
}

.magic__visual.is-visible .morph__layer--chips {
  opacity: 1;
  transform: none;
  transition-delay: 0.6s;
}

.magic__visual.is-visible .morph-chip {
  opacity: 1;
  transform: none;
  transition-delay: calc(0.75s + var(--d, 0) * 70ms);
}

@media (prefers-reduced-motion: reduce) {
  .morph__layer--text { opacity: 0; }
  .morph__layer--chips { opacity: 1; transform: none; }
  .morph-chip { opacity: 1; transform: none; }
}

/* ---------- SEO editorial card ---------- */

.editorial {
  max-width: 760px;
  margin: 48px auto 0;
  padding: clamp(36px, 4vw, 56px);
  background: var(--paper-2);
  border: 1px solid var(--line);
  border-radius: var(--radius-card);
}

.editorial p {
  font-size: 18px;
  line-height: 1.7;
  color: var(--ink-soft);
}

.editorial p + p { margin-top: 20px; }

.editorial a {
  color: var(--accent);
  text-decoration: underline;
  text-underline-offset: 3px;
}

/* ---------- Pricing ---------- */

.pricing__chips {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  margin-top: 40px;
  margin-bottom: 24px;
}

.pricing__chip {
  display: inline-flex;
  align-items: baseline;
  gap: 12px;
  padding: 22px 28px;
  border-radius: var(--radius-card);
  background: var(--paper);
  border: 1px solid var(--line);
  min-width: 280px;
}

.pricing__chip--accent {
  background: var(--moss);
  border-color: transparent;
}

.pricing__chip .mono-label {
  color: var(--moss-dark);
}

.pricing__chip .pricing__amount {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 36px;
  line-height: 1;
  color: var(--ink);
  letter-spacing: -0.03em;
}

.pricing__note {
  margin-top: 8px;
  font-size: 15px;
  color: var(--muted);
}

.pricing__note a { color: var(--ink); text-decoration: underline; text-underline-offset: 3px; }

.pricing__cta-row {
  margin-top: 28px;
}

/* ---------- FAQ ---------- */

.faq-list {
  display: grid;
  gap: 12px;
  margin-top: 48px;
}

.faq-item {
  border: 1px solid var(--line);
  border-radius: var(--radius-card);
  background: var(--paper);
  overflow: hidden;
  transition: border-color 0.15s ease;
}

.faq-item[open] { border-color: rgba(13, 31, 22, 0.18); }

.faq-item summary {
  list-style: none;
  cursor: pointer;
  padding: 22px 28px;
  padding-right: 72px;
  position: relative;
  font-family: var(--font-sans);
  font-size: 19px;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--ink);
}

.faq-item summary::-webkit-details-marker { display: none; }

.faq-item summary::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 28px;
  width: 16px;
  height: 16px;
  transform: translateY(-50%);
  background-image:
    linear-gradient(var(--ink), var(--ink)),
    linear-gradient(var(--ink), var(--ink));
  background-size: 16px 1.5px, 1.5px 16px;
  background-position: center;
  background-repeat: no-repeat;
  transition: transform 0.2s ease, background-size 0.2s ease;
}

.faq-item[open] summary::after {
  background-size: 16px 1.5px, 0 16px;
}

.faq-answer {
  padding: 0 28px 24px;
  font-size: 16px;
  line-height: 1.6;
  color: var(--ink-soft);
  max-width: 68ch;
}

.faq-answer a {
  color: var(--accent);
  text-decoration: underline;
  text-underline-offset: 3px;
}

/* ---------- Materials grid ---------- */

.materials-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
  margin-top: 48px;
}

.material-card {
  display: grid;
  gap: 16px;
  padding: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius-card);
  background: var(--paper);
  overflow: hidden;
  color: var(--ink);
  transition: border-color 0.2s ease, transform 0.2s ease;
}

.material-card:hover {
  border-color: rgba(13, 31, 22, 0.18);
  transform: translateY(-2px);
}

.material-card__thumb {
  aspect-ratio: 4 / 3;
  background: var(--paper-2);
  overflow: hidden;
  border-bottom: 1px solid var(--line);
}

.material-card__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* ---- Article thumbs (CSS-only) ---- */

.athumb {
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
  isolation: isolate;
  display: grid;
  grid-template-rows: auto 1fr auto;
  padding: 16px 18px;
  color: var(--athumb-fg, var(--ink));
  background: var(--athumb-bg, var(--paper-2));
}

.athumb::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(60% 80% at var(--athumb-g1-x, 15%) var(--athumb-g1-y, 20%), var(--athumb-g1, var(--moss)), transparent 65%),
    radial-gradient(60% 70% at var(--athumb-g2-x, 85%) var(--athumb-g2-y, 80%), var(--athumb-g2, var(--accent-soft)), transparent 60%);
  z-index: 0;
  opacity: 0.85;
}

.athumb > * { position: relative; z-index: 1; }

.athumb__label {
  align-self: start;
  font-family: var(--font-mono);
  font-size: 10.5px;
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--athumb-meta, var(--ink-soft));
  opacity: 0.8;
}

.athumb__glyph {
  place-self: center;
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(56px, 7vw, 96px);
  line-height: 1;
  letter-spacing: -0.04em;
  color: var(--athumb-glyph, var(--ink));
  text-shadow: 0 1px 0 rgba(255, 255, 255, 0.2);
}

.athumb__tag {
  justify-self: start;
  align-self: end;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.55);
  border: 1px solid rgba(13, 31, 22, 0.08);
  font-family: var(--font-mono);
  font-size: 10.5px;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--athumb-tag-fg, var(--ink-soft));
  backdrop-filter: blur(6px);
}

/* glyph variants */

.athumb__glyph--list {
  display: inline-grid;
  gap: 8px;
  grid-template-columns: 64px;
  grid-auto-rows: 8px;
  place-self: center;
  align-content: center;
}
.athumb__glyph--list i {
  display: block;
  height: 6px;
  border-radius: 3px;
  background: var(--athumb-glyph, var(--ink));
  opacity: 0.9;
}
.athumb__glyph--list i:nth-child(1) { width: 100%; }
.athumb__glyph--list i:nth-child(2) { width: 78%; }
.athumb__glyph--list i:nth-child(3) { width: 92%; }
.athumb__glyph--list i:nth-child(4) { width: 60%; opacity: 0.45; }

.athumb__glyph--vs em {
  font-style: italic;
  background: linear-gradient(180deg, transparent 62%, var(--accent) 62%);
  padding: 0 6px;
}

/* ---- Per-thumb palettes ---- */

/* 01 speed — persimmon + cream */
.athumb--01 {
  --athumb-bg: #FFE2D2;
  --athumb-g1: #FFB894; --athumb-g1-x: 10%; --athumb-g1-y: 15%;
  --athumb-g2: #FFD6BC; --athumb-g2-x: 90%; --athumb-g2-y: 85%;
  --athumb-glyph: #8A2E0F;
}

/* 02 order online — moss + paper */
.athumb--02 {
  --athumb-bg: #D9E5D7;
  --athumb-g1: #B6CDB4; --athumb-g1-x: 80%; --athumb-g1-y: 20%;
  --athumb-g2: #E9EEDC; --athumb-g2-x: 15%; --athumb-g2-y: 90%;
  --athumb-glyph: #2A4A30;
}

/* 03 auto — deep forest + moss */
.athumb--03 {
  --athumb-bg: #2A4036;
  --athumb-g1: #3C6B4A; --athumb-g1-x: 20%; --athumb-g1-y: 20%;
  --athumb-g2: #FF6A3D; --athumb-g2-x: 90%; --athumb-g2-y: 95%;
  --athumb-glyph: #F4EFE6;
  --athumb-meta: rgba(244, 239, 230, 0.7);
  --athumb-tag-fg: #F4EFE6;
}
.athumb--03 .athumb__tag { background: rgba(13, 31, 22, 0.35); border-color: rgba(244, 239, 230, 0.15); }

/* 04 list — paper-2 + accent-soft */
.athumb--04 {
  --athumb-bg: #EEE7D9;
  --athumb-g1: #F6D8C3; --athumb-g1-x: 95%; --athumb-g1-y: 10%;
  --athumb-g2: #E8E1D1; --athumb-g2-x: 10%; --athumb-g2-y: 100%;
  --athumb-glyph: #0D1F16;
}

/* 05 no extras — warm cream / stripped */
.athumb--05 {
  --athumb-bg: #F4EFE6;
  --athumb-g1: #EDE2D0; --athumb-g1-x: 30%; --athumb-g1-y: 30%;
  --athumb-g2: #E6DDC7; --athumb-g2-x: 80%; --athumb-g2-y: 80%;
  --athumb-glyph: #FF6A3D;
}
.athumb--05 .athumb__glyph { font-size: clamp(80px, 9vw, 140px); letter-spacing: -0.1em; }

/* 06 clock — moss-dark + accent */
.athumb--06 {
  --athumb-bg: #3C6B4A;
  --athumb-g1: #5C8C6A; --athumb-g1-x: 80%; --athumb-g1-y: 25%;
  --athumb-g2: #FFC5A5; --athumb-g2-x: 15%; --athumb-g2-y: 90%;
  --athumb-glyph: #F4EFE6;
  --athumb-meta: rgba(244, 239, 230, 0.7);
  --athumb-tag-fg: #F4EFE6;
}
.athumb--06 .athumb__tag { background: rgba(13, 31, 22, 0.3); border-color: rgba(244, 239, 230, 0.15); }
.athumb--06 .athumb__glyph { font-style: normal; }

/* 07 telegram bot — cream + ink */
.athumb--07 {
  --athumb-bg: #F1ECDF;
  --athumb-g1: #E1D9C1; --athumb-g1-x: 85%; --athumb-g1-y: 15%;
  --athumb-g2: #FFE1D0; --athumb-g2-x: 20%; --athumb-g2-y: 85%;
  --athumb-glyph: #0D1F16;
}
.athumb--07 .athumb__glyph {
  font-family: var(--font-mono);
  font-style: normal;
  font-weight: 500;
  font-size: clamp(48px, 6vw, 72px);
  letter-spacing: 0;
}

/* 08 FC — persimmon + ink */
.athumb--08 {
  --athumb-bg: #0D1F16;
  --athumb-g1: #3C6B4A; --athumb-g1-x: 80%; --athumb-g1-y: 80%;
  --athumb-g2: #FF6A3D; --athumb-g2-x: 20%; --athumb-g2-y: 20%;
  --athumb-glyph: #F4EFE6;
  --athumb-meta: rgba(244, 239, 230, 0.7);
  --athumb-tag-fg: #F4EFE6;
}
.athumb--08 .athumb__tag { background: rgba(244, 239, 230, 0.12); border-color: rgba(244, 239, 230, 0.25); }
.athumb--08 .athumb__glyph {
  font-family: var(--font-sans);
  font-style: normal;
  font-weight: 700;
  font-size: clamp(64px, 8vw, 104px);
  letter-spacing: -0.06em;
}

/* 09 vs — cream + split */
.athumb--09 {
  --athumb-bg: #EDE7DA;
  --athumb-g1: #D8D0BB; --athumb-g1-x: 10%; --athumb-g1-y: 30%;
  --athumb-g2: #B6CDB4; --athumb-g2-x: 90%; --athumb-g2-y: 70%;
  --athumb-glyph: #0D1F16;
}

/* 10 screenshot → — paper + arrow */
.athumb--10 {
  --athumb-bg: #FBF7EE;
  --athumb-g1: #FFC5A5; --athumb-g1-x: 5%; --athumb-g1-y: 90%;
  --athumb-g2: #B6CDB4; --athumb-g2-x: 95%; --athumb-g2-y: 10%;
  --athumb-glyph: #FF6A3D;
}
.athumb--10 .athumb__glyph { font-family: var(--font-sans); font-style: normal; font-size: clamp(72px, 9vw, 120px); }

/* 11 delivery — moss + cream */
.athumb--11 {
  --athumb-bg: #D9E5D7;
  --athumb-g1: #B6CDB4; --athumb-g1-x: 20%; --athumb-g1-y: 85%;
  --athumb-g2: #FFD6BC; --athumb-g2-x: 85%; --athumb-g2-y: 15%;
  --athumb-glyph: #3C6B4A;
}
.athumb--11 .athumb__glyph { font-style: normal; }
.athumb--11 .athumb__glyph::after {
  content: " мин";
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 0.3em;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  vertical-align: middle;
  margin-left: 6px;
  color: var(--athumb-glyph);
  opacity: 0.6;
}

.material-card__body {
  padding: 0 24px 28px;
  display: grid;
  gap: 10px;
}

.material-card__title {
  font-family: var(--font-sans);
  font-size: 20px;
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: var(--ink);
}

.material-card__desc {
  font-size: 15px;
  line-height: 1.5;
  color: var(--muted);
}

.material-card__arrow {
  margin-top: 4px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--accent);
}

/* ---------- Materials hub (materials.html) ---------- */

.materials-hero {
  padding: clamp(48px, 7vw, 96px) 0 clamp(32px, 4vw, 56px);
  background: var(--paper);
}

.materials-hero h1 {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(44px, 6vw, 84px);
  line-height: 1;
  letter-spacing: -0.03em;
  color: var(--ink);
  margin-top: 24px;
  margin-bottom: 20px;
}

.materials-hero p { max-width: 56ch; }

.materials-cluster {
  margin-top: 48px;
}

.materials-cluster + .materials-cluster { margin-top: 72px; }

.materials-cluster__title {
  font-family: var(--font-sans);
  font-size: 20px;
  font-weight: 600;
  color: var(--ink);
  letter-spacing: -0.01em;
  margin-bottom: 24px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--line);
}

/* ---------- Final CTA (mesh) ---------- */

.final-cta {
  padding: clamp(72px, 10vw, 140px) 0;
  background: var(--paper);
}

.mesh-card {
  position: relative;
  border-radius: var(--radius-hero);
  padding: clamp(56px, 8vw, 120px) clamp(32px, 4vw, 56px);
  background: radial-gradient(60% 70% at 20% 25%, var(--mesh-2), transparent 60%),
              radial-gradient(55% 55% at 80% 20%, var(--mesh-3), transparent 65%),
              radial-gradient(60% 60% at 70% 85%, var(--mesh-4), transparent 60%),
              var(--mesh-1);
  text-align: center;
  overflow: hidden;
  isolation: isolate;
}

.mesh-card h2 {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(48px, 7vw, 96px);
  line-height: 1;
  letter-spacing: -0.03em;
  color: var(--paper);
  max-width: 14ch;
  margin: 0 auto 40px;
}

.mesh-card .btn--on-mesh {
  margin-bottom: 16px;
}

.mesh-card__micro {
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(244, 239, 230, 0.75);
}

/* ---------- Footer ---------- */

.site-footer {
  background: var(--ink);
  color: var(--paper);
  padding: clamp(56px, 7vw, 96px) 0 32px;
}

.site-footer__grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1.2fr;
  gap: 32px;
}

.site-footer h4 {
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(244, 239, 230, 0.5);
  margin-bottom: 16px;
}

.site-footer p { color: rgba(244, 239, 230, 0.75); font-size: 15px; line-height: 1.55; }
.site-footer p + p { margin-top: 10px; }

.site-footer a {
  color: var(--paper);
  text-decoration: none;
  font-size: 15px;
  line-height: 1.7;
  transition: color 0.15s ease;
}

.site-footer a:hover { color: var(--accent); }

.site-footer__links {
  display: grid;
  gap: 4px;
}

.site-footer__logo {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 28px;
  color: var(--paper);
  margin-bottom: 12px;
}

.site-footer__legal {
  margin-top: 48px;
  padding-top: 24px;
  border-top: 1px solid rgba(244, 239, 230, 0.08);
  font-size: 13px;
  color: rgba(244, 239, 230, 0.5);
  line-height: 1.6;
}

/* ---------- Reveal animations ---------- */

.reveal {
  opacity: 1;
  transform: none;
}

@media (prefers-reduced-motion: no-preference) {
  .reveal {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity 0.6s ease-out, transform 0.6s ease-out;
  }

  .reveal.is-visible {
    opacity: 1;
    transform: none;
  }

  /* Hero load sequence */
  .hero__title .word {
    opacity: 0;
    transform: translateY(14px);
    transition: opacity 0.55s ease-out, transform 0.55s ease-out;
  }

  .hero__title.is-ready .word {
    opacity: 1;
    transform: none;
  }

  .hero__subhead,
  .hero__cta-row,
  .hero__microcopy,
  .hero__floating-card {
    opacity: 0;
    transform: translateY(10px);
    transition: opacity 0.5s ease-out, transform 0.5s ease-out;
  }

  body.is-ready .hero__subhead {
    opacity: 1; transform: none; transition-delay: 0.45s;
  }
  body.is-ready .hero__cta-row {
    opacity: 1; transform: none; transition-delay: 0.7s;
  }
  body.is-ready .hero__microcopy {
    opacity: 1; transform: none; transition-delay: 0.85s;
  }
  body.is-ready .hero__floating-card {
    opacity: 1; transform: none; transition-delay: 1s;
  }

  .hero__visual {
    opacity: 0;
    transform: translateX(24px);
    transition: opacity 0.7s ease-out 0.25s, transform 0.7s ease-out 0.25s;
  }

  body.is-ready .hero__visual {
    opacity: 1;
    transform: none;
  }
}

/* ---------- Responsive ---------- */

@media (max-width: 1024px) {
  .hero__grid {
    grid-template-columns: 1fr;
    gap: 48px;
  }

  .hero__visual { margin-right: 0; max-width: 520px; }

  .steps {
    grid-template-columns: 1fr;
  }

  .materials-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .site-footer__grid {
    grid-template-columns: 1fr 1fr;
  }

  .magic__body {
    grid-template-columns: 1fr;
  }

  .section-number {
    font-size: clamp(96px, 22vw, 160px);
  }
}

@media (max-width: 760px) {
  .container { width: calc(100% - 32px); }

  .sticky-nav__inner {
    gap: 12px;
  }

  .nav-links a[href="#faq"],
  .nav-links a[href="materials.html"]:not(.nav-cta) {
    display: none;
  }

  .hero { padding-top: 40px; }

  .split { grid-template-columns: 1fr; }

  .materials-grid { grid-template-columns: 1fr; }

  .site-footer__grid { grid-template-columns: 1fr; gap: 32px; }

  .pricing__chip { width: 100%; min-width: 0; }

  .faq-item summary { font-size: 17px; padding: 20px 24px; padding-right: 60px; }
  .faq-item summary::after { right: 22px; }

  .proof__row { gap: 10px; font-size: 12px; }
}

/* ---------- Prefers-reduced-motion global gate ---------- */

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
  }
}
