/*
Theme Name: TSV Korntal Steeldarts
Theme URI: https://www.tsv-korntal.de
Author: TSV Korntal e.V.
Author URI: https://www.tsv-korntal.de
Description: Offizielles WordPress-Theme der Steeldarts-Abteilung des TSV Korntal e.V. – Wo Präzision auf Gemeinschaft trifft.
Version: 1.0.0
Requires at least: 5.8
Tested up to: 6.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: tsv-korntal-steeldarts
Tags: sports, one-page, responsive, custom-colors
*/

/* ============================================================
   SELBST GEHOSTETE SCHRIFTEN (DSGVO-konform, keine Google CDN)
   ============================================================ */

/* Bebas Neue – Regular 400 */
@font-face{font-family:'Bebas Neue';font-style:normal;font-weight:400;font-display:swap;src:url('fonts/bebas-neue-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Bebas Neue';font-style:normal;font-weight:400;font-display:swap;src:url('fonts/bebas-neue-latin.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}

/* DM Sans – Normal 300–700 (variable font, eine Datei) */
@font-face{font-family:'DM Sans';font-style:normal;font-weight:300 700;font-display:swap;src:url('fonts/dm-sans-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'DM Sans';font-style:normal;font-weight:300 700;font-display:swap;src:url('fonts/dm-sans-latin.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}

/* DM Sans – Italic 400 */
@font-face{font-family:'DM Sans';font-style:italic;font-weight:400;font-display:swap;src:url('fonts/dm-sans-italic-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'DM Sans';font-style:italic;font-weight:400;font-display:swap;src:url('fonts/dm-sans-italic-latin.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}

/* Playfair Display – Bold 700 */
@font-face{font-family:'Playfair Display';font-style:normal;font-weight:700;font-display:swap;src:url('fonts/playfair-display-latin-ext-700.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Playfair Display';font-style:normal;font-weight:700;font-display:swap;src:url('fonts/playfair-display-latin-700.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}

/* Playfair Display – Bold Italic 700 */
@font-face{font-family:'Playfair Display';font-style:italic;font-weight:700;font-display:swap;src:url('fonts/playfair-display-italic-latin-ext-700.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Playfair Display';font-style:italic;font-weight:700;font-display:swap;src:url('fonts/playfair-display-italic-latin-700.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}

/* ============================================================
   DESIGN TOKENS & RESET
   ============================================================ */
:root{--blue:#2563a8;--blue-dark:#1a4578;--blue-deeper:#0f2b4e;--navy:#162742;--red:#c8102e;--red-dark:#a00d24;--gold:#c9a84c;--gold-light:#e0c675;--gold-pale:#f0dfa0;--wheat:#f5e8cc;--wheat-light:#faf3e3;--cream:#fefcf7;--white:#fff;--g50:#f9fafb;--g100:#f3f4f6;--g200:#e5e7eb;--g300:#d1d5db;--g400:#9ca3af;--g500:#6b7280;--g600:#4b5563;--g700:#374151;--g800:#1f2937;--g900:#111827;--fd:'Bebas Neue',sans-serif;--fs:'Playfair Display',serif;--fb:'DM Sans',sans-serif;--ease:cubic-bezier(.16,1,.3,1);--ease2:cubic-bezier(.34,1.56,.64,1);--nh:72px;--sp-y:100px}
/* --sp-y: globales vertikales Section-Padding. Zentrale Stelle für die Rhythmik
   zwischen allen Content-Sections. Wert hier ändern → wirkt überall (außer
   Sonderfälle: .hero hat kein Padding, .sb ist Stats-Strip unter Hero,
   .ctb hat zusätzlich horizontales Padding für die rote Mitte). */
@media(max-width:768px){:root{--sp-y:60px}}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:var(--nh);overflow-x:clip}
/* font-synthesis:none verhindert, dass Browser fehlende Schnitte algorithmisch
   "nachfetten" (Bebas Neue ist nur als 400 geladen → ohne diese Regel rendern
   Browser einen Faux-Bold auf h1/h2/h3, was die Headings künstlich verbreitert). */
body{font-family:var(--fb);color:var(--g800);background:var(--cream);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased;font-synthesis:none}
img{max-width:100%;display:block}a{text-decoration:none;color:inherit}button{cursor:pointer;border:none;font-family:inherit}ul{list-style:none}
.ctr{max-width:1320px;margin:0 auto;padding:0 24px}
.slbl{font-family:var(--fd);font-size:.875rem;letter-spacing:4px;text-transform:uppercase;color:var(--gold);margin-bottom:8px}
.sttl{font-family:var(--fd);font-size:clamp(2.5rem,5vw,4rem);letter-spacing:2px;line-height:1;color:var(--navy)}
.sttl span{color:var(--blue)}
/* Globale graue Subline unter Section-Headern (.slbl + .sttl). Werte identisch zu .tmhd p/.hshd p/.sphd p/.cnhd p */
.ssub{color:var(--g500);max-width:600px;margin:16px auto 0;font-size:1.05rem;text-align:center}
.bp{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;background:var(--red);color:var(--white);font-weight:600;font-size:.95rem;border-radius:50px;transition:all .4s var(--ease);position:relative;overflow:hidden;z-index:1}
.bp::before{content:'';position:absolute;inset:0;background:var(--red-dark);transform:scaleX(0);transform-origin:right;transition:transform .4s var(--ease);z-index:-1;border-radius:50px}
.bp:hover::before{transform:scaleX(1);transform-origin:left}.bp:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(200,16,46,.3)}
.bo{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;background:transparent;color:var(--blue);font-weight:600;font-size:.95rem;border:2px solid var(--blue);border-radius:50px;transition:all .4s var(--ease)}
.bo:hover{background:var(--blue);color:var(--white);transform:translateY(-2px);box-shadow:0 8px 24px rgba(37,99,168,.25)}
.bg{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;background:linear-gradient(135deg,var(--gold),var(--gold-light));color:var(--navy);font-weight:700;font-size:.95rem;border-radius:50px;transition:all .4s var(--ease)}
/* Größere Variante für finale CTA-Buttons (.bp/.bg). Auf Mobile schrumpft sie auf normale Button-Größe
   zurück (wie der „Über uns"-CTA) → bleibt nie über 2 Zeilen / wirkt nicht klobig. */
.btn-lg{font-size:1.1rem;padding:18px 44px}
@media(max-width:600px){.btn-lg{font-size:.95rem;padding:13px 26px}}
.bg:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(201,168,76,.35)}
.rv{opacity:0;transform:translateY(40px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.rv.vis{opacity:1;transform:translateY(0)}
.rl{opacity:0;transform:translateX(-60px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.rl.vis{opacity:1;transform:translateX(0)}
.rr{opacity:0;transform:translateX(60px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.rr.vis{opacity:1;transform:translateX(0)}

/* ============================================================
   NAVIGATION
   ============================================================ */
.nav{position:fixed;top:0;left:0;right:0;height:var(--nh);z-index:1000;transition:all .4s var(--ease)}
/* Gescrollt: Navy-Hintergrund (gleicher Ton wie Inner-Pages ungescrollt) + leichter Schlagschatten */
.nav.sc{background:var(--navy);box-shadow:0 2px 20px rgba(0,0,0,.25)}
.ni{max-width:1320px;margin:0 auto;padding:0 24px;height:100%;display:flex;align-items:center;justify-content:space-between}
.nl{display:flex;align-items:center;gap:12px}.nl img{height:44px;width:auto;transition:transform .3s var(--ease2)}.nl:hover img{transform:scale(1.08) rotate(-3deg)}
.nlt{font-family:var(--fd);font-size:1.15rem;letter-spacing:2px;color:var(--white);transition:color .4s;line-height:1.1}
.nav.sc .nlt{color:var(--white)}.nlt small{font-family:var(--fb);font-size:.65rem;letter-spacing:1.5px;opacity:.7;display:block}
.nk{display:flex;align-items:center;gap:32px}
.nk li{list-style:none}
.nk a,.nk li a{font-size:.85rem;font-weight:500;letter-spacing:.5px;color:rgba(255,255,255,.85);transition:color .3s;position:relative}
.nav.sc .nk a,.nav.sc .nk li a{color:rgba(255,255,255,.85)}
.nk a::after,.nk li a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--red);transition:width .3s var(--ease)}
.nk a:hover::after,.nk li a:hover::after{width:100%}
/* Active State – aktuelle Seite in Goldton (WP-Menü + Fallback) */
.nk .current-menu-item>a,.nk .current_page_item>a,.nk .current-menu-ancestor>a{color:var(--gold)!important}
.nk .current-menu-item>a::after,.nk .current_page_item>a::after,.nk .current-menu-ancestor>a::after{display:none}
/* Social-Icons im Header */
.nsoc{display:flex!important;align-items:center;gap:14px;margin-left:8px}
.nsoc::after{display:none}
.nicn{display:inline-flex;align-items:center;justify-content:center;color:var(--gold)!important;padding:0!important;transition:transform .3s var(--ease2),color .3s var(--ease)}
.nicn::after{display:none!important}
.nicn:hover{color:var(--gold-light)!important;transform:translateY(-2px) scale(1.08)}
.nicn svg{display:block}
/* Instagram-Icon (Header + Footer): eigenes SVG, eingefärbt via Mask in der
   currentColor des Links (--gold; Hover → --gold-light bleibt erhalten) */
.ig-icon{display:block;width:22px;height:22px;background-color:currentColor;-webkit-mask:url(images/ui/instagram.svg) center/contain no-repeat;mask:url(images/ui/instagram.svg) center/contain no-repeat}
.nc,.nk li a.nc{padding:10px 24px!important;background:var(--red)!important;color:var(--white)!important;border-radius:50px;font-weight:600!important;font-size:.85rem!important;transition:all .3s var(--ease)!important}
.nc:hover,.nk li a.nc:hover{background:var(--red-dark)!important;transform:translateY(-1px);box-shadow:0 4px 16px rgba(200,16,46,.3)}.nc::after,.nk li a.nc::after{display:none!important}
.nk .sub-menu{display:none}
.nt{display:none;flex-direction:column;gap:5px;background:none;padding:8px}
.nt span{width:24px;height:2px;background:var(--white);transition:all .3s;border-radius:2px}
.nav.sc .nt span{background:var(--white)}
/* Inner-Pages: Navy-Hintergrund bereits ohne Scroll (auf Startseite ist Navbar transparent über Hero) */
body.page:not(.home) .nav{background:var(--navy)}
@media(max-width:900px){.nt{display:flex}.nk{position:fixed;top:0;right:0;transform:translateX(100%);width:300px;height:100vh;background:var(--white);flex-direction:column;padding:100px 40px 40px;gap:24px;transition:transform .5s var(--ease);box-shadow:-10px 0 40px rgba(0,0,0,.1);align-items:flex-start}.nk.open{transform:translateX(0)}.nk a,.nk li a{color:var(--g700)!important;font-size:1rem}.nc,.nk li a.nc{margin-top:16px}.nt.open span{background:var(--navy)!important}}

/* ============================================================
   HERO
   - min-height: clamp(580px, 78vh, 760px) – min 580px (Mobile lesbar),
     78% Viewport (Laptops ~700px), max 760px (große Monitore werden gedeckelt).
   - Pro Slide eigener Gradient (inline-style) + optional Hintergrundbild
     via .slide__bg, das über den Gradient gelegt wird.
   ============================================================ */
.hero{position:relative;min-height:clamp(580px,78vh,760px);overflow:hidden;background:linear-gradient(135deg,var(--navy) 0%,var(--blue-dark) 40%,var(--blue) 100%)}
/* Spalten-Verhältnis Text:Bild im Hero. „5fr 6fr" gibt dem Bild minimal mehr Platz (~55%) → landschaftsförmiger.
   Zum Justieren: einfach die Zahlen in grid-template-columns ändern.
   Beispiele: 1fr 1fr (50/50)  ·  5fr 6fr (47/53)  ·  1fr 1.3fr (43/57)  ·  2fr 3fr (40/60). */
.hc{position:relative;z-index:3;width:100%;max-width:1320px;margin:0 auto;padding:110px 24px 90px;display:grid;grid-template-columns:5fr 6fr;align-items:center;gap:60px}
.ht{color:var(--white);display:flex;flex-direction:column;align-items:flex-start}
.hbd{display:inline-flex;align-items:center;gap:8px;padding:8px 20px;background:rgba(201,168,76,.15);border:1px solid rgba(201,168,76,.3);border-radius:50px;font-size:.8rem;font-weight:500;color:var(--gold-light);letter-spacing:1px;margin-bottom:24px;animation:fiu .8s var(--ease) .2s both}
.hh1{font-family:var(--fd);font-weight:400;font-size:clamp(3rem,6vw,5.5rem);line-height:.95;letter-spacing:3px;margin-bottom:24px;animation:fiu .8s var(--ease) .4s both}
.hh1 .hl{color:var(--gold)}
.hs{font-size:1.1rem;line-height:1.7;color:rgba(255,255,255,.75);max-width:500px;margin-bottom:36px;animation:fiu .8s var(--ease) .6s both}
/* Pro-Slide-CTA innerhalb des .ht Text-Blocks. Crossfade läuft mit dem Slide-Inhalt. */
.hcta{margin-top:8px;animation:fiu .8s var(--ease) .8s both;align-self:flex-start}
/* Hero-Bildkasten mit FIXEM Seitenverhältnis 3/2 (= 1.5).
   Vorteil: alle Slides haben die exakt gleiche Bildfläche → keine Layout-Sprünge
   zwischen Slides, Crossfade wirkt deutlich ruhiger.
   Zum Justieren des Verhältnisses: nur die Zahl bei aspect-ratio ändern.
   Beispiele: 3/2 (1.50) · 16/9 (1.78) · 4/3 (1.33) · 1/1 (quadratisch) */
.hv{position:relative;aspect-ratio:3/2;width:100%;animation:fiu 1s var(--ease) .6s both;overflow:visible}

/* Bild füllt den Kasten vollständig (object-fit: cover = zoomt rein, crop ist OK,
   KEINE Verzerrung) – wenn Bild kleiner ist, wird hochskaliert; wenn größer, runter.
   Alternative: object-fit:contain → Bild komplett zeigen, dafür ggf. Letterbox-Streifen. */
.htr{display:block;width:100%;height:100%;object-fit:cover;object-position:center;filter:drop-shadow(0 20px 60px rgba(0,0,0,.4))}
@keyframes fiu{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
.hslider{position:relative;min-height:inherit}
.slide{position:absolute;inset:0;display:flex;align-items:center;align-items:safe center;opacity:0;transition:opacity .8s ease;pointer-events:none}
.slide.active{opacity:1;z-index:2;pointer-events:auto}
.slide__bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0;opacity:.55;mix-blend-mode:overlay;pointer-events:none}
.slide>.hc{position:relative;z-index:2}
.hind{position:absolute;bottom:16px;left:50%;transform:translateX(-50%);display:flex;gap:10px;z-index:10}
.hdot{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.35);cursor:pointer;transition:background .3s;padding:0;border:none}
.hdot.active{background:var(--gold)}
/* Mobile-Hero: volle Viewport-Höhe (svh = klein, ohne Browser-Chrome-Sprung) + großzügiger Abstand zum Header */
@media(max-width:768px){.hero{min-height:100vh;min-height:100svh}.hc{grid-template-columns:1fr;text-align:center;padding:140px 24px 100px}.ht{align-items:center}.hs{display:none}.hcta{align-self:center}.hv{order:-1;max-width:420px;margin:0 auto}}
/* Niedrige Desktop-Viewports (z. B. 14"-Laptops): vh-Untergrenze würde den Hero zu flach machen
   → Inhalt überläuft zentriert nach oben unter die Navbar. Mehr garantierte Höhe + etwas weniger
   Padding gibt dem zentrierten Inhalt genug Platz. (safe center auf .slide fängt Restfälle ab.) */
@media(min-width:769px) and (max-height:880px){.hero{min-height:760px}.hc{padding-top:100px;padding-bottom:72px}}
/* Schmale Telefone (z. B. iPhone SE 375×667): Hero-Inhalt muss in 100svh passen, sonst rutscht der CTA
   unter die nächste Section. Weniger Top-/Bottom-Padding (kleinerer Abstand Bild↔Navbar) + engerer
   Gap + etwas kompakteres Bild/H1 holen die nötige Höhe zurück. */
@media(max-width:600px){.hc{padding:92px 20px 48px;gap:24px}.hbd{margin-bottom:16px}.hh1{font-size:clamp(2.6rem,11vw,3.6rem);margin-bottom:18px}.hv{max-width:330px}}
/* Mobile: Hero-Inhalt OBEN verankern statt vertikal zentriert (Bild sitzt nah an der Navbar).
   Auf hohen Viewports verhindert das das „schwebende/zerstückelte" Wirken; auf kurzen (SE) ist es
   ebenfalls sicherer (kein Zentrier-Überlauf nach unten). */
@media(max-width:768px){.slide{align-items:flex-start}}
/* Große/hohe Handys (z. B. iPhone 14/15 (Pro Max), Pixel): Hero NICHT voll 100svh (wirkte zerstückelt),
   sondern moderat niedriger (86svh) + mehr Abstand oben zur Navbar. SE (kurz, <740px) bleibt bei der
   engen Regel oben. */
@media(max-width:600px) and (min-height:740px){.hero{min-height:86svh}.hc{padding-top:96px;padding-bottom:72px;gap:34px}.hv{max-width:360px}}

/* ============================================================
   STATS
   ============================================================ */
.sb{position:relative;z-index:5;padding-top:60px}
.si{background:var(--white);border-radius:20px;padding:40px;display:grid;grid-template-columns:repeat(4,1fr);gap:24px;box-shadow:0 8px 40px rgba(0,0,0,.08);border:1px solid var(--g100)}
.sti{text-align:center}
.stn{font-family:var(--fd);font-size:clamp(2rem,4vw,3rem);color:var(--blue);line-height:1;margin-bottom:4px}
.stn .pl{color:var(--gold)}
.stl{font-size:.85rem;color:var(--g500);font-weight:500}
.sti::after{content:'';display:block;width:30px;height:3px;background:var(--gold);margin:12px auto 0;border-radius:2px}
@media(max-width:768px){.si{grid-template-columns:repeat(2,1fr)}}

/* ============================================================
   TROPHIES
   ============================================================ */
/* NEWS & TERMINE */
.nws{padding:var(--sp-y) 0;background:linear-gradient(180deg,var(--cream) 0%,var(--wheat-light) 100%)}
.nwhd{text-align:center;margin-bottom:48px}
.nwg{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.nwc{background:var(--white);border-radius:16px;padding:28px 28px 24px;border:1px solid var(--g100);display:flex;flex-direction:column;gap:12px;transition:all .3s var(--ease)}
.nwc:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(0,0,0,.08);border-color:var(--gold-pale)}
.nwch{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}
.nwcat{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:50px;font-size:.75rem;font-weight:600;letter-spacing:.5px}
/* Ankündigungen: solid Rot für maximale Sichtbarkeit auf weißer Card */
.nwcat--ankuendigungen{background:var(--red);color:var(--white)}
.nwcat--spielberichte{background:rgba(37,99,168,.14);color:var(--blue-dark);border:1px solid rgba(37,99,168,.25)}
.nwcat--daily-tsv{background:rgba(201,168,76,.22);color:#7a5f10;border:1px solid rgba(201,168,76,.4)}
.nwcat--sonstiges{background:var(--g200);color:var(--g700)}
/* Kategorie-Icons in den News-Pillen: eigene SVGs, eingefärbt in --blue per Mask.
   Dateien: images/ui/news_ankuendigungen.svg, news_spielbericht.svg, news_daily_TSV.svg */
.nwcat--ankuendigungen::before,
.nwcat--spielberichte::before,
.nwcat--daily-tsv::before{content:'';flex:0 0 auto;width:1.35em;height:1.35em;background-color:var(--blue);-webkit-mask:center/contain no-repeat;mask:center/contain no-repeat}
.nwcat--ankuendigungen::before{-webkit-mask-image:url(images/ui/news_ankuendigungen.svg);mask-image:url(images/ui/news_ankuendigungen.svg);background-color:#fff} /* weiß statt blau – sitzt auf rotem Pillen-Hintergrund */
.nwcat--spielberichte::before{-webkit-mask-image:url(images/ui/news_spielbericht.svg);mask-image:url(images/ui/news_spielbericht.svg)}
.nwcat--daily-tsv::before{-webkit-mask-image:url(images/ui/news_daily_TSV.svg);mask-image:url(images/ui/news_daily_TSV.svg)}
.nwdt{font-size:.78rem;color:var(--g400);font-weight:500}
.nwtt{font-family:var(--fd);font-size:1.25rem;letter-spacing:1px;color:var(--navy);line-height:1.2}
.nwtx{font-size:.88rem;color:var(--g500);line-height:1.6;flex:1;display:-webkit-box;-webkit-line-clamp:5;-webkit-box-orient:vertical;overflow:hidden}
.nwlk{font-size:.85rem;font-weight:600;color:var(--blue);align-self:flex-start;transition:color .2s}
.nwlk:hover{color:var(--blue-dark)}
.nwmt{text-align:center;padding:48px;color:var(--g400);display:flex;flex-direction:column;align-items:center;gap:12px}
.nwmt span{font-size:2.5rem}
@media(max-width:900px){.nwg{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.nwg{grid-template-columns:1fr}}
.nwtt a{color:inherit;text-decoration:none}.nwtt a:hover{color:var(--blue)}

/* ============================================================
   NEWS-ARCHIV & BLOG
   ============================================================ */
.bla{padding:var(--sp-y) 0;background:var(--cream)}
/* Kategorie-Filter auf /news/ (Frontend, query-param ?kat=slug) */
.news-filter{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:48px}
.nf-btn{display:inline-flex;align-items:center;padding:8px 20px;border-radius:50px;border:1.5px solid var(--g200);background:var(--white);color:var(--navy);font-family:var(--fb);font-weight:600;font-size:.85rem;text-decoration:none;transition:all .25s var(--ease)}
.nf-btn:hover{border-color:var(--blue);color:var(--blue)}
.nf-btn.is-active{background:var(--blue);border-color:var(--blue);color:var(--white)}
/* Blog-Eintrag (horizontal: Bild links, Text rechts) — ganze Card klickbar via Stretched-Link */
.ble{position:relative;display:grid;grid-template-columns:300px 1fr;gap:32px;align-items:center;border-bottom:1px solid var(--g200);padding:32px 0}
.ble:first-child{border-top:1px solid var(--g200)}
.ble-img{border-radius:12px;overflow:hidden;background:var(--navy);aspect-ratio:3/2;width:300px;display:flex;align-items:center;justify-content:center}
.ble-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s var(--ease)}
.ble:hover .ble-img img{transform:scale(1.04)}
.ble-dummy{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:2.8rem;opacity:.3;background:linear-gradient(135deg,var(--blue-dark),var(--navy))}
.ble-body{display:flex;flex-direction:column;gap:10px}
.ble-meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.ble-title{font-family:var(--fd);font-size:1.7rem;letter-spacing:1px;line-height:1.1;margin:0}
.ble-title a{color:var(--navy);text-decoration:none;transition:color .25s var(--ease)}
.ble-title a::after{content:'';position:absolute;inset:0;z-index:1} /* Stretched-Link: ganze Card klickbar */
.ble:hover .ble-title a{color:var(--blue)}
.ble-teaser{color:var(--g500);line-height:1.7;font-size:.95rem;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.ble-readmore{font-family:var(--fb);font-size:.85rem;font-weight:600;color:var(--blue);margin-top:2px}
/* Nummerierte Pagination (the_posts_pagination) */
.news-pagination{margin-top:56px}
.news-pagination .nav-links{display:flex;justify-content:center;align-items:center;gap:8px;flex-wrap:wrap}
.news-pagination .page-numbers{display:inline-flex;align-items:center;justify-content:center;min-width:42px;height:42px;padding:0 12px;border-radius:50px;border:1.5px solid var(--g200);color:var(--navy);font-family:var(--fb);font-weight:600;font-size:.9rem;text-decoration:none;transition:all .25s var(--ease)}
.news-pagination a.page-numbers:hover{border-color:var(--blue);color:var(--blue)}
.news-pagination .page-numbers.current{background:var(--blue);border-color:var(--blue);color:var(--white)}
.news-pagination .page-numbers.dots{border:none;min-width:auto}
/* ---- Single Post (direkte URL /news/slug/) ---- */
.blp{padding:var(--sp-y) 0;background:var(--cream);--blp-w:940px} /* --blp-w: gemeinsame Artikel-Spaltenbreite (Bild + Text + Leisten fluchten) */
.blp-bar{max-width:var(--blp-w);margin:0 auto 28px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.blp-backlink{font-family:var(--fb);font-weight:600;font-size:.9rem;color:var(--blue);text-decoration:none}
.blp-backlink:hover{text-decoration:underline}
.blp-bar-meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.blp-readtime{font-size:.82rem;color:var(--g400);font-weight:500}
.blp-img{border-radius:16px;overflow:hidden;margin:0 auto 48px;max-width:var(--blp-w);aspect-ratio:16/9} /* 16:9, gleiche Breite wie .blp-cnt → Bild und Text fluchten */
.blp-img img{width:100%;height:100%;object-fit:cover;display:block}
.blp-cnt{max-width:var(--blp-w);margin:0 auto}
.blp-cnt h2{font-family:var(--fd);font-size:2rem;color:var(--navy);letter-spacing:1px;margin:32px 0 16px}
.blp-cnt h3{font-family:var(--fd);font-size:1.4rem;color:var(--navy);letter-spacing:.5px;margin:24px 0 12px}
.blp-cnt p{color:var(--g600);line-height:1.85;margin-bottom:20px;font-size:1.05rem}
.blp-cnt img{border-radius:12px;max-width:100%;height:auto;margin:24px 0}
.blp-cnt a{color:var(--blue);text-decoration:underline}
.blp-cnt ul,.blp-cnt ol{margin:0 0 20px 24px;color:var(--g600);line-height:1.8}
.blp-cnt li{margin-bottom:6px}
/* Social-Share */
.blp-share{max-width:var(--blp-w);margin:40px auto 0;display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding-top:24px;border-top:1px solid var(--g200)}
.blp-share-lbl{font-weight:600;color:var(--navy);font-size:.9rem}
.blp-share-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;border-radius:50px;border:1.5px solid var(--g200);background:var(--white);color:var(--navy);font-family:var(--fb);font-size:.85rem;font-weight:600;cursor:pointer;text-decoration:none;transition:all .25s var(--ease)}
.blp-share-btn:hover{border-color:var(--blue);color:var(--blue)}
.blp-share-btn.is-copied{border-color:var(--blue);color:var(--blue);background:var(--wheat-light)}
/* Vor/Zurück-Navigation */
.blp-nav{max-width:var(--blp-w);margin:40px auto 0;display:grid;grid-template-columns:1fr 1fr;gap:16px}
.blp-nav-item{position:relative;z-index:1;display:flex;flex-direction:column;gap:6px;padding:18px 22px;border:1px solid var(--g200);border-radius:14px;text-decoration:none;background:var(--white);transition:all .3s var(--ease)}
.blp-nav-item:hover{border-color:var(--blue);transform:translateY(-3px);box-shadow:0 12px 28px rgba(0,0,0,.05)}
.blp-nav-next{text-align:right}
.blp-nav-dir{font-size:.78rem;font-weight:600;color:var(--blue);letter-spacing:.3px}
.blp-nav-ttl{font-family:var(--fd);font-size:1.1rem;letter-spacing:.5px;color:var(--navy);line-height:1.15}
/* Verwandte Artikel */
.blp-rel{max-width:980px;margin:64px auto 0;padding-top:48px;border-top:1px solid var(--g200)}
.blp-rel-hd{font-family:var(--fd);font-size:1.6rem;letter-spacing:1.5px;color:var(--navy);text-align:center;margin-bottom:28px}
.blp-rel-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.blp-relc{position:relative;background:var(--white);border:1px solid var(--g100);border-radius:14px;overflow:hidden;transition:all .3s var(--ease)}
.blp-relc:hover{transform:translateY(-4px);box-shadow:0 14px 32px rgba(0,0,0,.06)}
.blp-relc-img{aspect-ratio:3/2;background:var(--navy);overflow:hidden}
.blp-relc-img img{width:100%;height:100%;object-fit:cover;display:block}
.blp-relc-body{padding:16px 18px 20px;display:flex;flex-direction:column;gap:8px}
.blp-relc-ttl{font-family:var(--fd);font-size:1.15rem;letter-spacing:.5px;line-height:1.15;margin:0}
.blp-relc-ttl a{color:var(--navy);text-decoration:none}
.blp-relc-ttl a::after{content:'';position:absolute;inset:0}
.blp-relc:hover .blp-relc-ttl a{color:var(--blue)}
@media(max-width:768px){
	.ble{grid-template-columns:1fr;gap:16px;padding:24px 0}
	.ble-img{width:100%;aspect-ratio:16/9}
	.ble-title{font-size:1.4rem}
	.blp-img{margin-bottom:32px;aspect-ratio:16/9}
	.blp-nav{grid-template-columns:1fr}
	.blp-nav-next{text-align:left}
	.blp-rel-grid{grid-template-columns:1fr}
}

/* ============================================================
   ABOUT
   ============================================================ */
.abt{padding:var(--sp-y) 0;background:var(--cream);position:relative}
.abg{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;margin-bottom:80px}
.abg:last-child{margin-bottom:0} /* wenn .abg allein im Container steht (z.B. Teams-Intro), kein doppeltes Whitespace zur Section-Padding */
.abg--46{grid-template-columns:4fr 6fr} /* Teams-Intro oben: Bild 40% / Text 60% (klappt bei ≤768px via Regel weiter unten auf 1 Spalte) */
.abg--46 .abiw{aspect-ratio:3/4} /* oberes Intro-Bild im Hochformat statt 4/3-Querformat */
.abtx-list{list-style:none;margin:6px 0 0;padding:0}
.abtx-list li{color:var(--g600);line-height:1.7;margin-bottom:10px;font-weight:500}
.abiw{position:relative;border-radius:20px;overflow:hidden;aspect-ratio:4/3;background:var(--g100)}
.abiw img{width:100%;height:100%;object-fit:cover}
.abab{position:absolute;bottom:-20px;right:-20px;background:var(--blue);color:var(--white);padding:16px 24px;border-radius:12px;font-family:var(--fd);font-size:1.1rem;letter-spacing:2px;box-shadow:0 8px 24px rgba(37,99,168,.3)}
.abtx h3{font-family:var(--fs);font-size:1.6rem;color:var(--navy);margin-bottom:16px;font-style:italic}
.abtx h3.abtx-title{font-family:var(--fd);font-size:clamp(1.8rem,2.8vw,2.4rem);letter-spacing:2px;font-style:normal;font-weight:400;line-height:1.1;margin-bottom:20px;text-transform:uppercase} /* normale Section-Heading-Optik (kein Zitat) */
.abtx p{color:var(--g600);margin-bottom:16px;line-height:1.8}
/* flex-wrap:wrap verhindert Überlauf der 3 Value-Pills auf schmalen Mobile-Viewports
   (vorher Cut-Off durch body overflow-x:hidden) */
.abv{display:flex;flex-wrap:wrap;justify-content:center;gap:24px;margin:24px 0}
@media(max-width:600px){.abv{gap:14px 16px}.abv--left{justify-content:center}} /* Mobile: Werte zentriert statt linksbündig */
.abvi{display:flex;align-items:center;gap:8px;font-weight:600;color:var(--navy);font-size:.9rem}
.abvic{width:36px;height:36px;background:var(--wheat-light);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.1rem}
.abv--left{justify-content:flex-start} /* Über uns: Werte linksbündig unter dem Text statt zentriert */
/* Werte-Icons (Gemeinschaft/Präzision/Leidenschaft): eigene SVGs, eingefärbt in --blue per Mask */
.vic{display:block;width:30px;height:30px;background-color:var(--blue);-webkit-mask:center/contain no-repeat;mask:center/contain no-repeat}
.vic--gemeinschaft{-webkit-mask-image:url(images/ui/val-gemeinschaft.svg);mask-image:url(images/ui/val-gemeinschaft.svg)}
.vic--praezision{-webkit-mask-image:url(images/ui/val-praezision.svg);mask-image:url(images/ui/val-praezision.svg)}
.vic--leidenschaft{-webkit-mask-image:url(images/ui/val-leidenschaft.svg);mask-image:url(images/ui/val-leidenschaft.svg)}

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.tst{padding:var(--sp-y) 0;background:var(--cream);position:relative}
.tml{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:60px}
.tmc{background:var(--white);border-radius:16px;padding:32px;position:relative;border:1px solid var(--g100);transition:all .4s var(--ease)}
.tmc:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(0,0,0,.06);border-color:var(--gold-pale)}
.tmq{font-style:italic;color:var(--g600);line-height:1.7;margin-bottom:20px;font-size:.95rem}
.tmq::before{content:'„';font-family:var(--fs);font-size:3rem;color:var(--gold);line-height:0;display:block;margin-bottom:10px}
.tma{display:flex;align-items:center;gap:12px}
.tmav{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--blue-dark));display:flex;align-items:center;justify-content:center;color:var(--white);font-weight:700;font-size:.9rem}
.tmn{font-weight:600;color:var(--navy);font-size:.9rem}
.tmr{font-size:.75rem;color:var(--g400)}

/* ============================================================
   VENUES
   ============================================================ */
.vns{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:60px}
.vnc{background:var(--white);border-radius:16px;overflow:hidden;border:1px solid var(--g100);transition:all .4s var(--ease)}
.vnc:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(0,0,0,.06)}
.vnimg{height:200px;background:linear-gradient(135deg,var(--blue-dark),var(--blue));display:flex;align-items:center;justify-content:center;color:var(--white);font-family:var(--fd);font-size:2rem;letter-spacing:3px;position:relative;overflow:hidden}
.vnimg::after{content:'';position:absolute;inset:0;background-image:url('images/ui/floral-pattern.svg');background-size:480px 480px;background-repeat:repeat;opacity:.08}
.vnbd{padding:24px}.vnbd h4{font-family:var(--fd);font-size:1.2rem;letter-spacing:1px;color:var(--navy);margin-bottom:8px}.vnbd p{font-size:.9rem;color:var(--g500);line-height:1.6}
.vntg{display:inline-block;padding:4px 12px;background:var(--wheat-light);color:var(--gold);font-size:.75rem;font-weight:600;border-radius:50px;margin-top:12px}
@media(max-width:768px){.abg{grid-template-columns:1fr;gap:40px}.tml{grid-template-columns:1fr}.vns{grid-template-columns:1fr}}

/* ============================================================
   CTA BAND
   ============================================================ */
/* clamp() seitliche Polsterung: 24px auf Mobile, skaliert hoch bis 48px auf Desktop.
   Bug-Fix: zuvor war padding:80px 0 → Text klebte auf schmalen Viewports am Rand. */
/* „Unsere Krone"-Emblem als Übergang vor der finalen CTA-Sektion. SVG behält seine Eigenfarbe (grau)
   – kein Mask/Recolor. Größe/Abstand zentral hier justierbar. */
.krone-divider{text-align:center;padding:clamp(40px,6vw,64px) 24px clamp(28px,4vw,40px)}
.krone-divider img{display:inline-block;width:clamp(160px,20vw,220px);height:auto}
.krone-divider--white{background:var(--white)} /* Startseite + Über uns: weißer Hintergrund hinter dem Siegel */
.ctb{background:linear-gradient(135deg,var(--navy) 0%,var(--blue-dark) 50%,var(--blue) 100%);padding:var(--sp-y) clamp(24px,4vw,48px);text-align:center;position:relative;overflow:hidden}
.ctb::before{content:'';position:absolute;inset:0;background-image:url('images/ui/floral-pattern.svg');background-size:800px 800px;background-repeat:repeat;opacity:.06}
.ctbc{position:relative;z-index:1}
.ctb h2{font-family:var(--fd);font-size:clamp(2rem,4vw,3.5rem);color:var(--white);letter-spacing:3px;margin-bottom:12px}
.ctb p{color:rgba(255,255,255,.7);font-size:1.1rem;margin-bottom:32px;max-width:500px;margin-left:auto;margin-right:auto}

/* ============================================================
   POKALE & HIGHLIGHTS
   ============================================================ */
.hlb{padding:var(--sp-y) 0;background:var(--cream);overflow:hidden}
.hlhd{text-align:center;margin-bottom:48px}
.hlhd .slbl{margin-bottom:8px}
/* Carousel-Wrapper enthält Scrollbereich + Navigations-Pfeile. */
.hlwrap{position:relative}
/* Horizontaler Scroll-Container mit CSS Scroll-Snap. Native Touch-Swipes auf Mobile,
   programmatisch via .hlnav auf Desktop. Scrollbar wird visuell entfernt. */
.hlg{display:flex;gap:20px;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;scroll-behavior:smooth;scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch;padding:8px 4px 18px;scroll-padding-left:4px}
.hlg::-webkit-scrollbar{display:none}
.hlc{flex:0 0 240px;background:var(--white);border:1px solid var(--g100);border-radius:14px;padding:28px 20px 24px;text-align:center;transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s var(--ease);display:flex;flex-direction:column;align-items:center;scroll-snap-align:start}
.hlc:hover{transform:translateY(-4px);box-shadow:0 14px 32px rgba(22,39,66,.08);border-color:var(--gold-pale)}
.hli{width:56px;height:56px;display:flex;align-items:center;justify-content:center;color:var(--gold);margin-bottom:14px}
.hli svg{width:100%;height:100%;display:block}
/* Highlight-Icons: eigene SVGs, eingefärbt in der .hli-Farbe (--gold) per Mask.
   Zuordnung Titel→Icon via tsv_highlight_icon_slug_from_title() in inc/highlight-icons.php */
.hlimg{display:block;width:100%;height:100%;background-color:currentColor;-webkit-mask:center/contain no-repeat;mask:center/contain no-repeat}
.hlimg--wachstum{-webkit-mask-image:url(images/ui/hl-wachstum.svg);mask-image:url(images/ui/hl-wachstum.svg)}
.hlimg--meister{-webkit-mask-image:url(images/ui/hl-meister.svg);mask-image:url(images/ui/hl-meister.svg)}
.hlimg--bester-spieler{-webkit-mask-image:url(images/ui/hl-bester-spieler.svg);mask-image:url(images/ui/hl-bester-spieler.svg)}
.hlimg--pokal{-webkit-mask-image:url(images/ui/hl-pokal.svg);mask-image:url(images/ui/hl-pokal.svg)}
.hlimg--rangliste{-webkit-mask-image:url(images/ui/hl-rangliste.svg);mask-image:url(images/ui/hl-rangliste.svg)}
.hlimg--highlight-player{-webkit-mask-image:url(images/ui/hl-highlight-player.svg);mask-image:url(images/ui/hl-highlight-player.svg)}
.hlimg--doppelaufstieg{-webkit-mask-image:url(images/ui/hl-doppelaufstieg.svg);mask-image:url(images/ui/hl-doppelaufstieg.svg)}
.hlimg--gruendung{-webkit-mask-image:url(images/ui/hl-gruendung.svg);mask-image:url(images/ui/hl-gruendung.svg)}
.hly{font-family:var(--fd);font-size:1.6rem;letter-spacing:2px;color:var(--blue);line-height:1;margin-bottom:10px}
.hlh{font-family:var(--fd);font-size:1.05rem;letter-spacing:1.5px;color:var(--navy);margin-bottom:8px;line-height:1.2}
.hlt{font-size:.85rem;color:var(--g600);line-height:1.55;margin:0}
/* Navigations-Pfeile links/rechts (Desktop). Werden vom JS aktiviert/deaktiviert je nach Scroll-Position. */
.hlnav{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;background:var(--white);box-shadow:0 6px 20px rgba(22,39,66,.15);border:1px solid var(--g100);color:var(--navy);font-size:1.8rem;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:5;transition:transform .25s var(--ease),background .25s var(--ease),color .25s var(--ease),opacity .25s var(--ease);font-family:var(--fd)}
.hlnav:hover:not(:disabled){background:var(--navy);color:var(--white);transform:translateY(-50%) scale(1.08)}
.hlnav:disabled{opacity:.25;cursor:default;pointer-events:none}
.hlnav--prev{left:-18px}
.hlnav--next{right:-18px}
@media(max-width:768px){
	.hlnav{display:none}
	.hlc{flex:0 0 220px;padding:24px 18px 20px}
	.hli{width:48px;height:48px}
	.hly{font-size:1.4rem}
	.hlh{font-size:.95rem}
}

/* ============================================================
   TEAMS
   ============================================================ */
.tms{padding:var(--sp-y) 0;background:var(--g50);position:relative}
.tms::before{content:'';position:absolute;top:0;left:0;right:0;height:400px;background:linear-gradient(180deg,var(--cream) 0%,var(--g50) 100%)}
.tms .ctr{position:relative;z-index:1}
.tmhd{text-align:center;margin-bottom:60px}.tmhd p{color:var(--g500);max-width:600px;margin:16px auto 0;font-size:1.05rem}
.tov{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:80px}
a.tkc{display:block;text-decoration:none;color:inherit}
.tkc{background:var(--white);border-radius:20px;padding:36px;text-align:center;border:1px solid var(--g100);transition:all .5s var(--ease);position:relative;overflow:hidden}
.tkc::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--blue),var(--gold));transform:scaleX(0);transition:transform .5s var(--ease)}
.tkc:hover::before{transform:scaleX(1)}.tkc:hover{transform:translateY(-8px);box-shadow:0 20px 48px rgba(0,0,0,.08)}
.tkci{width:64px;height:64px;border-radius:16px;background:var(--wheat-light);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;font-size:1.8rem}
/* Mannschafts-Icons: eigene SVGs, flach eingefärbt in --blue per CSS-Mask.
   SVG-Dateien ablegen unter: images/ui/team-1.svg, team-2.svg, team-3.svg */
.tkcimg{display:block;width:42px;height:42px;background-color:var(--blue);-webkit-mask:center/contain no-repeat;mask:center/contain no-repeat}
.tkcimg--1{-webkit-mask-image:url(images/ui/team-1.svg);mask-image:url(images/ui/team-1.svg)}
.tkcimg--2{-webkit-mask-image:url(images/ui/team-2.svg);mask-image:url(images/ui/team-2.svg)}
.tkcimg--3{-webkit-mask-image:url(images/ui/team-3.svg);mask-image:url(images/ui/team-3.svg)}
.tkc h3{font-family:var(--fd);font-size:1.5rem;letter-spacing:2px;color:var(--navy);margin-bottom:4px}
.tkc .lg{font-size:.8rem;color:var(--gold);font-weight:600;margin-bottom:12px}
.tkc p{font-size:.9rem;color:var(--g500);line-height:1.6}
.tkc .tmb{margin-top:16px;padding-top:16px;border-top:1px solid var(--g100);font-size:.85rem;color:var(--g600);font-weight:500}
/* Player Cards – 3D Flip */
.plg{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:24px}
.plc{perspective:800px;cursor:pointer}
.plc-inner{position:relative;width:100%;transition:transform .6s var(--ease);transform-style:preserve-3d;-webkit-transform-style:preserve-3d}
.plc:hover .plc-inner,.plc.flipped .plc-inner{transform:rotateY(180deg)}
.plc-front,.plc-back{backface-visibility:hidden;-webkit-backface-visibility:hidden;border-radius:16px;overflow:hidden;border:1px solid var(--g100);background:var(--white)}
.plc-front{position:relative}
.plc-back{position:absolute;inset:0;transform:rotateY(180deg);display:flex;flex-direction:column;justify-content:center;align-items:center;padding:28px 20px;text-align:center;background:linear-gradient(135deg,var(--navy),var(--blue-dark))}
/* Bild (quadratisch) */
.plim{aspect-ratio:1/1;background:linear-gradient(135deg,var(--blue-dark),var(--blue));position:relative;overflow:hidden}
.plim .plcap{position:absolute;top:10px;right:12px;z-index:2;font-family:var(--fd);font-size:1.8rem;letter-spacing:2px;color:var(--gold);text-shadow:0 2px 6px rgba(0,0,0,.45);transition:opacity .25s var(--ease)}
.plc:hover .plim .plcap,.plc.flipped .plim .plcap{opacity:0}
.plim img.pl-photo{width:100%;height:100%;object-fit:cover;object-position:top center}
/* Vorderseite Info */
.plc-info{padding:14px 16px;text-align:center;min-height:92px;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:2px}
.plc-info h4{font-weight:700;color:var(--navy);font-size:1rem;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}
.plc-nick{font-size:.78rem;color:var(--gold);font-style:italic;margin-bottom:4px}
.plc-info .plr{font-size:.78rem;color:var(--blue);font-weight:600}
/* Rückseite */
.plc-back-hd{margin-bottom:20px;width:100%}
.pln-back{font-family:var(--fd);font-size:2.5rem;color:rgba(255,255,255,.15);letter-spacing:3px;display:block}
.plc-back h4{font-weight:700;color:var(--white);font-size:1.05rem;margin-top:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}
.plc-back .pls{display:flex;gap:24px;justify-content:center;margin-bottom:8px}
.plc-back .plsv{font-family:var(--fd);font-size:1.5rem;color:var(--gold);letter-spacing:1px}
.plc-back .plsl{font-size:.7rem;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:.5px}
.plc-back .plst{text-align:center}
.plc-seit{font-size:.82rem;color:rgba(255,255,255,.6);margin-top:12px}
.plc-seit::before{content:'📅 ';font-size:.8rem}
.plc-back .pldr{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:12px;padding-top:12px;border-top:1px solid rgba(255,255,255,.12);font-size:.8rem;color:rgba(255,255,255,.55)}.plc-back .pldr::before{content:'🎯';font-size:.85rem}
.plc-back .pldw{text-align:center;font-size:.75rem;color:rgba(255,255,255,.45);margin-top:2px;letter-spacing:.5px}
/* Team-Sektionen (Spieler gruppiert nach Mannschaft) */
.tsg{margin-top:72px;padding-top:64px;border-top:2px solid var(--g100);scroll-margin-top:100px}
.tsh{text-align:center;margin-bottom:40px}
.tsh h2{font-family:var(--fd);font-size:2rem;letter-spacing:3px;color:var(--navy);margin-bottom:10px}
.tsl{display:inline-block;font-size:.85rem;font-weight:600;color:var(--gold);letter-spacing:1.5px;text-transform:uppercase;border:1.5px solid var(--gold);border-radius:50px;padding:4px 16px}
.tsnp{text-align:center;color:var(--g400);padding:40px 0;grid-column:1/-1;font-size:.95rem}
@media(max-width:768px){.tov{grid-template-columns:1fr}.plg{grid-template-columns:1fr 1fr;gap:12px}.tsg{margin-top:48px;padding-top:48px}}@media(max-width:480px){.plg{grid-template-columns:1fr 1fr;gap:8px}.plc-info h4{font-size:.85rem}.plc-info{padding:10px 10px;min-height:78px}.pln-back{font-size:1.8rem}.plc-back .plsv{font-size:1.2rem}}

/* Wiederverwendbarer Section-Header im Team-Stil: Bebas-Headline + goldene Outline-Pille (.tsl) darunter */
.shd{text-align:center;margin-bottom:48px}
.shd h2{font-family:var(--fd);font-size:clamp(2rem,4vw,3rem);letter-spacing:3px;color:var(--navy);line-height:1.05;margin-bottom:14px}
.shd h2 span{color:var(--blue)} /* Akzent-Wort im Section-Header (z.B. „EINZEL") in Hellblau */
.shd .tsl{vertical-align:middle}

/* Teams-Seite: Vorteils-Sektion (6 Cards, nutzt .bfg/.bfc aus Mitglied-werden) */
.tadv{padding:var(--sp-y) 0;background:var(--cream)}

/* Teams-Seite: „Alle Mitglieder" — zwei Spalten (Ehren-/Gründungsmitglieder + Passive) */
.aml{padding:var(--sp-y) 0;background:var(--cream)}
.amg{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:start}
.amc{background:var(--white);border-radius:16px;padding:32px;border:1px solid var(--g100)}
.amc h3{font-family:var(--fd);font-size:1.4rem;letter-spacing:2px;color:var(--navy);margin-bottom:20px;padding-bottom:12px;border-bottom:2px solid var(--gold)}
.aml-list{list-style:none;margin:0;padding:0}
.aml-list li{color:var(--g700);padding:9px 0;border-bottom:1px solid var(--g100);font-weight:500}
.aml-list li:last-child{border-bottom:none}
.aml-list--2col{columns:2;column-gap:28px}
.aml-list--2col li{break-inside:avoid}
@media(max-width:768px){.amg{grid-template-columns:1fr}.aml-list--2col{columns:1}}

/* ============================================================
   HISTORY / TIMELINE
   ============================================================ */
.hst{padding:var(--sp-y) 0;background:var(--cream);position:relative}
.hshd{text-align:center;margin-bottom:80px}.hshd p{color:var(--g500);max-width:600px;margin:16px auto 0;font-size:1.05rem}
.tl{position:relative;max-width:900px;margin:0 auto}
.tl::before{content:'';position:absolute;top:0;bottom:0;left:50%;width:3px;background:linear-gradient(180deg,var(--gold),var(--blue),var(--gold));transform:translateX(-50%);border-radius:2px}
.tli{position:relative;display:flex;margin-bottom:60px}
.tli:nth-child(odd){justify-content:flex-start;padding-right:calc(50% + 40px);text-align:right}
.tli:nth-child(even){justify-content:flex-end;padding-left:calc(50% + 40px)}
.tld{position:absolute;left:50%;top:20px;transform:translateX(-50%);width:20px;height:20px;background:var(--white);border:3px solid var(--gold);border-radius:50%;z-index:1;transition:all .3s var(--ease2)}
.tli:hover .tld{background:var(--gold);transform:translateX(-50%) scale(1.3);box-shadow:0 0 20px rgba(201,168,76,.4)}
.tlc{background:var(--white);padding:28px;border-radius:16px;border:1px solid var(--g100);transition:all .4s var(--ease);overflow:hidden}
.tli:hover .tlc{transform:translateY(-4px);box-shadow:0 12px 32px rgba(0,0,0,.06);border-color:var(--gold-pale)}
/* Optionaler Bild-Header in der Timeline-Karte. Negative Margins extenden das
   Bild bis an die Card-Ränder. Höhe richtet sich nach Bild-Seitenverhältnis,
   damit nichts beschnitten wird (Köpfe/Beine bei Gruppenfotos bleiben drin). */
.tlc__img{margin:-28px -28px 20px;overflow:hidden;background:var(--g100)}
.tlc__img img{display:block;width:100%;height:auto}
.tly{font-family:var(--fd);font-size:1.6rem;color:var(--blue);letter-spacing:2px;margin-bottom:4px}
.tltt{font-weight:700;color:var(--navy);margin-bottom:8px}.tldc{font-size:.9rem;color:var(--g500);line-height:1.6}
@media(max-width:768px){.tl::before{left:20px}.tli:nth-child(odd),.tli:nth-child(even){padding-left:60px;padding-right:0;text-align:left;justify-content:flex-start}.tld{left:20px}}

/* ============================================================
   SPONSORING
   ============================================================ */
.sps{padding:var(--sp-y) 0;background:var(--white)}
.sphd{text-align:center;margin-bottom:60px}.sphd p{color:var(--g500);max-width:600px;margin:16px auto 0;font-size:1.05rem}
.spl{display:flex;flex-wrap:wrap;justify-content:center;gap:48px;align-items:center;margin-bottom:60px}
/* Sponsor-Logo-Boxen: 240×120 mit großzügigem Innen-Padding für Atemraum um Logo/Text. */
.spli{width:240px;height:120px;background:var(--g50);border-radius:14px;display:flex;align-items:center;justify-content:center;font-family:var(--fd);font-size:1.1rem;color:var(--g400);letter-spacing:2px;transition:all .3s var(--ease);border:1px solid var(--g100);overflow:hidden;padding:36px;text-align:center}
.spli img{width:100%;height:100%;object-fit:contain}
.spli:hover{transform:translateY(-5px);box-shadow:0 12px 28px rgba(0,0,0,.08);border-color:var(--gold-pale);color:var(--navy)}
@media(max-width:600px){.spl{gap:24px}.spli{width:180px;height:96px;padding:18px}}
.sppk{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:60px;padding-top:16px}
.spp{background:var(--g50);border-radius:20px;padding:36px;text-align:center;border:2px solid transparent;transition:all .4s var(--ease);position:relative}
.spp.ft{border-color:var(--gold);background:var(--wheat-light);padding:52px 36px 36px}
.spp.ft::before{content:'★ BELIEBT';position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--gold);color:var(--navy);font-size:.7rem;font-weight:700;padding:4px 16px;border-radius:50px;letter-spacing:1px}
.spp:hover{transform:translateY(-6px);box-shadow:0 16px 40px rgba(0,0,0,.06)}
.spp h4{font-family:var(--fd);font-size:1.4rem;letter-spacing:2px;color:var(--navy);margin-bottom:8px}
.spp .pr{font-family:var(--fd);font-size:2.2rem;color:var(--blue);margin-bottom:4px}.spp .pr small{font-size:.9rem;color:var(--g400)}
.spp ul{text-align:left;margin:20px 0}.spp ul li{padding:8px 0;font-size:.9rem;color:var(--g600);border-bottom:1px solid var(--g200);display:flex;align-items:center;gap:8px}.spp ul li::before{content:'✓';color:var(--blue);font-weight:700}
.spct{display:grid;grid-template-columns:auto 1fr;gap:40px;align-items:center;background:var(--g50);border-radius:20px;padding:40px;margin-top:40px}
.spci{width:120px;height:120px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--blue-dark));display:flex;align-items:center;justify-content:center;color:var(--white);font-size:2.5rem;font-family:var(--fd);box-shadow:0 8px 24px rgba(37,99,168,.25)}
.spcx h4{font-family:var(--fd);font-size:1.3rem;color:var(--navy);letter-spacing:1px;margin-bottom:4px}
.spcx .rl2{color:var(--blue);font-size:.85rem;font-weight:500;margin-bottom:12px}
.spcx p{font-size:.95rem;color:var(--g500);line-height:1.6;margin-bottom:16px}
@media(max-width:768px){.sppk{grid-template-columns:1fr}.spct{grid-template-columns:1fr;text-align:center}.spci{margin:0 auto}}

/* ============================================================
   VERBÄNDE (Über uns - Mitgliedschaften)
   Selbe Logo-Box-Mechanik wie Sponsoren auf Startseite.
   ============================================================ */
.vbn{padding:var(--sp-y) 0;background:var(--white)}
.vbhd{text-align:center;margin-bottom:48px}
.vbhd .slbl{margin-bottom:8px}
.vbl{display:flex;flex-wrap:wrap;justify-content:center;gap:48px;align-items:center}
.vbli{width:240px;height:120px;background:var(--g50);border-radius:14px;display:flex;align-items:center;justify-content:center;font-family:var(--fd);font-size:1.05rem;color:var(--g400);letter-spacing:2px;transition:all .3s var(--ease);border:1px solid var(--g100);overflow:hidden;padding:36px;text-align:center}
.vbli img{width:100%;height:100%;object-fit:contain}
.vbli a{display:flex;width:100%;height:100%;align-items:center;justify-content:center;color:inherit}
.vbli:hover{transform:translateY(-5px);box-shadow:0 12px 28px rgba(0,0,0,.08);border-color:var(--gold-pale);color:var(--navy)}
@media(max-width:600px){.vbl{gap:24px}.vbli{width:180px;height:96px;padding:18px;font-size:.95rem}}

/* ============================================================
   MEMBERSHIP
   ============================================================ */
.mbr{padding:var(--sp-y) 0;background:var(--cream);position:relative} /* flaches cream wie auf der Über-uns-Seite (vorher Verlauf cream→wheat + Gold-Glow) */
.mbr .ctr{position:relative;z-index:1}
.mhd{text-align:center;margin-bottom:60px}.mhd p{color:var(--g500);max-width:600px;margin:16px auto 0;font-size:1.05rem}
.bfg{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:60px}
.bfc{background:var(--white);border-radius:16px;padding:32px;border:1px solid var(--g100);transition:all .4s var(--ease)}
.bfc:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(0,0,0,.06)}
.bfi{width:48px;height:48px;background:var(--wheat-light);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;margin-bottom:16px}
/* Vorteils-Icons: eigene SVGs aus images/ui/ per CSS-mask in Blau eingefärbt (wie .tkcimg).
   Eigenfarbe der SVG egal – nur Form/Alpha zählt. Modifier = Dateiname-Slug. */
.bfimg{display:block;width:26px;height:26px;background-color:var(--blue);-webkit-mask:center/contain no-repeat;mask:center/contain no-repeat}
.bfimg--struktur{-webkit-mask-image:url(images/ui/struktur.svg);mask-image:url(images/ui/struktur.svg)}
.bfimg--schild{-webkit-mask-image:url(images/ui/schild.svg);mask-image:url(images/ui/schild.svg)}
.bfimg--scheibe{-webkit-mask-image:url(images/ui/scheibe.svg);mask-image:url(images/ui/scheibe.svg)}
.bfimg--baumpflanze{-webkit-mask-image:url(images/ui/baumpflanze.svg);mask-image:url(images/ui/baumpflanze.svg)}
.bfimg--pfeil{-webkit-mask-image:url(images/ui/pfeil.svg);mask-image:url(images/ui/pfeil.svg)}
.bfimg--lovinghands{-webkit-mask-image:url(images/ui/lovinghands.svg);mask-image:url(images/ui/lovinghands.svg)}
.bfimg--pokal{-webkit-mask-image:url(images/ui/hl-pokal.svg);mask-image:url(images/ui/hl-pokal.svg)}
.bfimg--gemeinschaft{-webkit-mask-image:url(images/ui/val-gemeinschaft.svg);mask-image:url(images/ui/val-gemeinschaft.svg)}
.bfimg--treppenchart{-webkit-mask-image:url(images/ui/treppenchart.svg);mask-image:url(images/ui/treppenchart.svg)}
.bfimg--shirt{-webkit-mask-image:url(images/ui/shirt.svg);mask-image:url(images/ui/shirt.svg)}
.bfimg--yingyang{-webkit-mask-image:url(images/ui/gleichgewicht_yingyang.svg);mask-image:url(images/ui/gleichgewicht_yingyang.svg)}
.bfc h4{font-weight:700;color:var(--navy);margin-bottom:8px}.bfc p{font-size:.9rem;color:var(--g500);line-height:1.6}
.csts{background:var(--white);border-radius:24px;padding:48px;margin-bottom:60px;border:1px solid var(--g100)}
.csts h3{font-family:var(--fd);font-size:2rem;color:var(--navy);text-align:center;letter-spacing:2px;margin-bottom:32px}
.csg{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.csi{display:flex;align-items:flex-start;gap:16px;padding:20px;background:var(--g50);border-radius:12px}
.csa{font-family:var(--fd);font-size:1.8rem;color:var(--blue);white-space:nowrap;line-height:1;min-width:56px} /* min-width hält die Zahlenspalte stabil, damit der Beschreibungstext bündig startet (auch bei kurzen Beträgen wie „25€") */
.csd h5{font-weight:600;color:var(--navy);margin-bottom:4px}.csd p{font-size:.85rem;color:var(--g500);line-height:1.6}.csd p+p{margin-top:.7em} /* Abstand zwischen zwei Absätzen in einer Kosten-Card */
.exps{display:grid;grid-template-columns:repeat(2,1fr);gap:40px;margin-bottom:60px}
.expc h3{font-family:var(--fd);font-size:1.5rem;color:var(--navy);letter-spacing:1px;margin-bottom:20px;display:flex;align-items:center;gap:10px}
/* Inline-Icons in den Erwartungs-Headern (geschenk / handinhand), blau eingefärbt per mask */
.exic{display:inline-block;width:26px;height:26px;flex:0 0 auto;background-color:var(--blue);-webkit-mask:center/contain no-repeat;mask:center/contain no-repeat}
.exic--geschenk{-webkit-mask-image:url(images/ui/geschenk.svg);mask-image:url(images/ui/geschenk.svg)}
.exic--handinhand{-webkit-mask-image:url(images/ui/handinhand.svg);mask-image:url(images/ui/handinhand.svg)}
.expl li{padding:12px 0;border-bottom:1px solid var(--g100);font-size:.95rem;color:var(--g600);display:flex;align-items:flex-start;gap:10px}
.expl li::before{content:'→';color:var(--gold);font-weight:700;flex-shrink:0}
@media(max-width:768px){.bfg{grid-template-columns:1fr}.csg{grid-template-columns:1fr}.exps{grid-template-columns:1fr}}

/* ============================================================
   CONTACT
   ============================================================ */
.cnt{padding:var(--sp-y) 0;background:var(--white)}
.cnt--alt{background:var(--cream)} /* alternierender Section-Hintergrund (Kontakt) für globale Rhythmik */
.cnhd{text-align:center;margin-bottom:60px}.cnhd p{color:var(--g500);max-width:600px;margin:16px auto 0;font-size:1.05rem}
.bdp{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:60px}
.bdc{background:var(--g50);border-radius:16px;padding:32px;text-align:center;border:1px solid var(--g100);transition:all .4s var(--ease)}
.bdc:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(0,0,0,.06)}
.bdav{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--blue-dark));display:flex;align-items:center;justify-content:center;color:var(--white);font-size:1.5rem;font-family:var(--fd);margin:0 auto 16px;box-shadow:0 4px 16px rgba(37,99,168,.2)}
.bdc h4{font-weight:700;color:var(--navy);margin-bottom:4px}
.bdc .bdr{font-size:.8rem;color:var(--blue);font-weight:500;margin-bottom:12px}
.bdc p{font-size:.85rem;color:var(--g500);line-height:1.6;margin-bottom:16px}
.bdcl{display:inline-flex;align-items:center;gap:6px;font-size:.85rem;color:var(--blue);font-weight:600;transition:color .3s}.bdcl:hover{color:var(--red)}
.mpg{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.mpc{border-radius:20px;overflow:hidden;border:1px solid var(--g100);background:var(--white)}
.mpc iframe{width:100%;height:280px;border:none}
.mpi{padding:24px}.mpi h4{font-family:var(--fd);font-size:1.2rem;color:var(--navy);letter-spacing:1px;margin-bottom:8px}.mpi p{font-size:.9rem;color:var(--g500);line-height:1.6}
@media(max-width:768px){.bdp{grid-template-columns:1fr}.mpg{grid-template-columns:1fr}}

/* ============================================================
   FOOTER
   ============================================================ */
.ft{background:var(--navy);color:rgba(255,255,255,.6);padding:60px 0 30px}
.fti{display:grid;grid-template-columns:1fr 1fr 1fr;gap:40px;margin-bottom:32px;align-items:start}
/* Spalte 2 (Navigation) zentriert, Spalte 3 (Rechtliches) rechtsbündig */
.fti>div:nth-child(2){text-align:center}
.fti>div:nth-child(3){text-align:right}
.ftb p{font-size:.9rem;line-height:1.7;margin-top:16px}
.ftb p strong{color:var(--gold);font-weight:600;letter-spacing:.5px}
.ftl{display:flex;align-items:center;gap:12px}.ftl img{height:40px}
.ftlt{font-family:var(--fd);font-size:1rem;letter-spacing:2px;color:var(--white)}
.ft h5{font-family:var(--fd);font-size:.9rem;letter-spacing:2px;color:var(--white);margin-bottom:16px}
.ft ul li{margin-bottom:8px}.ft ul li a{font-size:.85rem;transition:color .3s}.ft ul li a:hover{color:var(--gold)}
.ftsoc{display:flex;gap:16px;margin-top:20px}
.ftsoc a{display:inline-flex;align-items:center;justify-content:center;color:var(--gold);transition:transform .3s var(--ease2),opacity .3s var(--ease)}
.ftsoc a:hover{color:var(--gold-light);transform:translateY(-2px) scale(1.08)}
.ftsoc svg{display:block}
.ftmlogo{display:flex;align-items:center;justify-content:center;min-height:80px;margin:8px 0 24px}
.ftmlogo__img{max-height:64px;width:auto;opacity:.9}
.ftbt{border-top:1px solid rgba(255,255,255,.1);padding-top:24px;display:flex;justify-content:space-between;font-size:.8rem}
@media(max-width:768px){.fti{grid-template-columns:1fr}.fti>div:nth-child(2),.fti>div:nth-child(3){text-align:left}.ftbt{flex-direction:column;gap:8px}.ftmlogo{min-height:60px}}

/* ============================================================
   SCROLL PROGRESS & BACK TO TOP
   ============================================================ */
.sprg{position:fixed;top:0;left:0;height:3px;background:linear-gradient(90deg,var(--red),var(--gold));z-index:10000;transition:width .1s}
.btt{position:fixed;bottom:30px;right:30px;width:48px;height:48px;background:var(--blue);color:var(--white);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.2rem;z-index:999;opacity:0;transform:translateY(20px);transition:all .4s var(--ease);box-shadow:0 4px 16px rgba(37,99,168,.3)}
.btt.vis{opacity:1;transform:translateY(0)}.btt:hover{background:var(--navy);transform:translateY(-4px)}

/* ============================================================
   LOADER
   ============================================================ */
.ldr{position:fixed;inset:0;background:var(--navy);z-index:100000;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:20px;transition:opacity .6s,visibility .6s}
.ldr.hd{opacity:0;visibility:hidden}
.ldr img{width:120px;animation:lp 1s ease-in-out infinite}
@keyframes lp{0%,100%{transform:scale(1);opacity:.7}50%{transform:scale(1.1);opacity:1}}
.ldrt{font-family:var(--fd);color:var(--white);font-size:1.2rem;letter-spacing:4px;opacity:.6}

/* ============================================================
   INNER PAGES (Impressum, Datenschutz, etc.)
   ============================================================ */
.page-content{padding:calc(var(--nh) + 32px) 0 var(--sp-y);min-height:60vh}
.page-content h1{font-family:var(--fd);font-size:clamp(2rem,4vw,3rem);color:var(--navy);margin-bottom:24px;letter-spacing:2px}
.page-content h2{font-family:var(--fd);font-size:1.8rem;color:var(--navy);margin:32px 0 16px;letter-spacing:1px}
.page-content h3{font-size:1.2rem;font-weight:700;color:var(--navy);margin:24px 0 12px}
.page-content p{color:var(--g600);line-height:1.8;margin-bottom:16px}
.page-content a{color:var(--blue);text-decoration:underline}
.page-content ul,.page-content ol{margin:0 0 16px 24px;color:var(--g600)}
.page-content ul{list-style:disc}
.page-content ol{list-style:decimal}
.page-content li{margin-bottom:8px;line-height:1.7}

/* ============================================================
   GOOGLE MAPS ZWEI-KLICK-EINWILLIGUNG (DSGVO)
   ============================================================ */
.mck{position:relative;width:100%;aspect-ratio:4/3;background:var(--g100);border-radius:16px 16px 0 0;overflow:hidden;display:flex;align-items:center;justify-content:center}
.mck iframe{position:absolute;inset:0;width:100%;height:100%;border:0;border-radius:16px 16px 0 0}
.mcki{text-align:center;padding:32px 24px;max-width:320px}
.mckico{font-size:2.5rem;margin-bottom:12px}
.mcki p{font-size:.875rem;color:var(--g600);line-height:1.6;margin-bottom:16px}
.mcki p:first-of-type{font-size:1rem;color:var(--g800);margin-bottom:8px}
.mcki a{color:var(--blue);text-decoration:underline}
.mckb{background:var(--blue);color:#fff;border:none;padding:10px 24px;border-radius:50px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .3s}
.mckb:hover{background:var(--blue-dark)}

/* ===== Kontakt-Redesign ===== */
/* 2 Ansprechpartner-Karten, Foto linksbündig */
.bdp--2{grid-template-columns:repeat(2,1fr)}
.bdc--row{display:flex;align-items:center;gap:28px;text-align:left}
.bdc-photo{flex:0 0 auto;width:180px;height:180px;border-radius:16px;overflow:hidden;background:var(--g100)}
.bdc-photo img{width:100%;height:100%;object-fit:cover}
.bdc-body{flex:1;min-width:0}
.bdc--row h4{margin-bottom:2px}
@media(max-width:768px){.bdp--2{grid-template-columns:1fr}}
@media(max-width:480px){.bdc--row{flex-direction:column;text-align:center;gap:16px}}

/* Subline unter Section-Headline */
.cntsub{max-width:760px;margin:0 auto 40px;text-align:center;color:var(--g600);line-height:1.7}

/* Eine Spielstätte: Karte links / Text rechts */
.mpg--single{grid-template-columns:1fr;margin:0 auto} /* volle Container-Breite – greift Breite der .bdp--2-Karten oben auf */
/* Map-Row spiegelt exakt die .abg-Logik des Simon-Blocks darunter:
   gap:80px + 1fr/1fr => Karte gleich BREIT wie das Trainingsbild. Dafür wird
   die umschließende Card aufgelöst (kein Rahmen/BG), die Karte selbst gerundet. */
.mpg--single .mpc{border:none;background:transparent;overflow:visible}
.mpc--row{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.mpc--row .mck{aspect-ratio:4/3;height:auto;min-height:340px;border-radius:20px} /* 4/3 + eigene Rundung wie .abiw */
.mpc--row .mck iframe{border-radius:20px}
.mpc--row .mpi{display:flex;flex-direction:column;justify-content:center;padding:0}
/* Vereinsheim-Infoblock: gruppiert mit Trennlinien (Optik der Simon-Sektion) */
.mpc--row .mpi h4{font-family:var(--fd);font-size:1.7rem;color:var(--navy);letter-spacing:2px;margin-bottom:2px}
.vhg{padding:16px 0;border-top:1px solid var(--g200)}
.vhg:first-of-type{border-top:none}
.vhl{font-family:var(--fd);font-size:.8rem;letter-spacing:3px;text-transform:uppercase;color:var(--blue);margin-bottom:6px}
.vhg p{font-size:.95rem;color:var(--g600);line-height:1.75;margin:0}
/* Slogan als goldene Outline-Pille — exakt wie die Liga-Badge (.tsl) auf der Teams-Seite */
.vhslogan{margin-top:22px}
@media(max-width:768px){.mpc--row{grid-template-columns:1fr;gap:40px}.mpc--row .mck{min-height:260px}}
.trz{list-style:none;margin:0 0 20px;padding:0}
.trz li{display:flex;justify-content:space-between;align-items:baseline;gap:16px;padding:11px 0;border-bottom:1px solid var(--g100)}
.trz li:last-child{border-bottom:none}
.trz-d{font-family:var(--fd);font-size:1.15rem;letter-spacing:1px;color:var(--navy)}
.trz-t{color:var(--g600);font-weight:500}
.trz-t em{color:var(--gold);font-style:normal;font-weight:600;font-size:.85em}

/* ============================================================
   KONTAKTFORMULAR  (Form links / Kontaktdaten-Panel rechts)
   ============================================================ */
.cfg{display:grid;grid-template-columns:1.25fr .85fr;gap:48px;align-items:stretch}
/* Formular-Spalte – gleiche Höhe wie das Daten-Panel daneben (stretch).
   .cff/.cfm als Flex-Spalten, das Nachricht-Feld (.cfield--grow) absorbiert
   die Höhendifferenz, damit der Button bündig am Karten-Boden sitzt. */
.cff{background:var(--white);border:1px solid var(--g200);border-radius:20px;padding:36px;box-shadow:0 12px 32px rgba(22,39,66,.05);display:flex;flex-direction:column}
.cfm{flex:1;display:flex;flex-direction:column}
.cfm .cfield{margin-bottom:18px}
.cfm .cfield--grow{flex:1;display:flex;flex-direction:column;min-height:0}
.cfm .cfield--grow textarea{flex:1}
.cfrow{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.cfm label{display:block;font-family:var(--fb);font-weight:600;font-size:.9rem;color:var(--navy);margin-bottom:7px}
.cfopt{font-weight:400;color:var(--g400);font-size:.82em}
.cfreq{color:var(--red)}
.cfm input,.cfm select,.cfm textarea{width:100%;font-family:var(--fb);font-size:.95rem;color:var(--navy);background:var(--g50);border:1px solid var(--g200);border-radius:12px;padding:13px 16px;transition:border-color .25s var(--ease),box-shadow .25s var(--ease),background .25s var(--ease)}
.cfm textarea{resize:vertical;min-height:90px;line-height:1.6}
.cfm select{appearance:none;-webkit-appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='9' viewBox='0 0 14 9'%3E%3Cpath fill='none' stroke='%232563a8' stroke-width='2' d='M1 1l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;padding-right:42px}
.cfm input:focus,.cfm select:focus,.cfm textarea:focus{outline:none;background:var(--white);border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,168,.12)}
.cfm input::placeholder,.cfm textarea::placeholder{color:var(--g400)}
.cfm .bp{margin-top:4px;border:none;cursor:pointer;font-family:var(--fb);align-self:flex-start}
/* Datenschutz-Pflicht-Checkbox */
.cfcheck{display:flex;align-items:flex-start;gap:10px}
.cfcheck input{flex:0 0 auto;width:18px;height:18px;margin-top:3px;accent-color:var(--blue);cursor:pointer}
.cfcheck label{margin-bottom:0;font-weight:400;font-size:.82rem;color:var(--g500);line-height:1.55}
.cfcheck label a{color:var(--blue);text-decoration:underline}
/* Honeypot: für Menschen unsichtbar, für Bots ein Köder */
.cfhp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
/* Status-Meldungen */
.cfmsg{border-radius:12px;padding:16px 18px;margin-bottom:24px;font-size:.92rem;line-height:1.6}
.cfmsg strong{font-weight:700}
.cfmsg--ok{background:rgba(37,99,168,.08);border:1px solid rgba(37,99,168,.25);color:var(--blue-dark)}
.cfmsg--err{background:rgba(200,16,46,.07);border:1px solid rgba(200,16,46,.25);color:var(--red-dark)}
.cfmsg a{color:inherit;text-decoration:underline;font-weight:600}
/* Daten-Panel (Navy-Karte) */
.cfd{background:linear-gradient(150deg,var(--navy) 0%,var(--blue-dark) 100%);color:#fff;border-radius:20px;padding:36px;position:relative;overflow:hidden}
.cfd::before{content:'';position:absolute;top:-80px;right:-80px;width:240px;height:240px;border-radius:50%;background:radial-gradient(circle,rgba(201,168,76,.16) 0%,transparent 70%);pointer-events:none}
.cfd-label{font-family:var(--fd);font-size:.8rem;letter-spacing:4px;text-transform:uppercase;color:var(--gold);margin-bottom:8px;position:relative}
.cfd h3{font-family:var(--fd);font-size:1.9rem;letter-spacing:2px;line-height:1;color:#fff;margin-bottom:24px;position:relative}
.cfd-list{list-style:none;margin:0 0 24px;padding:0;position:relative}
.cfd-list li{padding:14px 0;border-top:1px solid rgba(255,255,255,.12)}
.cfd-list li:first-child{border-top:none;padding-top:0}
.cfd-k{display:block;font-family:var(--fd);font-size:.78rem;letter-spacing:3px;text-transform:uppercase;color:var(--gold-light);margin-bottom:4px}
.cfd-v{display:block;font-family:var(--fb);font-size:.95rem;color:rgba(255,255,255,.88);line-height:1.55;word-break:break-word}
.cfd-v a{color:#fff;text-decoration:none;transition:color .25s var(--ease)}
.cfd-v a:hover{color:var(--gold)}
.cfd-social{display:flex;gap:12px;flex-wrap:wrap;position:relative}
.cfd-social .bo{color:#fff;border-color:rgba(255,255,255,.4);padding:10px 22px;font-size:.88rem}
.cfd-social .bo:hover{background:var(--gold);border-color:var(--gold);color:var(--navy)}
@media(max-width:880px){
.cfg{grid-template-columns:1fr;gap:32px}
.cff,.cfd{padding:28px}
}
@media(max-width:480px){
.cfrow{grid-template-columns:1fr;gap:0}
}

/* ============================================================
   INNER PAGE HERO  (angelehnt an Landing Page Hero)
   ============================================================ */
.page-hero{position:relative;padding:180px 0 120px;background:linear-gradient(135deg,var(--navy) 0%,var(--blue-dark) 40%,var(--blue) 100%);text-align:center;overflow:hidden}

/* Dot-Pattern – 3 Layer wie Landing Page */
.page-hero__pattern{position:absolute;inset:0;opacity:.06;background-image:radial-gradient(circle at 20% 50%,var(--gold) 1px,transparent 1px),radial-gradient(circle at 80% 20%,var(--gold) 1px,transparent 1px),radial-gradient(circle at 60% 80%,var(--gold) 1px,transparent 1px);background-size:60px 60px,80px 80px,40px 40px}

/* Gold-Glow rechts oben + links unten (wie .hgl auf Landing Page) */
.page-hero__glow{position:absolute;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(201,168,76,.12) 0%,transparent 70%);top:-120px;right:-80px;animation:pg 4s ease-in-out infinite alternate;pointer-events:none}
.page-hero__glow--left{top:auto;right:auto;bottom:-120px;left:-80px;width:400px;height:400px;animation-delay:2s}

/* Badge (wie .hbd auf Landing Page) */
.page-hero__badge{display:inline-flex;align-items:center;gap:8px;padding:8px 24px;background:rgba(201,168,76,.15);border:1px solid rgba(201,168,76,.3);border-radius:50px;font-size:.85rem;font-weight:500;color:var(--gold-light);letter-spacing:2px;text-transform:uppercase;margin-bottom:24px;animation:fiu .8s var(--ease) .2s both}

/* Titel */
.page-hero__title{font-family:var(--fd);font-size:clamp(2.8rem,6vw,4.5rem);letter-spacing:3px;line-height:1.05;color:#fff;margin-bottom:20px;animation:fiu .8s var(--ease) .4s both}
.page-hero__title span{color:var(--gold);position:relative}
.page-hero__title span::after{content:'';position:absolute;bottom:2px;left:0;width:100%;height:3px;background:var(--red);border-radius:2px}

/* Subtitle */
.page-hero__subtitle{font-family:var(--fb);font-size:1.15rem;color:rgba(255,255,255,.7);max-width:600px;margin:0 auto;line-height:1.7;animation:fiu .8s var(--ease) .6s both}

/* Dekorative Goldlinie unter Subtitle */
.page-hero__line{width:60px;height:3px;background:linear-gradient(90deg,var(--gold),var(--gold-light));border-radius:2px;margin:28px auto 0;animation:fiu .8s var(--ease) .8s both}

/* Inner-Pages: Background-Verlauf der Teams-Sektion ausblenden (sieht
   sonst doppelt zum Inner-Page-Hero aus). Section-Padding ist seit der
   Vereinheitlichung über --sp-y einheitlich — kein Top-Override mehr nötig. */
body.page:not(.home) .tms::before{display:none}
body.page:not(.home) .tms,
body.page:not(.home) .abt,
body.page:not(.home) .hst,
body.page:not(.home) .mbr,
body.page:not(.home) .sps,
body.page:not(.home) .cnt{position:relative;z-index:5}

@media(max-width:768px){
.page-hero{padding:124px 0 84px} /* mehr Abstand Badge↔Navbar auf Mobile (Navbar 72px → ~52px Luft) */
.page-hero__glow{width:300px;height:300px}
.page-hero__glow--left{width:250px;height:250px}
}
