:root{
  --burgundy:#5b0b1c;
  --burgundy-dark:#3b0610;
  --cream:#f6f1eb;
  --ink:#1e1e1e;
  --gold:#c79b32;
}

/* Reset & base ---------------------------------------------------------- */
*{
  box-sizing:border-box;
}

html,body{
  width:100%;
  height:100%;
}

body{
  margin:0;
  font-family:"EB Garamond", Georgia, serif;
  color:#fff;
  background:var(--burgundy);
  overflow-x:hidden;
}

/* GOLD-TEXT ------------------------------------------------------------- */
.goldtext{
  background:linear-gradient(90deg,#fff7c7,#d4af37,#b38728,#fff7c7);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}

/* HERO ------------------------------------------------------------------ */
.hero{
  position:relative;
  height:clamp(220px, 32vh, 300px);
  overflow:hidden;
}

/* Bildausschnitt: beide Köpfe + etwas Himmel */
.hero-img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:50% 36%;
  display:block;
  filter:brightness(.9) saturate(1.05);
}

/* Vignette + sanfter Verlauf nach unten */
.hero-overlay{
  position:absolute;
  inset:0;
  background:
    radial-gradient(
      circle at 50% 45%,
      rgba(0,0,0,0) 0%,
      rgba(0,0,0,0) 45%,
      rgba(0,0,0,0.28) 75%,
      rgba(0,0,0,0.48) 100%
    ),
    linear-gradient(
      180deg,
      rgba(0,0,0,.08),
      rgba(91,11,28,.65)
    );
}

.branding{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0 1rem;
  text-align:center;
}

.branding .names{
  font-family:"Great Vibes", cursive;
  font-size:clamp(2.4rem, 5vw, 3.6rem);
  transform:translateY(-10%);
  text-shadow:0 0 16px rgba(0,0,0,.6);
}

/* Handy / kleine Geräte ------------------------------------------------- */
@media (max-width:600px){
  .hero{
    height:250px;
  }

  .hero-img{
    width:100%;
    height:100%;
    object-fit:cover;
    object-position:50% 42%;
    transform:scale(1.12);
    transform-origin:center center;
  }

  .branding .names{
    transform:translateY(155%);
    font-size:clamp(2.4rem, 7vw, 3.2rem);
  }
}

/* Desktop / große Bildschirme ------------------------------------------ */
@media (min-width:1024px){
  .hero{
    height:750px;
  }

  .hero-img{
    width:100%;
    height:750px;
    object-fit:cover;
    object-position:26% 48%;
    transform:scale(1.0);
    transform-origin:center center;
  }

  .branding .names{
    transform:translateY(175%);
    font-size:clamp(7rem, 8vw, 3.6rem);
  }
}

/* Layout ---------------------------------------------------------------- */
.wrap{
  padding:clamp(14px, 4vw, 26px);
}

.card{
  background:#fff;
  color:var(--ink);
  border-radius:22px;
  border:1px solid rgba(0,0,0,.06);
  box-shadow:0 30px 70px rgba(0,0,0,.30);
  max-width:1200px;
  margin:0 auto;
}

.content-grid{
  display:grid;
  grid-template-columns:1.08fr 1fr;
  gap:1.6rem;
  padding:1.6rem 1.6rem 1.7rem;
}

@media (max-width:900px){
  .content-grid{
    grid-template-columns:1fr;
    padding:1.1rem 1.1rem 1.3rem;
    gap:1.2rem;
  }
}

.notice-card{
  max-width:900px;
  padding:1.5rem 1.6rem;
  margin:1.4rem auto 0;
}

.notice-inner{
  text-align:center;
}

.notice-text{
  margin:.4rem 0 0;
  color:#4b5563;
  line-height:1.7;
}

.info-side{
  padding:.2rem;
}

.form-side{
  padding:.2rem;
}

.full-width{
  grid-column:1 / -1;
}

/* Überschriften / Intro ------------------------------------------------- */
.headline{
  color:var(--burgundy);
  text-align:center;
  margin:.1rem 0 .8rem;
  font-size:clamp(1.45rem, 3.6vw, 2rem);
  letter-spacing:.03em;
}

/* Handy: Headline-Abstand enger ---------------------------------------- */
@media (max-width:600px){
  .headline{
    margin:.3rem 0 .4rem;
  }
}

.form-intro{
  margin:.15rem 0 .8rem;
  color:#4b5563;
  line-height:1.7;
  font-size:.97rem;
  text-align:center;
}

/* goldene Hervorhebung im Text */
.form-intro em{
  color:var(--gold);
  font-style:normal;
  font-weight:600;
}

/* du/euch-Umschaltung --------------------------------------------------- */
/* Standard: du-Version anzeigen, ihr-Version verstecken */
.intro-sing{
  display:inline;
}
.intro-plural{
  display:none;
}

/* Wenn Begleitungen ausgewählt sind → ihr-Version anzeigen */
body.use-plural .intro-sing{
  display:none;
}
body.use-plural .intro-plural{
  display:inline;
}

/* Einleitung auf dem Handy enger ---------------------------------------- */
@media (max-width:600px){
  .form-intro{
    margin:.2rem 0 .45rem;
    line-height:1.5;
    padding:0 .4rem;
  }
}

/* „Unser Tag“ Card ------------------------------------------------------ */
.intro-wrap{
  background:#fff9f6;
  border-radius:20px;
  padding:1.2rem 1.35rem 1.3rem;
  border:1px solid #f5d4d1;
  box-shadow:0 16px 40px rgba(91,11,28,.12);
  margin-bottom:1.5rem;
}

.section-title{
  font-size:.95rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  text-align:center;
  margin:0 0 .55rem;
  color:var(--gold);
}

.intro-lead{
  margin:.2rem 0 .7rem;
  color:#2b2b2b;
  line-height:1.9;
  font-size:1.02rem;
  text-align:center;
}

.intro-steps{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  flex-direction:column;
  gap:1.1rem;
}

.intro-step{
  display:grid;
  grid-template-columns:auto 1fr;
  column-gap:.75rem;
  align-items:flex-start;
}

.intro-icon{
  font-size:1.6rem;
  line-height:1;
  margin-top:.1rem;
}

.intro-text h3{
  margin:0 0 .18rem;
  font-size:1.05rem;
  color:#111827;
  font-weight:700;
}

.intro-text p{
  margin:0;
  font-size:.96rem;
  line-height:1.8;
  color:#3f3f46;
}

.intro-note{
  margin:.9rem 0 0;
  color:#4b5563;
  line-height:1.8;
  font-size:.96rem;
}

/* Handy: „Unser Tag“ etwas dichter ------------------------------------- */
@media (max-width:600px){
  .intro-wrap{
    padding:1rem 1.1rem 1.1rem;
    margin-bottom:1.1rem;
  }
}

/* Hinweis & Timeline ---------------------------------------------------- */
.hint{
  margin-top:.9rem;
  padding:.7rem .9rem;
  border-radius:14px;
  background:#fdf7f7;
  border:1px solid #f5d4d1;
  color:#5b3b49;
  font-size:.9rem;
  line-height:1.6;
}

.timeline{
  margin-top:1.2rem;
  background:#ffffff;
  border-radius:18px;
  padding:1rem 1.15rem 1.2rem;
  border:1px solid rgba(148,163,184,0.45);
}

.timeline-headline{
  text-align:center;
  color:#5b0b1c;
  margin-bottom:.7rem;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size:.84rem;
}

.timeline-list{
  list-style:none;
  margin:0;
  padding:0;
}

.timeline-list li{
  padding:.6rem 0 .8rem;
  border-bottom:1px dashed #e5e7eb;
  font-size:.93rem;
  color:#374151;
}

.timeline-list li:last-child{
  border-bottom:none;
}

.timeline-label{
  font-weight:700;
  color:#111827;
  font-size:1rem;
  margin-bottom:.1rem;
}

.timeline-datetime{
  font-size:.9rem;
  color:#6b7280;
}

.timeline-place{
  font-size:.9rem;
  color:#374151;
  margin-top:.15rem;
}

.timeline-desc{
  font-size:.88rem;
  color:#4b5563;
  font-style:italic;
  margin-top:.12rem;
}

/* Handy: Timeline enger ------------------------------------------------- */
@media (max-width:600px){
  .timeline{
    margin-top:.9rem;
    padding:.85rem .9rem 1rem;
  }

  .timeline-list li{
    padding:.5rem 0 .7rem;
  }
}

/* Formular-Bereich ------------------------------------------------------ */
.rsvp-form{
  margin-top:.1rem;
}

.rsvp-form label{
  display:block;
  font-weight:600;
  color:#5b3b49;
  margin:.75rem 0 .35rem;
}

/* Handy: Labels etwas dichter ------------------------------------------ */
@media (max-width:600px){
  .rsvp-form label{
    margin:.55rem 0 .25rem;
  }
}

.rsvp-form input,
.rsvp-form textarea,
.rsvp-form select{
  width:100%;
  border:1px solid #ddd;
  border-radius:14px;
  padding:.8rem .95rem;
  background:#fff;
  color:#000;
  font-family:inherit;
  font-size:1rem;
}

.rsvp-form input::placeholder{
  color:#b0b0b0;
}

/* einheitliche Größe & Ausrichtung für Radio-Buttons und Checkboxen */
.rsvp-form input[type="radio"],
.rsvp-form input[type="checkbox"]{
  width:22px;
  height:22px;
  margin:0;
  flex:0 0 22px;
  vertical-align:middle;
}

.rsvp-form textarea{
  resize:vertical;
  min-height:80px;
}

.rsvp-form .grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:.8rem;
  margin-bottom:1.1rem;
}

