/* ── Reset & base ─────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --deep-twilight:      #03045e;
  --deep-twilight-300:  #020338;
  --french-blue:        #023e8a;
  --bright-teal-blue:   #0077b6;
  --blue-green:         #0096c7;
  --turquoise-surf:     #00b4d8;
  --sky-aqua:           #48cae4;
  --frosted-surf:       #90e0ef;
  --ice-mist:           #ade8f4;
  --light-cyan:         #caf0f8;
  --blue:               var(--bright-teal-blue);
  --blue-dark:          var(--french-blue);
  --teal:               var(--turquoise-surf);
  --cream:              #f4fcfe;
  --peach:              #dff6fb;
  --coral:              var(--french-blue);
  --green:              var(--turquoise-surf);
  --green-dark:         var(--blue-green);
  --red:                var(--deep-twilight);
  --red-dark:           var(--deep-twilight-300);
  --amber:              var(--sky-aqua);
  --amber-dark:         var(--bright-teal-blue);
  --gray-50:            #f4fcfe;
  --gray-100:           #e9f9fc;
  --gray-200:           #d2f3f9;
  --gray-400:           #6d8fad;
  --gray-500:           #466785;
  --gray-700:           #1d4467;
  --gray-900:           var(--deep-twilight);
  --text:               #12324f;
  --surface:            #ffffff;
  --surface-soft:       #fbfeff;
  --surface-tint:       #f7fcff;
  --surface-gradient:   linear-gradient(180deg, #ffffff 0%, #fbfeff 100%);
  --surface-gradient-soft: linear-gradient(180deg, #fbfeff 0%, #effafd 100%);
  --surface-gradient-muted: linear-gradient(180deg, #f7fcff 0%, #e9f9fc 100%);
  --focus-ring:         rgba(0, 119, 182, 0.18);
  --note-bg:            linear-gradient(180deg, #effafd 0%, #dbf4fa 100%);
  --note-border:        var(--sky-aqua);
  --note-text:          var(--french-blue);
  --yes-bg:             rgba(0, 180, 216, 0.14);
  --yes-text:           var(--blue-green);
  --maybe-bg:           rgba(72, 202, 228, 0.18);
  --maybe-text:         var(--bright-teal-blue);
  --no-bg:              rgba(3, 4, 94, 0.08);
  --no-text:            var(--deep-twilight);
  --success-bg:         #e9f9fc;
  --success-border:     #b6eaf4;
  --success-text:       var(--french-blue);
  --danger-bg:          rgba(3, 4, 94, 0.06);
  --danger-border:      rgba(3, 4, 94, 0.16);
  --danger-text:        var(--deep-twilight);
  --radius:     8px;
  --shadow:     0 8px 28px rgba(2,62,138,0.08), 0 2px 10px rgba(3,4,94,0.06);
}

html { font-size: 17px; }

body {
  font-family: Georgia, 'Times New Roman', serif;
  background:
    radial-gradient(circle at top, rgba(72,202,228,0.18) 0%, transparent 32%),
    linear-gradient(180deg, var(--gray-50) 0%, var(--cream) 38%, var(--gray-100) 100%);
  color: var(--text);
  line-height: 1.6;
  min-height: 100vh;
}
body.modal-open {
  overflow: hidden;
}

/* ── Landing page ────────────────────────────────────────── */
.landing-body {
  background: #00AFB9;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem 1.25rem;
}
.landing-shell {
  width: min(1180px, 100%);
  min-height: calc(100vh - 4rem);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
}
.landing-logo {
  width: min(1050px, 94vw);
  max-width: 100%;
  height: auto;
  display: block;
  margin: 0 auto 1.5rem;
  filter: drop-shadow(0 20px 48px rgba(2, 62, 138, 0.18));
}
.landing-copy {
  font-size: clamp(1.05rem, 2vw, 1.3rem);
  color: #fff;
  margin-bottom: 1.25rem;
}
.landing-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.95rem 1.7rem;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--french-blue) 0%, var(--turquoise-surf) 100%);
  color: #fff;
  text-decoration: none;
  font-family: system-ui, sans-serif;
  font-size: 1rem;
  font-weight: 700;
  box-shadow: 0 14px 30px rgba(2, 62, 138, 0.18);
  transition: transform 0.16s ease, box-shadow 0.16s ease;
}
.landing-cta:hover {
  transform: translateY(-2px);
  box-shadow: 0 18px 36px rgba(2, 62, 138, 0.24);
}
.landing-cta:focus-visible {
  outline: 3px solid var(--focus-ring);
  outline-offset: 3px;
}
@media (max-width: 640px) {
  .landing-body {
    padding: 1.5rem 1rem;
  }

  .landing-shell {
    min-height: calc(100vh - 3rem);
  }

  .landing-logo {
    width: min(875px, 96vw);
  }
}

