/* giadaedemilio.com — homepage layout (editorial direction, ADR-019)
 *
 * Builds on /static/site.css design tokens. Sections:
 *   topnav, hero, storia, dettagli, honeymoon shell, rsvp shell,
 *   lista nozze, thanks, footer.
 * The luna-di-miele Leaflet narrative keeps its own stylesheet; this
 * file only styles the wrapping section header + container.
 */

html { scroll-behavior: smooth; }
body { overflow-x: hidden; }

/* Override generic h1/h2/h3 reset from site.css inside homepage sections —
 * homepage controls margins via flex/gap on parent wrappers. */
.section h1, .section h2, .section h3,
.hero h1 { margin: 0; }

/* ---------- Section scaffold (shared) ---------- */
.s-wrap { width: 100%; max-width: 1200px; margin: 0 auto; padding: 0 clamp(20px, 5vw, 64px); }
.section {
  padding: clamp(80px, 14vh, 160px) 0;
  position: relative;
  overflow: hidden;
}
.section--tight { padding: clamp(48px, 8vh, 96px) 0; }

.eyebrow {
  font-family: var(--font-body);
  font-size: 11px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--accent-quiet);
  font-weight: 500;
  display: inline-flex;
  align-items: center;
  gap: 14px;
}
.eyebrow::before, .eyebrow::after {
  content: "";
  height: 1px;
  width: 28px;
  background: currentColor;
  opacity: 0.6;
}
.eyebrow.is-solo::before, .eyebrow.is-solo::after { display: none; }

.h-display {
  font-family: var(--font-display);
  font-weight: 400;
  line-height: 1.05;
  letter-spacing: -0.02em;
  margin: 0;
  color: var(--fg-primary);
  text-wrap: balance;
}
.h-display em, .h-display i { font-style: italic; color: var(--accent-quiet); }

.lede {
  font-size: var(--text-base);
  line-height: 1.7;
  color: var(--fg-secondary);
  margin: 0;
  max-width: 56ch;
  text-wrap: pretty;
}

/* ---------- Reveal animation (scroll-driven) ---------- */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 900ms var(--easing-soft), transform 900ms var(--easing-soft);
  transition-delay: var(--reveal-delay, 0ms);
}
.reveal.is-on { opacity: 1; transform: translateY(0); }

@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; transition: none; }
}

/* ===== TOP NAV ============================================ */
.topnav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 50;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 18px clamp(20px, 5vw, 64px);
  background: var(--color-cream);
  pointer-events: none;
}
.topnav__brand,
.topnav__menu { pointer-events: auto; }
.topnav__brand {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 18px;
  color: var(--fg-primary);
  letter-spacing: 0.01em;
  text-decoration: none;
  border: 0;
}
.topnav__menu {
  display: flex;
  gap: clamp(12px, 2vw, 28px);
  flex-wrap: nowrap;
  white-space: nowrap;
}
.topnav__menu a {
  font-family: var(--font-body);
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--fg-secondary);
  text-decoration: none;
  border: 0;
  transition: color var(--duration-fast);
}
.topnav__menu a:hover { color: var(--accent); }

.topnav__progress {
  position: absolute;
  bottom: 0; left: 0;
  height: 1px;
  background: var(--accent-quiet);
  opacity: 0.7;
  width: var(--progress, 0%);
  transition: width 100ms linear;
}

@media (max-width: 860px) {
  .topnav__menu a:nth-child(n+3) { display: none; }
}
@media (max-width: 560px) {
  .topnav {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 14px;
    padding: 10px 16px;
  }
  .topnav__menu {
    display: flex;
    min-width: 0;
    gap: 14px;
    overflow-x: auto;
    scrollbar-width: none;
  }
  .topnav__menu::-webkit-scrollbar { display: none; }
  .topnav__menu a {
    display: inline-flex;
    font-size: 10px;
    letter-spacing: 0.12em;
  }
  .topnav__menu a:nth-child(n+3) { display: inline-flex; }
}

