:root {
  --grad: var(--gradient-spirit);
  --max: 1240px;
  --pad: clamp(20px, 4vw, 56px);
}

/* SECTION SHELL */
section { padding: clamp(72px, 9vw, 140px) var(--pad); position: relative; }
section .inner { max-width: var(--max); margin: 0 auto; position: relative; }
.eyebrow { font-family: var(--font-serif); font-style: italic; font-size: 17px; letter-spacing: 0.04em; color: var(--ink-500); display: inline-flex; align-items: center; gap: 12px; margin-bottom: 22px; }
.eyebrow::before { content: ""; width: 30px; height: 1px; background: currentColor; }
p + p { margin-top: 1em; }

.grad-word {
  background: var(--grad);
  -webkit-background-clip: text; background-clip: text;
  color: transparent; -webkit-text-fill-color: transparent;
  font-style: italic;
}

/* ============ PHOTO + GRADIENT RECTANGLE ============ */
.photo-card { position: relative; isolation: isolate; }
.photo-card .photo {
  position: relative; z-index: 2;
  width: 100%; height: 100%;
  object-fit: cover;
  border-radius: 6px;
  display: block;
}
.photo-card::before {
  content: "";
  position: absolute; inset: 0;
  background: var(--grad);
  border-radius: 6px;
  transform: rotate(4deg) translate(14px, 14px);
  z-index: 1;
}
.photo-card.tilt-l::before { transform: rotate(-4deg) translate(-14px, 14px); }
.photo-card.tilt-soft::before { transform: rotate(3deg) translate(10px, 10px); }
.photo-card.tilt-tr::before { transform: rotate(3deg) translate(14px, -12px); }

/* ============ DOVE ============ */
.dove {
  position: absolute;
  pointer-events: none;
  background: transparent;
  background-color: transparent;
  mix-blend-mode: multiply;
  display: block;
  z-index: 6;
}
.dove img {
  background: transparent;
  background-color: transparent;
  mix-blend-mode: multiply;
  display: block;
  width: 100%;
  height: auto;
}
.whygo .dove, .whygo .dove img,
.testi .dove, .testi .dove img,
footer .dove, footer .dove img { mix-blend-mode: normal; }

/* ============ HERO ============ */
.hero { padding-top: clamp(28px, 3vw, 48px); padding-bottom: clamp(56px, 7vw, 100px); overflow: visible; }
.hero-grid { display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr); gap: clamp(40px, 5vw, 80px); align-items: center; }
.hero h1 { font-family: var(--font-serif); font-weight: 600; font-size: clamp(50px, 6.2vw, 96px); line-height: 1.0; letter-spacing: -0.018em; margin: 0 0 24px; text-wrap: balance; }
.hero .sub { max-width: 50ch; font-size: clamp(18px, 1.4vw, 22px); line-height: 1.5; color: var(--ink-700); margin-bottom: 32px; }
.hero-ctas { display: flex; gap: 14px; flex-wrap: wrap; }
.hero-ctas .btn { white-space: nowrap; }

.hero-carousel { position: relative; width: 100%; aspect-ratio: 1/1; isolation: isolate; }
.hero-carousel .slides { position: relative; z-index: 2; width: 100%; height: 100%; }
.hero-carousel .slide { position: absolute; inset: 0; opacity: 0; transition: opacity 1.2s ease; }
.hero-carousel .slide.is-active { opacity: 1; }
.hero-carousel .slide img { width: 100%; height: 100%; object-fit: cover; border-radius: 6px; display: block; }
.hero-carousel::before {
  content: "";
  position: absolute; inset: 0;
  background: var(--grad);
  border-radius: 6px;
  transform: rotate(3deg) translate(14px, 14px);
  z-index: 1;
}
.hero-carousel .hero-peek {
  position: absolute;
  left: -22%;
  top: -22%;
  width: 46%;
  z-index: 6;
  transform: scaleX(-1) rotate(-4deg);
  pointer-events: none;
  filter: drop-shadow(0 22px 26px rgba(20,17,12,0.18));
}
.hero-carousel .hero-peek img {
  width: 100%;
  height: auto;
  background: transparent;
  background-color: transparent;
  mix-blend-mode: normal;
  display: block;
}

