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

:root {
  --maroon: #772432;        /* True Maroon */
  --maroon-dark: #3b0104;   /* Deep Maroon */
  --blue: #004165;          /* Loyal Blue */
  --yellow-soft: #fbf3cf;   /* Happy Yellow, soft tint */
  --bg: #f5f5f5;            /* Fair Gray */
  --card: #ffffff;
  --ink: #20242b;
  --muted: #5f6a6a;
  --line: #dfe3e3;
}

body {
  font-family: "Source Sans 3", "Segoe UI", Arial, sans-serif;
  background: var(--bg);
  color: var(--ink);
  line-height: 1.55;
}

h1, h2, h3, .brand, .stat-num {
  font-family: "Montserrat", "Segoe UI", Arial, sans-serif;
}

.topbar {
  background: var(--maroon);
  color: #fff;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  padding: 0.75rem 1.25rem;
  gap: 0.5rem;
}
.brand {
  grid-column: 2;
  color: #fff;
  font-weight: 700;
  font-size: 1.4rem;
  text-decoration: none;
  text-align: center;
}
.nav {
  grid-column: 3;
  justify-self: end;
  display: flex;
  align-items: center;
  gap: 0.25rem;
  flex-wrap: wrap;
}
.nav a.btn-topbar {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  border: 1px solid rgba(255, 255, 255, 0.6);
  border-radius: 6px;
  padding: 0.4rem 0.9rem;
  color: #fff;
  font-weight: 600;
}
.nav a.btn-topbar svg { display: block; }
.nav a.btn-topbar:hover { background: rgba(255, 255, 255, 0.15); color: #fff; }

@media (max-width: 600px) {
  .topbar { grid-template-columns: 1fr; justify-items: center; }
  .brand { grid-column: 1; }
  .nav { grid-column: 1; justify-self: center; }
}
.nav a {
  color: #f0d9dd;
  text-decoration: none;
  padding: 0.35rem 0.7rem;
  border-radius: 6px;
  font-size: 0.95rem;
}
.nav a:hover { background: rgba(255, 255, 255, 0.12); color: #fff; }
.nav a.active { background: rgba(255, 255, 255, 0.18); color: #fff; }
.logout-form { margin-left: 0.25rem; }
.logout-form button {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  background: transparent;
  border: 1px solid rgba(255, 255, 255, 0.5);
  color: #fff;
  padding: 0.35rem 0.7rem;
  border-radius: 6px;
  cursor: pointer;
  font-size: 0.9rem;
  font-family: inherit;
}
.logout-form button svg { display: block; }
.logout-form button:hover { background: rgba(255, 255, 255, 0.12); }

.container { max-width: 880px; margin: 2rem auto; padding: 0 1.25rem; }
.page-head {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  margin-bottom: 1.5rem;
  gap: 0.85rem;
}
.page-head-center { justify-content: center; }
h1 { font-size: 1.5rem; color: var(--maroon); }
h2 { font-size: 1.15rem; margin-bottom: 1rem; }

.card {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 1.5rem 1.75rem;
  margin-bottom: 1.5rem;
}

.grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; }
@media (max-width: 680px) {
  .grid { grid-template-columns: 1fr; }
}

.stats { display: flex; gap: 1.5rem; margin-bottom: 1.5rem; flex-wrap: wrap; }
.stat {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 1.25rem 1.75rem;
  flex: 1;
  min-width: 140px;
}
.stat-num { display: block; font-size: 1.8rem; font-weight: 700; color: var(--maroon); line-height: 1.2; }
.stat-label { color: var(--muted); font-size: 0.9rem; }

table { width: 100%; border-collapse: collapse; }
th, td {
  text-align: left;
  padding: 0.75rem 0.6rem;
  border-bottom: 1px solid var(--line);
}
th {
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.4px;
  color: var(--muted);
}
tbody tr:last-child td { border-bottom: none; }
.num { text-align: right; white-space: nowrap; }
.actions { text-align: right; white-space: nowrap; }
.data-table td .member-name { font-weight: 600; margin-right: 0.6rem; }

/* Member-row state: green tint for active, gray for inactive */
.data-table tr.inactive-row { background: #f0f1f1; color: var(--muted); }
.data-table tr.inactive-row .member-name { color: var(--muted); }

/* Icon-only edit button */
.icon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 8px;
  color: var(--blue);
  text-decoration: none;
}
.icon-btn:hover { background: #e4eef3; }
.icon-btn svg { display: block; }
.inactive-row td { color: var(--muted); }

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
  padding: 0.5rem 1rem;
  border-radius: 7px;
  border: 1px solid var(--line);
  background: #fff;
  color: var(--ink);
  text-decoration: none;
  font-size: 0.95rem;
  font-family: inherit;
  cursor: pointer;
}
.btn svg { display: block; }
.btn:hover { background: #eef0f0; }
.btn-primary { background: var(--maroon); border-color: var(--maroon); color: #fff; }
.btn-primary:hover { background: var(--maroon-dark); border-color: var(--maroon-dark); }
.btn-danger { background: #fff; border-color: #b23b3b; color: #b23b3b; }
.btn-danger:hover { background: #b23b3b; color: #fff; }
.danger-zone h2 { color: #b23b3b; }
.link {
  color: var(--blue);
  text-decoration: none;
  background: none;
  border: none;
  font-size: 0.95rem;
  font-family: inherit;
  cursor: pointer;
  padding: 0;
}
.link:hover { text-decoration: underline; }
.link-danger { color: #b23b3b; margin-left: 0.75rem; }
.inline { display: inline; }

.form-card { max-width: 480px; }
label { display: block; font-weight: 600; margin: 0.9rem 0 0.3rem; font-size: 0.95rem; }
input[type="text"], input[type="password"], input[type="date"] {
  width: 100%;
  padding: 0.55rem 0.65rem;
  border: 1px solid var(--line);
  border-radius: 7px;
  font-size: 1rem;
  font-family: inherit;
}
input:focus { outline: 2px solid var(--maroon); border-color: var(--maroon); }
.checkbox {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-weight: 400;
  margin: 0.4rem 0;
  cursor: pointer;
}
.checkbox input { width: auto; }
.form-card button, .auth-card button { margin-top: 1.1rem; }
.hint { color: var(--muted); font-size: 0.85rem; margin-top: 0.3rem; }
.optional { color: var(--muted); font-weight: 400; font-size: 0.85rem; }

fieldset.attendance-list {
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 0.75rem 1rem;
  margin-top: 1rem;
}
fieldset.attendance-list legend { font-weight: 600; padding: 0 0.4rem; }
.attendance-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 0.75rem;
  margin-bottom: 0.4rem;
}
.attendance-head .hint { margin: 0; }

.auth-card { max-width: 360px; margin: 3rem auto; }
.alert {
  background: #fdecec;
  color: #b23b3b;
  border: 1px solid #f3c2c2;
  padding: 0.55rem 0.75rem;
  border-radius: 7px;
  margin: 0.75rem 0;
  font-size: 0.9rem;
}

.badge {
  display: inline-block;
  padding: 0.15rem 0.55rem;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 600;
}
.badge-on { background: #e4eef3; color: var(--blue); }
.badge-off { background: #ecefee; color: var(--muted); }
.muted { color: var(--muted); }
.meeting-meta { margin-bottom: 1rem; }
.meeting-meta p { margin-bottom: 0.5rem; }

.meeting-list { list-style: none; margin-bottom: 0.75rem; }
.meeting-list li {
  padding: 0.75rem 0;
  border-bottom: 1px solid var(--line);
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
}
.meeting-list li:last-child { border-bottom: none; }
.pill {
  margin-left: auto;
  background: #f0e6e8;
  color: var(--maroon);
  padding: 0.1rem 0.55rem;
  border-radius: 999px;
  font-size: 0.8rem;
  font-weight: 600;
}

.bar {
  display: inline-block;
  width: 60px;
  height: 7px;
  background: var(--line);
  border-radius: 999px;
  overflow: hidden;
  vertical-align: middle;
  margin-right: 0.4rem;
}
.bar-fill { display: block; height: 100%; background: var(--maroon); }

/* Officer dashboard */
.cta-banner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  background: var(--yellow-soft);
  border: 1px solid #ecdfa3;
  border-radius: 10px;
  padding: 1rem 1.25rem;
  margin-bottom: 1.5rem;
  flex-wrap: wrap;
}
.cta-banner strong { color: var(--maroon); font-size: 1.05rem; }
.cta-sub { color: var(--muted); font-size: 0.9rem; margin-top: 0.15rem; }

.quick-actions {
  display: flex;
  gap: 0.6rem;
  flex-wrap: wrap;
  margin-bottom: 1.5rem;
}

.big-stat { display: flex; align-items: baseline; gap: 0.75rem; }
.big-num {
  font-family: "Montserrat", "Segoe UI", Arial, sans-serif;
  font-size: 2.4rem;
  font-weight: 700;
  color: var(--maroon);
  line-height: 1;
}
.trend { font-weight: 700; font-size: 0.95rem; }
.trend-up { color: #2f7d3b; }
.trend-down { color: #b23b3b; }
.trend-flat { color: var(--muted); }

.sparkline { width: 100%; height: 70px; display: block; }

.risk-list { list-style: none; }
.risk-list li {
  padding: 0.6rem 0;
  border-bottom: 1px solid var(--line);
  display: flex;
  align-items: baseline;
  gap: 0.6rem;
  flex-wrap: wrap;
}
.risk-list li:last-child { border-bottom: none; }

/* Leaderboard recognition banner */
.recognition-card { padding: 1.1rem 1.5rem; }
.recognition-title {
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.6px;
  color: var(--muted);
  margin-bottom: 0.75rem;
}
.recognition-row {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex-wrap: wrap;
  padding: 0.35rem 0;
}
.recognition-label {
  font-weight: 600;
  color: var(--maroon);
  font-size: 0.95rem;
  min-width: 9rem;
}
.recognition-chips { display: flex; gap: 0.35rem; flex-wrap: wrap; }
.chip {
  display: inline-block;
  padding: 0.2rem 0.65rem;
  border-radius: 999px;
  font-size: 0.85rem;
  font-weight: 600;
}
.chip-perfect { background: #e4eef3; color: var(--blue); }
.chip-streak  { background: var(--yellow-soft); color: var(--maroon); }
@media (max-width: 600px) {
  .recognition-label { min-width: 0; flex: 1 1 100%; }
}

/* Mobile responsive admin */
@media (max-width: 600px) {
  .container { padding: 0 0.75rem; margin: 1rem auto; }
  .card { padding: 1rem 1.1rem; margin-bottom: 1rem; }
  .grid, .stats { gap: 1rem; }
  h1 { font-size: 1.3rem; }
  h2 { font-size: 1.05rem; }

  /* Page head: title above, action button below, full width */
  .page-head { gap: 0.6rem; margin-bottom: 1rem; }
  .page-head > .btn { width: 100%; text-align: center; }

  /* Quick actions: each button on its own row, taller for tap */
  .quick-actions { flex-direction: column; gap: 0.5rem; }
  .quick-actions .btn { width: 100%; text-align: center; padding: 0.7rem 1rem; }

  /* CTA banner: stack content + button */
  .cta-banner { flex-direction: column; align-items: stretch; }
  .cta-banner .btn { width: 100%; text-align: center; }

  /* Data tables → stacked cards */
  .data-table, .data-table tbody { display: block; }
  .data-table thead { display: none; }
  .data-table tr {
    display: block;
    border: 1px solid var(--line);
    border-radius: 8px;
    padding: 0.55rem 0.85rem 0.6rem;
    margin-bottom: 0.5rem;
  }
  .data-table tr:last-child { margin-bottom: 0; }
  .data-table td {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.75rem;
    border: none;
    padding: 0.15rem 0;
    text-align: right;
  }
  .data-table td:empty { display: none; }
  .data-table td::before {
    content: attr(data-label);
    color: var(--muted);
    font-weight: 600;
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.4px;
    text-align: left;
  }
  .data-table td:not([data-label])::before { content: none; }
  .data-table td.name-cell {
    font-weight: 700;
    font-size: 1.05rem;
    padding-bottom: 0.4rem;
    margin-bottom: 0.25rem;
    border-bottom: 1px solid var(--line);
    display: block;
    text-align: left;
  }
  .data-table td.name-cell-flex {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.6rem;
    padding-bottom: 0;
    margin-bottom: 0;
    border-bottom: none;
  }
  .data-table td.name-cell .member-name { font-weight: 700; font-size: 1.05rem; }
  .data-table td.name-cell::before { display: none; }
  .data-table td.actions {
    padding-top: 0.3rem;
    gap: 1.25rem;
    justify-content: flex-end;
  }
  .data-table td.actions .link { padding: 0.2rem 0; }

  /* Form attendance: bigger tap targets */
  .checkbox { padding: 0.55rem 0.25rem; font-size: 1rem; min-height: 44px; }
  .checkbox input { width: 20px; height: 20px; }
  .form-card button, .auth-card button { width: 100%; }

  /* Topbar nav: tighter, wrap nicely */
  .topbar { padding: 0.6rem 0.75rem; gap: 0.4rem; }
  .nav { gap: 0.2rem; flex-wrap: wrap; justify-content: center; }
  .nav a { padding: 0.3rem 0.55rem; font-size: 0.9rem; }

  /* Recognition card chips wrap fully */
  .recognition-card { padding: 0.9rem 1.1rem; }
}

.sitefoot {
  text-align: center;
  color: var(--muted);
  font-size: 0.85rem;
  padding: 1.5rem 1rem;
}

/* Leaderboard */
.leaderboard .rank {
  text-align: center;
  width: 2.5rem;
  font-weight: 700;
  color: var(--muted);
  font-family: "Montserrat", "Segoe UI", Arial, sans-serif;
}
.leaderboard tr.top-1 { background: var(--yellow-soft); }
.leaderboard tr.top-2 { background: #ecedee; }
.leaderboard tr.top-3 { background: #f7ecee; }
.leaderboard tr.top-1 .rank { color: var(--maroon); }
.leaderboard tr.top-2 .rank { color: var(--maroon); }
.leaderboard tr.top-3 .rank { color: var(--maroon); }
.leaderboard-card { max-width: 720px; margin-left: auto; margin-right: auto; }
.leaderboard th, .leaderboard td { padding: 0.8rem 0.7rem; }
.leaderboard th { font-size: 0.95rem; }
.leaderboard th.rank { text-align: center; }
.leaderboard td.num, .leaderboard th.num { text-align: center; }
.leaderboard tbody tr:hover { filter: brightness(0.96); }
.streak { white-space: nowrap; }
.small { font-size: 0.95rem; }

@media (max-width: 600px) {
  .leaderboard,
  .leaderboard tbody { display: block; }
  .leaderboard thead { display: none; }
  .leaderboard .bar { display: none; }
  .leaderboard tr {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    border: 1px solid var(--line);
    border-radius: 8px;
    padding: 0.5rem 0.85rem;
    margin-bottom: 0.4rem;
  }
  .leaderboard tr:last-child { margin-bottom: 0; }
  .leaderboard td {
    display: block;
    border: none;
    padding: 0.15rem 0;
    line-height: 1.25;
  }
  .leaderboard td.rank {
    width: auto;
    font-size: 1.5rem;
    margin-right: 0.85rem;
  }
  .leaderboard td.rank::before { content: "#"; }
  .leaderboard td.member-cell {
    flex: 1;
  }
  .leaderboard td.member-cell a {
    font-family: "Montserrat", "Segoe UI", Arial, sans-serif;
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--muted);
  }
  .leaderboard tr.top-1 td.member-cell a { color: var(--maroon); }
  .leaderboard tr.top-2 td.member-cell a { color: var(--maroon); }
  .leaderboard tr.top-3 td.member-cell a { color: var(--maroon); }
  .leaderboard td.num {
    flex: 1 1 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    text-align: left;
    font-size: 1.2rem;
  }
  .leaderboard td.num::before {
    content: attr(data-label);
    color: var(--muted);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.4px;
  }
}
