/**
 * Invitation model 2 (Romantic)
 * Background images via CSS variables: --model-2-header, --model-2-countdown, --model-2-location
 */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,600&family=Great+Vibes&display=swap');

body.invitation-model-2 {
  font-family: 'Cormorant Garamond', serif;
}

body.invitation-model-2 .script {
  font-family: 'Great Vibes', cursive;
}

.invitation-model-2 .pink {
  background: #fdf8f6;
}

.invitation-model-2 .white {
  background: #ffffff;
}

/* Hero */
.invitation-model-2 .hero-wrap {
  position: relative;
  min-height: 100vh;
  background-image: var(--model-2-header);
  background-size: cover;
  background-position: center;
}

.invitation-model-2 .hero-wrap::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(90,60,70,0.25) 0%, rgba(50,35,45,0.5) 100%);
}

.invitation-model-2 .hero-inner {
  position: relative;
  z-index: 2;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 2rem;
  text-align: center;
  color: #fff;
}

.invitation-model-2 .hero-divider {
  width: 80px;
  height: 1px;
  margin: 1rem auto;
  background: rgba(255,255,255,0.8);
}

.invitation-model-2 .hero-amp {
  margin: 0 0.5rem;
  font-size: 1.25rem;
  opacity: 0.9;
}

/* About */
.invitation-model-2 .about-row {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 2rem;
  align-items: center;
  max-width: 900px;
  margin: 0 auto;
}

@media (max-width: 767px) {
  .invitation-model-2 .about-row {
    grid-template-columns: 1fr;
  }
}

.invitation-model-2 .about-photo {
  width: 100%;
  max-width: 280px;
  height: 320px;
  object-fit: cover;
  border-radius: 0.5rem;
  box-shadow: 0 12px 40px rgba(0,0,0,0.12);
}

.invitation-model-2 .about-names .script {
  font-size: 2rem;
  color: #5c4048;
}

/* Countdown */
.invitation-model-2 .countdown-section {
  position: relative;
  padding: 4rem 0;
  color: #fff;
  background-image: var(--model-2-countdown);
  background-size: cover;
  background-position: center;
}

.invitation-model-2 .countdown-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(70,50,60,0.5);
}

.invitation-model-2 .countdown-inner {
  position: relative;
  z-index: 1;
}

.invitation-model-2 .countdown-box {
  padding: 1.5rem;
  text-align: center;
  color: #3d3236;
  border-radius: 0.75rem;
  background: rgba(255,252,250,0.95);
  box-shadow: 0 8px 24px rgba(0,0,0,0.1);
}

/* Location */
.invitation-model-2 .location-section {
  position: relative;
  padding: 4rem 0;
  color: #fff;
  background-image: var(--model-2-location);
  background-size: cover;
  background-position: center;
}

.invitation-model-2 .location-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.45);
}

.invitation-model-2 .location-card {
  overflow: hidden;
  color: #2c2c2c;
  border-radius: 0.75rem;
  background: rgba(255,252,250,0.98);
  box-shadow: 0 8px 32px rgba(0,0,0,0.1);
}

/* Organizational details – same overlay for all models */
.invitation-model-2 #organizational-details {
  position: relative;
}
.invitation-model-2 #organizational-details::before {
  content: '';
  position: absolute;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.45);
}
.invitation-model-2 #organizational-details .container {
  position: relative;
  z-index: 1;
}