/* ============ WHY GO ============ */
.whygo { background: var(--ink-900); color: var(--cream-100); overflow: hidden; }
.whygo::after { content: ""; position: absolute; inset: -20% -10% auto auto; width: 60%; height: 100%; background: radial-gradient(closest-side, rgba(255,122,46,0.20), transparent 70%); pointer-events: none; }
.whygo .eyebrow { color: rgba(244,239,224,0.55); }
.whygo h2 { font-family: var(--font-serif); font-weight: 600; font-size: clamp(44px, 5.6vw, 84px); line-height: 1.0; letter-spacing: -0.012em; margin: 0 0 28px; text-wrap: balance; color: var(--cream-100); }
.whygo .body p { color: rgba(244,239,224,0.82); font-size: clamp(18px, 1.4vw, 21px); line-height: 1.6; max-width: 52ch; }
.whygo-grid { position: relative; z-index: 2; display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1.15fr); gap: clamp(48px, 6vw, 96px); align-items: center; }
.whygo .photo-card { aspect-ratio: 4/5; }
.whygo .cta-row { margin-top: 36px; }

.photo-card .photo-corner-dove {
  position: absolute;
  z-index: 5;
  pointer-events: none;
}
.photo-card .photo-corner-dove img {
  width: 100%;
  height: auto;
  background: transparent;
  background-color: transparent;
  mix-blend-mode: normal;
  display: block;
  filter: drop-shadow(0 18px 22px rgba(20,17,12,0.22));
}
.whygo .photo-card .photo-corner-dove {
  right: -14%;
  bottom: -12%;
  width: 50%;
  transform: rotate(6deg);
}

/* ============ NUMBERS ============ */
.numbers { text-align: center; overflow: visible; }
.numbers .head-row { display: inline-flex; align-items: flex-start; justify-content: center; gap: clamp(8px, 1vw, 18px); margin-bottom: 60px; flex-wrap: nowrap; position: relative; }
.numbers h2 { font-family: var(--font-serif); font-weight: 600; font-size: clamp(56px, 7vw, 104px); line-height: 1.0; letter-spacing: -0.014em; margin: 0; max-width: 24ch; text-wrap: balance; position: relative; }
.numbers h2 em { font-style: italic; }
.numbers h2 .feather-anchor { position: relative; display: inline; }
.numbers h2 .feather-anchor .head-dove { position: absolute; left: 70%; top: -1.0em; width: clamp(140px, 16vw, 240px); transform: rotate(-12deg); z-index: 3; pointer-events: none; }
.numbers h2 .feather-anchor .head-dove img { width: 100%; height: auto; background: transparent; background-color: transparent; display: block; mix-blend-mode: normal; filter: drop-shadow(0 14px 18px rgba(20,17,12,0.18)); }
.numbers .row { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(40px, 6vw, 96px); align-items: end; }
.numbers .num { font-family: var(--font-serif); font-weight: 600; font-size: clamp(72px, 11vw, 160px); line-height: 0.9; letter-spacing: -0.02em; background: var(--grad); -webkit-background-clip: text; background-clip: text; color: transparent; -webkit-text-fill-color: transparent; }
.numbers .label { font-family: var(--font-serif); font-style: italic; font-size: clamp(17px, 1.3vw, 20px); color: var(--ink-500); margin-top: 14px; max-width: 22ch; margin-inline: auto; }
.numbers .footnote { margin-top: 64px; font-family: var(--font-serif); font-style: italic; font-size: clamp(17px, 1.25vw, 20px); color: var(--ink-500); max-width: 56ch; margin-inline: auto; }

