.sched-page { padding-bottom: var(--sp-7); }
.sched-head { display: flex; justify-content: space-between; align-items: flex-end; margin: var(--sp-4) 0 var(--sp-3); }
.sched-head__title { margin: 0; font-size: var(--t-28); letter-spacing: var(--ls-snug); }
.sched-head__sub { color: var(--text-mute); font-size: var(--t-12); }
.sched-sub {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--accent); color: #1a1300; border: 0; border-radius: var(--r-md);
  padding: 8px 14px; font-weight: var(--w-bold); font-size: var(--t-12); text-decoration: none;
}
.sched-sub:hover { background: var(--accent-strong); text-decoration: none; }

.sched-feat {
  margin: var(--sp-3) 0 var(--sp-5); padding: var(--sp-4); border: 1px solid var(--border);
  border-radius: var(--r-lg); background: var(--grad-hero), var(--surface-2); box-shadow: var(--elev-2);
}
.sched-feat__eb { font-size: var(--t-10); text-transform: uppercase; letter-spacing: var(--ls-caps); color: var(--accent); font-weight: var(--w-bold); }
.sched-feat__name { margin: var(--sp-2) 0 4px; font-size: var(--t-22); }
.sched-feat__meta { color: var(--text-mute); font-size: var(--t-13); }
.sched-feat__img { width: 100%; height: 180px; object-fit: cover; border-radius: var(--r-md); margin-top: var(--sp-3); border: 1px solid var(--border); }
.sched-chips, .meet__chips { display: flex; flex-wrap: wrap; gap: var(--sp-2); margin-top: var(--sp-3); }

.chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 5px 10px; border-radius: var(--r-full);
  background: var(--surface-1); border: 1px solid var(--border);
  color: var(--text-mute); font-size: var(--t-12); text-decoration: none;
}
.chip--dir { color: var(--accent); border-color: rgba(251,191,36,.3); }
.chip--wx  { color: var(--info); }

.sched-list { display: flex; flex-direction: column; gap: var(--sp-3); }
.meet {
  display: flex; gap: var(--sp-4); align-items: flex-start;
  padding: var(--sp-4); border: 1px solid var(--border); border-radius: var(--r-md); background: var(--surface-1);
}
.meet--done { opacity: 0.6; }
.meet__date { flex: none; width: 56px; text-align: center; }
.meet__mon  { font-size: var(--t-10); text-transform: uppercase; letter-spacing: var(--ls-caps); color: var(--accent); font-weight: var(--w-bold); }
.meet__day  { font-family: var(--font-mono); font-size: var(--t-28); font-weight: var(--w-black); line-height: 1; }
.meet__body { flex: 1; min-width: 0; }
.meet__name { font-weight: var(--w-bold); font-size: var(--t-16); }
.meet__meta { color: var(--text-mute); font-size: var(--t-12); margin-top: 2px; }
.meet__img  { width: 100%; max-height: 140px; object-fit: cover; border-radius: var(--r-sm); margin-top: var(--sp-3); border: 1px solid var(--border); }
.meet__results { margin-top: var(--sp-3); font-size: var(--t-12); color: var(--text-mute); border-top: 1px solid var(--divider); padding-top: var(--sp-2); }
.meet__results b { color: var(--text); }
.meet__status {
  flex: none; font-size: var(--t-10); text-transform: uppercase; letter-spacing: var(--ls-wide);
  padding: 3px 9px; border-radius: var(--r-full);
}
.st-next { background: var(--accent-soft); color: var(--accent); border: 1px solid rgba(251,191,36,.3); }
.st-upcoming { background: var(--surface-2); color: var(--text-mute); border: 1px solid var(--border); }
.st-done { background: rgba(34,197,94,.12); color: var(--success); border: 1px solid rgba(34,197,94,.25); }

.empty { padding: var(--sp-6); text-align: center; color: var(--text-mute); }

.chip--attach  { color: var(--text); border-color: var(--border-strong); }
.chip--history { color: var(--accent); border-color: rgba(251,191,36,.3); }

/* Hero race-day forecast — richer than a chip; only on the featured "Next up". */
.sched-feat__wx {
  margin-top: var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: var(--surface-1);
}
.wx__head { display: flex; align-items: center; gap: var(--sp-4); flex-wrap: wrap; }
.wx__icon { font-size: 2.2rem; line-height: 1; }
.wx__temp { display: flex; align-items: baseline; gap: var(--sp-2); }
.wx__hi   { font-family: var(--font-mono); font-size: var(--t-28); font-weight: var(--w-black); color: var(--text); line-height: 1; }
.wx__lo   { font-family: var(--font-mono); font-size: var(--t-12); color: var(--text-mute); }
.wx__bits { display: flex; gap: var(--sp-3); color: var(--text-mute); font-size: var(--t-13); }
.wx__label { color: var(--text-mute); font-size: var(--t-12); margin-top: var(--sp-2); }
