body {
  background: radial-gradient(circle at top, #020617 0, #020617 40%, #020617 60%, #020617 100%), var(--color-bg);
}

.sports-layout {
  display: flex;
  flex-direction: column;
  gap: var(--space-8);
}

.sports-hero {
  display: grid;
  gap: var(--space-6);
  align-items: center;
}

@media (min-width: 768px) {
  .sports-hero {
    grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
  }
}

.sports-hero-text h1 {
  margin-top: var(--space-3);
}

.sports-hero-lead {
  margin-top: var(--space-3);
  color: var(--color-text-muted);
  max-width: 36rem;
}

.sports-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-top: var(--space-4);
}

.sports-hero-meta {
  margin-top: var(--space-3);
  max-width: 40rem;
  font-size: var(--text-sm);
}

.sports-hero-media {
  justify-self: stretch;
}

.sports-hero-image-wrapper {
  border-radius: var(--radius-card);
  overflow: hidden;
  border: 1px solid var(--color-border-subtle);
  background: radial-gradient(circle at top left, rgba(34,211,238,0.35), rgba(15,23,42,0.98));
  box-shadow: var(--shadow-md);
}

.sports-hero-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.sports-section-header h2 {
  margin-bottom: var(--space-1);
}

.sports-filter-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.field--inline {
  min-width: 13rem;
}

.sports-filter-extra {
  display: grid;
  gap: var(--space-4);
  align-items: center;
}

@media (min-width: 768px) {
  .sports-filter-extra {
    grid-template-columns: minmax(0, 1.1fr) minmax(0, 1.4fr);
  }
}

.sports-filter-image {
  border-radius: var(--radius-card);
  overflow: hidden;
}

.sports-filter-visual {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.sports-filter-copy h3 {
  margin-bottom: var(--space-2);
}

.sports-table {
  min-width: 640px;
}

.sports-basketball-grid,
.sports-tennis-grid,
.sports-faq-grid {
  margin-top: var(--space-4);
}

.sports-event-card .card-meta {
  margin-top: 0;
}

.sports-card-heading {
  align-items: center;
}

.sports-card-tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.sports-icon {
  font-size: 1.15rem;
}

.sports-tennis-list,
.sports-infographic-list {
  margin-top: var(--space-2);
  margin-bottom: var(--space-2);
  padding-left: var(--space-4);
}

.sports-tennis-list li,
.sports-infographic-list li {
  color: var(--color-text);
  font-size: var(--text-sm);
  list-style: disc;
}

.sports-tennis-list li + li,
.sports-infographic-list li + li {
  margin-top: var(--space-1);
}

.sports-calendar-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.sports-calendar-header {
  flex-wrap: wrap;
}

.sports-calendar-legend {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  font-size: var(--text-xs);
}

.sports-status {
  padding: 0.25rem 0.7rem;
  border-radius: var(--radius-pill);
  border: 1px solid var(--color-border-subtle);
}

.sports-status--live {
  border-color: var(--color-danger);
  color: var(--color-danger);
}

.sports-status--upcoming {
  border-color: var(--color-accent);
  color: var(--color-accent);
}

.sports-status--planned {
  border-color: var(--color-primary);
  color: var(--color-primary);
}

.sports-calendar-item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-top: var(--space-2);
}

.calendar-dot--football {
  background: #22d3ee;
}

.calendar-dot--basketball {
  background: #f97316;
}

.calendar-dot--tennis {
  background: #a3e635;
}

.calendar-dot--other {
  background: #e5e7eb;
}

.sports-calendar-text {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}

.sports-infographic-wrapper {
  display: grid;
  gap: var(--space-4);
}

@media (min-width: 768px) {
  .sports-infographic-wrapper {
    grid-template-columns: minmax(0, 1.2fr) minmax(0, 1.4fr);
  }
}

.sports-infographic-media {
  border-radius: var(--radius-card);
  overflow: hidden;
}

.sports-infographic-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.sports-infographic-copy h3 {
  margin-bottom: var(--space-2);
}

.sports-faq-item h3 {
  margin-bottom: var(--space-2);
}

.sports-legal {
  margin-bottom: var(--space-4);
}

@media (max-width: 639.98px) {
  .sports-hero-actions {
    flex-direction: column;
    align-items: flex-start;
  }

  .sports-table {
    font-size: var(--text-xs);
  }
}