/* ── Logo ────────────────────────────────────────────────── */
.site-logo {
  height: 77px;
  width: auto;
  display: block;
  flex-shrink: 0;
}
.admin-nav-logo {
  height: 32px;
  width: auto;
  display: block;
  flex-shrink: 0;
}

/* ── Header ──────────────────────────────────────────────── */
.site-header {
  background: linear-gradient(135deg, var(--deep-twilight) 0%, var(--french-blue) 38%, var(--bright-teal-blue) 72%, var(--turquoise-surf) 100%);
  color: #fff;
  padding: 1.6rem 2.6rem;
  position: sticky;
  top: 0;
  z-index: 100;
  box-shadow: 0 10px 24px rgba(3,4,94,0.22);
}
.header-inner {
  max-width: 1280px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 1.75rem;
}
.site-title {
  font-size: 2.2rem;
  font-weight: 700;
  letter-spacing: -0.01em;
}
.header-sub {
  font-size: 1.65rem;
  opacity: 0.8;
}

/* ── Cards ───────────────────────────────────────────────── */
.card {
  background: var(--surface-gradient);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 1.5rem;
  border: 1px solid var(--gray-200);
}

/* ── Site footer ─────────────────────────────────────────── */
.site-footer {
  text-align: center;
  padding: 1.5rem;
  color: var(--gray-500);
  font-size: 0.9rem;
}
.site-footer:empty { display: none; }
.site-footer a { color: var(--blue); }

/* ── RSVP two-column layout ──────────────────────────────── */
.rsvp-layout {
  display: grid;
  grid-template-columns: 420px 1fr;
  gap: 1.5rem;
  max-width: 1200px;
  margin: 0 auto;
  padding: 1.5rem;
  align-items: start;
}

.rsvp-left {
  position: sticky;
  top: 132px; /* clears the sticky header */
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}

.rsvp-right {
  /* scrollable side */
}

/* ── Event details ───────────────────────────────────────── */
.event-date-heading {
  font-size: 1.3rem;
  font-weight: 600;
  color: var(--gray-700);
  margin-bottom: 1rem;
  line-height: 1.3;
}
.event-kicker {
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--blue);
  font-weight: 700;
  margin-bottom: 0.5rem;
}
.event-title {
  font-size: 1.9rem;
  font-weight: 700;
  color: var(--gray-900);
  line-height: 1.2;
  margin-bottom: 0.5rem;
}
.event-meta { margin-bottom: 1rem; }
.event-meta-row {
  display: flex;
  gap: 0.75rem;
  padding: 0.4rem 0;
  border-bottom: 1px solid var(--gray-100);
  font-size: 1rem;
}
.event-meta-row:last-child { border-bottom: none; }
.meta-label {
  color: var(--gray-500);
  min-width: 80px;
  flex-shrink: 0;
}
.meta-value { font-weight: 600; }
.meta-value-multiline {
  white-space: pre-line;
  line-height: 1.5;
}

.event-notes {
  background: var(--note-bg);
  border-left: 4px solid var(--note-border);
  border-radius: 0 6px 6px 0;
  padding: 0.75rem 1rem;
  margin-top: 1rem;
}
.notes-label {
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--amber-dark);
  font-weight: 700;
  display: block;
  margin-bottom: 0.25rem;
}
.notes-text {
  font-size: 1rem;
  color: var(--gray-700);
  margin: 0;
  white-space: pre-line;
}

.location-image-wrap { margin-top: 1rem; }
.location-image-caption {
  font-size: 0.85rem;
  color: var(--gray-500);
  margin-bottom: 0.4rem;
}
.location-image {
  width: 100%;
  border-radius: 6px;
  border: 1px solid var(--gray-200);
  display: block;
}
.event-media-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1rem;
  margin-top: 1rem;
}
.event-media-card {
  background: var(--surface-gradient-soft);
  border: 1px solid var(--gray-200);
  border-radius: 6px;
  padding: 0.85rem;
}
.event-media-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  margin-bottom: 0.45rem;
  flex-wrap: wrap;
}
.event-media-card-header .location-image-caption {
  margin-bottom: 0;
}
.event-map-embed {
  width: 100%;
  min-height: 240px;
  border: 1px solid var(--gray-200);
  border-radius: 6px;
  display: block;
  background: var(--surface);
}
.event-map-link {
  color: var(--blue);
  text-decoration: none;
  font-size: 0.85rem;
  font-family: system-ui, sans-serif;
  font-weight: 600;
}
.event-map-link:hover {
  text-decoration: underline;
}