/* ===== HERO =============================================== */
.hero {
  min-height: 100vh;
  display: grid;
  place-items: center;
  position: relative;
  overflow: hidden;
  background: var(--color-cream);
  padding: 120px clamp(20px, 5vw, 64px) 80px;
}
.hero__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(20px, 3vh, 40px);
  align-items: center;
  justify-items: center;
  width: 100%;
  max-width: 1200px;
  text-align: center;
  position: relative;
  z-index: 2;
}
.hero__eyebrow {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 18px;
  font-family: var(--font-body);
  font-size: 11px;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--accent-quiet);
  font-weight: 500;
}
.hero__eyebrow span { display: inline-block; }
.hero__rule { width: 60px; height: 1px; background: currentColor; opacity: 0.55; }

.hero__lockup {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(3rem, 10vw, 8rem);
  line-height: 0.95;
  letter-spacing: -0.03em;
  color: var(--fg-primary);
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: baseline;
  gap: 0.35em;
  text-wrap: balance;
}
.hero__lockup .amp {
  display: inline-block;
  color: var(--accent);
  font-style: italic;
  font-weight: 400;
  font-size: 1em;
}
.hero__lockup .name { display: inline-block; }
.hero__lockup .name--g { color: var(--fg-primary); }
.hero__lockup .name--e { color: var(--accent-quiet); }

.hero__meta {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 14px;
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(1.1rem, 1.6vw, 1.45rem);
  color: var(--fg-secondary);
}
.hero__meta-dot { color: var(--accent); font-style: normal; font-size: 0.6em; transform: translateY(-0.2em); }
.hero__meta-strong { color: var(--fg-primary); }

.hero__count {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  align-self: center;
  margin-top: 16px;
  padding-top: 18px;
  border-top: 1px solid var(--accent-quiet);
  width: max-content;
  min-width: 200px;
  max-width: 280px;
  background: var(--color-cream);
  position: relative;
  z-index: 3;
}
.hero__count-num {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(2rem, 3.4vw, 3rem);
  line-height: 1;
  color: var(--accent);
}
.hero__count-label {
  font-family: var(--font-body);
  font-size: 10px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--fg-muted);
  margin-top: 6px;
}

/* Hero illustration: float behind type, mix-blend onto cream paper */
.hero__art {
  position: absolute;
  pointer-events: none;
  user-select: none;
  mix-blend-mode: multiply;
  z-index: 1;
}
.hero__art--foxes {
  position: absolute;
  bottom: clamp(24px, 5vh, 64px);
  left: 50%;
  transform: translateX(-50%);
  width: min(440px, 36vw);
  opacity: 1;
  filter: saturate(1.2) contrast(1.04);
  z-index: 0;
}

.scroll-hint {
  position: absolute;
  bottom: 32px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  font-family: var(--font-body);
  font-size: 10px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--fg-muted);
  z-index: 3;
  text-decoration: none;
  border: 0;
}
.scroll-hint__line {
  width: 1px;
  height: 40px;
  background: var(--accent-quiet);
  position: relative;
  overflow: hidden;
}
.scroll-hint__line::after {
  content: "";
  position: absolute;
  top: -10px;
  left: 0;
  width: 100%;
  height: 12px;
  background: var(--accent);
  animation: scrollDrip 2.4s ease-in-out infinite;
}
@keyframes scrollDrip {
  0% { transform: translateY(0); }
  60% { transform: translateY(50px); }
  100% { transform: translateY(50px); }
}

@media (max-width: 720px) {
  .hero__art--foxes {
    bottom: 28px;
    width: min(360px, 92vw);
    opacity: 1;
  }
}

/* ===== STORIA ============================================= */
.storia {
  background:
    linear-gradient(180deg, var(--color-cream) 0%, var(--color-cream-warm) 52%, var(--color-cream) 100%);
  position: relative;
  overflow: hidden;
}
.storia::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent 0%, rgba(196,153,60,0.10) 50%, transparent 100%);
  opacity: 0.55;
  pointer-events: none;
}
.storia .s-wrap {
  max-width: 1240px;
  position: relative;
  z-index: 1;
}
.storia__head {
  text-align: center;
  margin-bottom: clamp(42px, 7vh, 76px);
  display: flex;
  flex-direction: column;
  gap: 20px;
  align-items: center;
}
.storia__title { font-size: clamp(2.5rem, 6vw, 4.5rem); }

