/* ═══════════════════════════════════════════════════════════════════════════
   QuickVites — Global Styles
   Emerald default theme. Per-event theme overrides --primary / --accent
   via an inline <style> block in the page <head>.
   ═══════════════════════════════════════════════════════════════════════════ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

/* ── Design Tokens ────────────────────────────────────────────────────────── */
:root {
  /* Status colours — fixed across all themes */
  --going:       #16a34a;
  --going-bg:    #dcfce7;
  --maybe:       #d97706;
  --maybe-bg:    #fef3c7;
  --declining:   #dc2626;
  --declining-bg:#fee2e2;

  /* Primary brand — emerald. Overridden per-event. */
  --primary:      #047857;
  --primary-soft: #22c55e;
  --primary-bg:   #ecfdf5;

  /* Accent — a warm slate. Overridden per-event. */
  --accent:       #475569;

  /* Surfaces */
  --bg:     #fafaf9;
  --card:   #ffffff;
  --text:   #1c1917;
  --muted:  #6b7280;
  --border: #e2e8f0;

  /* Shape */
  --radius:    16px;
  --radius-sm: 10px;

  /* Shadows — neutral, no colour tint */
  --shadow:    0 1px 3px rgba(0,0,0,0.06), 0 4px 16px rgba(0,0,0,0.05);
  --shadow-lg: 0 4px 6px rgba(0,0,0,0.04), 0 12px 32px rgba(0,0,0,0.08);

  /* Spacing scale — 4 8 12 16 24 32 48 */
}

/* ── Base ─────────────────────────────────────────────────────────────────── */
body {
  font-family: 'Nunito', ui-rounded, -apple-system, BlinkMacSystemFont,
    'SF Pro Rounded', 'Segoe UI', system-ui, sans-serif;
  background: var(--bg);
  color: var(--text);
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
  line-height: 1.5;
}

a { color: var(--primary); }

