/* ============================================
   RSVP Dashboard (confirmed view)
   ============================================ */

.rsvp-dashboard {
  padding-top: 4rem;
  min-height: 100vh;
}

.rsvp-title {
  color: #D4A843;
}

.rsvp-status {
  margin: 1.5rem 0;
  padding: 1rem 1.5rem;
  border-radius: 8px;
  font-size: 0.95rem;
}

.rsvp-status--confirmed {
  background: color-mix(in srgb, var(--color-accent-green) 12%, transparent);
  border: 1px solid color-mix(in srgb, var(--color-accent-green) 30%, transparent);
}

.rsvp-status--pending {
  background: color-mix(in srgb, var(--color-accent-blue) 12%, transparent);
  border: 1px solid color-mix(in srgb, var(--color-accent-blue) 30%, transparent);
}

.rsvp-card {
  width: 100%;
  max-width: 400px;
  margin: 1.5rem auto;
  padding: 1.5rem;
  border: 1px solid color-mix(in srgb, var(--color-text) 12%, transparent);
  border-radius: 12px;
  text-align: left;
}

.rsvp-card-heading {
  font-family: Bentham, Georgia, serif;
  font-weight: normal;
  font-size: 1.2rem;
  letter-spacing: 0.15em;
  color: var(--color-header);
  margin-bottom: 1rem;
  transition: color 0.4s ease;
}

.rsvp-guest-list {
  list-style: none;
  margin-bottom: 1rem;
}

.rsvp-guest-list li {
  padding: 0.5rem 0;
  border-bottom: 1px solid color-mix(in srgb, var(--color-text) 8%, transparent);
  font-size: 0.95rem;
}

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

.rsvp-guest-tags {
  display: block;
  font-size: 0.8rem;
  opacity: 0.6;
  margin-top: 0.2rem;
}

.rsvp-empty {
  font-size: 0.9rem;
  opacity: 0.6;
  margin-bottom: 1rem;
}

.rsvp-card .btn {
  width: 100%;
  text-align: center;
}

.rsvp-actions {
  display: flex;
  gap: 1rem;
  justify-content: center;
  margin-top: 2rem;
  flex-wrap: wrap;
}

/* RSVP status list (confirmed view) */
.rsvp-status-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.rsvp-status-item {
  padding: 0.5rem 0;
  font-size: 0.9rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.rsvp-status-item--done {
  color: var(--color-accent-green);
}

.rsvp-status-item--pending {
  color: var(--color-gold);
}

/* ============================================
   RSVP Wizard
   ============================================ */

.rsvp-wizard {
  position: fixed;
  inset: 0;
  display: flex;
  z-index: 50;
}

/* Step indicator nav (left sidebar on desktop, bottom bar on mobile) */
.rsvp-wizard-nav {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 1.5rem;
  padding: 2rem 1rem;
  background: color-mix(in srgb, var(--color-bg), var(--color-text) 5%);
  border-right: 1px solid color-mix(in srgb, var(--color-bg), var(--color-text) 10%);
  min-width: 160px;
}

.rsvp-wizard-dot {
  display: flex;
  align-items: center;
  justify-content: start;
  gap: 0.75rem;
  width: 100%;
  background: none;
  border: none;
  cursor: pointer;
  color: color-mix(in srgb, var(--color-bg), var(--color-text) 40%);
  transition: color 0.2s;
  text-align: left;
  padding: 0.25rem 0;
}

.rsvp-wizard-dot.active {
  color: var(--color-title);
}

.rsvp-wizard-dot-number {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border-radius: 50%;
  border: 2px solid currentcolor;
  font-size: 0.8rem;
  font-weight: bold;
  flex-shrink: 0;
}

.rsvp-wizard-dot.active .rsvp-wizard-dot-number {
  background: var(--color-title);
  color: #fff;
  border-color: var(--color-title);
}

.rsvp-wizard-dot-label {
  font-size: 0.8rem;
  font-weight: 500;
}

/* Scrolling sections container */
.rsvp-wizard-scroller {
  flex: 1;
  overflow-y: auto;
  scroll-snap-type: y proximity;
  scroll-behavior: smooth;
}

.rsvp-section {
  min-height: 100vh;
  scroll-snap-align: start;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: 2rem;
  padding-top: 3rem;
}

.rsvp-section-inner {
  max-width: 500px;
  width: 100%;
}

/* Section typography */
.rsvp-section-step {
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: color-mix(in srgb, var(--color-bg), var(--color-text) 40%);
  margin-bottom: 0.5rem;
}

.rsvp-section-title {
  font-family: Bentham, serif;
  font-size: 1.8rem;
  color: var(--color-gold);
  margin-bottom: 0.5rem;
}

.rsvp-gold {
  color: var(--color-gold);
}

.rsvp-section-subtitle {
  color: color-mix(in srgb, var(--color-bg), var(--color-text) 60%);
  font-size: 0.95rem;
  margin-bottom: 1.5rem;
  line-height: 1.5;
}

/* Guest rows (section 1) */
.rsvp-guest-row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.5rem;
}