.storia__diary {
  position: relative;
  max-width: 1160px;
  margin: 0 auto;
}
.storia__diary::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;
  width: 1px;
  background: linear-gradient(180deg, transparent, rgba(196,153,60,0.46), transparent);
  transform: translateX(-0.5px);
}
.storia__entry {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(280px, 0.78fr);
  grid-template-areas: "media copy";
  align-items: center;
  gap: clamp(28px, 6vw, 88px);
  padding: clamp(38px, 7vw, 88px) 0;
  border-top: 1px solid rgba(196,153,60,0.32);
}
.storia__entry:first-child {
  border-top: 0;
  padding-top: 0;
}
.storia__entry:last-child {
  border-bottom: 1px solid rgba(196,153,60,0.32);
}
.storia__entry:nth-child(even) {
  grid-template-columns: minmax(280px, 0.78fr) minmax(0, 1.08fr);
  grid-template-areas: "copy media";
}

.storia__media {
  grid-area: media;
  margin: 0;
  position: relative;
  aspect-ratio: 4 / 5;
  background: var(--color-cream-deep);
  overflow: hidden;
  box-shadow: 0 18px 48px rgba(54,43,32,0.10);
}
.storia__media::after {
  content: "";
  position: absolute;
  inset: 0;
  border: 1px solid rgba(26,22,18,0.10);
  pointer-events: none;
}
.storia__photo {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.storia__copy {
  grid-area: copy;
  display: flex;
  flex-direction: column;
  gap: 12px;
  max-width: 430px;
  position: relative;
  z-index: 1;
}
.storia__copy::before {
  content: "";
  width: 54px;
  height: 1px;
  background: var(--accent-quiet);
  margin-bottom: 2px;
}
.storia__entry:nth-child(even) .storia__copy {
  justify-self: end;
}
.storia__chapter {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 5.25rem;
  font-weight: 300;
  line-height: 0.78;
  color: rgba(196,153,60,0.24);
}
.storia__copy h3 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 2.75rem;
  line-height: 1.02;
  margin: 0;
}
.storia__copy p {
  margin: 0;
  color: var(--fg-secondary);
  line-height: 1.68;
  font-size: 1.04rem;
}
.storia__copy p + p { margin-top: 4px; }

@media (max-width: 920px) {
  .storia__diary::before { display: none; }
  .storia__entry,
  .storia__entry:nth-child(even) {
    grid-template-columns: 1fr;
    grid-template-areas:
      "media"
      "copy";
    gap: 24px;
    padding: 44px 0;
  }
  .storia__entry:first-child { padding-top: 0; }
  .storia__entry:nth-child(even) .storia__copy {
    justify-self: start;
  }
  .storia__media { aspect-ratio: 4 / 4.6; }
  .storia__copy {
    max-width: 640px;
  }
  .storia__copy h3 { font-size: 2.35rem; }
  .storia__chapter { font-size: 4.25rem; }
}

@media (max-width: 720px) {
  .storia__entry,
  .storia__entry:nth-child(even) {
    gap: 20px;
    padding: 36px 0;
  }
  .storia__media {
    aspect-ratio: 4 / 4.35;
    margin-inline: -18px;
  }
  .storia__copy { gap: 10px; }
  .storia__copy h3 { font-size: 1.85rem; }
  .storia__chapter { font-size: 3.2rem; }
}

/* ===== DETTAGLI =========================================== */
.dettagli {
  background: var(--color-cream-warm);
  position: relative;
}
.dettagli__inner {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: clamp(40px, 6vw, 96px);
  align-items: start;
  max-width: 1100px;
  margin: 0 auto;
}
.dettagli__head { display: flex; flex-direction: column; gap: 20px; position: sticky; top: 100px; }
.dettagli__title { font-size: clamp(2.5rem, 5vw, 4rem); }