.rsvp-form .grid.two{
  grid-template-columns:1fr 1fr;
}

@media (max-width:520px){
  .rsvp-form .grid,
  .rsvp-form .grid.two{
    grid-template-columns:1fr;
  }
}

/* Teilnahme-Box --------------------------------------------------------- */
.attend{
  margin-top:.8rem;
  margin-bottom:.7rem;
  padding:.85rem 1rem 1rem;
  border-radius:16px;
  border:1px solid #f5d4d1;
  background:#fff7f7;
}

.attend-label{
  font-weight:700;
  color:#5b3b49;
  margin:0 0 .4rem;
}

.radio-row{
  display:flex;
  align-items:center;
  gap:.6rem;
  margin:.35rem 0;
  color:#4b3743;
  font-size:.95rem;
  line-height:1.3;
}

.radio-row input{
  margin:0;
}

/* Events --------------------------------------------------------------- */
.events{
  border:1px solid #eee;
  padding:.8rem 1rem 1rem;
  border-radius:16px;
  background:#fff;
  max-width:100%;
  margin-top:.7rem;
}

.events legend{
  padding:0 .3rem;
  color:#5b3b49;
  font-weight:700;
  font-size:.95rem;
}

.events-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:.35rem .9rem;
  margin-top:.25rem;
}