/* ============ HOW IT WORKS ============ */
.how { background: var(--cream-50); overflow: clip; }
.how .inner { padding: 0 clamp(8px, 1.5vw, 24px); }
.how .head { display: grid; grid-template-columns: 1.1fr 1fr; gap: clamp(36px, 5vw, 88px); align-items: end; margin-bottom: 80px; }
.how h2 { font-family: var(--font-serif); font-weight: 600; font-size: clamp(44px, 5.6vw, 84px); line-height: 1.0; letter-spacing: -0.01em; margin: 0; text-wrap: balance; }
.how .lede { font-family: var(--font-serif); font-size: clamp(19px, 1.5vw, 22px); line-height: 1.55; color: var(--ink-700); max-width: 56ch; }
.how-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(72px, 8vw, 110px) clamp(56px, 6vw, 88px);
}
.how-card { display: flex; flex-direction: column; gap: 10px; }
.how-card .photo-card { aspect-ratio: 1/1; margin-bottom: 26px; }
.how-card .step-no { font-family: var(--font-serif); font-style: italic; color: var(--sun-pink); font-size: 20px; letter-spacing: 0.06em; min-height: 2.4em; display: flex; align-items: flex-start; margin: 0; }
.how-card h3 { font-family: var(--font-serif); font-weight: 600; font-size: clamp(28px, 2.6vw, 38px); margin: 0; line-height: 1.05; letter-spacing: -0.005em; }
.how-card p { font-family: var(--font-serif); font-size: 18px; line-height: 1.55; color: var(--ink-700); margin: 0; max-width: 50ch; }

/* ============ TESTIMONIALS ============ */
.testi { background: var(--ink-900); color: var(--cream-100); overflow: hidden; }
.testi .eyebrow { color: rgba(244,239,224,0.55); }
.testi h2 { font-family: var(--font-serif); font-weight: 600; font-size: clamp(40px, 4.6vw, 68px); line-height: 1.05; letter-spacing: -0.01em; margin: 0 0 60px; max-width: 22ch; text-wrap: balance; }
.testi .feature { background: var(--grad); color: #fff; border-radius: 18px; padding: clamp(48px, 6vw, 88px); position: relative; overflow: hidden; }
.testi .feature blockquote { margin: 0; font-family: var(--font-serif); font-weight: 600; font-style: italic; font-size: clamp(28px, 3.2vw, 46px); line-height: 1.18; letter-spacing: -0.005em; max-width: 24ch; position: relative; z-index: 2; }
.testi .feature .attr { margin-top: 32px; font-family: var(--font-serif); font-style: italic; font-size: 18px; color: rgba(255,255,255,0.92); position: relative; z-index: 2; }
.testi .feature .feature-dove { position: absolute; top: 8%; right: 4%; width: clamp(120px, 14vw, 200px); opacity: 0.32; z-index: 1; }
.testi-row { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(20px, 2.5vw, 32px); margin-top: 28px; }
.testi-card { background: rgba(244,239,224,0.04); border: 1px solid rgba(244,239,224,0.12); border-radius: 14px; padding: clamp(28px, 3vw, 44px); }
.testi-card blockquote { margin: 0; font-family: var(--font-serif); font-weight: 600; font-style: italic; font-size: clamp(22px, 2vw, 28px); line-height: 1.25; color: var(--cream-100); }
.testi-card .attr { margin-top: 22px; font-family: var(--font-serif); font-style: italic; font-size: 16px; color: rgba(244,239,224,0.55); }
.testi .source-note { margin-top: 24px; font-family: var(--font-serif); font-style: italic; font-size: 14px; color: rgba(244,239,224,0.35); }

/* ============ FLIRTATION NATION ============ */
.nation { overflow: visible; }
.nation .grid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1.05fr); gap: clamp(80px, 8vw, 140px); align-items: center; }
.nation .left { position: relative; }
.nation h2 { font-family: var(--font-serif); font-weight: 600; font-size: clamp(44px, 5.4vw, 78px); line-height: 1.02; letter-spacing: -0.012em; margin: 0 0 28px; text-wrap: balance; }
.nation p { font-family: var(--font-serif); font-size: clamp(18px, 1.4vw, 21px); line-height: 1.55; color: var(--ink-700); max-width: 52ch; }
.nation .cta-row { margin-top: 36px; }