.dettagli__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1px;
  background: var(--border-quiet);
  border: 1px solid var(--border-quiet);
}
.dettagli__card {
  background: var(--color-cream);
  padding: clamp(24px, 3vw, 36px);
  display: flex;
  flex-direction: column;
  gap: 10px;
  min-height: 200px;
  transition: background var(--duration-base);
}
.dettagli__card:hover { background: #fff; }

.dettagli__card-label {
  font-family: var(--font-body);
  font-size: 10px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--accent-quiet);
  font-weight: 500;
}
.dettagli__card-primary {
  font-family: var(--font-display);
  font-size: clamp(1.4rem, 2vw, 1.7rem);
  font-style: italic;
  line-height: 1.2;
  color: var(--fg-primary);
}
.dettagli__card-secondary {
  font-size: var(--text-sm);
  color: var(--fg-secondary);
  line-height: 1.6;
  margin-top: auto;
}
.dettagli__card-icon {
  width: 28px;
  height: 28px;
  margin-bottom: 4px;
  display: inline-block;
}
.dettagli__card-icon svg { width: 100%; height: 100%; stroke: var(--accent-quiet); fill: none; stroke-width: 1.4; }

@media (max-width: 720px) {
  .dettagli__inner { grid-template-columns: 1fr; gap: 32px; }
  .dettagli__head { position: static; }
  .dettagli__grid { grid-template-columns: 1fr; }
}

/* ===== HONEYMOON (shell only — Leaflet narrative keeps its own CSS) === */
.honeymoon {
  background: var(--color-ink);
  color: var(--color-cream);
  padding: clamp(80px, 14vh, 160px) 0;
  position: relative;
  overflow: hidden;
}
.honeymoon__head {
  text-align: center;
  margin-bottom: clamp(48px, 6vh, 80px);
  display: flex;
  flex-direction: column;
  gap: 20px;
  align-items: center;
}
.honeymoon__head .eyebrow { color: var(--color-gold); }
.honeymoon__title {
  font-size: clamp(2.5rem, 6vw, 4.5rem);
  color: var(--color-cream);
}
.honeymoon__title em { color: var(--color-gold); }
.honeymoon__lede { color: rgba(245,240,232,0.75); }

/* The Leaflet container lives inside .honeymoon. Frame the stage so the
 * mobile active-stop panel can sit above the map without changing Leaflet. */
.honeymoon__map-stage {
  max-width: 1280px;
  margin: 0 auto;
  border: 1px solid rgba(196,153,60,0.22);
  border-radius: 6px;
  overflow: hidden;
  background: #1F1A14;
  position: relative;
}

.honeymoon #luna-di-miele-map {
  max-width: none;
  margin: 0;
}

/* ===== RSVP =============================================== */
.rsvp { background: var(--color-cream); position: relative; }
.rsvp__inner { max-width: 720px; margin: 0 auto; position: relative; z-index: 2; }
.rsvp__head { text-align: center; margin-bottom: clamp(40px, 6vh, 72px); display: flex; flex-direction: column; gap: 18px; align-items: center; }
.rsvp__title { font-size: clamp(2.3rem, 5vw, 3.6rem); }

/* The HTMX-rendered .card fragment lives here — keep it readable. */
.rsvp__inner .card {
  background: var(--bg-surface);
  border-radius: var(--radius-md);
  padding: clamp(24px, 3vw, 40px);
  box-shadow: var(--shadow-soft);
  border: 1px solid var(--border-quiet);
}
.rsvp__inner .card > h3 {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  font-size: clamp(1.6rem, 3vw, 2rem);
  color: var(--fg-primary);
  margin: 0 0 8px;
}

/* Form scaffolding (matches design bundle) ------------------------- */
.form { display: flex; flex-direction: column; gap: 28px; }
.form .row { display: grid; gap: 24px; grid-template-columns: 1fr 1fr; margin: 0; }
@media (max-width: 600px) {
  .form .row { grid-template-columns: 1fr; }
}

/* Underline-style field. Reset the global input styling defined in
 * site.css so the underline aesthetic wins inside .rsvp__inner. */