@media (max-width:540px){
  .events-grid{
    grid-template-columns:1fr;
  }
}

/* Checkbox + Text nebeneinander ---------------------------------------- */
.check{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:.6rem;
  margin:.25rem 0;
  color:#4b3743;
  font-weight:600;
  font-size:.94rem;
  line-height:1.3;
}

.check input{
  margin:0;
  flex-shrink:0;
}

.check span{
  display:inline-block;
}

.check.disabled{
  opacity:.5;
}

/* Begleitungen ---------------------------------------------------------- */
.companions{
  margin:.95rem 0 .4rem;
  display:grid;
  gap:.9rem;
}

.comp-card{
  border:1px solid #eee;
  border-radius:14px;
  padding:.6rem 1rem .8rem;
  background:#fafafa;
}

.comp-head{
  font-weight:700;
  color:#5b3b49;
  margin-bottom:.35rem;
}

.comp-events{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:.3rem .8rem;
}

@media (max-width:540px){
  .comp-events{
    grid-template-columns:1fr;
  }
}

/* Buttons & Meldungen --------------------------------------------------- */
.btn-primary{
  margin-top:1.2rem;
  width:100%;
  border:none;
  border-radius:16px;
  padding:.9rem 1.2rem;
  font-weight:700;
  font-family:inherit;
  font-size:1rem;
  cursor:pointer;
  background:linear-gradient(180deg,var(--burgundy),var(--burgundy-dark));
  color:#fff;
  box-shadow:0 10px 26px rgba(91,11,28,.30);
}

.btn-primary:hover{
  opacity:.97;
}

.alert{
  margin:.4rem 0 .9rem;
  padding:.75rem .95rem;
  border-radius:12px;
  background:#fff4e6;
  color:#7c2d12;
  border:1px solid #fed7aa;
  font-size:.92rem;
}

.alert ul{
  margin:.3rem 0 0;
  padding-left:1.1rem;
}

.msg{
  margin-top:.8rem;
  padding:.8rem 1rem;
  border-radius:14px;
  background:#f2f2f2;
  color:#222;
  font-size:.96rem;
  line-height:1.8;
}

/* Footer ---------------------------------------------------------------- */
.footer{
  text-align:center;
  padding:1.4rem .4rem 0;
  font-size:.78rem;
  opacity:.8;
  color:#fef2f2;
}
