/* =============================================================================
 *  NAG27 — admin dashboard styles (loaded on top of styles.css)
 * ========================================================================== */
.admin-body { background: var(--cream-200); min-height: 100vh; display: flex; flex-direction: column; }
.admin-header { background: var(--green-900); border-bottom: 1px solid rgba(0,0,0,.2); }
.admin-header .brand-text { color: #fff; }
.admin-bar { display: flex; align-items: center; justify-content: space-between; min-height: 64px; }
.admin-actions { display: flex; gap: .6rem; flex-wrap: wrap; }
.admin-header .btn-ghost { --fg: var(--gold-200); border-color: rgba(233,199,154,.45); }
.admin-header .btn-ghost:hover { --bg: var(--gold-500); --fg: #1f3322; }
.admin-main { padding-block: 2.4rem 4rem; flex: 1; }

/* login */
.login-card {
  max-width: 420px; margin: 6vh auto 0; background: var(--white);
  border: 1px solid var(--cream-300); border-radius: 18px; padding: 2.2rem;
  box-shadow: var(--shadow-md);
}
.login-title { font-size: 1.6rem; margin-bottom: .3rem; }
.login-form { display: grid; gap: 1.1rem; margin-top: 1.4rem; }
.login-form .field span { font-weight: 600; font-size: .92rem; color: var(--ink-700); }
.remember { display: flex; align-items: center; gap: .5rem; font-size: .92rem; color: var(--ink-700); }
.remember input { width: auto; }
.login-fine { font-size: .82rem; margin-top: 1.2rem; }

/* stats */
.stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 1rem; margin-bottom: 1.8rem; }
.stat {
  background: var(--white); border: 1px solid var(--cream-300); border-radius: var(--radius);
  padding: 1.1rem 1.3rem; box-shadow: var(--shadow-sm);
}
.stat .n { font-family: var(--font-display); font-size: 2rem; font-weight: 600; color: var(--green-700); line-height: 1; }
.stat .l { font-size: .82rem; text-transform: uppercase; letter-spacing: .08em; color: var(--ink-500); margin-top: .4rem; }
.stat.attending .n { color: var(--green-700); }
.stat.maybe .n { color: var(--gold-600); }
.stat.no .n { color: var(--terra-600); }

/* table tools */
.table-tools { display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; margin-bottom: .9rem; }
.filter-input {
  flex: 1; min-width: 220px; font-size: 1rem; padding: .6rem .85rem;
  border: 1.5px solid var(--cream-300); border-radius: var(--radius-sm); background: var(--white);
}
.filter-input:focus { outline: none; border-color: var(--green-700); box-shadow: 0 0 0 3px rgba(70,96,63,.18); }

/* table */
.table-wrap { overflow-x: auto; background: var(--white); border: 1px solid var(--cream-300); border-radius: var(--radius); box-shadow: var(--shadow-sm); }
.rsvp-table { border-collapse: collapse; width: 100%; font-size: .92rem; }
.rsvp-table th, .rsvp-table td { padding: .7rem .9rem; text-align: left; border-bottom: 1px solid var(--cream-200); white-space: nowrap; vertical-align: top; }
.rsvp-table th { position: sticky; top: 0; background: var(--cream-200); font-weight: 600; color: var(--ink-700); cursor: pointer; user-select: none; }
.rsvp-table th:hover { color: var(--green-700); }
.rsvp-table tbody tr:hover { background: #fbf7ee; }
.rsvp-table td.wrap { white-space: normal; min-width: 180px; max-width: 320px; }
.badge { display: inline-block; padding: .15em .6em; border-radius: 999px; font-size: .78rem; font-weight: 600; }
.badge.yes { background: #e7f0e3; color: var(--green-700); }
.badge.maybe { background: #f7ecd2; color: var(--gold-600); }
.badge.no { background: #f6e2da; color: var(--terra-600); }
.empty-note { text-align: center; padding: 2rem; }

@media (max-width: 640px) {
  .login-card { margin-top: 3vh; padding: 1.6rem; }
}