.uf { display: flex; flex-direction: column; gap: 8px; position: relative; margin: 0; }
.uf__label {
  font-family: var(--font-body);
  font-size: 10px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--fg-muted);
  font-weight: 500;
}
.uf__req { color: var(--accent); margin-left: 3px; }
.rsvp__inner .uf__input,
.rsvp__inner .uf__textarea,
.rsvp__inner .uf__select {
  font-family: var(--font-display);
  font-size: 1.25rem;
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--border-strong);
  border-radius: 0;
  padding: 8px 2px 12px;
  color: var(--fg-primary);
  outline: none;
  transition: border-color var(--duration-fast);
  width: 100%;
  max-width: none;
  box-shadow: none;
}
.rsvp__inner .uf__input:focus,
.rsvp__inner .uf__textarea:focus,
.rsvp__inner .uf__select:focus {
  border-bottom-color: var(--accent);
  box-shadow: none;
}
.rsvp__inner .uf__textarea {
  font-family: var(--font-body);
  font-size: 1rem;
  resize: vertical;
  min-height: 80px;
}
.uf--invalid .uf__input,
.uf--invalid .uf__textarea,
.uf--invalid .uf__select { border-bottom-color: var(--color-maple); }
.uf__error { font-size: 11px; color: var(--color-maple); margin-top: 4px; }

/* Segmented control for binary choices (presente sì/no). The radio
 * input stays in the DOM (so the form post is identical to the legacy
 * markup); :has() promotes the wrapping label to the active state. */
.seg {
  display: inline-grid;
  grid-template-columns: 1fr 1fr;
  border: 1px solid var(--border-strong);
  border-radius: 999px;
  overflow: hidden;
  background: #fff;
  width: max-content;
  max-width: 100%;
}
.seg__btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 22px;
  margin: 0;
  font-family: var(--font-body);
  font-size: 13px;
  letter-spacing: 0.04em;
  color: var(--fg-secondary);
  cursor: pointer;
  transition: all var(--duration-fast);
  white-space: nowrap;
  background: transparent;
}
.seg__btn input[type="radio"] {
  position: absolute;
  opacity: 0;
  pointer-events: none;
  width: 1px;
  height: 1px;
}
.seg__btn:hover { color: var(--fg-primary); }
.seg__btn:has(input:checked) {
  background: var(--color-ink);
  color: var(--color-cream);
}
.seg__btn + .seg__btn { border-left: 1px solid var(--border-strong); }
.seg__btn:has(input:checked) + .seg__btn,
.seg__btn + .seg__btn:has(input:checked) { border-left-color: var(--color-ink); }
.seg__btn input[type="radio"]:focus-visible + span {
  outline: 2px solid var(--accent);
  outline-offset: 4px;
  border-radius: 999px;
}

/* Per-guest block — numbered head + indented body */
.guest {
  display: flex;
  flex-direction: column;
  gap: 20px;
  padding: 24px 0;
  border-bottom: 1px solid var(--border-quiet);
}
.guest:first-of-type { padding-top: 8px; }
.guest:last-of-type { border-bottom: 0; }
.guest__head {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  align-items: center;
  justify-content: space-between;
}
.guest__head-l { display: flex; align-items: baseline; gap: 14px; }
.guest__num {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  color: var(--accent-quiet);
}
.guest__name {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  font-size: 1.35rem;
  margin: 0;
  color: var(--fg-primary);
}
.guest__tag {
  font-family: var(--font-body);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--fg-muted);
}
.guest__body {
  display: flex; flex-direction: column; gap: 18px;
  padding-left: clamp(0px, 4vw, 28px);
  border-left: 1px solid var(--border-quiet);
  margin-left: 4px;
  padding-bottom: 4px;
}

.contatti {
  border-top: 1px solid var(--border-quiet);
  padding-top: 28px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.contatti__title {
  font-family: var(--font-body);
  font-size: 11px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--accent-quiet);
  font-weight: 500;
  margin: 0;
}

.form__error {
  text-align: center;
  font-size: 13px;
  color: var(--color-maple);
  background: rgba(176, 58, 46, 0.08);
  border: 1px solid rgba(176, 58, 46, 0.2);
  padding: 10px 14px;
  border-radius: var(--radius-sm);
  margin: 0;
}

.form__actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 16px;
  margin: 0;
}

