/* RSVP Page Styles */
.rsvp-card {
  max-width: 720px; /* widen a bit */
  margin: 1.5rem auto; /* slightly reduce vertical margin */
  background: #fff;
  border-radius: 1.25rem;
  box-shadow: 0 6px 24px rgba(163,129,241,0.25);
  border: 1px solid #ffd2a6;
  padding: 1.5rem 1.25rem; /* reduce padding to compress height */
}
.rsvp-title {
  text-align: center;
  color: #f05a00;
  font-weight: 800;
  font-family: Roboto, "Helvetica Neue", Arial, sans-serif;
}
.rsvp-subtitle {
  text-align: center;
  color: #4b5563;
  margin-bottom: 1rem; /* reduce spacing */
}
.rsvp-input {
  border-radius: 0.75rem;
  border: 1px solid #ffd2a6;
  padding: 0.85rem 1rem;
}
.rsvp-input:focus {
  border-color: #ff8a3d;
  box-shadow: 0 0 0 0.2rem rgba(255,138,61,0.2);
}
/* Labels placed above inputs to avoid overlap */
.rsvp-label {
  display: block;
  margin-top: 0.25rem;
  color: #f05a00;
  font-weight: 600;
}
.rsvp-submit {
    background: linear-gradient(180deg, #ff7a1a, #e95700);
    color: #fff;
    font-weight: 700;
    padding: 0.9rem 1rem;
    border-radius: 0.75rem;
    margin-top: 1.5rem;
}
.rsvp-submit:hover {
  background: linear-gradient(180deg, #ff8a3d, #f05a00);
  color: #fff;
}

/* Example: Custom radio button styles */
.form-check-input[type="radio"] {
  accent-color: #f05a00; /* Modern browsers */
  width: 1.2em;
  height: 1.2em;
  margin-right: 0.5em;
}

.form-check-label {
  font-weight: 600;
  color: #4b5563;
}

/* Mobile tweaks */
@media (max-width: 600px) {
  .rsvp-card { padding: 1.25rem 1rem; }
  .rsvp-title { font-size: 1.6rem; }
  .rsvp-input { padding: 0.75rem 0.9rem; }
}

/* Wider on large screens */
@media (min-width: 992px) {
  .rsvp-card { max-width: 840px; }
}
