:root {
  --navy: #112e54;
  --blue: #246493;
  --aqua: #4cb1cf;
  --pale: #eef5f9;
  --ink: #132f4b;
  --muted: #617488;
  --border: #dce7ee;
}
* { box-sizing: border-box; }
body {
  background: #fff;
  color: var(--ink);
  font-family: "Avenir Next", "Segoe UI", Arial, sans-serif;
  margin: 0;
}
.admin { background: #f6f9fb; }
.site-header {
  align-items: center;
  background: var(--navy);
  color: #fff;
  display: flex;
  justify-content: space-between;
  min-height: 74px;
  padding: 0 max(calc((100vw - 1120px) / 2), 20px);
}
.brand {
  align-items: center;
  color: white;
  display: flex;
  font-weight: 700;
  gap: 14px;
  text-decoration: none;
}
.mark {
  background: var(--aqua);
  border-radius: 11px;
  font-weight: 800;
  letter-spacing: .06em;
  padding: 12px 10px;
}
.mode { color: #ccecf4; }
main {
  margin: 0 auto;
  max-width: 1120px;
  padding: 34px 18px 64px;
}
h1 {
  font-size: clamp(2rem, 4.5vw, 3.2rem);
  letter-spacing: -.045em;
  line-height: 1.08;
  margin: 10px 0 16px;
}
h2 { letter-spacing: -.025em; }
.eyebrow {
  color: var(--aqua);
  font-size: .77rem;
  font-weight: 800;
  letter-spacing: .15em;
  margin: 0;
}
.hero {
  background: linear-gradient(120deg, var(--navy), #327bab);
  border-radius: 26px;
  color: white;
  margin-bottom: 38px;
  padding: clamp(32px, 7vw, 62px);
}
.hero .eyebrow { color: #75dbef; }
.hero p:not(.eyebrow) {
  color: #dbedf6;
  font-size: 1.05rem;
  margin: 0;
  max-width: 530px;
}
.card-grid { display: grid; gap: 18px; grid-template-columns: repeat(auto-fill, minmax(290px, 1fr)); }
.meet-card, .swimmer, .upload, .published {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 25px;
}
.meet-card {
  color: var(--ink);
  display: block;
  text-decoration: none;
}
.meet-card h2 { font-size: 1.35rem; margin: 12px 0 9px; }
.meet-card p, .detail-hero > p:not(.eyebrow) { color: var(--muted); }
.season { color: var(--blue); font-size: .78rem; font-weight: 750; letter-spacing: .12em; }
.counts, .summary {
  background: var(--pale);
  border-radius: 12px;
  color: var(--muted);
  display: flex;
  gap: 10px;
  margin: 21px 0;
  padding: 13px 15px;
}
.counts strong, .summary strong { color: var(--blue); }
.arrow, .back, td a { color: var(--blue); font-weight: 650; }
.back { display: inline-block; margin-bottom: 32px; text-decoration: none; }
.detail-hero { border-bottom: 1px solid var(--border); margin-bottom: 35px; padding-bottom: 28px; }
.summary { display: inline-flex; }
.summary strong { font-size: 1.3rem; margin-left: 7px; }
.summary strong:first-child { margin-left: 0; }
.sessions-program { margin-bottom: 34px; }
.sessions-program h2 { font-size: 1.2rem; margin: 0 0 16px; }
.session-grid { display: flex; flex-wrap: wrap; gap: 12px; }
.session-card { background: var(--pale); border-radius: 14px; display: grid; gap: 5px; min-width: 190px; padding: 14px 17px; }
.session-card span { color: var(--blue); font-size: .76rem; font-weight: 750; letter-spacing: .08em; text-transform: uppercase; }
.session-card small { color: var(--muted); font-size: 1rem; font-weight: 700; }
.documents { margin-bottom: 34px; }
.documents h2 { font-size: 1.2rem; margin: 0 0 16px; }
.document-list { display: grid; gap: 10px; max-width: 620px; }
.document-link { align-items: center; background: #fff; border: 1px solid var(--border); border-radius: 12px; color: var(--ink); display: flex; font-weight: 650; gap: 12px; padding: 12px 14px; text-decoration: none; }
.pdf-mark { background: #d7434f; border-radius: 6px; color: #fff; font-size: .72rem; font-weight: 800; padding: 6px 7px; }
.swimmers { display: grid; gap: 16px; }
.swimmer header { align-items: center; display: flex; justify-content: space-between; margin-bottom: 18px; }
.swimmer h2 { font-size: 1.2rem; margin: 0; }
.swimmer header span, .race small { color: var(--muted); font-size: .9rem; }
.races { display: flex; flex-wrap: wrap; gap: 10px; }
.race { background: var(--pale); border-radius: 12px; display: grid; gap: 5px; min-width: 200px; padding: 12px 14px; }
.race-number, .race-meta { color: var(--aqua); font-size: .76rem; font-weight: 750; }
.race-meta { align-items: center; display: flex; gap: 7px; }
.race-meta b { background: var(--aqua); border-radius: 6px; color: var(--navy); padding: 3px 6px; }
.admin-intro { margin-bottom: 26px; }
.admin-intro h1 { font-size: clamp(2rem, 4vw, 2.6rem); }
.admin-intro > p:not(.eyebrow) { color: var(--muted); }
code { background: #e9f2f6; border-radius: 5px; padding: 2px 6px; }
.flash { border-radius: 12px; margin-bottom: 22px; padding: 15px 18px; }
.flash.success { background: #e4f7eb; color: #13613a; }
.flash.error { background: #ffebeb; color: #8d2828; }
.upload { max-width: 560px; }
.upload h2, .published h2 { font-size: 1.2rem; margin: 0 0 22px; }
label { color: var(--muted); display: block; font-size: .88rem; font-weight: 650; margin-bottom: 18px; }
input {
  border: 1px solid #cadbe3;
  border-radius: 9px;
  display: block;
  font: inherit;
  margin-top: 8px;
  padding: 12px;
  width: 100%;
}
input[type=file] { background: var(--pale); }
.button {
  background: var(--blue);
  border: 0;
  border-radius: 10px;
  color: #fff;
  cursor: pointer;
  display: inline-block;
  font-weight: 650;
  padding: 13px 18px;
  text-decoration: none;
}
.published { margin-top: 22px; }
table { border-collapse: collapse; font-size: .94rem; width: 100%; }
td, th { border-bottom: 1px solid var(--border); padding: 12px 10px; text-align: left; }
th { color: var(--muted); font-size: .8rem; letter-spacing: .04em; text-transform: uppercase; }
.actions { align-items: center; display: flex; gap: 14px; }
.actions form { margin: 0; }
.delete-button { background: transparent; border: 0; color: #a93240; cursor: pointer; font: inherit; padding: 0; text-decoration: underline; }
.empty { background: var(--pale); border-radius: 20px; color: var(--muted); padding: 45px 25px; text-align: center; }
footer { border-top: 1px solid var(--border); color: var(--muted); padding: 28px; text-align: center; }
@media (max-width: 720px) {
  .mode { display: none; }
  .races { display: grid; }
  .race { min-width: 100%; }
}