.btn-primary {
  background: var(--color-ink);
  color: var(--color-cream);
  border: 0;
  padding: 16px 44px;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.15rem;
  border-radius: 999px;
  cursor: pointer;
  letter-spacing: 0.01em;
  transition: all var(--duration-base);
}
.btn-primary:hover { background: var(--accent); }
.btn-primary:disabled { opacity: 0.5; cursor: not-allowed; }

.btn-quiet {
  background: 0;
  border: 0;
  font-family: var(--font-body);
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--fg-muted);
  cursor: pointer;
  padding: 8px 4px;
  transition: color var(--duration-fast);
}
.btn-quiet:hover { color: var(--accent-hover); background: transparent; }

/* Confirmation panel (card_riepilogo) */
.rsvp__sent {
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 20px;
  align-items: center;
  padding: 24px 0 16px;
}
.rsvp__sent-icon {
  width: 64px; height: 64px;
  border-radius: 50%;
  border: 1.5px solid var(--accent);
  display: grid;
  place-items: center;
  color: var(--accent);
}
.rsvp__sent h3 {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  font-size: 2rem;
  margin: 0;
}
.rsvp__sent p {
  color: var(--fg-secondary);
  max-width: 460px;
  line-height: 1.7;
  margin: 0;
}
.rsvp__sent table { margin-top: 20px; }
.rsvp__sent .muted { margin-top: 18px; }

/* ===== LISTA NOZZE ======================================== */
.lista {
  background: var(--color-ink);
  color: var(--color-cream);
  position: relative;
  overflow: hidden;
}
.lista__head { text-align: center; margin-bottom: clamp(40px, 6vh, 72px); display: flex; flex-direction: column; gap: 20px; align-items: center; }
.lista__head .eyebrow { color: var(--color-gold); }
.lista__title { font-size: clamp(2.3rem, 5vw, 3.6rem); color: var(--color-cream); }
.lista__title em { color: var(--color-gold); }
.lista__lede { color: rgba(245,240,232,0.75); }

.lista__bank {
  max-width: 680px;
  margin: 0 auto;
  padding: clamp(24px, 4vw, 40px) 0;
  border-top: 1px solid rgba(196,153,60,0.3);
  border-bottom: 1px solid rgba(196,153,60,0.3);
}
.lista__bank-head {
  display: flex;
  align-items: center;
  gap: 18px;
  margin-bottom: 16px;
}
.lista__label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  color: var(--color-gold);
}
.lista__copy {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.3rem;
  line-height: 1.5;
  color: rgba(245,240,232,0.92);
  margin: 0;
}
.lista__bank-details {
  display: grid;
  gap: 14px;
  margin: 24px 0 0;
}
.lista__bank-details > div {
  display: grid;
  grid-template-columns: 140px minmax(0, 1fr);
  gap: 18px;
  align-items: baseline;
}
.lista__bank-details dt {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--color-gold);
}
.lista__bank-details dd {
  font-family: var(--font-mono);
  font-size: 14px;
  letter-spacing: 0.04em;
  color: var(--color-cream);
  margin: 0;
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  overflow-wrap: anywhere;
}
.lista__bank-details dd span { min-width: 0; }
.lista__copy-button[type="button"] {
  width: 22px;
  height: 22px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  padding: 0;
  color: var(--color-gold);
  background: transparent;
  border: 0;
  border-radius: 0;
  cursor: pointer;
  line-height: 0;
  transition: color var(--duration-fast), opacity var(--duration-fast);
}
.lista__copy-button svg {
  width: 18px;
  height: 18px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.9;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.lista__copy-button[type="button"]:hover,
.lista__copy-button[type="button"].is-copied {
  color: var(--color-cream);
  background: transparent;
}
.lista__copy-button[type="button"]:focus-visible {
  color: var(--color-cream);
  background: transparent;
  outline: 1px solid currentColor;
  outline-offset: 3px;
}
.lista__copy-button[type="button"]:active {
  transform: none;
}

@media (max-width: 720px) {
  .lista__bank-details > div { grid-template-columns: 1fr; gap: 4px; }
}

/* ===== CHI CI HA AIUTATO (thanks) ========================= */
.thanks { background: var(--color-cream-warm); position: relative; }
.thanks__head { text-align: center; margin-bottom: clamp(40px, 6vh, 64px); display: flex; flex-direction: column; gap: 16px; align-items: center; }
.thanks__title { font-size: clamp(2.2rem, 4.5vw, 3.4rem); }
.thanks__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: clamp(24px, 3vw, 40px);
  max-width: 1000px;
  margin: 0 auto;
}
.thanks__card {
  display: flex; flex-direction: column; gap: 6px;
  text-align: center;
  padding: 20px;
}
.thanks__role {
  font-family: var(--font-body);
  font-size: 10px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--accent-quiet);
}
.thanks__name {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.4rem;
  color: var(--fg-primary);
}
.thanks__detail {
  font-size: 13px;
  color: var(--fg-secondary);
  line-height: 1.6;
  margin: 0;
}

