/* ==========================================================================
   SG WBO – wbo-features.css
   Neue Features: Countdown, Download-Center, POTM, Sportstätten, Sponsoren-Slider
   Einbinden in header.php:
     <link rel="stylesheet" href="/assets/css/wbo-features.css">
   ========================================================================== */

/* ==========================================================================
   FEATURE 1: Next Game Countdown
   ========================================================================== */

.cdw-section {
  padding: clamp(2rem, 4vw, 3.5rem) 0;
}

/* Karte Basis */
.cdw-card {
  max-width: 780px;
  margin: 0 auto;
  padding: clamp(1.5rem, 3vw, 2.5rem);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.25rem;
  text-align: center;
  border: 1px solid rgba(0, 150, 71, .18);
  background: rgba(255, 255, 255, .72);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  transition: box-shadow .25s ease;
}

.cdw-card:hover {
  box-shadow: 0 8px 32px rgba(0, 150, 71, .14);
}

/* Live-Variante */
.cdw-card--live {
  border-color: var(--accent, #ff5a5f);
  background: rgba(255, 255, 255, .85);
}

/* Badges */
.cdw-badge {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  padding: .3rem .85rem;
  border-radius: 999px;
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  background: var(--primary-bg-light, #e0f4ea);
  color: var(--primary-dark, #007838);
  border: 1px solid rgba(0, 150, 71, .2);
}

.cdw-badge--live {
  background: rgba(255, 90, 95, .12);
  color: var(--accent, #ff5a5f);
  border-color: rgba(255, 90, 95, .25);
  animation: cdw-pulse-border 2s infinite;
}

.cdw-badge--info {
  background: var(--gray-100, #e6e8ec);
  color: var(--gray-700, #3a4557);
  border-color: transparent;
}

.cdw-card__top {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  justify-content: center;
}

/* Live-Puls-Punkt */
.cdw-live-pulse {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--accent, #ff5a5f);
  animation: cdw-dot-blink .9s ease-in-out infinite;
}

@keyframes cdw-dot-blink {
  0%, 100% { opacity: 1; }
  50%       { opacity: .25; }
}

@keyframes cdw-pulse-border {
  0%, 100% { box-shadow: 0 0 0 0 rgba(255, 90, 95, 0); }
  50%       { box-shadow: 0 0 0 4px rgba(255, 90, 95, .18); }
}

/* Mannschaften */
.cdw-card__matchup {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(.75rem, 3vw, 2rem);
  width: 100%;
}

.cdw-team {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .45rem;
  flex: 1;
  max-width: 180px;
}

.cdw-team__logo {
  width: clamp(48px, 10vw, 72px);
  height: clamp(48px, 10vw, 72px);
  object-fit: contain;
  filter: drop-shadow(0 2px 6px rgba(0,0,0,.1));
}

.cdw-team__name {
  font-size: clamp(.85rem, 2vw, 1.05rem);
  font-weight: 700;
  color: var(--text-primary, #111);
  line-height: 1.2;
}

.cdw-team__role {
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--text-tertiary, #6d7685);
}

.cdw-vs {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--gray-100, #e6e8ec);
  flex-shrink: 0;
}

.cdw-vs__text {
  font-size: .88rem;
  font-weight: 900;
  color: var(--gray-500, #6d7685);
  text-transform: uppercase;
  letter-spacing: .04em;
}

/* Info-Zeile */
.cdw-card__info-row {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem .75rem;
  justify-content: center;
}

.cdw-card__info-item {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  font-size: .86rem;
  color: var(--text-secondary, #4f5c70);
}

.cdw-card__info-item i {
  color: var(--primary, #009647);
  font-size: .8rem;
}

/* Countdown-Einheiten */
.cdw-countdown {
  display: flex;
  align-items: center;
  gap: clamp(.4rem, 1.5vw, 1rem);
  flex-wrap: nowrap;
}

.cdw-unit {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .25rem;
  min-width: clamp(54px, 13vw, 76px);
}

.cdw-unit__value {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: clamp(54px, 13vw, 76px);
  background: var(--primary, #009647);
  color: #fff;
  font-size: clamp(1.4rem, 4vw, 2.1rem);
  font-weight: 800;
  border-radius: .75rem;
  font-variant-numeric: tabular-nums;
  line-height: 1;
  transition: background-color .3s ease;
}

.cdw-unit__label {
  font-size: .7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--text-tertiary, #6d7685);
}

.cdw-countdown__sep {
  font-size: clamp(1.2rem, 3vw, 1.8rem);
  font-weight: 900;
  color: var(--primary, #009647);
  padding-bottom: 1.25rem; /* Ausrichten mit Wert-Box */
  line-height: 1;
}

/* CTA Buttons */
.cdw-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: .65rem;
  justify-content: center;
}

/* Fallback: kein Spiel */
.cdw-empty {
  max-width: 540px;
  margin: 0 auto;
  padding: clamp(1.5rem, 3vw, 2.5rem);
}

.cdw-empty__icon {
  font-size: 2.5rem;
  color: var(--gray-300, #b1bacb);
  display: block;
  margin-bottom: .75rem;
}

.cdw-empty__text {
  color: var(--text-secondary, #4f5c70);
}

/* Countdown abgelaufen-Zustand */
.cdw-unit__value--expired {
  background: var(--gray-400, #8e9aa8);
}

/* ==========================================================================
   FEATURE 2: Download-Center
   ========================================================================== */

.dlc-intro-icon {
  width: 52px;
  height: 52px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: var(--primary-bg-light, #e0f4ea);
  color: var(--primary, #009647);
  font-size: 1.4rem;
  flex-shrink: 0;
}

.dlc-cat-heading {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--text-primary, #111);
  display: flex;
  align-items: center;
  gap: .6rem;
  margin-bottom: 1rem;
  padding-bottom: .6rem;
  border-bottom: 2px solid var(--primary-bg-light, #e0f4ea);
}

.dlc-cat-heading i {
  color: var(--primary, #009647);
}

.dlc-cat-count {
  margin-left: auto;
  font-size: .78rem;
  font-weight: 600;
  color: var(--text-tertiary, #6d7685);
  background: var(--gray-100, #e6e8ec);
  padding: .15rem .55rem;
  border-radius: 999px;
}

/* Grid der Download-Karten */
.dlc-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1rem;
}

/* Download-Karte */
.dlc-card {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  padding: 1.1rem 1.25rem;
  transition: box-shadow .2s ease, transform .15s ease;
  background: rgba(255, 255, 255, .8);
  border: 1px solid rgba(0, 0, 0, .06);
}

.dlc-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(0, 0, 0, .09);
}

.dlc-card__icon {
  font-size: 1.8rem;
  flex-shrink: 0;
  line-height: 1;
  padding-top: .1rem;
}

.dlc-card__body {
  flex: 1;
  min-width: 0;
}

.dlc-card__title {
  font-size: .95rem;
  font-weight: 700;
  margin: 0 0 .25rem;
  color: var(--text-primary, #111);
}

.dlc-card__desc {
  font-size: .82rem;
  color: var(--text-secondary, #4f5c70);
  margin: 0 0 .5rem;
  line-height: 1.45;
}

.dlc-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: .35rem;
}

.dlc-meta-badge {
  display: inline-block;
  font-size: .72rem;
  font-weight: 600;
  padding: .15rem .5rem;
  border-radius: 4px;
  background: var(--gray-100, #e6e8ec);
  color: var(--gray-700, #3a4557);
}

.dlc-meta-badge--type {
  background: var(--primary-bg-light, #e0f4ea);
  color: var(--primary-dark, #007838);
}

.dlc-card__action {
  flex-shrink: 0;
  align-self: center;
}

.dlc-card__btn {
  white-space: nowrap;
  font-size: .82rem;
}

/* Hinweis-Box */
.dlc-hint {
  display: flex;
  align-items: flex-start;
  gap: .85rem;
}

.dlc-hint__icon {
  font-size: 1.4rem;
  color: var(--info, #3b82f6);
  flex-shrink: 0;
}

/* Responsive: auf kleinen Screens Karte stacken */
@media (max-width: 480px) {
  .dlc-card {
    flex-wrap: wrap;
  }

  .dlc-card__action {
    width: 100%;
  }

  .dlc-card__btn {
    width: 100%;
    text-align: center;
  }
}

/* ==========================================================================
   FEATURE 3: Player of the Match
   ========================================================================== */

/* Match-Header */
.potm-match-header {
  text-align: center;
}

.potm-match-header__teams {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(.75rem, 3vw, 2rem);
  flex-wrap: wrap;
  margin-bottom: .75rem;
}

.potm-match-header__team {
  font-size: clamp(1rem, 2.5vw, 1.35rem);
  font-weight: 800;
  color: var(--text-primary, #111);
}

.potm-match-header__score {
  font-size: clamp(1.3rem, 3.5vw, 1.8rem);
  font-weight: 900;
  color: var(--primary, #009647);
  padding: .1rem .65rem;
  background: var(--primary-bg-light, #e0f4ea);
  border-radius: .5rem;
}

.potm-match-header__vs {
  font-size: 1rem;
  font-weight: 700;
  color: var(--gray-400, #8e9aa8);
}

.potm-match-header__meta {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem .9rem;
  justify-content: center;
  color: var(--text-secondary, #4f5c70);
  font-size: .86rem;
}

.potm-match-header__meta i {
  color: var(--primary, #009647);
  margin-right: .3rem;
}

/* Status-Badge */
.potm-status-badge {
  display: inline-flex;
  align-items: center;
  gap: .3rem;
  padding: .2rem .65rem;
  border-radius: 999px;
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
}

.potm-status-badge--open {
  background: rgba(16, 185, 129, .15);
  color: #047857;
}

.potm-status-badge--closed {
  background: var(--gray-100, #e6e8ec);
  color: var(--gray-600, #4f5c70);
}

/* Bereits-Abgestimmt-Hinweis */
.potm-voted-notice {
  display: flex;
  align-items: center;
  gap: .5rem;
  font-size: .9rem;
  color: var(--text-primary, #111);
  background: rgba(16, 185, 129, .1);
  border: 1px solid rgba(16, 185, 129, .25);
}

/* Spieler-Grid */
.potm-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 1rem;
}

/* Spieler-Karte */
.potm-player-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 1.25rem 1rem;
  gap: .75rem;
  text-align: center;
  background: rgba(255, 255, 255, .8);
  border: 2px solid transparent;
  transition: border-color .2s ease, box-shadow .2s ease, transform .15s ease;
  position: relative;
  overflow: hidden;
}

.potm-player-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, .1);
}

.potm-player-card--leading {
  border-color: var(--warning, #f59e0b);
  background: rgba(245, 158, 11, .06);
}

.potm-player-card--voted {
  border-color: var(--primary, #009647);
  background: rgba(0, 150, 71, .06);
}

/* Avatar */
.potm-player-card__avatar {
  position: relative;
  width: 80px;
  height: 80px;
}

.potm-player-card__img {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  object-fit: cover;
  border: 3px solid var(--gray-200, #d1d5dc);
}

.potm-player-card--leading .potm-player-card__img {
  border-color: var(--warning, #f59e0b);
}

.potm-player-card--voted .potm-player-card__img {
  border-color: var(--primary, #009647);
}

.potm-player-card__crown {
  position: absolute;
  top: -6px;
  right: -4px;
  font-size: 1.1rem;
  color: var(--warning, #f59e0b);
  filter: drop-shadow(0 1px 3px rgba(0,0,0,.25));
}

/* Info */
.potm-player-card__info {
  display: flex;
  flex-direction: column;
  gap: .2rem;
  align-items: center;
}

.potm-player-card__number {
  font-size: .72rem;
  font-weight: 700;
  color: var(--text-tertiary, #6d7685);
  text-transform: uppercase;
  letter-spacing: .05em;
}

.potm-player-card__name {
  font-size: .95rem;
  font-weight: 700;
  color: var(--text-primary, #111);
  line-height: 1.2;
}

.potm-player-card__team {
  font-size: .78rem;
  color: var(--text-secondary, #4f5c70);
}

.potm-player-card__pos {
  font-size: .72rem;
  color: var(--text-tertiary, #6d7685);
  text-transform: uppercase;
  letter-spacing: .04em;
}

/* Ergebnisbalken */
.potm-player-card__result {
  width: 100%;
}

.potm-bar {
  height: 6px;
  background: var(--gray-100, #e6e8ec);
  border-radius: 999px;
  overflow: hidden;
  margin-bottom: .3rem;
}

.potm-bar__fill {
  height: 100%;
  background: var(--primary, #009647);
  border-radius: 999px;
  transition: width .6s ease;
}

.potm-player-card--leading .potm-bar__fill {
  background: var(--warning, #f59e0b);
}

.potm-bar__label {
  font-size: .75rem;
  color: var(--text-secondary, #4f5c70);
}

/* Vote-Button */
.potm-vote-btn {
  width: 100%;
  font-size: .84rem;
  padding: .4rem .8rem;
}

/* Deine-Wahl Badge */
.potm-voted-badge {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  color: var(--primary, #009647);
  font-size: .82rem;
  font-weight: 700;
}

/* Toast-Feedback */
.potm-toast {
  position: fixed;
  bottom: clamp(80px, 10vh, 100px);
  left: 50%;
  transform: translateX(-50%);
  background: var(--gray-900, #111827);
  color: #fff;
  padding: .65rem 1.25rem;
  border-radius: .65rem;
  font-size: .88rem;
  z-index: 9999;
  box-shadow: 0 4px 20px rgba(0,0,0,.25);
  transition: opacity .3s ease;
  white-space: nowrap;
  pointer-events: none;
}

.potm-toast.potm-toast--success {
  background: var(--primary, #009647);
}

.potm-toast.potm-toast--error {
  background: var(--error, #ef4444);
}

/* Gesamt-Votes */
.potm-total-votes {
  font-size: .88rem;
}

/* ==========================================================================
   FEATURE 4: Sportstätten-Check
   ========================================================================== */

.loc-intro-icon {
  width: 52px;
  height: 52px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: var(--primary-bg-light, #e0f4ea);
  color: var(--primary, #009647);
  font-size: 1.4rem;
  flex-shrink: 0;
}

/* Grid */
.loc-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 1.5rem;
}

/* Karte */
.loc-card {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  background: rgba(255, 255, 255, .8);
  border: 1px solid rgba(0, 0, 0, .07);
  transition: transform .2s ease, box-shadow .2s ease;
}

.loc-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 10px 30px rgba(0, 0, 0, .1);
}

/* Bild */
.loc-card__img-wrap {
  height: 180px;
  overflow: hidden;
}

.loc-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .35s ease;
}

.loc-card:hover .loc-card__img {
  transform: scale(1.04);
}

/* Body */
.loc-card__body {
  padding: 1.25rem;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: .6rem;
}

.loc-card__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: .75rem;
  flex-wrap: wrap;
}

.loc-card__name {
  font-size: 1.05rem;
  font-weight: 800;
  margin: 0;
  color: var(--text-primary, #111);
}

/* Untergrund-Badge */
.loc-badge {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  padding: .25rem .7rem;
  border-radius: 999px;
  font-size: .72rem;
  font-weight: 700;
  white-space: nowrap;
  flex-shrink: 0;
}

.loc-badge--rasen      { background: rgba(16,185,129,.15);  color: #047857; }
.loc-badge--kunstrasen { background: rgba(59,130,246,.12);  color: #1d4ed8; }
.loc-badge--halle      { background: rgba(139,92,246,.12);  color: #6d28d9; }
.loc-badge--asche      { background: rgba(107,114,128,.15); color: #374151; }
.loc-badge--sonstiges  { background: var(--gray-100);       color: var(--gray-600); }

.loc-card__address,
.loc-card__teams {
  font-size: .86rem;
  color: var(--text-secondary, #4f5c70);
  display: flex;
  align-items: flex-start;
  gap: .45rem;
  margin: 0;
}

.loc-card__address i,
.loc-card__teams i {
  color: var(--primary, #009647);
  margin-top: .15rem;
  flex-shrink: 0;
}

.loc-card__desc {
  font-size: .88rem;
  color: var(--text-primary, #111);
  margin: 0;
  line-height: 1.5;
}

/* Hinweis-Chips */
.loc-hints {
  display: flex;
  flex-direction: column;
  gap: .5rem;
  padding: .75rem;
  background: var(--gray-50, #f2f3f5);
  border-radius: .6rem;
}

.loc-hint {
  display: flex;
  align-items: flex-start;
  gap: .6rem;
  font-size: .82rem;
}

.loc-hint__title {
  font-weight: 700;
  color: var(--text-primary, #111);
  display: flex;
  align-items: center;
  gap: .3rem;
  white-space: nowrap;
  flex-shrink: 0;
  min-width: 80px;
}

.loc-hint__title i {
  color: var(--primary, #009647);
  font-size: .8rem;
}

.loc-hint__text {
  color: var(--text-secondary, #4f5c70);
  line-height: 1.4;
}

/* CTA */
.loc-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: .6rem;
  padding: 1rem 1.25rem;
  border-top: 1px solid var(--gray-100, #e6e8ec);
  background: rgba(255,255,255,.5);
}

.loc-card__actions .btn {
  flex: 1;
  font-size: .84rem;
  min-width: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .4rem;
}

/* Hinweis-Box */
.loc-hint-box {
  display: flex;
  align-items: flex-start;
  gap: .85rem;
}

.loc-hint-box__icon {
  font-size: 1.4rem;
  color: var(--info, #3b82f6);
  flex-shrink: 0;
}

/* ==========================================================================
   FEATURE 5: Sponsoren-Slider (modernisiert)
   ========================================================================== */

.spslider-section {
  padding: clamp(2.5rem, 5vw, 4rem) 0;
  background: var(--surface, #fff);
  border-top: 1px solid var(--gray-100, #e6e8ec);
}

.spslider-inner {
  display: flex;
  flex-direction: column;
  gap: 1.75rem;
}

/* Header */
.spslider-header {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .5rem;
  text-align: center;
}

.spslider-header__title {
  font-size: clamp(.95rem, 2.5vw, 1.15rem);
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--text-secondary, #4f5c70);
  display: flex;
  align-items: center;
  gap: .75rem;
  margin: 0;
}

.spslider-header__line {
  display: block;
  height: 1px;
  width: clamp(24px, 5vw, 48px);
  background: var(--gray-300, #b1bacb);
}

.spslider-header__sub {
  font-size: .82rem;
  color: var(--text-tertiary, #6d7685);
  margin: 0;
}

.spslider-header__cta {
  margin-top: .25rem;
}

/* Slider-Wrapper */
.spslider-wrap {
  position: relative;
  display: flex;
  align-items: center;
  gap: .5rem;
}

/* Prev/Next-Buttons */
.spslider-btn {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  border: 1px solid var(--gray-200, #d1d5dc);
  background: var(--surface, #fff);
  color: var(--gray-600, #4f5c70);
  cursor: pointer;
  transition: border-color .2s, background .2s, color .2s;
  z-index: 2;
}

.spslider-btn:hover {
  border-color: var(--primary, #009647);
  background: var(--primary-bg-light, #e0f4ea);
  color: var(--primary-dark, #007838);
}

.spslider-btn:focus-visible {
  outline: 2px solid var(--primary, #009647);
  outline-offset: 2px;
}

/* Track-Container (maskiert overflow) */
.spslider-track-outer {
  flex: 1;
  overflow: hidden;
  cursor: grab;
  outline: none;
  user-select: none;
}

.spslider-track-outer:active {
  cursor: grabbing;
}

/* Innerer Track (scrollt per JS) */
.spslider-track {
  display: flex;
  gap: 1.5rem;
  width: max-content;
  transition: transform .4s cubic-bezier(.4,0,.2,1);
  will-change: transform;
}

/* Pause bei Hover */
.spslider-wrap:hover .spslider-track {
  animation-play-state: paused;
}

/* Ein Logo-Slot */
.spslider-item {
  flex: 0 0 auto;
  width: clamp(100px, 16vw, 160px);
}

.spslider-logo-link {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 72px;
  padding: .6rem;
  border-radius: .65rem;
  border: 1px solid var(--gray-100, #e6e8ec);
  background: #fff;
  transition: border-color .2s ease, box-shadow .2s ease, transform .15s ease;
  text-decoration: none;
}

.spslider-logo-link:hover {
  border-color: var(--gray-300, #b1bacb);
  box-shadow: 0 4px 14px rgba(0,0,0,.08);
  transform: translateY(-2px);
}

.spslider-logo {
  max-width: 100%;
  max-height: 50px;
  width: auto;
  height: auto;
  object-fit: contain;
  filter: grayscale(30%);
  transition: filter .25s ease;
}

.spslider-logo-link:hover .spslider-logo {
  filter: grayscale(0%);
}

/* Fade-out an den Rändern */
.spslider-track-outer::before,
.spslider-track-outer::after {
  content: '';
  position: absolute;
  top: 0;
  width: 40px;
  height: 100%;
  z-index: 1;
  pointer-events: none;
}

.spslider-track-outer::before {
  left: 0;
  background: linear-gradient(to right, var(--surface, #fff), transparent);
}

.spslider-track-outer::after {
  right: 0;
  background: linear-gradient(to left, var(--surface, #fff), transparent);
}

/* ==========================================================================
   RESPONSIVE ANPASSUNGEN (alle Features)
   ========================================================================== */

@media (max-width: 576px) {

  /* Countdown */
  .cdw-countdown {
    gap: .3rem;
  }

  .cdw-unit {
    min-width: 52px;
  }

  .cdw-card__matchup {
    gap: .5rem;
  }

  .cdw-team__logo {
    width: 44px;
    height: 44px;
  }

  /* Download-Center */
  .dlc-grid {
    grid-template-columns: 1fr;
  }

  /* POTM */
  .potm-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  /* Sportstätten */
  .loc-grid {
    grid-template-columns: 1fr;
  }

  /* Sponsoren */
  .spslider-btn {
    display: none;
  }
}

@media (max-width: 400px) {
  /* POTM: 1-Spalten-Layout */
  .potm-grid {
    grid-template-columns: 1fr;
  }
}
