:root {
  --grad: var(--gradient-spirit);
  --max: 800px;
  --pad: clamp(20px, 4vw, 56px);
}
body { min-height: 100vh; }

/* ============ PAGE BODY ============ */
main { padding: clamp(40px, 6vw, 80px) var(--pad) clamp(80px, 10vw, 140px); }
.wrap { max-width: var(--max); margin: 0 auto; text-align: center; position: relative; }

/* Hero photo composition */
.hero-art {
  position: relative;
  width: 100%;
  max-width: 720px;
  aspect-ratio: 5/3;
  margin: 0 auto clamp(40px, 5vw, 64px);
  isolation: isolate;
}
.hero-art .photo {
  position: relative;
  z-index: 2;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 6px;
  display: block;
}
.hero-art::before {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--grad);
  border-radius: 6px;
  transform: rotate(-3deg) translate(-14px, 14px);
  z-index: 1;
}
.hero-art .accent-dove {
  position: absolute;
  right: -10%;
  top: -22%;
  width: clamp(160px, 22vw, 280px);
  z-index: 4;
  transform: rotate(-12deg);
  pointer-events: none;
  filter: drop-shadow(0 22px 26px rgba(20,17,12,0.22));
}
.hero-art .accent-dove img {
  width: 100%;
  height: auto;
  background: transparent;
  background-color: transparent;
  mix-blend-mode: normal;
  display: block;
}

h1 {
  font-family: var(--font-serif);
  font-weight: 600;
  font-size: clamp(40px, 5vw, 68px);
  line-height: 1.02;
  letter-spacing: -0.012em;
  margin: 0 0 20px;
  text-wrap: balance;
}
.grad-word {
  background: var(--grad);
  -webkit-background-clip: text; background-clip: text;
  color: transparent; -webkit-text-fill-color: transparent;
  font-style: italic;
}
.sub {
  font-family: var(--font-serif);
  font-size: clamp(18px, 1.4vw, 22px);
  line-height: 1.5;
  color: var(--ink-700);
  max-width: 52ch;
  margin: 0 auto clamp(40px, 5vw, 64px);
}

/* Form card */
.form-card {
  background: var(--cream-50);
  border: 1px solid color-mix(in srgb, var(--ink-900) 14%, transparent);
  border-radius: 18px;
  padding: clamp(36px, 5vw, 64px);
  box-shadow: 0 28px 60px -36px rgba(20,17,12,0.25);
  text-align: left;
}
.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; }

.submit-row {
  margin-top: 12px;
  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);
  margin-top: 16px;
  text-align: center;
}

@media (max-width: 720px) {
  .field-row { grid-template-columns: 1fr; }
}