/* ===== FOOTER ============================================= */
.footer {
  background: var(--color-cream);
  padding: 60px clamp(20px, 5vw, 64px);
  text-align: center;
  border-top: 1px solid var(--border-quiet);
}
.footer__lockup {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.4rem;
  color: var(--accent-quiet);
}
.footer__date {
  font-family: var(--font-body);
  font-size: 11px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--fg-muted);
  margin-top: 12px;
}

/* ===== MOBILE TIGHTENING ================================== */
/* Compress the desktop editorial spacing on phones, keep the foxes as a
 * visible background element, and drop desktop-only minimums on the dettagli
 * grid. */

@media (max-width: 720px) {
  .section { padding: 64px 0; }

  .hero { padding: 60px clamp(16px, 5vw, 32px) 128px; min-height: 100svh; }
  .hero__grid { gap: 20px; }
  .hero__lockup { font-size: clamp(3.2rem, 16vw, 5.5rem); gap: 0.2em; }
  .hero__meta { font-size: 1rem; gap: 10px; }
  .hero__count { margin-top: 8px; padding-top: 14px; min-width: 0; }
  .hero__art--foxes {
    bottom: 36px;
    width: min(380px, 94vw);
    opacity: 1;
  }
  .scroll-hint { bottom: 20px; }
  .scroll-hint__line { height: 28px; }

  /* Section heads: collapse the big vh-based bottoms. */
  .storia__head,
  .dettagli__head,
  .honeymoon__head,
  .rsvp__head,
  .lista__head,
  .thanks__head { margin-bottom: 36px; gap: 14px; }

  .storia__entry { gap: 20px; }
  .storia__copy h3 { font-size: 1.85rem; }

  .dettagli__inner { gap: 24px; }
  .dettagli__card { min-height: 0; padding: 20px; gap: 6px; }
  .dettagli__card-primary { font-size: 1.2rem; }

  .honeymoon { padding: 56px 0; }

  .rsvp__inner .card { padding: 20px; }
  .form { gap: 22px; }
  .guest { padding: 18px 0; gap: 14px; }
  .guest__body { gap: 14px; padding-left: 0; border-left: 0; margin-left: 0; }
  .guest__head { gap: 10px; }
  .guest__name { font-size: 1.15rem; }
  .seg { width: 100%; }
  .seg__btn { padding: 10px 12px; font-size: 12px; }
  .form__actions { flex-direction: column; gap: 12px; }
  .form__actions .btn-primary { width: 100%; padding: 14px 24px; }

  .lista__copy { font-size: 1.1rem; }
  .lista__bank-details dd { font-size: 12px; }

  .thanks__grid { gap: 18px; }
  .thanks__card { padding: 12px; }

  .footer { padding: 40px 20px; }
}

@media (max-width: 480px) {
  .section { padding: 52px 0; }
  .s-wrap { padding: 0 18px; }
  .hero { padding: 56px 18px 116px; }
  .hero__lockup { font-size: clamp(2.8rem, 18vw, 4.5rem); }
  .hero__count-num { font-size: 1.7rem; }
  .hero__art--foxes {
    bottom: 30px;
    width: min(340px, 96vw);
  }
  .topnav__brand { font-size: 16px; }
  .lista__copy { font-size: 1rem; }
}