.stack { position: relative; aspect-ratio: 1/1.35; }
.stack .sq { position: absolute; aspect-ratio: 1/1; overflow: visible; width: 64%; }
.stack .sq.back { top: 0; right: 0; }
.stack .sq.front { bottom: 0; left: 0; }

.nation .dove-stack {
  width: clamp(140px, 14vw, 200px);
  left: -6%;
  bottom: 8%;
  transform: rotate(-8deg);
  z-index: 8;
  filter: drop-shadow(0 22px 26px rgba(20,17,12,0.18));
}

/* ============ CLOSER ============ */
.closer { text-align: center; padding-top: clamp(120px, 14vw, 200px); padding-bottom: clamp(120px, 14vw, 200px); overflow: hidden; }
.closer .wordmark { font-size: clamp(34px, 3.6vw, 52px); margin-bottom: 28px; display: inline-block; }
.closer h2 { font-family: var(--font-serif); font-weight: 600; font-size: clamp(48px, 6.4vw, 100px); line-height: 1.0; letter-spacing: -0.014em; margin: 0 0 44px; text-wrap: balance; max-width: 18ch; margin-inline: auto; }
.closer .cta-glow {
  box-shadow: 0 18px 50px -10px rgba(255, 79, 139, 0.55), 0 0 0 1px rgba(255,255,255,0.0);
  transform: scale(1);
  padding: 18px 32px;
  font-size: 19px;
}
.closer .cta-glow:hover { box-shadow: 0 26px 60px -10px rgba(255, 79, 139, 0.7); transform: translateY(-1px); }
.closer .dove-l { left: -3%; top: 22%; width: clamp(300px, 30vw, 460px); opacity: 1; transform: rotate(-10deg); }
.closer .dove-r { right: -2%; bottom: 8%; width: clamp(221px, 25vw, 376px); opacity: 1; transform: scaleX(-1) rotate(-4deg); }

/* ============ FORM 1 — WAITLIST ============ */
.waitlist { padding-top: clamp(40px, 5vw, 80px); padding-bottom: clamp(120px, 14vw, 180px); overflow: visible; }
.waitlist .wrap { position: relative; max-width: 760px; margin: 0 auto; }
.waitlist .card {
  position: relative;
  background: var(--cream-50);
  border: 1px solid color-mix(in srgb, var(--ink-900) 14%, transparent);
  border-radius: 18px;
  padding: clamp(28px, 3.5vw, 48px) clamp(40px, 5vw, 72px) clamp(40px, 5vw, 72px);
  box-shadow: 0 28px 60px -36px rgba(20,17,12,0.25);
}
.waitlist .dove-laptop img { width: 100%; height: auto; background: transparent; background-color: transparent; display: block; mix-blend-mode: normal; }
.waitlist .head-row { display: flex; align-items: center; gap: clamp(8px, 1vw, 18px); margin: 0 0 8px; }
.waitlist h2 { font-family: var(--font-serif); font-weight: 600; font-size: clamp(26px, 2.6vw, 40px); line-height: 1.04; letter-spacing: -0.01em; margin: 0; text-wrap: balance; white-space: nowrap; }
.waitlist .head-row .dove-laptop {
  position: static;
  display: block;
  transform: scaleX(-1) translate(-4px, -90px);
  width: clamp(161px, 20vw, 281px);
  height: auto;
  flex-shrink: 0;
  pointer-events: none;
  margin: -30% 0;
  background: transparent;
  filter: none;
}
.waitlist .head-row .dove-laptop img { background: transparent; background-color: transparent; filter: none; box-shadow: none; }
.waitlist .sub { font-family: var(--font-serif); font-size: clamp(17px, 1.3vw, 19px); line-height: 1.55; color: var(--ink-700); margin: 0 0 28px; }