/* ── RSVP Form ───────────────────────────────────────────── */
.form-heading {
  font-size: 1.1rem;
  font-weight: 700;
  margin-bottom: 0.4rem;
}
.greeting {
  font-size: 1rem;
  color: var(--gray-500);
  margin-bottom: 1.25rem;
}

.status-buttons {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  margin-bottom: 1.25rem;
}

.btn-status {
  width: 100%;
  min-height: 52px;
  border-radius: 6px;
  border: 2px solid var(--gray-200);
  background: var(--surface);
  font-size: 1.05rem;
  font-family: inherit;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.12s ease;
  color: var(--text);
  padding: 0.6rem 1rem;
}
.btn-status:hover:not(:disabled) { transform: translateY(-1px); box-shadow: 0 2px 8px rgba(0,0,0,0.1); }
.btn-status:disabled { opacity: 0.45; cursor: not-allowed; }

.btn-yes.active  { background: var(--green);   border-color: var(--green);  color: #fff; }
.btn-no.active   { background: var(--red);     border-color: var(--red);    color: #fff; }
.btn-maybe.active { background: var(--amber);  border-color: var(--amber);  color: #fff; }

.btn-yes:not(.active):hover:not(:disabled)   { border-color: var(--green);  color: var(--green); }
.btn-no:not(.active):hover:not(:disabled)    { border-color: var(--red);    color: var(--red); }
.btn-maybe:not(.active):hover:not(:disabled) { border-color: var(--amber);  color: var(--amber); }

.comment-wrap { margin-bottom: 1rem; }
.comment-label {
  display: block;
  font-size: 0.9rem;
  color: var(--gray-500);
  margin-bottom: 0.35rem;
}
.comment-input {
  width: 100%;
  border: 1px solid var(--gray-200);
  border-radius: 6px;
  padding: 0.6rem 0.75rem;
  font-size: 1rem;
  font-family: inherit;
  resize: vertical;
  min-height: 70px;
  color: var(--text);
}
.comment-input:focus { outline: none; border-color: var(--blue); box-shadow: 0 0 0 3px var(--focus-ring); }
.char-counter {
  font-size: 0.8rem;
  color: var(--gray-400);
  text-align: right;
  margin-top: 0.25rem;
}

.btn-submit {
  width: 100%;
  min-height: 52px;
  background: var(--blue);
  color: #fff;
  border: none;
  border-radius: 6px;
  font-size: 1.1rem;
  font-weight: 700;
  font-family: inherit;
  cursor: pointer;
  transition: background 0.12s ease, transform 0.1s ease;
}
.btn-submit:hover:not(:disabled) { background: var(--blue-dark); }
.btn-submit:active:not(:disabled) { transform: scale(0.98); }
.btn-submit:disabled { background: var(--gray-400); cursor: not-allowed; }

/* Success state */
.btn-submit.submitted {
  background: var(--green);
  font-size: 1.05rem;
  pointer-events: none;
}

.rsvp-feedback {
  margin-top: 0.75rem;
  min-height: 1.4rem;
  font-size: 0.95rem;
  text-align: center;
}
.feedback-success { color: var(--green-dark); font-weight: 600; }
.feedback-error   { color: var(--red-dark); }

.current-rsvp {
  margin-top: 1rem;
  font-size: 0.95rem;
  color: var(--gray-500);
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.current-label { }
.current-status { font-weight: 700; }
.status-yes   { color: var(--green); }
.status-no    { color: var(--red); }
.status-maybe { color: var(--amber); }

.changes-note {
  margin-top: 0.6rem;
  font-size: 0.875rem;
  color: var(--gray-400);
}
.limit-reached { color: var(--red-dark); }

/* ── Roster ──────────────────────────────────────────────── */
.roster-heading {
  font-size: 1.1rem;
  font-weight: 700;
  margin-bottom: 0.75rem;
}
.roster-counts {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
  margin-bottom: 1rem;
}
.count-badge {
  padding: 0.25rem 0.65rem;
  border-radius: 20px;
  font-size: 0.85rem;
  font-weight: 600;
}
.count-yes   { background: var(--yes-bg); color: var(--yes-text); }
.count-no    { background: var(--no-bg); color: var(--no-text); }
.count-maybe { background: var(--maybe-bg); color: var(--maybe-text); }
.count-none  { background: var(--gray-100); color: var(--gray-500); }

.roster-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.roster-item {
  display: grid;
  grid-template-columns: 1fr auto;
  grid-template-rows: auto auto;
  align-items: center;
  gap: 0.1rem 0.75rem;
  padding: 0.6rem 0.5rem;
  border-radius: 6px;
  border-bottom: 1px solid var(--gray-100);
  transition: background 0.1s;
}
.roster-item:last-child { border-bottom: none; }
.roster-item:hover { background: var(--gray-50); }

/* Highlight current user's row */
.roster-mine {
  background: rgba(0,180,216,0.12) !important;
  border-left: 3px solid var(--blue);
  padding-left: 0.75rem;
}
.roster-mine:hover { background: rgba(0,180,216,0.2) !important; }

.roster-name {
  font-weight: 600;
  font-size: 1rem;
  grid-column: 1;
  grid-row: 1;
  display: flex;
  align-items: center;
  gap: 0.4rem;
}
.you-badge {
  background: var(--blue);
  color: #fff;
  font-size: 0.7rem;
  font-weight: 700;
  padding: 0.1rem 0.4rem;
  border-radius: 3px;
  vertical-align: middle;
  font-family: system-ui, sans-serif;
}
.roster-status {
  grid-column: 2;
  grid-row: 1;
  text-align: right;
}
.roster-comment {
  grid-column: 1 / -1;
  grid-row: 2;
  font-size: 0.875rem;
  color: var(--gray-500);
  font-style: italic;
  padding-top: 0.1rem;
}

/* Status pills */
.status-pill {
  display: inline-block;
  padding: 0.2rem 0.55rem;
  border-radius: 4px;
  font-size: 0.85rem;
  font-weight: 700;
  font-family: system-ui, sans-serif;
  white-space: nowrap;
}
.pill-yes   { background: var(--yes-bg); color: var(--yes-text); }
.pill-no    { background: var(--no-bg); color: var(--no-text); }
.pill-maybe { background: var(--maybe-bg); color: var(--maybe-text); }
.pill-none  { background: var(--gray-100); color: var(--gray-400); }

/* ── Admin nav ───────────────────────────────────────────── */
.admin-nav {
  background: linear-gradient(135deg, var(--deep-twilight) 0%, var(--french-blue) 62%, var(--bright-teal-blue) 100%);
  color: #fff;
  padding: 0 1.5rem;
  position: sticky;
  top: 0;
  z-index: 100;
}
.admin-nav-inner {
  max-width: 1100px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 2rem;
  height: 54px;
}
.admin-nav-brand {
  font-size: 1.05rem;
  font-weight: 700;
  color: #fff;
  white-space: nowrap;
}
.admin-nav-links {
  display: flex;
  gap: 0.25rem;
  align-items: center;
}
.nav-link {
  color: var(--light-cyan);
  text-decoration: none;
  padding: 0.4rem 0.75rem;
  border-radius: 4px;
  font-size: 0.95rem;
  font-family: system-ui, sans-serif;
  transition: background 0.1s, color 0.1s;
}
.nav-link:hover { background: rgba(173,232,244,0.14); color: #fff; }
.nav-active { background: rgba(173,232,244,0.2) !important; color: #fff !important; font-weight: 600; }
.nav-logout { margin-left: auto; color: var(--frosted-surf); }
.nav-logout:hover { color: #fff; background: rgba(173,232,244,0.14); }

/* ── Admin layout ────────────────────────────────────────── */
.admin-page { background: transparent; }
.admin-main { padding: 1.5rem; }
.admin-content {
  max-width: 1100px;
  margin: 0 auto;
  position: relative;
}
.dashboard-logo {
  position: absolute;
  right: calc(100% - 3.5rem);
  top: 0;
  width: 450px;
}
@media (max-width: 1560px) {
  .dashboard-logo { display: none; }
}
.admin-card { }
.event-selector-form {
  margin-bottom: 1.25rem;
}
.admin-event-media-grid {
  margin-top: 0;
}

.card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1.25rem;
  flex-wrap: wrap;
  gap: 0.75rem;
}
.card-title {
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--gray-900);
}
.admin-card-header-text {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}
.admin-card-copy {
  margin: 0;
  color: var(--gray-500);
  font-size: 0.95rem;
  font-family: system-ui, sans-serif;
}
.dashboard-empty-state {
  padding: 1rem 1.1rem;
  border: 1px dashed var(--gray-200);
  border-radius: 12px;
  background: var(--surface-gradient-soft);
}
.dashboard-empty-title {
  margin: 0 0 0.35rem;
  color: var(--gray-900);
  font-size: 1.05rem;
  font-weight: 700;
}
.dashboard-grid {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: 1rem;
}
.dashboard-card {
  min-width: 0;
}
.dashboard-card-main {
  grid-column: span 8;
}
.dashboard-card-side {
  grid-column: span 4;
}
.dashboard-card-third {
  grid-column: span 4;
}
.dashboard-card-half {
  grid-column: span 6;
}
.dashboard-current-shell {
  display: flex;
  flex-direction: column;
  gap: 1.1rem;
}
.dashboard-current-summary {
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
}
.dashboard-kicker {
  margin: 0;
  color: var(--blue);
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-family: system-ui, sans-serif;
}
.dashboard-current-title {
  margin: 0;
  color: var(--gray-900);
  font-size: 1.6rem;
  line-height: 1.15;
}
.dashboard-status-row {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
}
.dashboard-detail-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 0.85rem;
}
.dashboard-detail-card {
  background: var(--surface-gradient-soft);
  border: 1px solid var(--gray-200);
  border-radius: 12px;
  padding: 1rem;
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
  min-width: 0;
}
.dashboard-detail-label {
  margin: 0;
  color: var(--gray-500);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  font-family: system-ui, sans-serif;
}
.dashboard-detail-value {
  margin: 0;
  color: var(--gray-900);
  font-size: 1.05rem;
  font-weight: 700;
  line-height: 1.3;
}
.dashboard-detail-meta {
  margin: 0;
  color: var(--gray-500);
  font-size: 0.92rem;
  font-family: system-ui, sans-serif;
}
.dashboard-detail-multiline {
  white-space: pre-line;
}
.dashboard-link-list {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}
.dashboard-note {
  background: var(--note-bg);
  border-left: 4px solid var(--note-border);
  border-radius: 0 8px 8px 0;
  padding: 0.85rem 1rem;
}
.dashboard-action-stack {
  display: grid;
  gap: 0.75rem;
}
.dashboard-action-button {
  width: 100%;
}
.dashboard-counts {
  gap: 0.75rem;
}
.dashboard-summary-note {
  margin-top: 0.95rem;
}
.dashboard-mini-list,
.dashboard-schedule-list,
.dashboard-response-list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.dashboard-mini-item,
.dashboard-schedule-item,
.dashboard-response-item {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.85rem;
  padding: 0.9rem 1rem;
  border: 1px solid var(--gray-200);
  border-radius: 12px;
  background: var(--surface-gradient);
}
.dashboard-mini-item {
  flex-direction: column;
}
.dashboard-mini-title {
  margin: 0;
  color: var(--gray-900);
  font-weight: 700;
  line-height: 1.3;
}
.dashboard-mini-meta {
  margin: 0.2rem 0 0;
  color: var(--gray-500);
  font-size: 0.92rem;
  font-family: system-ui, sans-serif;
  word-break: break-word;
}
.dashboard-schedule-actions,
.dashboard-response-side {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.dashboard-form-card {
  scroll-margin-top: 84px;
}
.admin-anchor-section {
  scroll-margin-top: 70px;
}
.admin-card-note {
  color: var(--gray-500);
  font-family: system-ui, sans-serif;
}

.admin-history-summary-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 0.9rem;
}
.admin-history-summary-box {
  background: var(--surface-gradient-muted);
  border: 1px solid var(--gray-200);
  border-radius: 10px;
  padding: 1rem 1.1rem;
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}
.admin-history-summary-label {
  color: var(--gray-500);
  font-family: system-ui, sans-serif;
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.admin-history-list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.admin-history-item {
  display: grid;
  grid-template-columns: minmax(220px, 280px) 1fr;
  gap: 1rem;
  padding: 1rem;
  border: 1px solid var(--gray-200);
  border-radius: 12px;
  background: var(--surface-gradient);
}
.admin-history-item-past {
  background: linear-gradient(180deg, #ffffff 0%, #f7fcff 100%);
}
.admin-history-date {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
}
.admin-history-date strong {
  font-size: 1.05rem;
  color: var(--gray-900);
  line-height: 1.3;
}
.admin-history-date-label {
  color: var(--gray-500);
  font-family: system-ui, sans-serif;
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.admin-history-pill-row {
  display: flex;
  gap: 0.45rem;
  flex-wrap: wrap;
}
.admin-history-details {
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}
.admin-history-event {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.admin-history-event-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  flex-wrap: wrap;
}
.admin-history-event-title {
  font-size: 1rem;
  line-height: 1.35;
  color: var(--gray-900);
}
.admin-history-meta,
.admin-history-empty {
  color: var(--gray-500);
  font-family: system-ui, sans-serif;
  font-size: 0.95rem;
  margin: 0;
}

/* ── RSVP count boxes (admin) ────────────────────────────── */
.admin-counts {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
}
.admin-count-box {
  flex: 1;
  min-width: 90px;
  border-radius: 8px;
  padding: 1rem;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.25rem;
}
.admin-count-box.count-yes   { background: var(--yes-bg); }
.admin-count-box.count-maybe { background: var(--maybe-bg); }
.admin-count-box.count-no    { background: var(--no-bg); }
.admin-count-box.count-none  { background: var(--gray-100); }
.count-num {
  font-size: 2rem;
  font-weight: 700;
  line-height: 1;
}
.admin-count-box.count-yes   .count-num { color: var(--yes-text); }
.admin-count-box.count-maybe .count-num { color: var(--maybe-text); }
.admin-count-box.count-no    .count-num { color: var(--no-text); }
.admin-count-box.count-none  .count-num { color: var(--gray-500); }
.count-lbl { font-size: 0.85rem; color: var(--gray-500); font-family: system-ui, sans-serif; }

.admin-actions {
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
  align-items: center;
}

/* ── Flash message ───────────────────────────────────────── */
.flash-msg {
  background: var(--success-bg);
  border: 1px solid var(--success-border);
  border-radius: 6px;
  padding: 0.75rem 1rem;
  color: var(--success-text);
  font-size: 1rem;
  margin-bottom: 1rem;
  font-family: system-ui, sans-serif;
  transition: opacity 0.4s ease, transform 0.4s ease;
}
.flash-msg-hiding {
  opacity: 0;
  transform: translateY(-6px);
}

/* ── Admin table ─────────────────────────────────────────── */
.admin-table-wrap { overflow-x: auto; }
.admin-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.95rem;
  font-family: system-ui, sans-serif;
}
.admin-table th {
  text-align: left;
  padding: 0.6rem 0.75rem;
  border-bottom: 2px solid var(--gray-200);
  color: var(--gray-500);
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  white-space: nowrap;
}
.admin-table td {
  padding: 0.65rem 0.75rem;
  border-bottom: 1px solid var(--gray-100);
  vertical-align: middle;
}
.admin-table tbody tr:last-child td { border-bottom: none; }
.admin-table tbody tr:hover td { background: var(--gray-50); }
.row-yes   td { background: rgba(0,180,216,0.12); }
.row-no    td { background: rgba(3,4,94,0.08); }
.row-maybe td { background: rgba(72,202,228,0.18); }
.row-inactive td { opacity: 0.5; }
.comment-cell { color: var(--gray-500); font-style: italic; max-width: 240px; }
.date-cell { color: var(--gray-400); white-space: nowrap; font-size: 0.875rem; }
.actions-cell { white-space: nowrap; }
.admin-email-link {
  color: var(--blue);
  word-break: break-all;
}
.admin-cta-stack {
  display: flex;
  gap: 0.5rem;
  flex-direction: column;
  flex-wrap: wrap;
  align-items: stretch;
}

/* ── Forms (admin) ───────────────────────────────────────── */
.form-group { display: flex; flex-direction: column; }
.form-label {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--gray-700);
  margin-bottom: 0.35rem;
  font-family: system-ui, sans-serif;
}
.form-input {
  border: 1px solid var(--gray-200);
  border-radius: 6px;
  padding: 0.55rem 0.75rem;
  font-size: 1rem;
  font-family: inherit;
  color: var(--text);
  width: 100%;
  background: var(--surface);
}
.form-input:focus {
  outline: none;
  border-color: var(--blue);
  box-shadow: 0 0 0 3px var(--focus-ring);
}
textarea.form-input { resize: vertical; }
input[type="file"].form-input { padding: 0.4rem; }

.form-row {
  display: flex;
  gap: 1rem;
  align-items: flex-start;
}
.form-row .form-group { flex: 1; }

.inline-form .form-row {
  align-items: flex-end;
}
.form-checkbox {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  color: var(--gray-700);
  font-family: system-ui, sans-serif;
  font-size: 0.95rem;
}
.form-checkbox input {
  width: 1rem;
  height: 1rem;
}
.event-upload-preview {
  margin-bottom: 0.5rem;
}
.event-upload-preview-image {
  max-height: 110px;
  border-radius: 4px;
  border: 1px solid var(--gray-200);
}
.event-upload-preview-text {
  font-size: 0.85rem;
  color: var(--gray-500);
  display: block;
  margin-top: 0.25rem;
}
.location-preview-card {
  margin-top: 0.9rem;
  border: 1px solid var(--gray-200);
  border-radius: 10px;
  background: var(--surface-gradient-soft);
  padding: 1rem;
  display: grid;
  grid-template-columns: minmax(0, 240px) 1fr;
  gap: 1rem;
  align-items: start;
}
.location-preview-copy {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
}
.location-preview-label {
  color: var(--gray-500);
  font-family: system-ui, sans-serif;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}
.location-preview-name {
  color: var(--gray-900);
  font-size: 1.05rem;
  line-height: 1.3;
}
.location-preview-address {
  white-space: pre-line;
  color: var(--gray-700);
  margin: 0;
}
.location-preview-media {
  display: grid;
  grid-template-columns: minmax(0, 180px) 1fr;
  gap: 0.85rem;
  align-items: start;
}
.location-preview-photo-wrap {
  min-width: 0;
}
.location-preview-photo {
  width: 100%;
  display: block;
  border-radius: 6px;
  border: 1px solid var(--gray-200);
}
.location-preview-map {
  min-height: 220px;
}
.location-legacy-note {
  padding: 0.85rem 0.95rem;
  border-radius: 8px;
  background: var(--note-bg);
  border: 1px solid var(--note-border);
  color: var(--note-text);
  font-family: system-ui, sans-serif;
  font-size: 0.92rem;
}
.locations-list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.locations-empty-state {
  padding: 1rem 1.1rem;
  border: 1px dashed var(--gray-200);
  border-radius: 12px;
  background: var(--surface-gradient-soft);
}
.location-create-card {
  scroll-margin-top: 84px;
}
.location-card {
  border: 1px solid var(--gray-200);
  border-radius: 12px;
  background: var(--surface-gradient);
  padding: 1rem;
}
.location-card-header {
  margin-bottom: 1rem;
}
.location-card-title {
  font-size: 1.05rem;
  color: var(--gray-900);
  line-height: 1.3;
}
.location-card-meta {
  margin: 0.2rem 0 0;
  color: var(--gray-500);
  font-family: system-ui, sans-serif;
  font-size: 0.92rem;
}
.location-card-body {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 420px);
  gap: 1.25rem;
  align-items: start;
}
.location-card-preview {
  min-width: 0;
}
.location-card-form {
  min-width: 0;
}
.location-delete-note {
  margin-top: 0.75rem;
  color: var(--gray-500);
  font-size: 0.9rem;
  font-family: system-ui, sans-serif;
}

/* ── Buttons ─────────────────────────────────────────────── */
.btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0.6rem 1.25rem;
  background: var(--blue);
  color: #fff;
  border: none;
  border-radius: 6px;
  font-size: 1rem;
  font-weight: 600;
  font-family: system-ui, sans-serif;
  cursor: pointer;
  text-decoration: none;
  transition: background 0.12s;
  white-space: nowrap;
}
.btn-primary:hover { background: var(--blue-dark); }

.btn-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0.6rem 1.25rem;
  background: var(--surface);
  color: var(--gray-700);
  border: 1px solid var(--gray-200);
  border-radius: 6px;
  font-size: 1rem;
  font-weight: 600;
  font-family: system-ui, sans-serif;
  cursor: pointer;
  text-decoration: none;
  transition: background 0.12s, border-color 0.12s;
  white-space: nowrap;
}
.btn-secondary:hover { background: var(--gray-50); border-color: var(--gray-400); }

.btn-danger {
  background: rgba(3,4,94,0.02);
  color: var(--danger-text);
  border: 1px solid var(--danger-border);
}
.btn-danger:hover { background: var(--danger-bg); border-color: var(--red); }

.btn-sm {
  min-height: 36px;
  padding: 0.3rem 0.75rem;
  font-size: 0.875rem;
}

.btn-copy {
  background: var(--gray-100);
  color: var(--gray-700);
  border: 1px solid var(--gray-200);
  cursor: pointer;
  border-radius: 4px;
  font-family: system-ui, sans-serif;
  font-size: 0.8rem;
  margin-left: 0.35rem;
}
.btn-copy:hover { background: var(--gray-200); }
.btn-copy.copied { background: var(--success-bg); color: var(--success-text); border-color: var(--success-border); }

.rsvp-link-preview {
  font-size: 0.8rem;
  color: var(--blue);
  word-break: break-all;
  max-width: 220px;
  display: inline-block;
}

/* ── Collapsible forms ───────────────────────────────────── */
.collapsible-form {
  background: var(--gray-50);
  border-radius: 6px;
  padding: 1.25rem;
  margin-top: 0.5rem;
}
.scheduled-create-form {
  margin-top: 0.85rem;
}
.scheduled-create-card {
  background: var(--gray-50);
  border: 1px solid var(--gray-200);
  border-radius: 10px;
  padding: 1rem;
}
.scheduled-create-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 0.85rem;
}
.scheduled-create-note {
  margin-top: 0.75rem;
  color: var(--gray-500);
  font-size: 0.9rem;
  font-family: system-ui, sans-serif;
}
.scheduled-create-modal-box {
  max-width: 960px;
  padding: 2rem;
}
.scheduled-create-modal-header {
  margin-bottom: 1rem;
}
.scheduled-create-card-modal {
  background: transparent;
  border: none;
  border-radius: 0;
  padding: 0;
}

/* ── Modal ───────────────────────────────────────────────── */
.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(3,4,94,0.45);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 200;
  padding: 1rem;
}
.modal-box {
  background: var(--surface-gradient);
  border-radius: var(--radius);
  padding: 1.75rem;
  max-width: 440px;
  width: 100%;
  box-shadow: 0 8px 40px rgba(0,0,0,0.2);
}