.rsvp-icon-btn {
  background: none;
  border: none;
  cursor: pointer;
  color: color-mix(in srgb, var(--color-bg), var(--color-text) 30%);
  font-size: 1rem;
  padding: 0.5rem;
  border-radius: 4px;
  transition: color 0.15s, background 0.15s;
}

.rsvp-icon-btn:hover {
  color: var(--color-text);
  background: color-mix(in srgb, var(--color-bg), var(--color-text) 8%);
}

.rsvp-icon-btn.active {
  color: var(--color-accent-purple);
}

[data-to-be-removed="true"] .rsvp-icon-btn,
.rsvp-icon-btn--danger:hover {
  color: var(--color-accent-red);
}

.rsvp-add-btn {
  background: none;
  border: 1px dashed color-mix(in srgb, var(--color-bg), var(--color-text) 20%);
  color: color-mix(in srgb, var(--color-bg), var(--color-text) 50%);
  cursor: pointer;
  padding: 0.5rem 1rem;
  border-radius: 6px;
  font-size: 0.85rem;
  width: 100%;
  margin-bottom: 2rem;
  transition: border-color 0.15s, color 0.15s;
}

.rsvp-add-btn:hover {
  border-color: var(--color-title);
  color: var(--color-title);
}

/* Detail cards (section 2) */
.rsvp-detail-card {
  background: color-mix(in srgb, var(--color-bg), var(--color-text) 4%);
  border-radius: 8px;
  padding: 1.25rem;
  margin-bottom: 1rem;
}

.rsvp-detail-name {
  font-size: 1rem;
  font-weight: 600;
  color: var(--color-text);
  margin-bottom: 0.75rem;
}

.rsvp-check-row {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.4rem 0;
  cursor: pointer;
  font-size: 0.9rem;
  color: var(--color-text);
}

.rsvp-check-row em {
  color: color-mix(in srgb, var(--color-bg), var(--color-text) 50%);
  font-style: normal;
  font-size: 0.85rem;
}

.rsvp-check-row .fa-circle-info {
  color: var(--color-accent-blue);
  cursor: help;
}

.rsvp-check-row--highlight {
  animation: check-highlight 1s ease;
}

@keyframes check-highlight {
  0% { background: transparent; }

  20% {
    background: color-mix(in srgb, var(--color-accent-green), transparent 80%);
    border-radius: 6px;
  }
  100% { background: transparent; }
}

/* Music rows (section 3) */
.rsvp-music-row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.5rem;
}

.rsvp-music-input {
  flex: 1;
}

/* Secret question (section 4) */
.rsvp-secret-question {
  background: color-mix(in srgb, var(--color-bg), var(--color-title) 8%);
  border-left: 3px solid var(--color-title);
  padding: 1rem 1.25rem;
  border-radius: 0 6px 6px 0;
  margin-bottom: 1.5rem;
}

.rsvp-secret-question .rsvp-section-subtitle {
  margin-bottom: 0;
  font-style: italic;
}

.rsvp-secret-actions {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-top: 1rem;
}

.rsvp-remind-btn {
  display: flex;
  align-items: center;
  gap: 0.25rem;
}

.rsvp-remind-btn__sub {
  font-size: 0.75rem;
  opacity: 0.7;
}

/* Communication (section 5) */
.rsvp-comm-card {
  margin-bottom: 1.5rem;
}

.rsvp-form-group {
  margin-bottom: 1rem;
}