/* ── Buttons ─────────────────────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 11px 20px;
  border-radius: 999px;
  font-size: 0.95rem;
  font-weight: 700;
  cursor: pointer;
  border: none;
  text-decoration: none;
  transition: transform 0.1s ease, box-shadow 0.15s ease, background 0.15s ease;
  text-align: center;
  line-height: 1.2;
  font-family: inherit;
}
.btn:hover  { transform: translateY(-1px); box-shadow: 0 4px 12px rgba(0,0,0,0.12); }
.btn:active { transform: translateY(0) scale(0.98); }
.btn:focus-visible {
  outline: 3px solid var(--primary);
  outline-offset: 2px;
}

/* Status buttons — punchy, solid, no gradient */
.btn-going    { background: var(--going);    color: #fff; box-shadow: 0 2px 6px rgba(21,128,61,0.25); }
.btn-maybe    { background: var(--maybe);    color: #fff; box-shadow: 0 2px 6px rgba(180,83,9,0.25); }
.btn-declining{ background: var(--declining);color: #fff; box-shadow: 0 2px 6px rgba(185,28,28,0.25); }

/* Submit CTA — the one gradient as a delight moment */
.btn-submit {
  background: linear-gradient(135deg, var(--primary) 0%, var(--accent) 100%);
  color: #fff;
  width: 100%;
  font-size: 1.05rem;
  padding: 14px;
  margin-top: 8px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}
.btn-submit:hover { box-shadow: 0 6px 20px rgba(0,0,0,0.2); }

/* Directions button */
.btn-directions {
  background: #1d4ed8;
  color: #fff;
  box-shadow: 0 2px 6px rgba(29,78,216,0.25);
}

/* Outline / secondary */
.btn-outline {
  background: var(--card);
  color: var(--primary);
  border: 1.5px solid var(--border);
  box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}
.btn-outline:hover { background: var(--primary-bg); border-color: var(--primary-soft); }

/* Small add-guest button */
.btn-add {
  background: var(--primary-bg);
  color: var(--primary);
  padding: 7px 13px;
  font-size: 0.85rem;
  border: 1.5px solid transparent;
  box-shadow: none;
}
.btn-add:hover { background: color-mix(in srgb, var(--primary) 10%, white); }

/* Danger */
.btn-danger { background: var(--declining); color: #fff; }

/* Selected state — inner glow, no outer ring distracting surrounding UI */
.btn.selected {
  box-shadow: inset 0 2px 6px rgba(0,0,0,0.20), 0 0 0 3px rgba(255,255,255,0.8), 0 0 0 5px var(--primary);
  transform: translateY(-1px);
}
.btn-going.selected    { box-shadow: inset 0 2px 6px rgba(0,0,0,0.20), 0 0 0 3px rgba(255,255,255,0.8), 0 0 0 5px var(--going); }
.btn-maybe.selected    { box-shadow: inset 0 2px 6px rgba(0,0,0,0.20), 0 0 0 3px rgba(255,255,255,0.8), 0 0 0 5px var(--maybe); }
.btn-declining.selected{ box-shadow: inset 0 2px 6px rgba(0,0,0,0.20), 0 0 0 3px rgba(255,255,255,0.8), 0 0 0 5px var(--declining); }

/* ── Form fields ──────────────────────────────────────────────────────────── */
.field { margin-bottom: 16px; }

.field label {
  display: block;
  font-weight: 600;
  margin-bottom: 6px;
  font-size: 0.9rem;
  color: var(--text);
}
.field-hint {
  font-weight: 400;
  color: var(--muted);
  font-size: 0.82em;
}

.field input[type="text"],
.field input[type="tel"],
.field input[type="email"],
.field input[type="url"],
.field input[type="password"],
.field input[type="datetime-local"],
.field input[type="file"],
.field select {
  width: 100%;
  padding: 11px 14px;
  border: 1.5px solid var(--border);
  border-radius: var(--radius-sm);
  font-size: 0.95rem;
  font-family: inherit;
  transition: border-color 0.15s, box-shadow 0.15s;
  background: #fff;
  color: var(--text);
}
.field input:hover, .field select:hover { border-color: #94a3b8; }
.field input:focus, .field select:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--primary) 18%, transparent);
}

.field input[type="color"] {
  padding: 4px 6px;
  height: 40px;
  cursor: pointer;
  border-radius: var(--radius-sm);
  border: 1.5px solid var(--border);
  background: #fff;
}

/* Textarea (inline style in templates but these classes help) */
textarea {
  font-family: inherit;
  font-size: 0.95rem;
  color: var(--text);
}

/* Form hint text */
.hint { font-size: 0.82rem; color: var(--muted); display: block; margin-top: 4px; }

/* Success/Error messages */
.error-msg {
  background: #fef2f2;
  color: #991b1b;
  border: 1px solid #fca5a5;
  border-radius: var(--radius-sm);
  padding: 12px 16px;
  margin: 16px 0;
  font-weight: 600;
  font-size: 0.95rem;
}
.success-msg {
  background: #f0fdf4;
  color: #166534;
  border: 1px solid #86efac;
  border-radius: var(--radius-sm);
  padding: 12px 16px;
  margin: 16px 0;
  font-weight: 600;
  font-size: 0.95rem;
}

/* ── Guest add/remove rows ────────────────────────────────────────────────── */
.guest-section {
  background: #f8fafc;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 14px 16px;
  margin-bottom: 14px;
}
.guest-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-weight: 600;
  font-size: 0.9rem;
  margin-bottom: 10px;
}
.guest-hint {
  margin: -4px 0 10px;
  font-size: 0.82rem;
  color: var(--muted);
  line-height: 1.4;
}
.guest-list { display: flex; flex-direction: column; gap: 8px; }
.guest-input-row {
  display: flex;
  gap: 8px;
  align-items: center;
}
.guest-input-row input {
  flex: 1;
  padding: 9px 12px;
  border: 1.5px solid var(--border);
  border-radius: 8px;
  font-size: 0.95rem;
  font-family: inherit;
  background: #fff;
}
.guest-input-row input.kid-age-input {
  flex: 0 0 70px;
  width: 70px;
  text-align: center;
  -moz-appearance: textfield;
}
.guest-input-row input.kid-age-input::-webkit-outer-spin-button,
.guest-input-row input.kid-age-input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}
.guest-input-row input:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--primary) 15%, transparent);
}
.guest-input-row button {
  background: none;
  border: none;
  color: var(--muted);
  font-size: 1rem;
  cursor: pointer;
  padding: 4px 6px;
  border-radius: 4px;
  line-height: 1;
}
.guest-input-row button:hover { color: var(--declining); }

/* Admin edit RSVP guest rows */
.guest-row {
  display: flex;
  gap: 8px;
  margin-bottom: 8px;
  align-items: center;
}
.guest-row input { flex: 1; }
.btn-remove-guest {
  background: none;
  border: none;
  color: #9ca3af;
  font-size: 1rem;
  cursor: pointer;
  padding: 4px 6px;
  border-radius: 4px;
  line-height: 1;
}
.btn-remove-guest:hover { color: var(--declining); background: #fef2f2; }
.btn-add-guest {
  background: none;
  border: 1.5px dashed #d1d5db;
  border-radius: 8px;
  padding: 6px 14px;
  color: var(--muted);
  font-size: 0.9rem;
  cursor: pointer;
  margin-top: 4px;
  width: 100%;
  font-family: inherit;
}
.btn-add-guest:hover { border-color: var(--primary); color: var(--primary); }

/* ── Hero image ───────────────────────────────────────────────────────────── */
.hero {
  width: 100%;
  overflow: hidden;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  background: #f1f5f9;
}
.hero img {
  width: 100%;
  max-width: 600px;
  display: block;
  object-fit: contain;
}

/* ═══════════════════════════════════════════════════════════════════════════
   EVENT PAGE (public guest-facing)
   ═══════════════════════════════════════════════════════════════════════════ */
.event-page { background: var(--bg); }

.event-shell {
  max-width: 620px;
  margin: 0 auto;
  padding: 24px 16px 64px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

/* Hero within event shell */
.event-shell .hero {
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  background: #fff;
  max-height: none;
  padding: 0;
  border: 1px solid var(--border);
}
.event-shell .hero img {
  width: 100%;
  max-width: 100%;
  height: auto;
  object-fit: contain;
  display: block;
}

/* Event info card */
.event-card-main {
  background: var(--card);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  border: 1px solid var(--border);
  padding: 32px 28px;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.event-card-main::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--primary) 0%, var(--accent) 100%);
}

