:root {
  --bg: #0f1419;
  --surface: #1a222d;
  --border: #2a3544;
  --text: #e8edf2;
  --muted: #8b9aab;
  --accent: #c41e3a;
  --accent-2: #1e4d8c;
  --success: #2d8a4e;
  --warn: #c98a1a;
  --font: "Barlow", system-ui, sans-serif;
  --display: "Bebas Neue", sans-serif;
}

* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: var(--font);
  background: var(--bg);
  color: var(--text);
  line-height: 1.5;
}
a { color: #6eb5ff; text-decoration: none; }
a:hover { text-decoration: underline; }
.container { max-width: 1100px; margin: 0 auto; padding: 0 1.25rem; }
.patriot-bar { height: 4px; background: linear-gradient(90deg, var(--accent-2), #fff 50%, var(--accent)); }

.site-header {
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  padding: 1rem 0;
}
.header-inner { display: flex; align-items: center; justify-content: space-between; gap: 1rem; flex-wrap: wrap; }
.logo { display: flex; flex-direction: column; color: inherit; text-decoration: none; }
.logo-main { font-family: var(--display); font-size: 1.75rem; letter-spacing: 0.04em; }
.logo-sub { font-size: 0.8rem; color: var(--muted); }
.nav { display: flex; gap: 1.25rem; }
.nav a { color: var(--text); }

.main-content { padding: 2.5rem 0 4rem; min-height: 60vh; }
.site-footer { border-top: 1px solid var(--border); padding: 1.5rem 0; color: var(--muted); font-size: 0.9rem; }

.hero { margin-bottom: 2.5rem; }
.hero .label, .page-header .label, .label { color: var(--accent); text-transform: uppercase; letter-spacing: 0.12em; font-size: 0.75rem; font-weight: 600; }
.hero h1, .page-header h1 { font-family: var(--display); font-size: clamp(2.5rem, 6vw, 4rem); margin: 0.25rem 0; letter-spacing: 0.03em; }
.lead { font-size: 1.15rem; color: var(--muted); max-width: 42rem; }
.hero-actions { display: flex; gap: 0.75rem; flex-wrap: wrap; margin-top: 1.5rem; }

.btn {
  display: inline-block;
  padding: 0.65rem 1.25rem;
  border-radius: 4px;
  font-weight: 600;
  border: 2px solid transparent;
  cursor: pointer;
  text-decoration: none;
  font-family: inherit;
}
.btn-primary { background: var(--accent); color: #fff; }
.btn-outline { border-color: var(--border); color: var(--text); background: transparent; }
.btn-block { width: 100%; text-align: center; }

.card-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 1rem; }
.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 1.25rem;
}
.card h2, .card h3 { margin-top: 0; }

.section-title { font-family: var(--display); font-size: 1.5rem; letter-spacing: 0.04em; margin-bottom: 1rem; }
.muted { color: var(--muted); }
.small { font-size: 0.85rem; }

.table-wrap { overflow-x: auto; border: 1px solid var(--border); border-radius: 8px; }
.data-table { width: 100%; border-collapse: collapse; font-size: 0.95rem; }
.data-table th, .data-table td { padding: 0.75rem 1rem; text-align: left; border-bottom: 1px solid var(--border); }
.data-table th { background: var(--surface); color: var(--muted); font-size: 0.8rem; text-transform: uppercase; letter-spacing: 0.06em; }

.badge {
  display: inline-block;
  padding: 0.2rem 0.5rem;
  border-radius: 4px;
  font-size: 0.75rem;
  font-weight: 600;
  background: var(--border);
}
.badge-open, .badge-confirmed { background: rgba(45, 138, 78, 0.25); color: #7ddea0; }
.badge-awaiting_payment { background: rgba(201, 138, 26, 0.25); color: #f0c060; }
.badge-warn { background: rgba(196, 30, 58, 0.25); color: #ff8a9a; }

.chip-row { display: flex; flex-wrap: wrap; gap: 0.5rem; }
.chip { background: var(--surface); border: 1px solid var(--border); padding: 0.35rem 0.75rem; border-radius: 999px; font-size: 0.9rem; }

.auth-card {
  max-width: 400px;
  margin: 0 auto;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 2rem;
}
.form label { display: block; margin-bottom: 1rem; font-weight: 600; font-size: 0.9rem; }
.form input {
  display: block;
  width: 100%;
  margin-top: 0.35rem;
  padding: 0.65rem 0.75rem;
  border: 1px solid var(--border);
  border-radius: 4px;
  background: var(--bg);
  color: var(--text);
  font: inherit;
}
.error { color: #ff8a9a; }
code { background: var(--surface); padding: 0.15rem 0.4rem; border-radius: 3px; font-size: 0.85em; }

/* Passwordless login + manager admin */
.notice {
  background: rgba(30, 77, 140, 0.25);
  border: 1px solid var(--accent-2);
  color: #bcd4f0;
  padding: 0.75rem 1rem;
  border-radius: 6px;
  margin-bottom: 1rem;
}
.auth-alt { margin-top: 1rem; }
.auth-alt summary { cursor: pointer; color: var(--muted); font-size: 0.9rem; }
.auth-alt .form { margin-top: 1rem; }

.messages { list-style: none; padding: 0; margin: 0 0 1rem; }
.msg { padding: 0.6rem 1rem; border-radius: 6px; margin-bottom: 0.5rem; }
.msg-success { background: rgba(45, 138, 78, 0.25); color: #7ddea0; }
.msg-error { background: rgba(196, 30, 58, 0.25); color: #ff8a9a; }

.form-inline { display: flex; flex-wrap: wrap; gap: 0.75rem; align-items: flex-end; }
.form-inline label { margin-bottom: 0; }
.form-inline .check { display: flex; align-items: center; gap: 0.4rem; font-weight: 400; }
.form-inline .check input { width: auto; margin-top: 0; }
.inline { display: inline-flex; gap: 0.4rem; align-items: center; margin: 0; }
.inline input { width: auto; margin-top: 0; padding: 0.4rem 0.6rem; }
.btn-sm { padding: 0.4rem 0.7rem; font-size: 0.85rem; }
.event-list { list-style: none; padding: 0; }
.event-list li { padding: 0.5rem 0; border-bottom: 1px solid var(--border); }

.match-list { display: flex; flex-direction: column; gap: 0.75rem; }
.match-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 1rem 1.25rem;
}
.link-card { display: block; color: inherit; text-decoration: none; }
.link-card:hover { border-color: var(--accent-2); }
.match-teams { display: grid; grid-template-columns: 1fr auto 1fr; gap: 1rem; align-items: center; font-weight: 600; }
.match-teams .score { font-family: var(--display); font-size: 1.5rem; color: var(--accent); text-align: center; }
.match-teams .winner { color: #7ddea0; }
.match-meta { margin-top: 0.35rem; font-size: 0.85rem; color: var(--muted); }
.match-card.status-live { border-color: var(--accent); }

.scoreboard {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 1rem;
  background: var(--surface);
  border: 2px solid var(--border);
  border-radius: 12px;
  padding: 1.5rem;
  margin-bottom: 1.5rem;
  text-align: center;
}
.scoreboard-name { font-weight: 600; margin-bottom: 0.5rem; }
.scoreboard-points { font-family: var(--display); font-size: 4rem; line-height: 1; color: var(--accent); }
.scoreboard-clock { font-family: var(--display); font-size: 2rem; }
.scoreboard-rules { font-size: 0.85rem; color: var(--muted); margin-top: 0.5rem; }
.score-actions { display: grid; grid-template-columns: 1fr 1fr; gap: 0.75rem; margin-bottom: 2rem; }
.btn-score { font-size: 1.1rem; padding: 1.25rem; border: none; border-radius: 8px; font-weight: 700; cursor: pointer; }
.btn-home { background: var(--accent-2); color: #fff; }
.btn-away { background: var(--accent); color: #fff; }
.point-log { margin: 0; padding-left: 1.25rem; color: var(--muted); }