.rsvp-privacy-note {
  font-size: 0.8rem;
  color: color-mix(in srgb, var(--color-bg), var(--color-text) 50%);
  margin-top: 1rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.rsvp-privacy-note .fa-shield-halved {
  color: var(--color-accent-green);
}

/* Secret question photo list */
.secret-photo-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(80px, 1fr));
  gap: 0.5rem;
  margin-top: 0.75rem;
}

.secret-photo-list-item {
  position: relative;
  aspect-ratio: 1;
  border-radius: 6px;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--color-bg), var(--color-text) 15%);
}

.secret-photo-thumb {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.secret-photo-name {
  display: none;
}

.secret-photo-remove {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: none;
  color: transparent;
  cursor: pointer;
  text-decoration: none;
  transition: background 0.15s, color 0.15s;
  font-size: 1.1rem;
}

.secret-photo-remove:hover {
  background: color-mix(in srgb, transparent, black 50%);
  color: white;
}

/* Next button */
.rsvp-next-btn {
  margin-top: 2rem;
}

.rsvp-section--final .rsvp-section-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
}

/* ---- Responsive ---- */
@media (width <= 768px) {
  .rsvp-wizard {
    flex-direction: column-reverse;
  }

  .rsvp-wizard-nav {
    flex-direction: row;
    min-width: unset;
    border-right: none;
    border-top: 1px solid color-mix(in srgb, var(--color-bg), var(--color-text) 10%);
    padding: 0.5rem;
    gap: 0;
    justify-content: space-around;
    overflow-x: auto;
  }

  .rsvp-wizard-dot-label {
    display: none;
  }

  .rsvp-wizard-dot {
    justify-content: center;
  }

  .rsvp-section {
    min-height: calc(100vh - 60px);
    padding: 1.5rem 1rem;
  }
}

/* ============================================
   Evening attending toggle
   ============================================ */

.rsvp-attending-toggle {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin: 1.5rem 0;
}

.rsvp-attending-btn {
  flex: 1;
  min-width: 10rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.85rem 1.5rem;
  border: 2px solid var(--color-text);
  border-radius: 8px;
  background: transparent;
  color: var(--color-text);
  opacity: 0.6;
  transition: all 0.2s ease;
}

.rsvp-attending-btn:hover {
  opacity: 1;
  background: color-mix(in srgb, var(--color-text) 8%, transparent);
}

.rsvp-attending-btn--active {
  opacity: 1;
  border-color: var(--color-accent-green);
  color: var(--color-accent-green);
  background: color-mix(in srgb, var(--color-accent-green) 12%, transparent);
}

.rsvp-attending-btn--no.rsvp-attending-btn--active {
  border-color: var(--color-accent-red);
  color: var(--color-accent-red);
  background: color-mix(in srgb, var(--color-accent-red) 12%, transparent);
}

.rsvp-attending-toggle--required .rsvp-attending-btn {
  animation: shake 0.35s ease;
  border-color: var(--color-accent-red);
}

@keyframes shake {
  0%, 100% { transform: translateX(0); }
  25%       { transform: translateX(-4px); }
  75%       { transform: translateX(4px); }
}

/* ============================================
   Breakfast toggle (full_day: whole group)
   ============================================ */

.rsvp-breakfast-section {
  margin: 1.5rem 0 2rem;
  padding: 1.25rem;
  background: color-mix(in srgb, var(--color-bg), var(--color-text) 4%);
  border-radius: 8px;
}

.rsvp-breakfast-section .rsvp-section-subtitle {
  margin: 0 0 1rem;
}

.rsvp-toggle-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  cursor: pointer;
}

.rsvp-toggle-label {
  font-size: 0.95rem;
  color: var(--color-text);
}

.rsvp-toggle-switch {
  position: relative;
  display: inline-flex;
  align-items: center;
  width: 3rem;
  height: 1.6rem;
  flex-shrink: 0;
  background: color-mix(in srgb, var(--color-bg), var(--color-text) 20%);
  border: none;
  border-radius: 999px;
  cursor: pointer;
  transition: background 0.2s ease;
  padding: 0;
}

.rsvp-toggle-switch--active {
  background: var(--color-accent-green);
}

.rsvp-toggle-knob {
  position: absolute;
  left: 0.2rem;
  width: 1.2rem;
  height: 1.2rem;
  background: white;
  border-radius: 50%;
  transition: transform 0.2s ease;
  pointer-events: none;
}

.rsvp-toggle-switch--active .rsvp-toggle-knob {
  transform: translateX(1.4rem);
}