/* Event title — solid, weighted, no gradient text-fill */
.event-title {
  font-size: clamp(1.7rem, 5vw, 2.3rem);
  font-weight: 900;
  color: var(--primary);
  margin-bottom: 20px;
  line-height: 1.1;
  letter-spacing: -0.02em;
}

.event-date, .event-address {
  font-size: 1rem;
  color: var(--text);
  margin: 8px 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;
  font-weight: 600;
}
.event-address { color: var(--muted); font-weight: 500; }

.event-date .ico, .event-address .ico {
  font-size: 1.1rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px; height: 30px;
  border-radius: 50%;
  background: var(--primary-bg);
  flex-shrink: 0;
}

.event-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 24px;
  padding-top: 20px;
  border-top: 1px solid var(--border);
}
.event-actions .btn { padding: 10px 18px; font-size: 0.9rem; }

/* RSVP section card */
.rsvp-section {
  background: var(--card);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  border: 1px solid var(--border);
  padding: 28px 24px;
  margin: 0;
  max-width: none;
}
.rsvp-section h2 {
  font-size: 1.3rem;
  font-weight: 800;
  letter-spacing: -0.01em;
  margin-bottom: 20px;
  text-align: center;
  color: var(--text);
}

/* Status buttons row */
.status-buttons {
  display: flex;
  gap: 10px;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: 0;
}
.status-buttons .btn {
  flex: 1;
  min-width: 110px;
  padding: 12px 14px;
  font-size: 0.95rem;
  border-radius: 14px;       /* rounded rectangle, not full pill */
  font-weight: 700;
  letter-spacing: -0.005em;
}
.status-buttons .btn:hover {
  transform: translateY(-1px);
  filter: brightness(1.05);
}

/* SMS-consent disclosure shown directly under the phone field.
   Required by Twilio A2P 10DLC: opt-in checkbox + all four disclosures
   (program, frequency, msg & data rates, STOP/HELP) at point of phone
   number collection. Checkbox must be unchecked by default. */
.sms-consent {
  margin-top: 10px;
  padding: 10px 12px;
  background: #f8fafc;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
}
.sms-consent-label {
  display: flex;
  gap: 9px;
  align-items: flex-start;
  cursor: pointer;
  font-weight: 400;
}
.sms-consent-label input[type="checkbox"] {
  margin-top: 3px;
  flex-shrink: 0;
  cursor: pointer;
}
.sms-consent-label span {
  font-size: 0.82rem;
  line-height: 1.5;
  color: var(--muted);
}
.sms-consent-label strong { color: var(--text); }
.sms-consent-label a {
  color: var(--text);
  text-decoration: underline;
  text-decoration-color: var(--muted);
}

/* "Already RSVP'd? Update yours →" — quiet text link, ignores per-event theme */
.update-rsvp-link {
  font-size: 0.88rem;
  color: var(--muted);
  text-decoration: none;
  font-weight: 500;
  transition: color .15s;
}
.update-rsvp-link span {
  font-weight: 700;
  color: var(--text);
  border-bottom: 1px solid var(--border);
  padding-bottom: 1px;
  transition: color .15s, border-color .15s;
}
.update-rsvp-link:hover span {
  color: var(--primary);
  border-bottom-color: var(--primary);
}

/* RSVP form */
.rsvp-form {
  background: var(--card);
  border-radius: var(--radius-sm);
  padding: 20px 0 0;
  margin-top: 16px;
}
.rsvp-form.hidden { display: none; }

.form-status-label {
  font-size: 1rem;
  font-weight: 700;
  color: var(--primary);
  margin-bottom: 16px;
  text-align: center;
  background: var(--primary-bg);
  border-radius: var(--radius-sm);
  padding: 8px 12px;
}

/* Inline field (textarea is sometimes inline-styled — these are fallbacks) */
.field textarea {
  width: 100%;
  padding: 11px 14px;
  border: 1.5px solid var(--border);
  border-radius: var(--radius-sm);
  font-size: 0.95rem;
  font-family: inherit;
  background: #fff;
  resize: vertical;
}
.field textarea:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--primary) 15%, transparent);
}