/* ── Stats attendance bar ────────────────────────────────── */
.attendance-bar-wrap {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  min-width: 120px;
}
.attendance-bar {
  height: 10px;
  background: var(--green);
  border-radius: 5px;
  min-width: 2px;
  flex-shrink: 0;
}
.attendance-pct {
  font-weight: 600;
  font-size: 0.9rem;
  white-space: nowrap;
  color: var(--gray-700);
}

/* ── Public event page ───────────────────────────────────── */
.event-page-main {
  max-width: 840px;
  margin: 0 auto;
  padding: 1.5rem;
}
.public-page-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
  flex-wrap: wrap;
}
.public-summary-copy {
  color: var(--gray-500);
  margin: 0;
}
.public-roster-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 1rem;
}
.public-roster-privacy {
  margin-top: 1rem;
  padding: 1rem 1.1rem;
  border-radius: 14px;
  background: var(--surface-gradient-soft);
  border: 1px solid var(--gray-200);
}
.public-roster-section {
  border: 1px solid var(--gray-200);
  border-radius: 6px;
  padding: 1rem;
  background: var(--gray-50);
}
.public-roster-heading {
  font-size: 1rem;
  margin-bottom: 0.75rem;
}
.public-roster-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.public-roster-item {
  padding: 0.35rem 0;
  border-bottom: 1px solid rgba(148, 163, 184, 0.18);
  font-weight: 600;
}
.public-roster-item:last-child {
  border-bottom: none;
  padding-bottom: 0;
}
.public-roster-empty {
  color: var(--gray-500);
  margin: 0;
}