.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.field { display: flex; flex-direction: column; gap: 6px; margin-bottom: 18px; }
.field > label { font-family: var(--font-serif); font-style: italic; font-size: 14px; color: var(--ink-500); letter-spacing: 0.02em; }
.field input, .field textarea, .field select {
  background: var(--cream-100);
  border: 1px solid color-mix(in srgb, var(--ink-900) 14%, transparent);
  border-radius: 8px;
  padding: 12px 14px;
  font-family: var(--font-serif);
  font-size: 17px;
  color: var(--ink-900);
  outline: none;
  transition: border-color .15s ease, box-shadow .15s ease;
}
.field input:focus, .field textarea:focus, .field select:focus {
  border-color: var(--sun-pink);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--sun-pink) 18%, transparent);
}
.field textarea { resize: vertical; min-height: 96px; }

.radio-row { display: flex; gap: 10px; flex-wrap: wrap; }
.radio-row label {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 11px 18px;
  border: 1px solid color-mix(in srgb, var(--ink-900) 14%, transparent);
  background: var(--cream-100);
  border-radius: 999px;
  font-family: var(--font-serif);
  font-size: 16px;
  color: var(--ink-700);
  cursor: pointer;
  transition: border-color .15s ease, background .15s ease, color .15s ease;
}
.radio-row input[type="radio"] { accent-color: var(--sun-pink); margin: 0; }
.radio-row label:has(input:checked) {
  border-color: var(--sun-pink);
  background: color-mix(in srgb, var(--sun-pink) 8%, var(--cream-100));
  color: var(--ink-900);
}

.submit-row { margin-top: 8px; display: flex; align-items: center; gap: 18px; flex-wrap: wrap; }
.fineprint { font-family: var(--font-serif); font-style: italic; font-size: 14px; color: var(--ink-500); }

@media (max-width: 920px) {
  .hero-grid, .whygo-grid, .how .head, .how-cards, .nation .grid, .testi-row, .field-row, .numbers .row {
    grid-template-columns: 1fr !important;
  }
  .numbers .row { gap: 56px; }
  /* Mobile: in Why-Go, show body+CTA first, photo below */
  .whygo-grid > .photo-card { order: 2; margin-top: 36px; }
  .whygo-grid > .body { order: 1; }
  /* Mobile: Flirtation Nation — keep original stacked composition, just sized for mobile */
  .stack { aspect-ratio: 1/1.42; max-width: 540px; margin-inline: auto; }

  /* Closer dove: position near CTA instead of overlapping the heading */
  .closer .dove-l { width: clamp(180px, 22vw, 260px) !important; left: -8% !important; top: auto !important; bottom: 6% !important; }
  .nation .dove-stack { left: 2%; bottom: -4%; width: 140px; }
  .waitlist .dove-laptop { position: static; transform: scaleX(-1); width: 160px; margin: -20px auto 24px; display: block; }
  .hero-carousel { aspect-ratio: 1/1; }
  .hero-carousel .hero-peek { left: -18%; top: -18%; width: 40%; right: auto; }
  .numbers .head-row { flex-wrap: wrap; }
  .numbers .head-dove { width: 140px; }
  .waitlist h2 { white-space: normal; }
}

/* ============ MOBILE ≤ 480px ============ */
@media (max-width: 480px) {
  /* Bigger nav tap targets (≥44px) */
  .nav-links a { padding: 12px 4px; font-size: 16px; }
  .nav-inner { gap: 12px; padding-top: 10px; padding-bottom: 10px; }
  .nav-brand .wordmark { font-size: 24px; }
  .nav-brand .tag { font-size: 11px; }

  /* Contain decorative dove bleeds that push the page wider */
  .numbers .head-dove { width: 110px !important; left: 55% !important; top: -0.6em !important; }
  .photo-corner-dove { width: 130px !important; right: -8px !important; }
  .waitlist .dove-laptop { width: 130px !important; }

  /* Closer dove: keep it visible but don't let it eat the screen */
  .closer .dove-l { width: 200px !important; left: -10% !important; top: auto !important; bottom: 4% !important; }

  /* Slightly tighter hero on small screens */
  .hero h1 { font-size: clamp(40px, 12vw, 56px); }

  /* Make the closer CTA itself a comfortable tap target */
  .closer .cta-glow, .btn { min-height: 48px; }

  /* Footer links comfortable */
  footer a { padding: 8px 0; display: inline-block; }
}