/* Questions section */
.questions-section {
  background: var(--card);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  border: 1px solid var(--border);
  padding: 24px 24px;
  text-align: center;
}
.questions-section h3 {
  font-size: 1.05rem;
  font-weight: 700;
  margin-bottom: 14px;
  letter-spacing: -0.01em;
  color: var(--muted);
  text-transform: uppercase;
  font-size: 0.8rem;
  letter-spacing: 0.07em;
}
.questions-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: center;
}
.questions-actions .btn { flex: 1 1 140px; }

/* ═══════════════════════════════════════════════════════════════════════════
   THANKS PAGE
   ═══════════════════════════════════════════════════════════════════════════ */
.thanks-page {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 40px 20px;
  min-height: 100vh;
}
.thanks-card {
  background: var(--card);
  border-radius: var(--radius);
  box-shadow: var(--shadow-lg);
  border: 1px solid var(--border);
  padding: 48px 32px 40px;
  max-width: 440px;
  width: 100%;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.thanks-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--primary) 0%, var(--accent) 100%);
}
.thanks-emoji {
  font-size: 4rem;
  margin-bottom: 16px;
  animation: pop 0.45s cubic-bezier(0.34, 1.56, 0.64, 1);
  display: block;
}
@keyframes pop {
  0%   { transform: scale(0.4); opacity: 0; }
  100% { transform: scale(1);   opacity: 1; }
}
.thanks-card h1 {
  font-size: 2rem;
  font-weight: 900;
  color: var(--primary);
  margin-bottom: 12px;
  letter-spacing: -0.02em;
}
.thanks-card p { font-size: 1rem; margin: 8px 0; color: var(--text); }
.thanks-date { color: var(--muted); }
.thanks-footer { margin-top: 16px; font-size: 1.15rem; }
.thanks-address { color: var(--muted); font-size: 0.9rem; margin-top: 4px; }

.thanks-actions {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin: 24px 0 16px;
}
.thanks-actions .btn { width: 100%; }
.thanks-footer-note {
  font-size: 0.82rem;
  color: var(--muted);
  margin-top: 4px;
}

/* ── Closed-RSVPs banner ──────────────────────────────────────────────────── */
.rsvp-closed {
  padding: 24px;
  background: var(--primary-bg);
  border-radius: var(--radius-sm);
  text-align: center;
}
.rsvp-closed h2 { margin: 0 0 8px; color: var(--text); }
.rsvp-closed p  { margin: 0; color: var(--muted); }

/* ── Bring-a-dish duplicate warning ──────────────────────────────────────── */
.bring-warning {
  display: none;
  margin-top: 8px;
  padding: 10px 12px;
  background: var(--maybe-bg);
  border-left: 3px solid var(--maybe);
  border-radius: var(--radius-sm);
  font-size: 0.88rem;
  color: #78350f;
}

/* ── Who's coming list (details/summary) ─────────────────────────────────── */
.whos-coming-list {
  list-style: none;
  padding: 0;
  margin: 12px 0 0;
}
.whos-coming-item {
  padding: 10px 12px;
  border-bottom: 1px solid var(--border);
}
.whos-coming-item:last-child { border-bottom: none; }
.whos-coming-extras { color: var(--muted); font-size: 0.9em; }
.whos-coming-dish   { color: var(--text);  font-size: 0.9em; margin-top: 4px; }

/* ── Edit-link box (thanks page) ─────────────────────────────────────────── */
.edit-link-box {
  margin-top: 24px;
  padding: 16px;
  background: var(--primary-bg);
  border: 1px solid color-mix(in srgb, var(--primary) 20%, var(--border));
  border-radius: var(--radius-sm);
}
.edit-link-box p { margin: 0; }
.edit-link-box .edit-link-label {
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 8px;
}
.edit-link-row {
  display: flex;
  gap: 8px;
  align-items: center;
}
.edit-link-row input {
  flex: 1;
  padding: 8px 10px;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  font-size: 0.78rem;
  font-family: 'SF Mono', 'Fira Code', monospace;
  background: var(--card);
  color: var(--text);
}
.edit-link-row input:focus { outline: none; border-color: var(--primary); }
.btn-copy-link {
  padding: 8px 14px;
  background: var(--primary);
  color: #fff;
  border: none;
  border-radius: var(--radius-sm);
  font-size: 0.85rem;
  font-weight: 700;
  cursor: pointer;
  font-family: inherit;
  white-space: nowrap;
  transition: background 0.15s;
}
.btn-copy-link:hover { background: var(--primary-soft); }
.edit-link-note {
  margin-top: 8px;
  font-size: 0.78rem;
  color: var(--muted);
}

/* ── Saved confirmation (edit page) ──────────────────────────────────────── */
.save-confirmed {
  background: var(--going-bg);
  border: 1px solid var(--going);
  color: var(--going);
  padding: 12px 16px;
  border-radius: var(--radius-sm);
  margin-bottom: 16px;
  font-weight: 600;
  font-size: 0.95rem;
}