/* ── Responsive ──────────────────────────────────────────── */
@media (max-width: 900px) {
  .rsvp-layout {
    grid-template-columns: 1fr;
    padding: 1rem;
  }
  .rsvp-left {
    position: static;
  }
  .dashboard-grid {
    grid-template-columns: 1fr;
  }
  .dashboard-card-main,
  .dashboard-card-side,
  .dashboard-card-third,
  .dashboard-card-half {
    grid-column: auto;
  }
}

@media (max-width: 640px) {
  html { font-size: 16px; }
  .site-header { padding: 1.2rem 1rem; }
  .header-inner {
    gap: 0.85rem;
    flex-wrap: wrap;
  }
  .site-title { font-size: 1.8rem; }
  .header-sub { font-size: 1.1rem; }
  .event-title { font-size: 1.55rem; }
  .admin-nav-inner { gap: 1rem; }
  .admin-nav-brand { font-size: 0.9rem; }
  .nav-link { padding: 0.35rem 0.5rem; font-size: 0.875rem; }
  .form-row { flex-direction: column; }
  .admin-counts { gap: 0.5rem; }
  .admin-count-box { min-width: 70px; }
  .admin-history-item { grid-template-columns: 1fr; }
  .count-num { font-size: 1.5rem; }
  .event-page-main { padding: 1rem; }
  .dashboard-current-title { font-size: 1.35rem; }
  .dashboard-detail-grid,
  .dashboard-schedule-item,
  .dashboard-response-item {
    grid-template-columns: 1fr;
  }
  .dashboard-schedule-item,
  .dashboard-response-item {
    flex-direction: column;
  }
  .dashboard-schedule-actions,
  .dashboard-response-side {
    justify-content: flex-start;
  }
  .location-preview-card,
  .location-preview-media,
  .location-card-body {
    grid-template-columns: 1fr;
  }
}
