.reunion-banner {
  background: linear-gradient(135deg, var(--color-forest-900) 0%, var(--surface-dark) 100%);
  padding: 60px var(--space-2xl);
  text-align: center;
  border-bottom: 3px solid var(--accent-primary);
  flex-shrink: 0;
}

.reunion-banner h1 {
  font-family: var(--font-display);
  font-size: 40px;
  color: var(--text-on-dark);
  margin-bottom: 6px;
  font-weight: 700;
}

.reunion-banner .banner-tagline {
  color: var(--text-accent);
  font-style: italic;
  font-size: 17px;
  margin-bottom: 36px;
}

.big-countdown {
  display: flex;
  justify-content: center;
  gap: 36px;
  margin-bottom: 14px;
}

.big-cd-unit {
  text-align: center;
}

.big-cd-unit .bcd-num {
  display: block;
  font-family: var(--font-display);
  font-size: 60px;
  color: var(--text-accent);
  line-height: 1;
  font-weight: 700;
}

.big-cd-unit .bcd-lbl {
  display: block;
  font-size: 11px;
  color: rgba(246, 237, 216, 0.6);
  text-transform: uppercase;
  letter-spacing: 2px;
  margin-top: 6px;
}

.bcd-sep {
  font-size: 48px;
  color: rgba(200, 169, 110, 0.4);
  align-self: flex-start;
  padding-top: 8px;
}

.reunion-when-text {
  color: rgba(246, 237, 216, 0.6);
  font-style: italic;
  font-size: 14px;
  margin-top: 6px;
}

.detail-cards {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 18px;
  margin-bottom: 28px;
}

.detail-card {
  background: #fff;
  border-radius: 6px;
  padding: 22px 20px;
  border-top: 3px solid var(--accent-primary);
  box-shadow: var(--shadow-sm);
}

.detail-card h3 {
  font-family: var(--font-display);
  font-size: 17px;
  color: var(--surface-mid);
  margin-bottom: 10px;
}

.detail-card p {
  font-size: 13.5px;
  color: #555;
  line-height: 1.65;
}

.register-block {
  background: #fff;
  border-radius: 6px;
  padding: 26px;
  box-shadow: var(--shadow-sm);
  margin-bottom: 28px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  flex-wrap: wrap;
}

.register-block p {
  font-size: 14px;
  color: #555;
  line-height: 1.65;
  max-width: 560px;
}

.schedule-placeholder {
  background: #fff;
  border-radius: 6px;
  padding: 22px 26px;
  box-shadow: var(--shadow-sm);
  font-size: 13.5px;
  color: var(--text-muted);
  font-style: italic;
}

.reunion-prev-link {
  font-size: 14px;
  color: var(--text-secondary);
  margin-top: var(--space-xs);
}

.reunion-prev-link a {
  color: var(--accent-forest);
  font-style: italic;
}

.reunion-prev-link a:hover {
  text-decoration: underline;
}

@media (max-width: 720px) {
  .detail-cards {
    grid-template-columns: 1fr;
  }

  .big-cd-unit .bcd-num {
    font-size: 38px;
  }
}

/* ── Native Registration Form ── */
.reg-form-wrap {
  background: #fff;
  border: 1px solid var(--surface-border);
  border-top: 3px solid var(--accent-primary);
  border-radius: 6px;
  padding: 24px 26px;
  margin: 4px 0 28px;
  max-width: 680px;
}

.reg-form .reg-field {
  margin-bottom: 14px;
}

.reg-form .reg-row {
  display: flex;
  gap: 16px;
}

.reg-form .reg-row .reg-field {
  flex: 1;
}

.reg-form label {
  display: block;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-secondary);
  margin-bottom: 4px;
}

.reg-req { color: #c0392b; }

.reg-form input[type="text"],
.reg-form input[type="email"],
.reg-form input[type="tel"],
.reg-form input[type="number"],
.reg-form select,
.reg-form textarea {
  width: 100%;
  font-family: var(--font-body);
  font-size: 14px;
  padding: 8px 10px;
  border: 1px solid #ccc;
  border-radius: 4px;
  box-sizing: border-box;
}

.reg-form textarea { resize: vertical; }

.reg-checks {
  display: flex;
  flex-direction: column;
  gap: 5px;
}

.reg-checks label,
.reg-field--check label {
  font-weight: 400;
  font-size: 14px;
  display: flex;
  align-items: center;
  gap: 7px;
  margin: 0;
}

.reg-actions {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-top: 18px;
}

.reg-status {
  font-size: 13px;
  color: var(--text-muted);
  font-style: italic;
}

.reg-thankyou {
  text-align: center;
  padding: 20px;
}

.reg-thankyou p {
  font-size: 18px;
  color: var(--accent-forest);
  margin-bottom: 16px;
}

/* ── Admin: Registration management ── */
.reg-admin {
  background: var(--surface-border);
  border: 1px dashed var(--accent-primary);
  border-radius: 6px;
  padding: 18px 22px;
  margin: 8px 0 28px;
}

.reg-admin-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 14px;
  flex-wrap: wrap;
  gap: 10px;
}

.reg-admin-head h3 {
  font-family: var(--font-display);
  font-size: 18px;
  color: var(--surface-mid);
  margin: 0;
}

.btn--sm {
  font-size: 12px;
  padding: 6px 14px;
}

.reg-admin-empty {
  font-style: italic;
  color: var(--text-muted);
  font-size: 14px;
}