/* ── Lookup page sub-text ─────────────────────────────────────────────────── */
.lookup-subtext {
  font-size: 0.95rem;
  color: var(--muted);
  line-height: 1.5;
  text-align: center;
  margin: 0;
}
.lookup-help-text {
  margin-top: 24px;
  font-size: 0.82rem;
  color: var(--muted);
  line-height: 1.5;
}

/* ═══════════════════════════════════════════════════════════════════════════
   LOOKUP PAGE
   ═══════════════════════════════════════════════════════════════════════════ */
/* Reuses event-shell, event-card-main, rsvp-section, rsvp-form from above */

/* ═══════════════════════════════════════════════════════════════════════════
   FLYER PAGE (print-friendly)
   ═══════════════════════════════════════════════════════════════════════════ */
.flyer-page { background: #f1f5f9; padding: 0; margin: 0; }
.flyer-toolbar {
  display: flex;
  gap: 10px;
  justify-content: center;
  padding: 14px 16px;
  background: #fff;
  border-bottom: 1px solid var(--border);
}
.flyer-sheet {
  width: 8.5in;
  min-height: 11in;
  margin: 20px auto;
  background: #fff;
  box-shadow: var(--shadow);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.25in;
  overflow: hidden;
}
.flyer-img {
  width: 100%;
  height: 100%;
  max-width: 100%;
  max-height: 10.5in;
  object-fit: contain;
}
.flyer-fallback { text-align: center; padding: 40px; }
.flyer-fallback h1 { font-size: 3rem; color: var(--primary); margin-bottom: 20px; }
.flyer-fallback p  { font-size: 1.4rem; margin: 10px 0; }

@media print {
  .no-print { display: none !important; }
  body.flyer-page { background: #fff; }
  .flyer-sheet { width: 100%; min-height: auto; margin: 0; box-shadow: none; padding: 0; }
  .flyer-img { max-height: 10.5in; }
}
@media (max-width: 9in) {
  .flyer-sheet { width: 100%; min-height: auto; box-shadow: none; margin: 0; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   ADMIN PAGES
   ═══════════════════════════════════════════════════════════════════════════ */
.admin-page { background: #f8fafc; }

/* Admin top navigation bar */
.admin-topbar {
  background: #1e293b;
  color: #fff;
  padding: 0 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 52px;
  gap: 16px;
}
.admin-topbar-brand {
  font-weight: 700;
  font-size: 0.95rem;
  color: #f8fafc;
  text-decoration: none;
  letter-spacing: -0.01em;
  white-space: nowrap;
}
.admin-topbar-nav {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.admin-topbar-nav a {
  color: #94a3b8;
  text-decoration: none;
  font-size: 0.88rem;
  font-weight: 600;
  padding: 5px 10px;
  border-radius: 6px;
  transition: background 0.1s, color 0.1s;
}
.admin-topbar-nav a:hover { background: rgba(255,255,255,0.08); color: #f1f5f9; }
.admin-topbar-user {
  color: #64748b;
  font-size: 0.82rem;
  white-space: nowrap;
}
.admin-topbar-logout {
  background: none;
  border: 1px solid #334155;
  color: #94a3b8;
  font-size: 0.82rem;
  font-weight: 600;
  cursor: pointer;
  padding: 5px 10px;
  border-radius: 6px;
  font-family: inherit;
  transition: background 0.1s, color 0.1s;
}
.admin-topbar-logout:hover { background: rgba(255,255,255,0.08); color: #f1f5f9; border-color: #475569; }

/* Section header (event detail, create/edit) */
.admin-header {
  background: #fff;
  border-bottom: 1px solid var(--border);
  padding: 20px 24px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
}
.admin-header h1 { font-size: 1.3rem; color: var(--text); font-weight: 800; }
.admin-header p   { color: var(--muted); font-size: 0.9rem; margin-top: 2px; }
.admin-header-actions { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }

.back-link {
  color: var(--muted);
  text-decoration: none;
  font-size: 0.82rem;
  display: block;
  margin-bottom: 4px;
  font-weight: 600;
}
.back-link:hover { color: var(--text); }

.admin-main { max-width: 1400px; margin: 0 auto; padding: 24px 20px 60px; }

/* Admin login card */
.admin-login-card {
  max-width: 360px;
  margin: 80px auto 0;
  background: var(--card);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  border: 1px solid var(--border);
  padding: 36px 28px;
  text-align: center;
}
.admin-login-card h1 { font-size: 1.5rem; margin-bottom: 8px; color: var(--text); }
.admin-login-card .subtitle { color: var(--muted); font-size: 0.9rem; margin-bottom: 28px; }

/* Dashboard event cards */
.event-cards { display: flex; flex-direction: column; gap: 16px; }
.event-card {
  background: var(--card);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  border: 1px solid var(--border);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: box-shadow 0.15s;
}
.event-card:hover { box-shadow: var(--shadow-lg); }

.event-card-img {
  width: 100%;
  max-height: 180px;
  object-fit: cover;
  object-position: top;
}
.event-card-body { padding: 20px; }
.event-card-body h2 { font-size: 1.15rem; margin-bottom: 4px; font-weight: 800; color: var(--text); }
.event-card-date { color: var(--muted); margin-bottom: 4px; font-size: 0.88rem; }
.event-card-url { font-size: 0.85rem; color: var(--muted); margin-bottom: 12px; }
.event-card-url a { color: var(--primary); text-decoration: none; }
.event-card-url a:hover { text-decoration: underline; }

.rsvp-counts { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 10px; }
.count { font-weight: 700; font-size: 0.88rem; }
.count.going    { color: var(--going); }
.count.maybe    { color: var(--maybe); }
.count.declining{ color: var(--declining); }

.event-card-actions { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 12px; }
.event-card-actions .btn { padding: 8px 16px; font-size: 0.85rem; }

/* Archived badge */
.badge-archived {
  display: inline-block;
  font-size: 0.72rem;
  font-weight: 700;
  background: #f1f5f9;
  color: #64748b;
  border-radius: 4px;
  padding: 2px 8px;
  margin-left: 8px;
  vertical-align: middle;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

/* Summary bar (event detail page) */
.summary-bar {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  margin-bottom: 24px;
  background: var(--card);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  border: 1px solid var(--border);
  padding: 20px 24px;
}
.summary-item { text-align: center; min-width: 80px; }
.summary-num  { display: block; font-size: 2rem; font-weight: 800; }
.summary-label{ font-size: 0.75rem; color: var(--muted); font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; }
.summary-item.going    .summary-num { color: var(--going); }
.summary-item.maybe    .summary-num { color: var(--maybe); }
.summary-item.declining.summary-num { color: var(--declining); }
.summary-item.total    .summary-num { color: var(--primary); }

/* Headcount bar */
.headcount-row {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  align-items: center;
  font-size: 0.9rem;
  color: var(--text);
  margin-bottom: 12px;
}
.headcount-bar {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
  background: var(--primary-bg);
  border: 1px solid color-mix(in srgb, var(--primary) 20%, var(--border));
  border-radius: var(--radius);
  padding: 12px 18px;
  margin-bottom: 24px;
  font-size: 0.95rem;
}
.headcount-bar strong { color: var(--primary); }
.headcount-pill {
  background: #fff;
  padding: 5px 12px;
  border-radius: 999px;
  font-weight: 600;
  font-size: 0.88rem;
  box-shadow: 0 1px 3px rgba(0,0,0,0.05);
  border: 1px solid var(--border);
}
.headcount-pill.headcount-total { background: var(--primary); color: #fff; border-color: var(--primary); }

/* RSVP table */
.rsvp-table-wrap { overflow-x: auto; border-radius: var(--radius); border: 1px solid var(--border); box-shadow: var(--shadow); }
.rsvp-table {
  width: 100%;
  border-collapse: collapse;
  background: var(--card);
}
.rsvp-table th {
  background: #1e293b;
  color: #94a3b8;
  padding: 10px 14px;
  text-align: left;
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  font-weight: 700;
  white-space: nowrap;
}
.rsvp-table td {
  padding: 12px 14px;
  border-bottom: 1px solid #f8fafc;
  font-size: 0.9rem;
  white-space: nowrap;
}
.rsvp-table tr:last-child td { border-bottom: none; }
.rsvp-table tbody tr:hover td { background: #f8fafc; }
.rsvp-row-going    td:first-child { border-left: 3px solid var(--going); }
.rsvp-row-maybe    td:first-child { border-left: 3px solid var(--maybe); }
.rsvp-row-declining td:first-child { border-left: 3px solid var(--declining); }
.rsvp-date { color: var(--muted); font-size: 0.8rem; white-space: nowrap; }

/* RSVP row actions */
.rsvp-actions { white-space: nowrap; }
.btn-rsvp-edit {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 6px;
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--primary);
  border: 1.5px solid var(--primary);
  text-decoration: none;
  margin-right: 4px;
  background: transparent;
}
.btn-rsvp-edit:hover { background: var(--primary-bg); }
.btn-rsvp-delete {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 6px;
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--declining);
  border: 1.5px solid var(--declining);
  background: transparent;
  cursor: pointer;
  font-family: inherit;
}
.btn-rsvp-delete:hover { background: #fef2f2; }

/* Create/Edit event form */
.create-form {
  background: var(--card);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  border: 1px solid var(--border);
  padding: 28px 24px;
  max-width: 600px;
}

.slug-preview { display: flex; align-items: center; gap: 0; }
.slug-base {
  background: #f1f5f9;
  padding: 11px 10px 11px 14px;
  border: 1.5px solid var(--border);
  border-right: none;
  border-radius: 10px 0 0 10px;
  font-size: 0.85rem;
  color: var(--muted);
  white-space: nowrap;
  font-family: 'SF Mono', 'Fira Code', monospace;
}
.slug-preview input { border-radius: 0 10px 10px 0; }

.form-actions { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; margin-top: 24px; }
.form-actions .btn { min-width: 130px; text-align: center; }

.form-error {
  background: #fef2f2;
  border: 1.5px solid #fca5a5;
  border-radius: 8px;
  color: var(--declining);
  padding: 12px 16px;
  margin-bottom: 20px;
  font-size: 0.9rem;
}

.current-image { margin-bottom: 12px; }
.current-image img { max-width: 200px; border-radius: 8px; display: block; margin-bottom: 6px; }
.current-image span { font-size: 0.82rem; color: var(--muted); }

/* Field rows (two-column) */
.field-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.field-row .field { margin-bottom: 4px; }
@media (max-width: 500px) { .field-row { grid-template-columns: 1fr; } }

/* Optional features fieldset */
.options-fieldset {
  margin-top: 24px;
  border: 1px solid var(--border);
  padding: 16px;
  border-radius: var(--radius-sm);
  background: #f8fafc;
}
.options-fieldset legend {
  padding: 0 8px;
  font-weight: 700;
  font-size: 0.88rem;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* Color picker row */
.color-picker-row {
  display: flex;
  gap: 12px;
  align-items: center;
  flex-wrap: wrap;
  margin-top: 4px;
}
.color-picker-group {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.color-picker-group label { font-size: 0.82rem; font-weight: 600; color: var(--muted); }
.color-picker-inline {
  display: flex;
  gap: 8px;
  align-items: center;
}
.color-picker-inline input[type="color"] {
  width: 40px;
  height: 36px;
  padding: 2px 4px;
  border-radius: 6px;
  border: 1.5px solid var(--border);
  cursor: pointer;
}
.color-hex-input {
  width: 90px;
  padding: 7px 10px;
  border: 1.5px solid var(--border);
  border-radius: 6px;
  font-size: 0.85rem;
  font-family: 'SF Mono', 'Fira Code', monospace;
  color: var(--text);
  background: #fff;
}
.color-hex-input:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--primary) 15%, transparent);
}
.color-swatch {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 2px solid var(--border);
  display: inline-block;
  flex-shrink: 0;
}
.btn-color-reset, .btn-color-extract {
  font-size: 0.8rem;
  padding: 5px 10px;
  border-radius: 6px;
  border: 1.5px solid var(--border);
  background: #fff;
  color: var(--muted);
  cursor: pointer;
  font-family: inherit;
  font-weight: 600;
}
.btn-color-reset:hover, .btn-color-extract:hover {
  border-color: var(--primary);
  color: var(--primary);
}

/* Empty state */
.empty-state {
  text-align: center;
  padding: 48px 20px;
  color: var(--muted);
  font-size: 1rem;
}
.empty-state a { color: var(--primary); font-weight: 700; text-decoration: none; }

/* QR panel */
.qr-panel {
  background: var(--card);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  border: 1px solid var(--border);
  padding: 28px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px;
  align-items: start;
}
.qr-preview { text-align: center; }
.qr-preview img {
  max-width: 100%;
  width: 300px;
  height: 300px;
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 8px;
  background: #fff;
}
@media (max-width: 700px) { .qr-panel { grid-template-columns: 1fr; } }

/* Responsive event cards */
@media (min-width: 600px) {
  .event-card { flex-direction: row; }
  .event-card-img { width: 180px; max-height: none; object-fit: cover; }
}

/* Admin simple pages (users, forgot, reset, invite) */
.admin-simple-page {
  max-width: 480px;
  margin: 48px auto;
  padding: 0 20px;
}
.admin-simple-page h1 { font-size: 1.5rem; font-weight: 800; color: var(--text); margin-bottom: 8px; }
.admin-simple-page .page-intro { color: var(--muted); font-size: 0.9rem; margin-bottom: 24px; }
.admin-simple-page a { color: var(--primary); }

/* Users table */
.users-table {
  width: 100%;
  border-collapse: collapse;
  background: var(--card);
  border-radius: var(--radius);
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
  overflow: hidden;
  font-size: 0.88rem;
}
.users-table th {
  background: #f1f5f9;
  color: var(--muted);
  padding: 10px 12px;
  text-align: left;
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-weight: 700;
}
.users-table td { padding: 10px 12px; border-bottom: 1px solid #f8fafc; }
.users-table tr:last-child td { border-bottom: none; }
.users-table tr:hover td { background: #f8fafc; }
.users-table input[type="text"],
.users-table input[type="tel"],
.users-table input[type="email"] {
  padding: 5px 8px;
  border: 1.5px solid var(--border);
  border-radius: 6px;
  font-size: 0.85rem;
  font-family: inherit;
}
.users-table input:focus {
  outline: none;
  border-color: var(--primary);
}
.users-table button {
  padding: 4px 10px;
  border: 1.5px solid var(--border);
  border-radius: 6px;
  background: #fff;
  font-size: 0.8rem;
  font-weight: 600;
  cursor: pointer;
  font-family: inherit;
  color: var(--text);
}
.users-table button:hover { border-color: var(--primary); color: var(--primary); }
.users-table select {
  padding: 4px 8px;
  border: 1.5px solid var(--border);
  border-radius: 6px;
  font-size: 0.85rem;
  font-family: inherit;
}

/* Flash messages */
.flash-bar {
  padding: 10px 16px;
  border-radius: var(--radius-sm);
  margin-bottom: 16px;
  font-size: 0.9rem;
  font-weight: 600;
}
.flash-bar.success { background: #f0fdf4; color: #166534; border: 1px solid #86efac; }
.flash-bar.error   { background: #fef2f2; color: #991b1b; border: 1px solid #fca5a5; }
.flash-bar.info    { background: #eff6ff; color: #1e40af; border: 1px solid #93c5fd; }

/* ── Homepage ─────────────────────────────────────────────────────────────── */
body.home-page {
  background:
    radial-gradient(900px 500px at 50% -10%, color-mix(in srgb, var(--primary) 8%, transparent) 0%, transparent 70%),
    var(--bg);
  background-attachment: fixed;
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
}

.home-shell {
  width: 100%;
  max-width: 460px;
  padding: 40px 20px;
  display: flex;
  flex-direction: column;
  gap: 32px;
}

/* Hero */
.home-hero { text-align: center; }
.home-wordmark {
  display: block;
  margin: 0 auto 24px;
  max-width: 280px;
  width: 70%;
  height: auto;
}
.home-title {
  font-size: clamp(1.85rem, 5.5vw, 2.5rem);
  font-weight: 900;
  letter-spacing: -0.025em;
  line-height: 1.08;
  color: var(--text);
  margin-bottom: 14px;
}
.home-tagline {
  font-size: 1.02rem;
  line-height: 1.55;
  color: var(--muted);
  max-width: 380px;
  margin: 0 auto;
}

/* Card */
.home-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 32px 28px;
  box-shadow: 0 1px 3px rgba(0,0,0,0.04), 0 8px 28px rgba(0,0,0,0.04);
}
.home-card-title {
  font-size: 1.18rem;
  font-weight: 800;
  letter-spacing: -0.015em;
  margin-bottom: 6px;
  color: var(--text);
}
.home-card-sub {
  color: var(--muted);
  font-size: 0.92rem;
  line-height: 1.5;
  margin-bottom: 22px;
}
.home-request-form .field { margin-bottom: 14px; }
.home-submit { width: 100%; margin-top: 8px; }

.home-success-block { text-align: center; padding: 8px 0 4px; }
.home-success-ico {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  background: var(--going-bg);
  color: var(--going);
  border-radius: 50%;
  font-size: 1.6rem;
  font-weight: 700;
  margin-bottom: 16px;
}
.home-success-block h2 {
  font-size: 1.25rem;
  font-weight: 800;
  letter-spacing: -0.015em;
  margin-bottom: 8px;
  color: var(--text);
}
.home-success-block p {
  color: var(--muted);
  font-size: 0.95rem;
  line-height: 1.5;
}

.home-error {
  background: var(--declining-bg);
  color: #991b1b;
  border: 1px solid #fca5a5;
  padding: 11px 14px;
  border-radius: var(--radius-sm);
  font-size: 0.9rem;
  margin-bottom: 16px;
}

/* Footer */
.home-footer {
  text-align: center;
  font-size: 0.85rem;
  color: var(--muted);
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 10px;
}
.home-footer a {
  color: var(--muted);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: color .15s, border-color .15s;
}
.home-footer a:hover { color: var(--primary); border-bottom-color: var(--primary); }
.home-footer-sep { opacity: 0.4; }

@media (max-width: 480px) {
  .home-shell { padding: 32px 16px; gap: 28px; }
  .home-card { padding: 28px 22px; }
}

/* ── Powered-by footer (guest-facing pages) ───────────────────────────────── */
.powered-by {
  text-align: center;
  margin-top: 32px;
  padding: 16px 12px 8px;
  font-size: 0.82rem;
  color: var(--muted);
  line-height: 1.5;
}
.powered-by a {
  color: var(--muted);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  justify-content: center;
  gap: 4px;
  transition: color .15s;
}
.powered-by a:hover { color: var(--primary); }
.powered-by a:hover .powered-by-cta { color: var(--primary); }
.powered-by strong {
  font-weight: 800;
  color: var(--text);
  letter-spacing: -0.01em;
}
.powered-by-cta { color: var(--muted); }
