:root {
  font-family: system-ui, Segoe UI, Arial, sans-serif;
  --navy: #14385c;
  --navy-hover: #1d4d7d;
  --gold: #c79a3b;
}
body { margin: 0; color: #1a2330; background: #f4f6f9; }

.topbar { display: flex; align-items: center; gap: 1.25rem; padding: .6rem 1.25rem;
  background: #fff; border-bottom: 3px solid var(--gold); }
.topbar .brand { display: flex; align-items: baseline; gap: .6rem;
  text-decoration: none; }
.topbar .logo { height: 40px; display: block; align-self: center; }
.topbar .brand-sub { color: var(--navy); font-weight: 600; font-size: .95rem; }
.topbar .mainnav a { color: var(--navy); text-decoration: none; font-weight: 600;
  margin-right: 1rem; }
.topbar .mainnav a:hover { color: var(--gold); }
.topbar .who { margin-left: auto; color: #5a6470; font-size: .9rem; }

.inline { display: inline; }
main { max-width: 860px; margin: 1.5rem auto; padding: 0 1.25rem; }
.card { background: #fff; padding: 1.25rem; border-radius: 8px;
  box-shadow: 0 1px 3px rgba(0,0,0,.08); display: grid; gap: .75rem; max-width: 420px; }
label { display: grid; gap: .25rem; font-size: .9rem; }
input, select { padding: .5rem; border: 1px solid #c7d0db; border-radius: 6px; font-size: 1rem; }
button { background: var(--navy); color: #fff; border: 0; padding: .55rem 1rem;
  border-radius: 6px; cursor: pointer; font-size: 1rem; }
button:hover { background: var(--navy-hover); }
button.secondary { background: #e7ebf1; color: var(--navy); }
button.secondary:hover { background: #d7dde6; }
a.button { display: inline-block; background: var(--navy); color: #fff;
  padding: .45rem .85rem; border-radius: 6px; text-decoration: none; font-size: .95rem; }
a.button:hover { background: var(--navy-hover); }
.muted { color: #8a93a0; }

.flash { background: #fde2e1; border: 1px solid #f5b5b2; padding: .5rem .75rem;
  border-radius: 6px; list-style: none; }
.result-held { color: #14692c; font-weight: 600; }
.result-miss { color: #9a2b25; font-weight: 600; }
table { width: 100%; border-collapse: collapse; background: #fff; }
th, td { text-align: left; padding: .5rem .6rem; border-bottom: 1px solid #e3e8ef; font-size: .9rem; }
.toolbar { display: flex; gap: 1rem; align-items: center; margin: 1rem 0; flex-wrap: wrap; }
nav.admin a { margin-right: 1rem; }

.modal-overlay { position: fixed; inset: 0; background: rgba(20,30,45,.55);
  display: flex; align-items: center; justify-content: center; padding: 1rem; z-index: 10; }
.modal-card { background: #fff; max-width: 560px; width: 100%; border-radius: 10px;
  padding: 1.5rem 1.75rem; box-shadow: 0 10px 40px rgba(0,0,0,.25);
  border-top: 5px solid var(--gold); }
.modal-card h1 { margin-top: 0; color: var(--navy); }
.modal-actions { display: flex; gap: .75rem; margin-top: 1.25rem; }
