/* ═══════════════════════════════════════════════════════════
   FUSSBALL — Seiten-spezifische Komponenten (fussball.sv-heimstetten.de)
   Ergänzt svh-base.css + svh-abteilung.css. Innerhalb der Fußball-SWA
   1× gepflegt, von allen Fußball-Unterseiten eingebunden.
   ═══════════════════════════════════════════════════════════ */

/* Sub-Navigation (Bereiche innerhalb Fußball) — klebt unter der Hauptnav */
.subnav { position: sticky; top: 71px; z-index: 900; background: rgba(255,255,255,.97); backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); border-bottom: 1px solid var(--svh-linie); }
.subnav__inner { display: flex; gap: 2px; max-width: 1180px; margin: 0 auto; padding: 0 24px; overflow-x: auto; -ms-overflow-style: none; scrollbar-width: none; }
.subnav__inner::-webkit-scrollbar { display: none; }
.subnav__inner a { flex-shrink: 0; font-family: var(--font-display); font-size: 12px; font-weight: 800; letter-spacing: .05em; text-transform: uppercase; color: var(--svh-text-2); padding: 15px 16px; border-bottom: 2px solid transparent; white-space: nowrap; transition: color .2s, border-color .2s; }
.subnav__inner a:hover { color: var(--svh-rot); }
.subnav__inner a[aria-current="page"] { color: var(--svh-rot); border-bottom-color: var(--svh-rot); }

/* Hero mit Bild-Hintergrund (Variante) */
.hero--img { background: var(--svh-anthrazit); }
.hero--img .hero__bg { position: absolute; inset: 0; z-index: 0; }
.hero--img .hero__bg img { width: 100%; height: 100%; object-fit: cover; opacity: .32; }
.hero--img::after { display: none; }
.hero--img .hero__overlay { position: absolute; inset: 0; z-index: 1; background: linear-gradient(120deg, rgba(35,38,42,.94) 0%, rgba(42,45,49,.72) 55%, rgba(174,21,32,.30) 100%); }
.hero--img .container { position: relative; z-index: 2; }

/* Bereiche-Kacheln (Wegweiser zu den Unterseiten) */
.bereiche-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.bereich { display: flex; flex-direction: column; gap: 8px; background: #fff; border: 1px solid var(--svh-linie); border-radius: var(--r-md); padding: 24px 22px; transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease; }
.bereich:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--svh-rot-hell); }
.bereich__k { font-family: var(--font-display); font-size: 10.5px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; color: var(--svh-rot); }
.bereich__t { font-family: var(--font-display); font-size: 20px; font-weight: 900; letter-spacing: -.01em; text-transform: uppercase; color: var(--svh-text); line-height: 1.05; }
.bereich__d { font-size: 13.5px; line-height: 1.55; color: var(--svh-text-sek); flex: 1; }
.bereich__go { font-family: var(--font-display); font-size: 12px; font-weight: 800; letter-spacing: .04em; text-transform: uppercase; color: var(--svh-rot); }

/* Fakten-Liste (dl) */
.facts { display: grid; grid-template-columns: auto 1fr; gap: 10px 22px; margin: 4px 0 22px; }
.facts dt { font-family: var(--font-display); font-size: 12px; font-weight: 800; letter-spacing: .06em; text-transform: uppercase; color: var(--svh-rot); }
.facts dd { font-size: 14.5px; color: var(--svh-text-2); }

/* Zwei-Spalten-Feature (Text + Faktenkasten / Bild) */
.feature { display: grid; grid-template-columns: 1.15fr .85fr; gap: 38px; align-items: start; }
.feature__text h2 { margin-bottom: 14px; }
.feature__text p { color: var(--svh-text-sek); margin-bottom: 16px; line-height: 1.7; }
.feature__panel { background: var(--svh-bg); border: 1px solid var(--svh-linie); border-radius: var(--r-md); padding: 26px 28px; }
.feature__panel .facts { margin-bottom: 0; }

/* Externe Link-Buttons (Reihe) */
.pill-row { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 8px; }

/* Turnier-Karten */
.turnier { display: grid; grid-template-columns: auto 1fr; gap: 22px; align-items: center; background: #fff; border: 1px solid var(--svh-linie); border-left: 4px solid var(--svh-rot); border-radius: var(--r-md); padding: 24px 28px; margin-bottom: 14px; }
.turnier__no { font-family: var(--font-display); font-weight: 900; font-size: 34px; color: var(--svh-rot-hell); line-height: 1; }
.turnier__t { font-family: var(--font-display); font-size: 19px; font-weight: 800; letter-spacing: -.01em; color: var(--svh-text); margin-bottom: 4px; }
.turnier__d { font-size: 14px; color: var(--svh-text-sek); line-height: 1.55; }

/* Highlight-Callout (mit Bild) */
.callout { display: grid; grid-template-columns: 300px 1fr; gap: 0; background: #fff; border: 1px solid var(--svh-linie); border-radius: var(--r-lg); overflow: hidden; box-shadow: var(--shadow-sm); }
.callout__img { background: var(--svh-linie-2); }
.callout__img img { width: 100%; height: 100%; object-fit: cover; min-height: 220px; }
.callout__body { padding: 30px 34px; }
.callout__badge { display: inline-block; font-family: var(--font-display); font-size: 10px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; color: var(--svh-rot); background: var(--svh-rot-hell); border-radius: 100px; padding: 5px 13px; margin-bottom: 12px; }
.callout__body h3 { font-family: var(--font-display); font-size: 22px; font-weight: 900; letter-spacing: -.01em; text-transform: uppercase; color: var(--svh-text); line-height: 1.1; margin-bottom: 10px; }
.callout__body p { font-size: 14.5px; color: var(--svh-text-sek); line-height: 1.7; }

/* Zielliste (Nachwuchskonzept) */
.ziele { display: grid; grid-template-columns: 1fr 1fr; gap: 10px 28px; margin-top: 6px; }
.ziele li { position: relative; padding-left: 24px; font-size: 14.5px; line-height: 1.6; color: var(--svh-text-2); }
.ziele li::before { content: ''; position: absolute; left: 0; top: 8px; width: 9px; height: 9px; border-radius: 50%; background: var(--svh-rot); }

@media (max-width: 960px) {
  .bereiche-grid { grid-template-columns: 1fr 1fr; }
  .feature { grid-template-columns: 1fr; gap: 28px; }
  .callout { grid-template-columns: 1fr; }
  .callout__img img { min-height: 200px; }
  .ziele { grid-template-columns: 1fr; }
}
@media (max-width: 560px) {
  .bereiche-grid { grid-template-columns: 1fr; }
  .turnier { grid-template-columns: 1fr; gap: 10px; }
}