.reg-card {
  background: #fff;
  border-radius: 5px;
  box-shadow: var(--shadow-sm);
  padding: 14px 16px;
  margin-bottom: 10px;
}

.reg-card-main {
  display: flex;
  align-items: baseline;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 4px;
}

.reg-card-name {
  font-weight: 700;
  font-size: 16px;
  color: var(--surface-mid);
}

.reg-card-branch {
  font-size: 13px;
  color: var(--accent-forest);
  font-weight: 600;
}

.reg-card-count {
  font-size: 13px;
  color: var(--text-muted);
}

.reg-card-contact {
  font-size: 13px;
  color: var(--text-secondary);
  margin-bottom: 6px;
}

.reg-card-detail {
  font-size: 13px;
  color: var(--text-secondary);
  line-height: 1.5;
}

.reg-card-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 10px;
}

.reg-edit-btn, .reg-del-btn, .reg-save-btn, .reg-cancel-btn {
  font-size: 12px;
  font-weight: 600;
  padding: 5px 14px;
  border: none;
  border-radius: 4px;
  cursor: pointer;
  font-family: var(--font-body);
}

.reg-edit-btn, .reg-save-btn {
  background: var(--surface-dark);
  color: var(--text-on-dark);
}

.reg-del-btn {
  background: rgba(180, 30, 30, 0.8);
  color: #fff;
}

.reg-cancel-btn {
  background: #999;
  color: #fff;
}

.reg-edit-status {
  font-size: 12px;
  color: var(--text-muted);
  font-style: italic;
}

.reg-edit-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 10px;
}

.reg-edit-field {
  display: flex;
  flex-direction: column;
  gap: 3px;
  margin-bottom: 8px;
}

.reg-edit-field span {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.reg-edit-field--full { grid-column: 1 / -1; }

.reg-edit-field input,
.reg-edit-field select,
.reg-edit-field textarea {
  font-family: var(--font-body);
  font-size: 13px;
  padding: 6px 8px;
  border: 1px solid #ccc;
  border-radius: 4px;
  box-sizing: border-box;
}

.reg-edit-check {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: 13px;
  margin-bottom: 8px;
}

@media (max-width: 720px) {
  .reg-form .reg-row { flex-direction: column; gap: 14px; }
  .reg-edit-grid { grid-template-columns: 1fr; }
}

.reg-admin-head-btns {
  display: flex;
  gap: 10px;
  align-items: center;
}

.reg-add-form {
  border: 2px solid var(--accent-forest);
  margin-bottom: 14px;
}

.reg-add-title {
  font-family: var(--font-display);
  font-size: 15px;
  font-weight: 700;
  color: var(--accent-forest);
  margin-bottom: 12px;
}

.reg-preapprove-btn {
  font-size: 12px;
  font-weight: 600;
  padding: 5px 14px;
  border: none;
  border-radius: 4px;
  cursor: pointer;
  font-family: var(--font-body);
  background: var(--accent-forest);
  color: #fff;
}

.reg-preapprove-btn:hover { background: var(--accent-forest-light); }

.reg-card-status {
  font-size: 12px;
  font-style: italic;
  color: var(--text-muted);
}

.reg-status-ok { color: var(--accent-forest); font-style: normal; font-weight: 600; }
.reg-status-warn { color: #b8860b; }

/* Address row proportions */
.reg-row--address .reg-field--city { flex: 2; }
.reg-row--address .reg-field--state { flex: 1; }
.reg-row--address .reg-field--zip { flex: 1; }

.reg-preapprove-btn.reg-preapproved-done,
.reg-preapprove-btn:disabled {
  background: #999;
  color: #fff;
  cursor: default;
}

.reg-preapprove-btn.reg-preapproved-done:hover {
  background: #999;
}

/* ── Combined Date & Time + Location card ── */
.dc-sub {
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px solid var(--surface-border);
}

/* ── Announcement gallery card (large single thumbnail) ── */
.dc-announcement h3 {
  font-family: var(--font-display);
  font-size: 17px;
  color: var(--surface-mid);
  margin-bottom: 10px;
}

.sg-grid--announcement {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
}

.sg-grid--announcement .gallery-thumb img {
  aspect-ratio: auto;
  width: 100%;
  max-height: 280px;
  object-fit: contain;
  background: #f3efe6;
}

.gallery-upload-btn--sm {
  padding: 5px 12px;
  font-size: 12px;
}

.dc-announcement .sg-upload {
  margin-bottom: 8px;
}

.dc-announcement .gallery-empty {
  padding: 18px 12px;
}

.dc-announcement .gallery-empty p {
  font-size: 13px;
}

/* ── Activities & Planning gallery (full-width responsive, reunion-size thumbs) ── */
.ap-gallery {
  margin-bottom: 28px;
}

.ap-gallery .sg-upload {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin: 12px 0 16px;
}

.ap-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: 8px;
}

@media (max-width: 600px) {
  .ap-grid {
    grid-template-columns: repeat(auto-fill, minmax(96px, 1fr));
  }
}

/* ── "See More Details" link in the Date & Time card ── */
.dc-more {
  margin-top: 12px;
  padding-top: 12px;
}

.dc-more-link {
  font-family: var(--font-display);
  font-size: 15px;
  font-weight: 600;
  color: var(--accent-forest);
  text-decoration: none;
}

.dc-more-link:hover {
  text-decoration: underline;
}
