/*
Theme Name:  SpVgg Kapfelberg
Theme URI:   https://spvgg-kapfelberg.org
Author:      HuschDesign
Description: Custom Theme für die SpVgg Kapfelberg 1961
Version:     2.1.0
License:     GNU General Public License v2 or later
Text Domain: spvgg
*/

@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@700;800;900&family=Barlow:wght@400;500;600&display=swap');

/* ─────────────────────────────────────────────────
   RESET & BASIS
───────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --blue:        #0d1b3e;
  --blue-mid:    #1a2e6e;
  --blue-light:  #2a5298;
  --blue-accent: #4a90d9;
  --silver:      #c8d6e8;
  --white:       #ffffff;
  --gray-50:     #f6f8fc;
  --gray-100:    #edf1f7;
  --gray-200:    #d8e1ef;
  --gray-400:    #8fa3c0;
  --gray-600:    #4a5f7a;
  --gray-700:    #334155;
  --gray-800:    #1a2535;
  --radius:      10px;
  --shadow:      0 2px 20px rgba(13,27,62,.10);
  --shadow-lg:   0 12px 40px rgba(13,27,62,.18);
  --transition:  .22s cubic-bezier(.4,0,.2,1);
  --header-h:    68px;
}

html { scroll-behavior: smooth; }
body { font-family: 'Barlow', sans-serif; color: var(--gray-800); background: var(--white); }
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }

/* ─────────────────────────────────────────────────
   BUTTONS
───────────────────────────────────────────────── */
.btn { display: inline-flex; align-items: center; justify-content: center; font-family: 'Barlow', sans-serif; font-weight: 700; font-size: .9rem; padding: 10px 22px; border-radius: 7px; cursor: pointer; border: none; text-decoration: none; letter-spacing: .02em; transition: background var(--transition), transform var(--transition), box-shadow var(--transition); }
.btn:hover { transform: translateY(-1px); box-shadow: var(--shadow-lg); }
.btn-primary { background: var(--blue-mid); color: var(--white); }
.btn-primary:hover { background: var(--blue-light); }
.btn-white { background: var(--white); color: var(--blue-mid); }
.btn-white:hover { background: var(--gray-100); }
.btn-outline { background: transparent; color: var(--white); border: 2px solid rgba(255,255,255,.6); }
.btn-outline:hover { background: rgba(255,255,255,.12); border-color: var(--white); }

/* ─────────────────────────────────────────────────
   HEADER
───────────────────────────────────────────────── */
.site-header { position: fixed; top: 0; left: 0; right: 0; z-index: 1000; background: var(--white); box-shadow: 0 1px 0 var(--gray-200); height: var(--header-h); display: flex; align-items: center; }
.admin-bar .site-header { top: 32px; }
@media screen and (max-width: 782px) { .admin-bar .site-header { top: 46px; } }

.header-inner { max-width: 1160px; margin: 0 auto; padding: 0 24px; width: 100%; display: flex; align-items: center; gap: 32px; }

.site-logo { display: flex; align-items: center; gap: 12px; flex-shrink: 0; text-decoration: none; }
.site-logo .logo-img { height: 48px; width: auto; }
.site-logo .logo-img-fallback { width: 48px; height: 48px; background: var(--blue-mid); border-radius: 50%; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.site-logo .logo-img-fallback svg { width: 26px; height: 26px; fill: white; }
.logo-name { font-family: 'Barlow Condensed', sans-serif; font-weight: 900; font-size: 1.3rem; color: var(--blue-mid); letter-spacing: .01em; }

/* Desktop Nav */
.main-nav { margin-left: auto; }
.main-nav ul { list-style: none; display: flex; align-items: center; gap: 2px; }
.main-nav ul li { position: relative; }
.main-nav ul li > a { font-size: .88rem; font-weight: 500; color: var(--gray-600); padding: 6px 11px; border-radius: 6px; display: block; transition: color var(--transition), background var(--transition); white-space: nowrap; }
.main-nav ul li > a:hover, .main-nav ul li.current-menu-item > a, .main-nav ul li.current-menu-ancestor > a { color: var(--blue-mid); background: var(--gray-100); }
.main-nav ul li:has(> ul) > a::after { content: ' ↓'; font-size: .65rem; opacity: .45; }

/* Dropdown 2. Ebene */
.main-nav ul li ul { display: none; position: absolute; top: 100%; left: 0; min-width: 220px; z-index: 200; background: var(--white); border-radius: var(--radius); box-shadow: var(--shadow-lg); border-top: 3px solid var(--blue-accent); }
.main-nav ul li:hover > ul { display: block; }
.main-nav ul li::after { content: ''; position: absolute; bottom: -10px; left: 0; right: 0; height: 10px; }
.main-nav ul li > ul > li > a { padding: 9px 16px; font-size: .88rem; color: var(--gray-700); border-bottom: 1px solid var(--gray-100); display: block; white-space: nowrap; transition: background var(--transition), color var(--transition); }
.main-nav ul li > ul > li > a:hover { background: var(--gray-50); color: var(--blue-mid); }
.main-nav ul li > ul > li:last-child > a { border-bottom: none; }

/* Flyout 3. Ebene */
.main-nav ul li ul li { position: relative; }
.main-nav ul li ul li ul { display: none; position: absolute; top: -3px; left: 100%; min-width: 200px; background: var(--white); border-radius: var(--radius); box-shadow: var(--shadow-lg); border-top: 3px solid var(--blue-accent); overflow: hidden; }
.main-nav ul li ul li:hover > ul { display: block !important; }
.main-nav ul li ul li::after { content: ''; position: absolute; top: 0; right: -10px; width: 10px; height: 100%; }
.main-nav ul li ul li:has(ul) > a::after { content: ' →'; font-size: .7rem; opacity: .5; float: right; }

.header-cta { margin-left: 12px; flex-shrink: 0; }

/* Hamburger */
.hamburger { display: none; flex-direction: column; justify-content: center; gap: 5px; width: 40px; height: 40px; padding: 8px; background: none; border: none; cursor: pointer; margin-left: auto; flex-shrink: 0; }
.hamburger span { display: block; width: 100%; height: 2px; background: var(--blue-mid); border-radius: 2px; transition: transform .3s, opacity .3s; transform-origin: center; }
.hamburger.is-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.hamburger.is-open span:nth-child(2) { opacity: 0; }
.hamburger.is-open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Mobile Menü */
.mobile-menu { position: fixed; top: var(--header-h); left: 0; right: 0; bottom: 0; background: var(--white); z-index: 999; overflow-y: auto; transform: translateX(-100%); transition: transform .3s cubic-bezier(.4,0,.2,1); }
.mobile-menu.is-open { transform: translateX(0); }
.mobile-overlay { position: fixed; top: var(--header-h); left: 0; right: 0; bottom: 0; background: rgba(0,0,0,.45); z-index: 998; opacity: 0; pointer-events: none; transition: opacity .3s; }
.mobile-overlay.is-open { opacity: 1; pointer-events: all; }
.admin-bar .mobile-menu, .admin-bar .mobile-overlay { top: calc(var(--header-h) + 32px); }
@media screen and (max-width: 782px) { .admin-bar .mobile-menu, .admin-bar .mobile-overlay { top: calc(var(--header-h) + 46px); } }

.mobile-menu-inner { padding: 8px 16px 32px; }
.mobile-nav-list { list-style: none; }
.mobile-nav-list > li > a { display: block; padding: 14px 16px; font-weight: 600; font-size: 1rem; color: var(--gray-800); border-bottom: 1px solid var(--gray-100); transition: color var(--transition); }
.mobile-nav-list > li > a:hover { color: var(--blue-mid); }
.mobile-nav-list li ul { list-style: none; display: none; background: var(--gray-50); border-radius: 8px; margin: 4px 0 8px; overflow: hidden; }
.mobile-nav-list li.is-open > ul { display: block; }
.mobile-nav-list li ul li a { display: block; padding: 11px 20px; font-size: .9rem; color: var(--gray-600); border-bottom: 1px solid var(--gray-100); transition: color var(--transition); }
.mobile-nav-list li ul li:last-child a { border-bottom: none; }
.mobile-nav-list li ul li a:hover { color: var(--blue-mid); }
.mobile-nav-list li.menu-item-has-children > a::after { content: ' ↓'; font-size: .7rem; opacity: .4; float: right; margin-top: 3px; }
.mobile-nav-list li.menu-item-has-children.is-open > a::after { content: ' ↑'; }
.mobile-cta { display: block; width: 100%; text-align: center; margin-top: 16px; }

/* ─────────────────────────────────────────────────
   HERO
───────────────────────────────────────────────── */
.hero { margin-top: var(--header-h); min-height: 580px; background: var(--blue); display: flex; align-items: center; position: relative; overflow: hidden; }
.admin-bar .hero { margin-top: calc(var(--header-h) + 32px); }
@media screen and (max-width: 782px) { .admin-bar .hero { margin-top: calc(var(--header-h) + 46px); } }
.hero-bg { position: absolute; inset: 0; background-image: linear-gradient(to right, rgba(10,18,50,.88) 35%, rgba(10,18,50,.45) 100%); background-size: cover; background-position: center 30%; }
.hero-content { position: relative; z-index: 2; max-width: 1160px; margin: 0 auto; padding: 60px 24px; }
.hero-tag { display: inline-flex; align-items: center; gap: 10px; font-family: 'Barlow Condensed', sans-serif; font-weight: 700; font-size: .78rem; letter-spacing: .15em; text-transform: uppercase; color: var(--silver); margin-bottom: 16px; }
.hero-tag::before { content: ''; display: inline-block; width: 28px; height: 2px; background: var(--silver); }
.hero h1 { font-family: 'Barlow Condensed', sans-serif; font-weight: 900; font-size: clamp(2.8rem, 6vw, 4.2rem); color: var(--white); line-height: .95; letter-spacing: -.01em; margin-bottom: 16px; text-transform: uppercase; }
.hero p { font-size: 1.3rem; color: rgba(255,255,255,.85); margin-bottom: 32px; max-width: 780px; line-height: 1.5; white-space: pre-line; }
.hero-br { display: inline; }
@media (max-width: 600px) { .hero p { font-size: .88rem; white-space: normal; } .hero-br { display: none; } }
.hero-btns { display: flex; gap: 12px; flex-wrap: wrap; }

/* ─────────────────────────────────────────────────
   PAGE HERO
───────────────────────────────────────────────── */
.page-hero { margin-top: var(--header-h); background: var(--blue-mid); padding: 52px 0 44px; color: var(--white); position: relative; overflow: hidden; }
.admin-bar .page-hero { margin-top: calc(var(--header-h) + 32px); }
@media screen and (max-width: 782px) { .admin-bar .page-hero { margin-top: calc(var(--header-h) + 46px); } }
.page-hero::after { content: ''; position: absolute; right: -80px; top: -80px; width: 340px; height: 340px; border-radius: 50%; background: rgba(255,255,255,.03); pointer-events: none; }
.breadcrumb { display: flex; align-items: center; gap: 8px; font-size: .8rem; color: rgba(255,255,255,.45); margin-bottom: 16px; }
.breadcrumb a { color: rgba(255,255,255,.55); transition: color var(--transition); }
.breadcrumb a:hover { color: var(--white); }
.page-hero h1 { font-family: 'Barlow Condensed', sans-serif; font-weight: 900; font-size: clamp(2rem, 4vw, 3rem); line-height: 1.05; margin-bottom: 10px; }
.page-hero h1 span { color: var(--silver); }
.page-hero p { font-size: 1rem; color: rgba(255,255,255,.65); }
.page-subnav { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 24px; }
.subnav-link { padding: 7px 18px; border-radius: 20px; background: rgba(255,255,255,.12); color: var(--white); font-size: .85rem; font-weight: 600; border: 1px solid rgba(255,255,255,.25); transition: background var(--transition), border var(--transition); }
.subnav-link:hover { background: rgba(255,255,255,.25); border-color: rgba(255,255,255,.5); }

/* ─────────────────────────────────────────────────
   LAYOUT
───────────────────────────────────────────────── */
.section { padding: 64px 0; }
.section--gray { background: var(--gray-50); }
.container { max-width: 1160px; margin: 0 auto; padding: 0 24px; }
.section-title { font-family: 'Barlow Condensed', sans-serif; font-weight: 800; font-size: 2rem; color: var(--gray-800); margin-bottom: 32px; letter-spacing: -.01em; }
.section-title span { color: var(--blue-accent); }
.section[id] { scroll-margin-top: 90px; }
.abt-section-badge { display: inline-block; background: var(--blue-accent); color: var(--white); font-size: .75rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; padding: 4px 14px; border-radius: 20px; margin-bottom: 10px; }

/* ─────────────────────────────────────────────────
   SPIELPLAN + TABELLE
───────────────────────────────────────────────── */
/* Matchday Tabs */
.matchday-tabs { display: flex; gap: 8px; margin-bottom: 24px; border-bottom: 2px solid var(--gray-200); padding-bottom: 0; }
.matchday-tab { background: transparent; border: none; color: var(--gray-400); font-family: 'Barlow Condensed', sans-serif; font-size: 1.1rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; padding: 12px 24px; cursor: pointer; border-bottom: 3px solid transparent; margin-bottom: -2px; transition: color var(--transition), border-color var(--transition); }
.matchday-tab:hover { color: var(--blue-mid); }
.matchday-tab.active { color: var(--blue-mid); border-bottom-color: var(--blue-accent); }

.matchday { background: var(--gray-50); padding: 40px 0; }
.matchday-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.card { background: var(--white); border-radius: var(--radius); box-shadow: var(--shadow); overflow: hidden; }
.card-header { padding: 14px 20px; border-bottom: 1px solid var(--gray-200); font-weight: 700; font-size: .78rem; letter-spacing: .07em; text-transform: uppercase; color: var(--blue-mid); background: var(--gray-50); }
.match-row { display: flex; align-items: center; justify-content: space-between; padding: 13px 20px; border-bottom: 1px solid var(--gray-100); font-size: .9rem; transition: background var(--transition); }
.match-row:last-child { border-bottom: none; }
.match-row:hover { background: var(--gray-50); }
.match-teams { font-weight: 500; }
.match-teams strong { color: var(--blue-mid); font-weight: 700; }
.match-time { font-size: .8rem; color: var(--gray-400); background: var(--gray-100); padding: 3px 10px; border-radius: 20px; white-space: nowrap; margin-left: 12px; font-weight: 600; }
.table-row { display: flex; align-items: center; padding: 12px 20px; border-bottom: 1px solid var(--gray-100); font-size: .9rem; gap: 12px; transition: background var(--transition); }
.table-row:last-child { border-bottom: none; }
.table-row:hover { background: var(--gray-50); }
.table-pos { font-weight: 700; color: var(--gray-400); width: 20px; text-align: center; font-size: .85rem; }
.table-name { flex: 1; font-weight: 500; }
.table-pts { font-weight: 700; color: var(--blue-accent); font-size: .88rem; }
.table-row.highlight { background: linear-gradient(to right, rgba(74,144,217,.08), transparent); }
.table-row.highlight .table-name { color: var(--blue-mid); font-weight: 700; }
.table-row.highlight .table-pos { color: var(--blue-accent); }

/* ─────────────────────────────────────────────────
   NEWS
───────────────────────────────────────────────── */
.news-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.news-card { background: var(--white); border-radius: var(--radius); box-shadow: var(--shadow); overflow: hidden; transition: transform var(--transition), box-shadow var(--transition); }
.news-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.news-card .news-thumb { width: 100%; height: 190px; object-fit: cover; }
.news-card .no-thumb { width: 100%; height: 190px; background: linear-gradient(135deg, var(--blue) 0%, var(--blue-accent) 100%); }
.news-body { padding: 20px; }
.news-cat { font-size: .72rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--blue-accent); margin-bottom: 6px; }
.news-body h3 { font-family: 'Barlow Condensed', sans-serif; font-weight: 800; font-size: 1.15rem; line-height: 1.2; margin-bottom: 8px; color: var(--gray-800); }
.news-body p { font-size: .87rem; color: var(--gray-600); line-height: 1.55; margin-bottom: 14px; }
.news-link { font-size: .85rem; font-weight: 600; color: var(--blue-accent); display: inline-flex; align-items: center; gap: 4px; transition: gap var(--transition); }
.news-link:hover { gap: 8px; }

/* ─────────────────────────────────────────────────
   ABTEILUNGEN
───────────────────────────────────────────────── */
.abt-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.abt-card { border-radius: var(--radius); overflow: hidden; aspect-ratio: 4/3; display: flex; align-items: center; justify-content: center; position: relative; cursor: pointer; transition: transform var(--transition), box-shadow var(--transition); }
.abt-card:hover { transform: translateY(-4px) scale(1.02); box-shadow: var(--shadow-lg); }
.abt-card:nth-child(1) { background: var(--blue); }
.abt-card:nth-child(2) { background: var(--blue-mid); }
.abt-card:nth-child(3) { background: var(--blue-light); }
.abt-card:nth-child(4) { background: var(--blue-accent); }
.abt-card::before { content: ''; position: absolute; inset: 0; background: linear-gradient(135deg, rgba(255,255,255,.08) 0%, transparent 60%); }
.abt-card::after { content: ''; position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,.3) 0%, transparent 60%); }
.abt-label { position: relative; z-index: 2; font-family: 'Barlow Condensed', sans-serif; font-weight: 800; font-size: 1.25rem; letter-spacing: .08em; text-transform: uppercase; color: var(--white); text-align: center; }
.abt-icon { font-size: 2.4rem; display: block; margin-bottom: 8px; }

/* ─────────────────────────────────────────────────
   TERMINE
───────────────────────────────────────────────── */
.termine-list { display: flex; flex-direction: column; }
.termin-row { display: flex; align-items: center; gap: 20px; padding: 18px 0; border-bottom: 1px solid var(--gray-200); }
.termin-row:last-child { border-bottom: none; }
.termin-date { width: 56px; height: 56px; flex-shrink: 0; background: var(--blue-accent); border-radius: 10px; display: flex; flex-direction: column; align-items: center; justify-content: center; color: var(--white); }
.termin-day { font-family: 'Barlow Condensed', sans-serif; font-weight: 900; font-size: 1.4rem; line-height: 1; }
.termin-month { font-size: .68rem; font-weight: 600; letter-spacing: .06em; text-transform: uppercase; opacity: .75; }
.termin-info h4 { font-weight: 600; font-size: .97rem; margin-bottom: 2px; }
.termin-info span { font-size: .83rem; color: var(--gray-400); }
.termine-mehr { display: inline-flex; align-items: center; gap: 4px; margin-top: 24px; font-size: .87rem; font-weight: 600; color: var(--blue-accent); transition: gap var(--transition); }
.termine-mehr:hover { gap: 8px; }

/* ─────────────────────────────────────────────────
   VORSTAND
───────────────────────────────────────────────── */
.vorstand-bereich { margin-bottom: 56px; }
.vorstand-bereich:last-child { margin-bottom: 0; }
.bereich-titel { font-family: 'Barlow Condensed', sans-serif; font-weight: 800; font-size: 1.5rem; color: var(--blue-mid); margin-bottom: 24px; padding-bottom: 12px; border-bottom: 3px solid var(--blue-accent); display: inline-block; }
.vorstand-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 20px; }
.person-card { background: var(--white); border-radius: var(--radius); box-shadow: var(--shadow); overflow: hidden; display: flex; flex-direction: column; transition: transform var(--transition), box-shadow var(--transition); }
.person-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.person-foto { width: 100%; height: 220px; overflow: hidden; background: linear-gradient(135deg, var(--blue) 0%, var(--blue-accent) 100%); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.person-foto img { width: 100%; height: 100%; object-fit: cover; object-position: top center; }
.person-initials { font-family: 'Barlow Condensed', sans-serif; font-weight: 900; font-size: 3rem; color: rgba(255,255,255,.35); }
.person-info { padding: 20px; flex: 1; }
.person-info h3 { font-family: 'Barlow Condensed', sans-serif; font-weight: 800; font-size: 1.2rem; color: var(--gray-800); margin-bottom: 4px; }
.person-funktion { display: inline-block; font-size: .78rem; font-weight: 700; letter-spacing: .07em; text-transform: uppercase; color: var(--blue-accent); margin-bottom: 14px; }
.person-kontakt { display: flex; flex-direction: column; gap: 7px; }
.kontakt-link { display: flex; align-items: center; gap: 7px; font-size: .83rem; color: var(--gray-600); transition: color var(--transition); word-break: break-all; }
.kontakt-link:hover { color: var(--blue-mid); }
.kontakt-link svg { flex-shrink: 0; color: var(--blue-accent); }
.acf-hint { text-align: center; padding: 60px 24px; background: var(--gray-50); border-radius: var(--radius); border: 2px dashed var(--gray-200); }
.acf-hint h3 { font-family: 'Barlow Condensed', sans-serif; font-weight: 800; font-size: 1.4rem; color: var(--gray-800); margin-bottom: 8px; }
.acf-hint p { font-size: .92rem; color: var(--gray-600); }
.acf-hint strong { color: var(--blue-mid); }

/* ─────────────────────────────────────────────────
   FUSSBALL
───────────────────────────────────────────────── */
.mannschaft-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; align-items: start; }
.mannschaft-info-card { background: var(--white); border-radius: var(--radius); box-shadow: var(--shadow); padding: 28px; }
.mannschaft-info-card h3 { font-family: 'Barlow Condensed', sans-serif; font-weight: 800; font-size: 1.3rem; color: var(--blue-mid); margin-bottom: 12px; }
.mannschaft-info-card p { font-size: .92rem; color: var(--gray-600); line-height: 1.65; margin-bottom: 20px; }
.trainer-bereich { display: flex; align-items: center; gap: 12px; padding: 12px 16px; background: var(--gray-50); border-radius: 8px; margin-bottom: 20px; }
.trainer-label { font-size: .72rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--gray-400); }
.trainer-name { font-weight: 700; color: var(--blue-mid); font-size: .95rem; }
.widget-platzhalter { border: 2px dashed var(--gray-200); border-radius: 8px; padding: 20px; text-align: center; color: var(--gray-400); }
.widget-icon { font-size: 1.8rem; margin-bottom: 6px; }
.widget-platzhalter p { font-weight: 600; font-size: .9rem; color: var(--gray-600); margin-bottom: 2px; }
.widget-platzhalter span { font-size: .78rem; }
.mannschaft-foto-wrap { border-radius: var(--radius); overflow: hidden; }
.mannschaft-foto { width: 100%; height: 320px; object-fit: cover; border-radius: var(--radius); }
.mannschaft-foto-placeholder { width: 100%; height: 320px; background: linear-gradient(135deg, var(--blue) 0%, var(--blue-accent) 100%); border-radius: var(--radius); display: flex; flex-direction: column; align-items: center; justify-content: center; color: rgba(255,255,255,.4); gap: 8px; }
.mannschaft-foto-placeholder span { font-size: 3rem; }
.section-divider { height: 1px; background: var(--gray-200); max-width: 1160px; margin: 0 auto; }
.jugend-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 14px; margin-bottom: 32px; }
.jugend-card { display: flex; align-items: center; gap: 14px; background: var(--white); border-radius: var(--radius); box-shadow: var(--shadow); padding: 16px 20px; transition: transform var(--transition), box-shadow var(--transition); }
.jugend-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-lg); }
.jugend-badge { width: 44px; height: 44px; flex-shrink: 0; background: var(--blue-accent); border-radius: 8px; display: flex; align-items: center; justify-content: center; font-family: 'Barlow Condensed', sans-serif; font-weight: 900; font-size: 1.3rem; color: var(--white); }
.jugend-info h4 { font-weight: 700; font-size: .95rem; color: var(--gray-800); margin-bottom: 2px; }
.jugend-info span { font-size: .8rem; color: var(--gray-400); }
.jugend-hinweis { display: flex; gap: 20px; align-items: center; justify-content: space-between; background: linear-gradient(135deg, var(--blue) 0%, var(--blue-mid) 100%); border-radius: var(--radius); padding: 28px; color: var(--white); }
.hinweis-icon { font-size: 2.4rem; flex-shrink: 0; }
.jugend-hinweis h4 { font-family: 'Barlow Condensed', sans-serif; font-weight: 800; font-size: 1.3rem; margin-bottom: 6px; }
.jugend-hinweis p { font-size: .9rem; color: rgba(255,255,255,.75); line-height: 1.6; max-width: 480px; }
.jugend-hinweis .btn { flex-shrink: 0; white-space: nowrap; }

/* ─────────────────────────────────────────────────
   ÜBER UNS
───────────────────────────────────────────────── */
.ueber-grid { display: grid; grid-template-columns: 1fr 300px; gap: 48px; align-items: start; }
.ueber-jahr { font-family: 'Barlow Condensed', sans-serif; font-weight: 900; font-size: 5rem; color: var(--gray-100); line-height: 1; margin-bottom: -20px; }
.ueber-text p { font-size: .97rem; color: var(--gray-600); line-height: 1.75; margin-bottom: 16px; }
.pdf-downloads { margin-top: 32px; }
.pdf-downloads h3 { font-family: 'Barlow Condensed', sans-serif; font-weight: 800; font-size: 1.2rem; color: var(--blue-mid); margin-bottom: 14px; }
.pdf-grid { display: flex; flex-direction: column; gap: 10px; }
.pdf-card { display: flex; align-items: center; gap: 14px; background: var(--white); border-radius: var(--radius); box-shadow: var(--shadow); padding: 14px 18px; transition: transform var(--transition), box-shadow var(--transition); border: 1px solid var(--gray-200); }
.pdf-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-lg); border-color: var(--blue-accent); }
.pdf-icon { font-size: 1.8rem; flex-shrink: 0; }
.pdf-info { flex: 1; display: flex; flex-direction: column; }
.pdf-titel { font-weight: 700; font-size: .95rem; color: var(--gray-800); }
.pdf-sub { font-size: .78rem; color: var(--gray-400); }
.pdf-arrow { font-size: 1.1rem; color: var(--blue-accent); font-weight: 700; }
.fakten-box { background: var(--blue-mid); border-radius: var(--radius); padding: 28px; color: var(--white); position: sticky; top: 88px; }
.fakten-box h3 { font-family: 'Barlow Condensed', sans-serif; font-weight: 800; font-size: 1rem; letter-spacing: .08em; text-transform: uppercase; color: rgba(255,255,255,.5); margin-bottom: 20px; padding-bottom: 14px; border-bottom: 1px solid rgba(255,255,255,.1); }
.fakt-item { display: flex; flex-direction: column; padding: 14px 0; border-bottom: 1px solid rgba(255,255,255,.08); }
.fakt-item:last-child { border-bottom: none; }
.fakt-zahl { font-family: 'Barlow Condensed', sans-serif; font-weight: 900; font-size: 2.4rem; line-height: 1; }
.fakt-label { font-size: .82rem; color: rgba(255,255,255,.5); margin-top: 2px; }
.fahnen-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.fahne-card { background: var(--white); border-radius: var(--radius); box-shadow: var(--shadow); overflow: hidden; }
.fahne-foto-wrap { height: 280px; background: var(--gray-100); display: flex; align-items: center; justify-content: center; overflow: hidden; }
.fahne-foto-wrap img { width: 100%; height: 100%; object-fit: contain; padding: 16px; }
.fahne-placeholder { font-size: 5rem; opacity: .2; }
.fahne-label { padding: 16px 20px; font-weight: 600; font-size: .92rem; color: var(--blue-mid); text-align: center; border-top: 1px solid var(--gray-100); }
.sportheim-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: center; }
.sportheim-foto-wrap { border-radius: var(--radius); overflow: hidden; height: 300px; background: var(--gray-100); display: flex; align-items: center; justify-content: center; }
.sportheim-foto-wrap img { width: 100%; height: 100%; object-fit: cover; }
.sportheim-placeholder { font-size: 5rem; opacity: .2; }
.sportheim-info p { font-size: .97rem; color: var(--gray-600); line-height: 1.75; margin-bottom: 20px; }
.sportheim-adresse { display: flex; align-items: center; gap: 8px; font-size: .9rem; color: var(--gray-600); font-weight: 500; }
.sportheim-adresse svg { color: var(--blue-accent); flex-shrink: 0; }
.werte-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-top: 8px; }
.wert-card { background: var(--white); border-radius: var(--radius); box-shadow: var(--shadow); padding: 28px 24px; text-align: center; transition: transform var(--transition), box-shadow var(--transition); }
.wert-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.wert-icon { font-size: 2.4rem; margin-bottom: 14px; }
.wert-card h3 { font-family: 'Barlow Condensed', sans-serif; font-weight: 800; font-size: 1.3rem; color: var(--blue-mid); margin-bottom: 10px; }
.wert-card p { font-size: .88rem; color: var(--gray-600); line-height: 1.65; }

/* ─────────────────────────────────────────────────
   NEWS ARCHIV SIDEBAR
───────────────────────────────────────────────── */
.news-archiv-wrap { display: grid; grid-template-columns: 1fr 300px; gap: 48px; align-items: start; }
.news-archiv-main .news-grid { grid-template-columns: repeat(2, 1fr); }

/* Sidebar Widgets */
.news-archiv-sidebar { display: flex; flex-direction: column; gap: 24px; position: sticky; top: 88px; }
.sidebar-widget { background: var(--white); border-radius: var(--radius); box-shadow: var(--shadow); padding: 24px; border: 1px solid var(--gray-200); }
.sidebar-widget-title { font-family: 'Barlow Condensed', sans-serif; font-weight: 800; font-size: 1.05rem; color: var(--blue-mid); margin-bottom: 16px; padding-bottom: 10px; border-bottom: 2px solid var(--blue-accent); }

/* Suche */
.sidebar-search-form { display: flex; gap: 0; }
.sidebar-search-input { flex: 1; padding: 10px 14px; border: 1px solid var(--gray-200); border-right: none; border-radius: 7px 0 0 7px; font-family: 'Barlow', sans-serif; font-size: .88rem; color: var(--gray-800); outline: none; transition: border-color var(--transition); }
.sidebar-search-input:focus { border-color: var(--blue-accent); }
.sidebar-search-btn { padding: 10px 16px; background: var(--blue-mid); color: var(--white); border: none; border-radius: 0 7px 7px 0; font-size: 1rem; font-weight: 700; cursor: pointer; transition: background var(--transition); }
.sidebar-search-btn:hover { background: var(--blue-light); }

/* Kategorien */
.sidebar-cat-list { list-style: none; display: flex; flex-direction: column; gap: 4px; }
.sidebar-cat-link { display: flex; align-items: center; justify-content: space-between; padding: 8px 12px; border-radius: 7px; font-size: .88rem; color: var(--gray-600); font-weight: 500; transition: background var(--transition), color var(--transition); }
.sidebar-cat-link:hover, .sidebar-cat-link.active { background: var(--gray-100); color: var(--blue-mid); }
.sidebar-cat-count { background: var(--gray-100); color: var(--gray-400); font-size: .72rem; font-weight: 700; padding: 2px 8px; border-radius: 20px; }
.sidebar-cat-link.active .sidebar-cat-count { background: var(--blue-accent); color: var(--white); }

/* Neueste Beiträge */
.sidebar-posts-list { list-style: none; display: flex; flex-direction: column; gap: 0; }
.sidebar-post-item { border-bottom: 1px solid var(--gray-100); }
.sidebar-post-item:last-child { border-bottom: none; }
.sidebar-post-link { display: flex; align-items: center; gap: 12px; padding: 10px 0; text-decoration: none; transition: opacity var(--transition); }
.sidebar-post-link:hover { opacity: .75; }
.sidebar-post-thumb { width: 52px; height: 52px; object-fit: cover; border-radius: 6px; flex-shrink: 0; }
.sidebar-post-thumb-placeholder { width: 52px; height: 52px; background: linear-gradient(135deg, var(--blue) 0%, var(--blue-accent) 100%); border-radius: 6px; flex-shrink: 0; }
.sidebar-post-title { display: block; font-size: .85rem; font-weight: 600; color: var(--gray-800); line-height: 1.3; margin-bottom: 3px; }
.sidebar-post-date { font-size: .75rem; color: var(--gray-400); }

/* Responsive */
@media (max-width: 900px) {
  .news-archiv-wrap { grid-template-columns: 1fr; }
  .news-archiv-sidebar { position: static; }
  .news-archiv-main .news-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .news-archiv-main .news-grid { grid-template-columns: 1fr; }
}

/* ─────────────────────────────────────────────────
   NEWS RIBBON & PAGINATION
───────────────────────────────────────────────── */
.news-thumb-wrap { position: relative; overflow: hidden; }
.news-thumb-wrap .news-thumb { width: 100%; height: 190px; object-fit: cover; display: block; }
.news-thumb-wrap .no-thumb { width: 100%; height: 190px; background: linear-gradient(135deg, var(--blue) 0%, var(--blue-accent) 100%); }
.news-ribbon { position: absolute; top: 14px; left: 0; background: var(--blue-mid); color: var(--white); font-size: .72rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; padding: 5px 14px 5px 12px; border-radius: 0 20px 20px 0; box-shadow: 2px 2px 8px rgba(0,0,0,.2); white-space: nowrap; }

/* News-Archiv Pagination */
.nav-links { display: flex; justify-content: center; align-items: center; gap: 8px; flex-wrap: wrap; }
.nav-links .page-numbers { display: inline-flex; align-items: center; justify-content: center; width: 40px; height: 40px; border-radius: 8px; font-weight: 700; font-size: .9rem; color: var(--gray-600); background: var(--gray-100); transition: background var(--transition), color var(--transition); }
.nav-links .page-numbers:hover { background: var(--blue-mid); color: var(--white); }
.nav-links .page-numbers.current { background: var(--blue-mid); color: var(--white); }
.nav-links .page-numbers.prev,
.nav-links .page-numbers.next { width: auto; padding: 0 18px; }
.single-hero { margin-top: var(--header-h); background: var(--blue-mid); padding: 60px 0 40px; color: var(--white); }
.admin-bar .single-hero { margin-top: calc(var(--header-h) + 32px); }
.post-category { font-size: .75rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--silver); margin-bottom: 12px; }
.single-hero h1 { font-family: 'Barlow Condensed', sans-serif; font-weight: 900; font-size: clamp(2rem, 4vw, 3rem); line-height: 1.1; margin-bottom: 16px; }
.post-meta { font-size: .88rem; color: rgba(255,255,255,.55); }
.post-content-wrap { max-width: 780px; margin: 0 auto; padding: 48px 24px; }
.post-content { font-size: 1rem; line-height: 1.75; color: var(--gray-800); }
.post-content h2 { font-family: 'Barlow Condensed', sans-serif; font-weight: 800; font-size: 1.6rem; margin: 32px 0 12px; color: var(--blue-mid); }
.post-content p { margin-bottom: 20px; }
.post-content img { border-radius: var(--radius); margin: 24px 0; }
.post-featured-img { width: 100%; max-height: 420px; object-fit: cover; border-radius: var(--radius); margin-bottom: 36px; }

/* ── Neues Single Post Layout ── */
.single-post-hero { margin-top: var(--header-h); background: var(--blue-mid); padding: 60px 0 48px; color: var(--white); background-size: cover; background-position: center; }
.admin-bar .single-post-hero { margin-top: calc(var(--header-h) + 32px); }
@media screen and (max-width:782px) { .admin-bar .single-post-hero { margin-top: calc(var(--header-h) + 46px); } }
.single-post-cat-badge { display: inline-flex; align-items: center; gap: 6px; background: var(--blue-accent); color: var(--white); font-size: .72rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; padding: 5px 14px; border-radius: 20px; margin-bottom: 14px; }
.single-post-hero h1 { font-family: 'Barlow Condensed', sans-serif; font-weight: 900; font-size: clamp(1.8rem, 4vw, 2.8rem); line-height: 1.1; margin-bottom: 16px; color: var(--white); }
.single-post-meta { display: flex; gap: 20px; flex-wrap: wrap; font-size: .85rem; color: rgba(255,255,255,.65); }
.single-post-wrap { display: grid; grid-template-columns: 1fr 300px; gap: 48px; align-items: start; }
.single-post-featured-img { width: 100%; max-height: 460px; object-fit: cover; border-radius: var(--radius); margin-bottom: 32px; }
.single-post-body { font-size: 1rem; line-height: 1.8; color: var(--gray-700); }
.single-post-body h2 { font-family: 'Barlow Condensed', sans-serif; font-weight: 800; font-size: 1.6rem; color: var(--blue-mid); margin: 36px 0 14px; padding-bottom: 8px; border-bottom: 2px solid var(--gray-200); }
.single-post-body h3 { font-family: 'Barlow Condensed', sans-serif; font-weight: 700; font-size: 1.3rem; color: var(--gray-800); margin: 28px 0 10px; }
.single-post-body p { margin-bottom: 20px; }
.single-post-body img { border-radius: var(--radius); margin: 24px 0; max-width: 100%; }
.single-post-body ul, .single-post-body ol { padding-left: 22px; margin-bottom: 20px; }
.single-post-body li { margin-bottom: 6px; line-height: 1.7; }
.single-post-body a { color: var(--blue-accent); text-decoration: underline; }
.single-post-body blockquote { border-left: 4px solid var(--blue-accent); padding: 12px 20px; background: var(--gray-50); margin: 24px 0; border-radius: 0 var(--radius) var(--radius) 0; font-style: italic; color: var(--gray-600); }
.single-post-tags { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 32px; padding-top: 24px; border-top: 1px solid var(--gray-200); }
.single-post-tag { padding: 5px 14px; background: var(--gray-100); color: var(--gray-600); border-radius: 20px; font-size: .8rem; font-weight: 600; transition: background var(--transition), color var(--transition); }
.single-post-tag:hover { background: var(--blue-mid); color: var(--white); }
.single-post-nav { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 40px; padding-top: 32px; border-top: 1px solid var(--gray-200); }
.single-post-nav-btn { display: flex; flex-direction: column; gap: 4px; padding: 16px 20px; background: var(--white); border-radius: var(--radius); box-shadow: var(--shadow); border: 1px solid var(--gray-200); transition: border-color var(--transition), box-shadow var(--transition); text-decoration: none; }
.single-post-nav-btn:hover { border-color: var(--blue-accent); box-shadow: var(--shadow-lg); }
.single-post-nav-btn--right { text-align: right; }
.nav-direction { font-size: .75rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: var(--blue-accent); }
.nav-title { font-size: .9rem; font-weight: 600; color: var(--gray-800); line-height: 1.3; }
.single-post-sidebar { position: sticky; top: 88px; display: flex; flex-direction: column; gap: 24px; }
.single-autor-box { display: flex; align-items: center; gap: 14px; }
.autor-avatar { width: 60px !important; height: 60px !important; border-radius: 50% !important; flex-shrink: 0; border: 3px solid var(--blue-accent); }
.single-autor-box strong { display: block; font-weight: 700; font-size: .95rem; color: var(--gray-800); margin-bottom: 2px; }
.single-autor-box span { font-size: .8rem; color: var(--gray-400); }
.single-kat-link { display: inline-flex; align-items: center; gap: 8px; padding: 8px 16px; background: var(--gray-100); border-radius: 7px; font-size: .9rem; font-weight: 600; color: var(--blue-mid); transition: background var(--transition); }
.single-kat-link:hover { background: var(--gray-200); }
@media (max-width: 900px) {
  .single-post-wrap { grid-template-columns: 1fr; }
  .single-post-sidebar { position: static; }
  .single-post-nav { grid-template-columns: 1fr; }
}

/* Sportheim Slider */
.sportheim-slider { position: relative; border-radius: var(--radius); overflow: hidden; }
.sportheim-slides { position: relative; width: 100%; }
.sportheim-slide { display: none; }
.sportheim-slide.active { display: block; }
.sportheim-slide img { width: 100%; height: 360px; object-fit: cover; display: block; }
.sportheim-slide-placeholder { width: 100%; height: 360px; background: var(--gray-100); display: flex; align-items: center; justify-content: center; font-size: 1.5rem; color: var(--gray-400); }
.slider-btn { position: absolute; top: 50%; transform: translateY(-50%); background: rgba(13,27,62,.7); color: var(--white); border: none; width: 40px; height: 40px; border-radius: 50%; font-size: 1.5rem; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: background var(--transition); z-index: 2; }
.slider-btn:hover { background: var(--blue-mid); }
.slider-btn--prev { left: 12px; }
.slider-btn--next { right: 12px; }
.slider-dots { position: absolute; bottom: 12px; left: 50%; transform: translateX(-50%); display: flex; gap: 6px; z-index: 2; }
.slider-dot { width: 8px; height: 8px; border-radius: 50%; background: rgba(255,255,255,.5); cursor: pointer; transition: background var(--transition); }
.slider-dot.active { background: var(--white); }
.mannschaft-liga-info { margin-top: 20px; padding-top: 16px; border-top: 1px solid var(--gray-200); display: flex; flex-direction: column; gap: 10px; }
.liga-item { display: flex; align-items: center; gap: 12px; }
.liga-label { font-size: .75rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--gray-400); min-width: 120px; }
.liga-wert { font-size: .92rem; font-weight: 600; color: var(--blue-mid); }
.liga-wert small { font-size: .75rem; font-weight: 400; color: var(--gray-400); }

/* FuPa Widget Kader Abstand */
.fp-team-squad-view-position-group-header { padding-top: 100px !important; }
.fp-team-squad-view-position-group-header:first-child { padding-top: 100px !important; }
.kader-widget-inner { overflow-x: auto !important; }
.kader-widget-inner > div { min-width: 0 !important; width: 100% !important; }
.kader-wrap { margin-top: 8px; }
.kader-foto { width: 100%; max-height: 480px; object-fit: cover; border-radius: var(--radius); display: block; }
.kader-toggle { width: 100%; display: flex; align-items: center; justify-content: center; gap: 10px; margin-top: 16px; padding: 14px 24px; background: var(--blue-mid); color: var(--white); border: none; border-radius: var(--radius); font-family: 'Barlow', sans-serif; font-size: 1rem; font-weight: 700; cursor: pointer; transition: background var(--transition); }
.kader-toggle:hover { background: var(--blue-light); }
.kader-toggle-arrow { font-size: 1.1rem; transition: transform var(--transition); }
.kader-accordion { max-height: 0; overflow: hidden; transition: max-height .4s cubic-bezier(.4,0,.2,1); }
.kader-accordion.is-open { max-height: 9999px; }
.kader-widget-inner { padding-top: 32px !important; }

/* ─────────────────────────────────────────────────
   VEREIN ÜBERSICHT
───────────────────────────────────────────────── */
.verein-intro-grid { display: grid; grid-template-columns: 1fr 280px; gap: 64px; align-items: center; }
.verein-intro-text p { font-size: .97rem; color: var(--gray-600); line-height: 1.75; margin-bottom: 16px; }
.verein-fakten-row { display: flex; gap: 32px; margin-top: 32px; padding-top: 24px; border-top: 1px solid var(--gray-200); }
.verein-fakt { display: flex; flex-direction: column; gap: 4px; }
.verein-fakt-zahl { font-family: 'Barlow Condensed', sans-serif; font-weight: 900; font-size: 1.8rem; color: var(--blue-mid); line-height: 1; }
.verein-fakt-label { font-size: .78rem; color: var(--gray-400); font-weight: 600; text-transform: uppercase; letter-spacing: .06em; }
.verein-wappen-wrap { display: flex; align-items: center; justify-content: center; }
.verein-wappen { max-width: 220px; width: 100%; filter: drop-shadow(0 8px 24px rgba(13,27,62,.15)); }
.verein-wappen-placeholder { font-size: 8rem; opacity: .15; }

/* Karten Grid */
.verein-karten-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; margin-top: 8px; }
.verein-karte { display: flex; align-items: center; gap: 20px; background: var(--white); border-radius: var(--radius); box-shadow: var(--shadow); padding: 28px; border: 1px solid var(--gray-200); text-decoration: none; transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition); }
.verein-karte:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); border-color: var(--blue-accent); }
.verein-karte-icon { font-size: 2.4rem; flex-shrink: 0; }
.verein-karte-body { flex: 1; }
.verein-karte-body h3 { font-family: 'Barlow Condensed', sans-serif; font-weight: 800; font-size: 1.2rem; color: var(--blue-mid); margin-bottom: 6px; }
.verein-karte-body p { font-size: .88rem; color: var(--gray-600); line-height: 1.6; margin: 0; }
.verein-karte-arrow { font-size: 1.3rem; color: var(--blue-accent); font-weight: 700; flex-shrink: 0; transition: transform var(--transition); }
.verein-karte:hover .verein-karte-arrow { transform: translateX(5px); }

@media (max-width: 900px) {
  .verein-intro-grid { grid-template-columns: 1fr; }
  .verein-intro-deko { display: none; }
  .verein-karten-grid { grid-template-columns: 1fr; }
}

/* ─────────────────────────────────────────────────
   FOOTER
───────────────────────────────────────────────── */
.site-footer { background: var(--blue); color: rgba(255,255,255,.65); padding: 56px 0 28px; border-top: 3px solid var(--blue-accent); }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1.6fr; gap: 40px; margin-bottom: 48px; }
.footer-brand .logo-name { color: var(--white); }
.footer-brand p { font-size: .87rem; line-height: 1.65; margin: 14px 0 18px; color: rgba(255,255,255,.55); }
.footer-addr { font-size: .84rem; color: rgba(255,255,255,.5); line-height: 1.7; }
.footer-col h4 { font-family: 'Barlow Condensed', sans-serif; font-weight: 700; font-size: 1rem; letter-spacing: .08em; text-transform: uppercase; color: var(--white); margin-bottom: 16px; }
.footer-col ul { list-style: none; display: flex; flex-direction: column; gap: 8px; }
.footer-col ul li a { font-size: .88rem; color: rgba(255,255,255,.5); transition: color var(--transition); }
.footer-col ul li a:hover { color: var(--white); }
.newsletter-form { display: flex; flex-direction: column; gap: 10px; margin-top: 4px; }
.newsletter-input { padding: 10px 14px; border-radius: 7px; border: 1px solid rgba(255,255,255,.15); background: rgba(255,255,255,.06); color: var(--white); font-size: .88rem; font-family: 'Barlow', sans-serif; outline: none; transition: border var(--transition); }
.newsletter-input::placeholder { color: rgba(255,255,255,.35); }
.newsletter-input:focus { border-color: var(--blue-accent); }
.newsletter-note { font-size: .75rem; color: rgba(255,255,255,.35); }
.footer-bottom { padding-top: 24px; border-top: 1px solid rgba(255,255,255,.08); display: flex; justify-content: space-between; align-items: center; font-size: .82rem; color: rgba(255,255,255,.35); flex-wrap: wrap; gap: 8px; }
.footer-bottom a { color: rgba(255,255,255,.4); transition: color var(--transition); }
.footer-bottom a:hover { color: var(--white); }
.footer-credit { color: rgba(255,255,255,.35); font-size: .82rem; }
.footer-credit a { color: var(--blue-accent); font-weight: 600; }
.footer-credit a:hover { color: var(--white); }
.footer-links { display: flex; gap: 20px; }

/* ─────────────────────────────────────────────────
   ANIMATIONEN
───────────────────────────────────────────────── */
@keyframes fadeUp { from { opacity: 0; transform: translateY(24px); } to { opacity: 1; transform: translateY(0); } }
.hero-content > * { animation: fadeUp .7s both; }
.hero-content > *:nth-child(1) { animation-delay: .1s; }
.hero-content > *:nth-child(2) { animation-delay: .22s; }
.hero-content > *:nth-child(3) { animation-delay: .34s; }
.hero-content > *:nth-child(4) { animation-delay: .44s; }

/* Welcome Banner */
.welcome-banner { background: var(--white); border-bottom: 1px solid var(--gray-200); padding: 20px 0; }
.welcome-inner { display: flex; align-items: center; gap: 20px; }
.welcome-icon { font-size: 2rem; flex-shrink: 0; }
.welcome-text { display: flex; flex-direction: column; gap: 4px; }
.welcome-text strong { font-family: 'Barlow Condensed', sans-serif; font-weight: 800; font-size: 1.2rem; color: var(--blue-mid); }
.welcome-text span { font-size: .92rem; color: var(--gray-600); line-height: 1.6; }
@media (max-width: 600px) { .welcome-icon { display: none; } }

/* Footer Kontakt & Social */
.footer-kontakt { display: flex; flex-direction: column; gap: 10px; margin-bottom: 20px; }
.footer-kontakt-item { display: flex; align-items: flex-start; gap: 8px; font-size: .85rem; color: rgba(255,255,255,.5); line-height: 1.5; }
.footer-kontakt-item svg { flex-shrink: 0; margin-top: 2px; color: var(--blue-accent); }
.footer-kontakt-item a { color: rgba(255,255,255,.5); transition: color var(--transition); }
.footer-kontakt-item a:hover { color: var(--white); }
.footer-social { display: flex; flex-direction: column; gap: 10px; }
.social-btn { display: flex; align-items: center; gap: 10px; padding: 9px 16px; border-radius: 8px; font-size: .88rem; font-weight: 600; color: var(--white); transition: opacity var(--transition), transform var(--transition); }
.social-btn:hover { opacity: .85; transform: translateX(3px); }
.social-btn.facebook { background: #1877f2; }
.social-btn.instagram { background: linear-gradient(45deg, #f09433, #e6683c, #dc2743, #cc2366, #bc1888); }

/* FuPa Widget */
[id^="fp-widget_root"] { max-width: 100% !important; overflow: hidden !important; }
[id^="fp-widget_root"] * { max-width: 100% !important; box-sizing: border-box !important; }

/* ─────────────────────────────────────────────────
   VORSTAND EDITOR CONTENT
───────────────────────────────────────────────── */
.vorstand-editor-content h2,
.vorstand-editor-content .wp-block-heading { font-family: 'Barlow Condensed', sans-serif; font-size: 1.8rem; font-weight: 800; color: var(--blue-mid); text-transform: uppercase; border-bottom: 3px solid var(--blue-accent); padding-bottom: 8px; margin: 48px 0 24px; }
.vorstand-editor-content h2:first-child,
.vorstand-editor-content .wp-block-heading:first-child { margin-top: 0; }
.vorstand-editor-content .wp-block-columns { display: flex !important; flex-wrap: wrap !important; gap: 24px !important; margin-bottom: 0 !important; justify-content: center !important; }
.vorstand-editor-content .wp-block-column { background: var(--white) !important; border-radius: var(--radius) !important; box-shadow: var(--shadow) !important; overflow: hidden !important; transition: transform var(--transition), box-shadow var(--transition) !important; padding: 0 !important; flex: 0 0 280px !important; max-width: 280px !important; border-bottom: 3px solid var(--blue-accent) !important; }
.vorstand-editor-content .wp-block-column:hover { transform: translateY(-4px) !important; box-shadow: var(--shadow-lg) !important; }
.vorstand-editor-content .wp-block-column .wp-block-heading,
.vorstand-editor-content .wp-block-column h3 { font-family: 'Barlow Condensed', sans-serif !important; font-size: 1.2rem !important; font-weight: 800 !important; color: var(--gray-800) !important; margin: 16px 0 6px !important; padding: 0 20px !important; border: none !important; text-transform: none !important; }
.vorstand-editor-content .wp-block-column p { font-size: .88rem !important; color: var(--gray-600) !important; margin: 0 !important; padding: 4px 20px !important; line-height: 1.5 !important; }
.vorstand-editor-content .wp-block-column p:last-child { padding-bottom: 24px !important; }
.vorstand-editor-content .wp-block-column a { font-size: .85rem !important; color: var(--blue-accent) !important; display: block !important; padding: 4px 20px 24px !important; }
.vorstand-editor-content .wp-block-column a:hover { color: var(--blue-mid) !important; }
.vorstand-editor-content .wp-block-column figure.wp-block-image { margin: 0 !important; width: 100% !important; display: block !important; }
.vorstand-editor-content .wp-block-column figure.wp-block-image img { width: 100% !important; height: 240px !important; border-radius: 0 !important; object-fit: cover !important; object-position: top center !important; border: none !important; display: block !important; }
@media (max-width: 900px) { .vorstand-editor-content .wp-block-columns { grid-template-columns: repeat(2, 1fr) !important; } }
@media (max-width: 600px) { .vorstand-editor-content .wp-block-columns { grid-template-columns: 1fr !important; } }

/* ─────────────────────────────────────────────────
   THE EVENTS CALENDAR — KARTEN LAYOUT
───────────────────────────────────────────────── */

/* Unnötiges ausblenden */
.tribe-events-c-subscribe-dropdown { display: none !important; }
.tribe-events-header__search { display: none !important; }
.tribe-events .tribe-events-calendar-list__event-featured-image-wrapper { display: none !important; }

/* Navigation */
.tribe-events .tribe-events-c-nav__next,
.tribe-events .tribe-events-c-nav__prev {
  background: var(--blue-mid) !important;
  color: var(--white) !important;
  padding: 9px 20px !important;
  border-radius: 7px !important;
  font-family: 'Barlow', sans-serif !important;
  font-size: .88rem !important;
  font-weight: 700 !important;
  border: none !important;
  transition: background var(--transition) !important;
}
.tribe-events .tribe-events-c-nav__next:hover,
.tribe-events .tribe-events-c-nav__prev:hover {
  background: var(--blue-light) !important;
  color: var(--white) !important;
}
.tribe-events .tribe-events-c-nav__today {
  background: var(--gray-100) !important;
  color: var(--gray-700) !important;
  padding: 9px 20px !important;
  border-radius: 7px !important;
  font-size: .88rem !important;
  font-weight: 700 !important;
}

/* Monats-Trenner (z.B. "März 2026") */
.tribe-events .tribe-events-calendar-list__month-separator {
  margin: 40px 0 20px !important;
  border: none !important;
}
.tribe-events .tribe-events-calendar-list__month-separator-text {
  font-family: 'Barlow Condensed', sans-serif !important;
  font-weight: 900 !important;
  font-size: 1.4rem !important;
  color: var(--blue-mid) !important;
  text-transform: uppercase !important;
  letter-spacing: .03em !important;
  padding-bottom: 10px !important;
  border-bottom: 3px solid var(--blue-accent) !important;
  display: block !important;
  width: 100% !important;
}

/* ── Event-Zeile als Karte ── */
.tribe-events .tribe-events-calendar-list__event-row {
  background: var(--white) !important;
  border-radius: var(--radius) !important;
  box-shadow: var(--shadow) !important;
  border: 1px solid var(--gray-200) !important;
  margin: 0 0 16px 0 !important;
  overflow: hidden !important;
  transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition) !important;
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: stretch !important;
}
.tribe-events .tribe-events-calendar-list__event-row:hover {
  transform: translateY(-3px) !important;
  box-shadow: var(--shadow-lg) !important;
  border-color: var(--blue-accent) !important;
}

/* Datum-Tag links (die schmale Spalte mit Tag-Zahl) */
.tribe-events .tribe-events-calendar-list__event-date-tag {
  background: linear-gradient(135deg, var(--blue) 0%, var(--blue-mid) 100%) !important;
  min-width: 90px !important;
  width: 90px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 20px 10px !important;
  flex-shrink: 0 !important;
  text-align: center !important;
  align-self: stretch !important;
}
.tribe-events .tribe-events-calendar-list__event-date-tag-datetime {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  height: 100% !important;
  padding-top: 0 !important;
}
.tribe-events .tribe-events-calendar-list__event-date-tag-weekday {
  font-family: 'Barlow', sans-serif !important;
  font-size: .7rem !important;
  font-weight: 700 !important;
  letter-spacing: .1em !important;
  text-transform: uppercase !important;
  color: rgba(255,255,255,.6) !important;
  margin-bottom: 4px !important;
}
.tribe-events .tribe-events-calendar-list__event-date-tag-daynum {
  font-family: 'Barlow Condensed', sans-serif !important;
  font-weight: 900 !important;
  font-size: 2.8rem !important;
  line-height: 1 !important;
  color: var(--white) !important;
  display: block !important;
}
.tribe-events .tribe-events-calendar-list__event-date-tag-month {
  font-family: 'Barlow', sans-serif !important;
  font-size: .7rem !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  color: var(--blue-accent) !important;
  margin-top: 4px !important;
  letter-spacing: .06em !important;
  display: block !important;
}

/* Kein Monat im HTML — via CSS simulieren */
.tribe-events .tribe-events-calendar-list__event-date-tag-weekday {
  display: block !important;
}

/* Inhalt rechts */
.tribe-events .tribe-events-calendar-list__event-wrapper {
  padding: 20px 24px !important;
  flex: 1 !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  width: auto !important;
}

/* Uhrzeit */
.tribe-events .tribe-events-calendar-list__event-datetime-wrapper {
  margin-bottom: 6px !important;
}
.tribe-events .tribe-events-calendar-list__event-datetime-wrapper abbr,
.tribe-events .tribe-events-calendar-list__event-datetime-wrapper time,
.tribe-events .tribe-events-calendar-list__event-datetime-wrapper * {
  font-size: .8rem !important;
  font-weight: 700 !important;
  color: var(--blue-accent) !important;
  letter-spacing: .05em !important;
  text-transform: uppercase !important;
  text-decoration: none !important;
}

/* Titel */
.tribe-events .tribe-events-calendar-list__event-title {
  margin: 0 0 8px 0 !important;
}
.tribe-events .tribe-events-calendar-list__event-title-link {
  font-family: 'Barlow Condensed', sans-serif !important;
  font-weight: 800 !important;
  font-size: 1.3rem !important;
  color: var(--gray-800) !important;
  line-height: 1.2 !important;
  text-decoration: none !important;
  background: transparent !important;
  border: none !important;
  transition: color var(--transition) !important;
}
.tribe-events .tribe-events-calendar-list__event-title-link:hover,
.tribe-events .tribe-events-calendar-list__event-title-link:focus,
.tribe-events .tribe-events-calendar-list__event-title-link:active,
.tribe-events .tribe-events-calendar-list__event-title-link:visited {
  color: var(--blue-mid) !important;
  background: transparent !important;
  border-color: transparent !important;
}

/* Beschreibung */
.tribe-events .tribe-events-calendar-list__event-description,
.tribe-events .tribe-events-calendar-list__event-description p {
  font-size: .88rem !important;
  color: var(--gray-600) !important;
  line-height: 1.6 !important;
  margin: 0 !important;
}

/* Ort */
.tribe-events .tribe-events-calendar-list__event-venue {
  font-size: .8rem !important;
  color: var(--gray-400) !important;
  margin: 8px 0 0 0 !important;
}

/* Grid-Spalten anpassen */
.tribe-events .tribe-events-calendar-list__event-row > .tribe-common-g-col {
  padding: 0 !important;
}

/* Paginierung */
.tribe-events .tribe-events-calendar-list-nav {
  padding-top: 32px !important;
}
.tribe-events .tribe-events-c-nav {
  padding-top: 0 !important;
}
.tribe-events .tribe-events-c-nav__list {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: space-between !important;
  flex-wrap: nowrap !important;
  gap: 12px !important;
}
.tribe-events .tribe-events-c-nav__list-item {
  width: auto !important;
  display: flex !important;
  align-items: center !important;
}
.tribe-events .tribe-events-c-nav__list-item--today {
  justify-content: center !important;
}

/* Einzelansicht */
.tribe-events-single .tribe-events-single-section--map { display: none !important; }

/* Responsive */
@media (max-width: 600px) {
  .tribe-events .tribe-events-calendar-list__event-date-tag {
    min-width: 70px !important;
    width: 70px !important;
    padding: 14px 8px !important;
  }
  .tribe-events .tribe-events-calendar-list__event-date-tag-daynum {
    font-size: 2rem !important;
  }
  .tribe-events .tribe-events-calendar-list__event-wrapper {
    padding: 14px 16px !important;
  }
}

/* Wrapper & Grundlayout */
.tribe-events-wrap, #tribe-events { max-width: 100%; }
.tribe-events-header__search { display: none !important; }
.tribe-events-c-subscribe-dropdown,
.tribe-common-c-loader,
.tribe-events__filter-bar { display: none !important; }

/* ── Navigation (Vor/Zurück/Heute) ── */
.tribe-events .tribe-events-c-nav,
.tribe-events .tribe-events-c-top-bar { margin-bottom: 32px; }
.tribe-events .tribe-events-c-nav__list { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
.tribe-events .tribe-events-c-nav__next,
.tribe-events .tribe-events-c-nav__prev { background: var(--blue-mid) !important; color: var(--white) !important; padding: 9px 20px !important; border-radius: 7px !important; font-size: .88rem !important; font-weight: 700 !important; border: none !important; transition: background var(--transition) !important; }
.tribe-events .tribe-events-c-nav__next:hover,
.tribe-events .tribe-events-c-nav__prev:hover { background: var(--blue-light) !important; }
.tribe-events .tribe-events-c-nav__today { background: var(--gray-100) !important; color: var(--gray-700) !important; padding: 9px 20px !important; border-radius: 7px !important; font-size: .88rem !important; font-weight: 700 !important; border: none !important; }
.tribe-events .tribe-events-c-nav__today:hover { background: var(--gray-200) !important; }

/* Ansicht-Wechsler */
.tribe-common .tribe-events-c-view-selector__list { display: flex; gap: 4px; }
.tribe-common .tribe-events-c-view-selector__list-item-link { padding: 7px 16px; border-radius: 6px; font-size: .85rem; font-weight: 600; color: var(--gray-600); background: var(--gray-100); transition: background var(--transition), color var(--transition); }
.tribe-common .tribe-events-c-view-selector__list-item-link:hover,
.tribe-common .tribe-events-c-view-selector__list-item-link--active { background: var(--blue-mid); color: var(--white); }

/* ── Monats-Überschrift (z.B. "März 2026") ── */
.tribe-events .tribe-events-calendar-list__month-separator,
.tribe-events .tribe-events-c-month-grid-nav { display: none; }
.tribe-events [class*="tribe-events-calendar-list__month-grid-cell"] h3,
.tribe-events .tribe-events-calendar-list__month-separator-text {
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 900;
  font-size: 1.5rem;
  color: var(--blue-mid);
  text-transform: uppercase;
  letter-spacing: .03em;
  padding: 8px 0 4px;
  border-bottom: 3px solid var(--blue-accent);
  margin-bottom: 20px;
  display: block;
}

/* ── KARTEN GRID ── */
.tribe-events .tribe-events-calendar-list__body,
.tribe-events .tribe-events-calendar-list { display: block; }

/* Monat-Gruppe */
.tribe-events .tribe-events-calendar-list__month-grid-cell {
  margin-bottom: 48px;
}

/* Artikel-Karte */
.tribe-events .tribe-events-calendar-list__event-row,
.tribe-events article.tribe-events-calendar-list__event {
  background: var(--white) !important;
  border-radius: var(--radius) !important;
  box-shadow: var(--shadow) !important;
  border: 1px solid var(--gray-200) !important;
  margin-bottom: 16px !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: row !important;
  transition: transform var(--transition), box-shadow var(--transition) !important;
  padding: 0 !important;
}
.tribe-events .tribe-events-calendar-list__event-row:hover,
.tribe-events article.tribe-events-calendar-list__event:hover {
  transform: translateY(-3px) !important;
  box-shadow: var(--shadow-lg) !important;
  border-color: var(--blue-accent) !important;
}

/* Datum-Box links */
.tribe-events .tribe-events-calendar-list__event-datetime-wrapper,
.tribe-events .tribe-event-schedule-details {
  background: linear-gradient(135deg, var(--blue) 0%, var(--blue-mid) 100%) !important;
  color: var(--white) !important;
  padding: 20px 20px !important;
  min-width: 110px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
  text-align: center !important;
}
.tribe-events .tribe-events-calendar-list__event-datetime-wrapper abbr,
.tribe-events .tribe-events-calendar-list__event-datetime-wrapper time,
.tribe-events .tribe-event-schedule-details * {
  color: var(--white) !important;
  text-decoration: none !important;
}

/* Tag-Zahl groß */
.tribe-events .tribe-events-calendar-list__event-date-tag-daynum {
  font-family: 'Barlow Condensed', sans-serif !important;
  font-weight: 900 !important;
  font-size: 2.6rem !important;
  line-height: 1 !important;
  color: var(--white) !important;
  display: block !important;
}
/* Wochentag */
.tribe-events .tribe-events-calendar-list__event-date-tag-weekday {
  font-size: .72rem !important;
  font-weight: 700 !important;
  letter-spacing: .1em !important;
  text-transform: uppercase !important;
  color: rgba(255,255,255,.65) !important;
  display: block !important;
  margin-bottom: 6px !important;
}
/* Monat */
.tribe-events .tribe-events-calendar-list__event-date-tag-month {
  font-size: .72rem !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  color: var(--blue-accent) !important;
  display: block !important;
  margin-top: 4px !important;
}

/* Inhalt rechts */
.tribe-events .tribe-events-calendar-list__event-wrapper,
.tribe-events .tribe-events-calendar-list__event-details {
  padding: 20px 24px !important;
  flex: 1 !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
}

/* Uhrzeit */
.tribe-events .tribe-events-calendar-list__event-datetime,
.tribe-events .tribe-event-schedule-details {
  font-size: .8rem !important;
  font-weight: 700 !important;
  color: var(--blue-accent) !important;
  letter-spacing: .06em !important;
  text-transform: uppercase !important;
  margin-bottom: 6px !important;
}

/* Titel */
.tribe-events .tribe-events-calendar-list__event-title,
.tribe-events .tribe-event-url {
  font-family: 'Barlow Condensed', sans-serif !important;
  font-weight: 800 !important;
  font-size: 1.25rem !important;
  color: var(--gray-800) !important;
  margin-bottom: 6px !important;
  line-height: 1.2 !important;
}
.tribe-events .tribe-events-calendar-list__event-title a,
.tribe-events .tribe-event-url a {
  color: var(--gray-800) !important;
  transition: color var(--transition) !important;
  text-decoration: none !important;
}
.tribe-events .tribe-events-calendar-list__event-title a:hover,
.tribe-events .tribe-event-url a:hover { color: var(--blue-mid) !important; }

/* Beschreibung */
.tribe-events .tribe-events-calendar-list__event-description,
.tribe-events .tribe-events-calendar-list__event-description p {
  font-size: .88rem !important;
  color: var(--gray-600) !important;
  line-height: 1.6 !important;
  margin: 0 !important;
}

/* Ort */
.tribe-events .tribe-events-calendar-list__event-venue,
.tribe-events .tribe-venue {
  font-size: .8rem !important;
  color: var(--gray-400) !important;
  margin-top: 8px !important;
  display: flex !important;
  align-items: center !important;
  gap: 4px !important;
}

/* Kein Bild anzeigen */
.tribe-events .tribe-events-calendar-list__event-featured-image,
.tribe-events .tribe-event__image { display: none !important; }

/* ── Paginierung ── */
.tribe-events-nav-pagination,
#tribe-events-footer {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  margin: 40px 0 !important;
  gap: 12px !important;
}
.tribe-events-nav-previous a,
.tribe-events-nav-next a {
  display: inline-flex !important;
  align-items: center !important;
  padding: 10px 22px !important;
  background: var(--blue-mid) !important;
  color: var(--white) !important;
  border-radius: 7px !important;
  font-weight: 700 !important;
  font-size: .9rem !important;
  transition: background var(--transition) !important;
}
.tribe-events-nav-previous a:hover,
.tribe-events-nav-next a:hover { background: var(--blue-light) !important; }
.tribe-events-nav-previous { float: none !important; }
.tribe-events-nav-next { float: none !important; text-align: right !important; }

/* ── Einzelansicht ── */
.tribe-events-single .tribe-events-single-section--map { display: none !important; }
.tribe-events-single .tribe-events-schedule { font-size: .9rem; color: var(--gray-600); margin-bottom: 20px; }

/* Responsive */
@media (max-width: 600px) {
  .tribe-events article.tribe-events-calendar-list__event,
  .tribe-events .tribe-events-calendar-list__event-row {
    flex-direction: column !important;
  }
  .tribe-events .tribe-events-calendar-list__event-datetime-wrapper {
    flex-direction: row !important;
    min-width: unset !important;
    padding: 14px 20px !important;
    gap: 12px !important;
    justify-content: flex-start !important;
  }
  .tribe-events .tribe-events-calendar-list__event-date-tag-daynum { font-size: 1.8rem !important; }
}

/* ─────────────────────────────────────────────────
   TENNIS
───────────────────────────────────────────────── */
.tennis-ueber-grid { display: grid; grid-template-columns: 1fr 320px; gap: 48px; align-items: start; }
.tennis-text p { font-size: .97rem; color: var(--gray-600); line-height: 1.75; margin-bottom: 16px; }
.tennis-fakten { display: flex; flex-direction: column; gap: 12px; }
.tennis-fakt-card { display: flex; align-items: center; gap: 16px; background: var(--white); border-radius: var(--radius); box-shadow: var(--shadow); padding: 16px 20px; }
.tennis-fakt-icon { font-size: 1.8rem; flex-shrink: 0; }
.tennis-fakt-card strong { display: block; font-weight: 700; font-size: .9rem; color: var(--gray-800); }
.tennis-fakt-card span { font-size: .83rem; color: var(--gray-400); }
.mitmachen-banner { background: linear-gradient(135deg, var(--blue) 0%, var(--blue-mid) 100%); border-radius: var(--radius); padding: 40px 48px; display: flex; align-items: center; justify-content: space-between; gap: 32px; color: var(--white); }
.mitmachen-content { display: flex; align-items: center; gap: 24px; }
.mitmachen-icon { font-size: 3rem; flex-shrink: 0; }
.mitmachen-banner h2 { font-family: 'Barlow Condensed', sans-serif; font-weight: 800; font-size: 1.8rem; margin-bottom: 8px; }
.mitmachen-banner p { font-size: .92rem; color: rgba(255,255,255,.75); line-height: 1.6; max-width: 480px; }
@media (max-width: 900px) { .tennis-ueber-grid { grid-template-columns: 1fr; } .mitmachen-banner { flex-direction: column; text-align: center; padding: 32px 24px; } .mitmachen-content { flex-direction: column; } }

/* ─────────────────────────────────────────────────
   PAGE EDITOR CONTENT (page.php)
───────────────────────────────────────────────── */
.page-editor-content { max-width: 780px; }
.page-editor-content h2 { font-family: 'Barlow Condensed', sans-serif; font-weight: 800; font-size: 1.5rem; color: var(--blue-mid); margin: 36px 0 12px; padding-bottom: 8px; border-bottom: 2px solid var(--gray-200); }
.page-editor-content h2:first-child { margin-top: 0; }
.page-editor-content h3 { font-family: 'Barlow Condensed', sans-serif; font-weight: 700; font-size: 1.2rem; color: var(--gray-800); margin: 24px 0 8px; }
.page-editor-content p { font-size: .97rem; color: var(--gray-600); line-height: 1.75; margin-bottom: 16px; }
.page-editor-content a { color: var(--blue-accent); text-decoration: underline; transition: color var(--transition); }
.page-editor-content a:hover { color: var(--blue-mid); }
.page-editor-content strong { color: var(--gray-800); font-weight: 700; }
.page-editor-content ul, .page-editor-content ol { padding-left: 20px; margin-bottom: 16px; }
.page-editor-content ul li, .page-editor-content ol li { font-size: .97rem; color: var(--gray-600); line-height: 1.75; margin-bottom: 4px; }
.page-editor-content hr { border: none; border-top: 1px solid var(--gray-200); margin: 32px 0; }

/* ─────────────────────────────────────────────────
   SINGLE EVENT ANSICHT
───────────────────────────────────────────────── */
.single-tribe_events .tribe-events-single { max-width: 860px; }

/* Titel */
.single-tribe_events .tribe-events-single .tribe-events-page-title,
.single-tribe_events h1.tribe-events-page-title {
  font-family: 'Barlow Condensed', sans-serif !important;
  font-weight: 900 !important;
  font-size: clamp(2rem, 4vw, 3rem) !important;
  color: var(--blue-mid) !important;
  margin-bottom: 8px !important;
  line-height: 1.1 !important;
}

/* Datum/Zeit oben */
.single-tribe_events .tribe-events-schedule {
  background: var(--blue-mid) !important;
  color: var(--white) !important;
  padding: 12px 20px !important;
  border-radius: var(--radius) !important;
  font-size: .9rem !important;
  font-weight: 600 !important;
  margin-bottom: 28px !important;
  display: inline-block !important;
}
.single-tribe_events .tribe-events-schedule abbr {
  color: var(--white) !important;
  text-decoration: none !important;
  border: none !important;
}

/* Beitragsbild */
.single-tribe_events .tribe-events-single-section img {
  border-radius: var(--radius) !important;
  margin-bottom: 24px !important;
}

/* Beschreibung */
.single-tribe_events .tribe-events-single-section p {
  font-size: .97rem !important;
  color: var(--gray-600) !important;
  line-height: 1.75 !important;
  margin-bottom: 16px !important;
}

/* Details-Box */
.single-tribe_events .tribe-events-single-section--details {
  background: var(--white) !important;
  border-radius: var(--radius) !important;
  box-shadow: var(--shadow) !important;
  border: 1px solid var(--gray-200) !important;
  padding: 28px !important;
  margin-top: 32px !important;
}
.single-tribe_events .tribe-events-single-section--details h2 {
  font-family: 'Barlow Condensed', sans-serif !important;
  font-weight: 800 !important;
  font-size: 1.2rem !important;
  color: var(--blue-mid) !important;
  margin-bottom: 16px !important;
  padding-bottom: 12px !important;
  border-bottom: 2px solid var(--blue-accent) !important;
}
.single-tribe_events .tribe-events-single-section--details dd,
.single-tribe_events .tribe-events-single-section--details dt {
  font-size: .92rem !important;
  color: var(--gray-600) !important;
  line-height: 1.65 !important;
}
.single-tribe_events .tribe-events-single-section--details dt {
  font-weight: 700 !important;
  color: var(--gray-800) !important;
  margin-top: 12px !important;
}
.single-tribe_events .tribe-events-single-section--details abbr {
  text-decoration: none !important;
  border: none !important;
  color: var(--gray-600) !important;
}

/* Karte ausblenden */
.single-tribe_events .tribe-events-single-section--map { display: none !important; }

/* Navigation vor/nach Event */
.single-tribe_events .tribe-events-nav-pagination {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  margin-top: 40px !important;
  padding-top: 24px !important;
  border-top: 1px solid var(--gray-200) !important;
}
.single-tribe_events .tribe-events-nav-pagination a {
  display: inline-flex !important;
  align-items: center !important;
  padding: 10px 20px !important;
  background: var(--blue-mid) !important;
  color: var(--white) !important;
  border-radius: 7px !important;
  font-weight: 700 !important;
  font-size: .88rem !important;
  transition: background var(--transition) !important;
}
.single-tribe_events .tribe-events-nav-pagination a:hover {
  background: var(--blue-light) !important;
}

/* Hero für Einzelansicht via JS anpassen */
.single-tribe_events .page-hero { display: none !important; }

/* ─────────────────────────────────────────────────
   SINGLE EVENT ANSICHT (eigenes Template)
───────────────────────────────────────────────── */
.single-event-wrap { display: grid; grid-template-columns: 1fr 300px; gap: 48px; align-items: start; }
.single-event-img { width: 100%; border-radius: var(--radius); margin-bottom: 28px; max-height: 420px; object-fit: cover; }
.single-event-text { font-size: .97rem; color: var(--gray-600); line-height: 1.75; }
.single-event-text p { margin-bottom: 16px; }
.single-event-text h2 { font-family: 'Barlow Condensed', sans-serif; font-weight: 800; font-size: 1.5rem; color: var(--blue-mid); margin: 28px 0 12px; }
.single-event-details-card { background: var(--white); border-radius: var(--radius); box-shadow: var(--shadow); padding: 24px; border: 1px solid var(--gray-200); position: sticky; top: 88px; }
.single-event-details-card h3 { font-family: 'Barlow Condensed', sans-serif; font-weight: 800; font-size: 1.2rem; color: var(--blue-mid); margin-bottom: 20px; padding-bottom: 12px; border-bottom: 2px solid var(--blue-accent); }
.single-event-detail-item { display: flex; align-items: flex-start; gap: 12px; padding: 12px 0; border-bottom: 1px solid var(--gray-100); }
.single-event-detail-item:last-child { border-bottom: none; }
.detail-icon { font-size: 1.2rem; flex-shrink: 0; margin-top: 2px; }
.single-event-detail-item strong { display: block; font-size: .75rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: var(--gray-400); margin-bottom: 2px; }
.single-event-detail-item span { font-size: .92rem; color: var(--gray-700); font-weight: 500; }
@media (max-width: 900px) {
  .single-event-wrap { grid-template-columns: 1fr; }
  .single-event-details-card { position: static; }
  .single-event-sidebar { order: -1; }
}

/* ─────────────────────────────────────────────────
   STARTSEITE TERMINE KARTEN
───────────────────────────────────────────────── */
.fp-termine-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.fp-termin-card { display: flex; align-items: center; gap: 0; background: var(--white); border-radius: var(--radius); box-shadow: var(--shadow); border: 1px solid var(--gray-200); overflow: hidden; text-decoration: none; transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition); }
.fp-termin-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); border-color: var(--blue-accent); }
.fp-termin-datum { background: linear-gradient(135deg, var(--blue) 0%, var(--blue-mid) 100%); min-width: 80px; width: 80px; padding: 18px 8px; display: flex; flex-direction: column; align-items: center; justify-content: center; align-self: stretch; text-align: center; flex-shrink: 0; }
.fp-termin-wochentag { font-size: .65rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: rgba(255,255,255,.55); display: block; margin-bottom: 2px; }
.fp-termin-tag { font-family: 'Barlow Condensed', sans-serif; font-weight: 900; font-size: 2.2rem; line-height: 1; color: var(--white); display: block; }
.fp-termin-monat { font-size: .65rem; font-weight: 700; text-transform: uppercase; color: var(--blue-accent); display: block; margin-top: 3px; letter-spacing: .06em; }
.fp-termin-info { padding: 14px 16px; flex: 1; }
.fp-termin-uhrzeit { font-size: .75rem; font-weight: 700; color: var(--blue-accent); display: block; margin-bottom: 4px; }
.fp-termin-info h4 { font-family: 'Barlow Condensed', sans-serif; font-weight: 800; font-size: 1.05rem; color: var(--gray-800); margin: 0 0 4px; line-height: 1.2; }
.fp-termin-kat { font-size: .75rem; color: var(--gray-400); font-weight: 600; }
.fp-termin-arrow { padding: 0 16px; font-size: 1.1rem; color: var(--blue-accent); flex-shrink: 0; font-weight: 700; transition: transform var(--transition); }
.fp-termin-card:hover .fp-termin-arrow { transform: translateX(4px); }
@media (max-width: 700px) { .fp-termine-grid { grid-template-columns: 1fr; } }

/* ─────────────────────────────────────────────────
   MITGLIED WERDEN
───────────────────────────────────────────────── */
.mitglied-intro { font-size: .97rem; color: var(--gray-600); line-height: 1.75; max-width: 720px; margin-bottom: 40px; }

/* Vorteile */
.mitglied-vorteile-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.mitglied-vorteil-card { background: var(--white); border-radius: var(--radius); box-shadow: var(--shadow); padding: 32px 24px; text-align: center; border-top: 3px solid var(--blue-accent); transition: transform var(--transition), box-shadow var(--transition); }
.mitglied-vorteil-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.mitglied-vorteil-icon { font-size: 2.4rem; display: block; margin-bottom: 14px; }
.mitglied-vorteil-card h3 { font-family: 'Barlow Condensed', sans-serif; font-weight: 800; font-size: 1.15rem; color: var(--blue-mid); margin-bottom: 10px; }
.mitglied-vorteil-card p { font-size: .9rem; color: var(--gray-600); line-height: 1.6; margin: 0; }

/* Beiträge */
.beitraege-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-bottom: 28px; }
.beitrag-card { background: var(--white); border-radius: var(--radius); box-shadow: var(--shadow); padding: 28px 20px; text-align: center; transition: transform var(--transition), box-shadow var(--transition); border: 2px solid transparent; }
.beitrag-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); }
.beitrag-card--highlight { border-color: var(--blue-accent); background: linear-gradient(135deg, var(--blue) 0%, var(--blue-mid) 100%); color: var(--white); }
.beitrag-card--family { grid-column: span 3; display: flex; align-items: center; justify-content: center; gap: 32px; padding: 24px 32px; background: var(--blue-mid); color: var(--white); }
.beitrag-icon { font-size: 2rem; display: block; margin-bottom: 10px; }
.beitrag-card--family .beitrag-icon { margin-bottom: 0; font-size: 2.4rem; }
.beitrag-gruppe { font-family: 'Barlow Condensed', sans-serif; font-weight: 800; font-size: 1.2rem; color: var(--blue-mid); margin-bottom: 4px; }
.beitrag-card--highlight .beitrag-gruppe,
.beitrag-card--family .beitrag-gruppe { color: var(--white); }
.beitrag-alter { font-size: .8rem; color: var(--gray-400); margin-bottom: 14px; }
.beitrag-card--highlight .beitrag-alter,
.beitrag-card--family .beitrag-alter { color: rgba(255,255,255,.6); }
.beitrag-preis { font-family: 'Barlow Condensed', sans-serif; font-weight: 900; font-size: 2.2rem; color: var(--blue-accent); line-height: 1; }
.beitrag-card--highlight .beitrag-preis { color: var(--white); }
.beitrag-card--family .beitrag-preis { color: var(--white); }
.beitrag-preis span { font-size: 1rem; font-weight: 600; opacity: .7; }
.beitrag-monat { font-size: .8rem; color: var(--gray-400); margin-top: 6px; }
.beitrag-card--highlight .beitrag-monat,
.beitrag-card--family .beitrag-monat { color: rgba(255,255,255,.55); }
.beitraege-hinweis { display: flex; align-items: flex-start; gap: 14px; background: var(--gray-100); border-radius: var(--radius); padding: 18px 20px; border-left: 4px solid var(--blue-accent); }
.beitraege-hinweis span { font-size: 1.4rem; flex-shrink: 0; }
.beitraege-hinweis p { font-size: .88rem; color: var(--gray-600); line-height: 1.65; margin: 0; }
.beitraege-hinweis strong { color: var(--gray-800); }

/* Downloads */
.download-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-bottom: 40px; }
.download-card { background: var(--white); border-radius: var(--radius); box-shadow: var(--shadow); padding: 28px; display: flex; flex-direction: column; gap: 16px; border: 1px solid var(--gray-200); transition: border-color var(--transition), box-shadow var(--transition); }
.download-card:hover { border-color: var(--blue-accent); box-shadow: var(--shadow-lg); }
.download-icon-wrap { width: 60px; height: 60px; background: linear-gradient(135deg, var(--blue) 0%, var(--blue-accent) 100%); border-radius: 12px; display: flex; align-items: center; justify-content: center; color: var(--white); flex-shrink: 0; }
.download-info h3 { font-family: 'Barlow Condensed', sans-serif; font-weight: 800; font-size: 1.2rem; color: var(--gray-800); margin-bottom: 6px; }
.download-info p { font-size: .88rem; color: var(--gray-600); line-height: 1.6; margin: 0; }
.download-btn { display: inline-flex; align-items: center; justify-content: center; padding: 11px 22px; background: var(--blue-mid); color: var(--white); border-radius: 7px; font-weight: 700; font-size: .9rem; transition: background var(--transition); margin-top: auto; }
.download-btn:hover { background: var(--blue-light); color: var(--white); }
.download-btn--soon { background: var(--gray-100); color: var(--gray-400); cursor: default; }
.download-btn--soon:hover { background: var(--gray-100); }

/* Kontakt Box */
.mitglied-kontakt-box { background: linear-gradient(135deg, var(--blue) 0%, var(--blue-mid) 100%); border-radius: var(--radius); padding: 36px 40px; display: flex; align-items: center; justify-content: space-between; gap: 32px; color: var(--white); }
.mitglied-kontakt-box h3 { font-family: 'Barlow Condensed', sans-serif; font-weight: 800; font-size: 1.5rem; margin-bottom: 6px; }
.mitglied-kontakt-box p { font-size: .92rem; color: rgba(255,255,255,.7); margin: 0; }
.mitglied-kontakt-links { display: flex; gap: 12px; flex-shrink: 0; }
.btn-outline-blue { display: inline-flex; align-items: center; justify-content: center; padding: 10px 22px; background: transparent; color: var(--white); border: 2px solid rgba(255,255,255,.4); border-radius: 7px; font-weight: 700; font-size: .9rem; transition: border-color var(--transition), background var(--transition); }
.btn-outline-blue:hover { border-color: var(--white); background: rgba(255,255,255,.1); color: var(--white); }

/* Responsive Mitglied werden */
@media (max-width: 900px) {
  .mitglied-vorteile-grid { grid-template-columns: repeat(2, 1fr); }
  .beitraege-grid { grid-template-columns: repeat(2, 1fr); }
  .beitrag-card--family { grid-column: span 2; flex-direction: column; gap: 12px; }
  .download-grid { grid-template-columns: 1fr; }
  .mitglied-kontakt-box { flex-direction: column; text-align: center; padding: 28px 24px; }
  .mitglied-kontakt-links { flex-direction: column; width: 100%; }
}
@media (max-width: 600px) {
  .mitglied-vorteile-grid { grid-template-columns: 1fr; }
  .beitraege-grid { grid-template-columns: 1fr; }
  .beitrag-card--family { grid-column: span 1; }
}

/* ─────────────────────────────────────────────────
   KONTAKT
───────────────────────────────────────────────── */

/* Info Karten */
.kontakt-info-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.kontakt-info-card { background: var(--white); border-radius: var(--radius); box-shadow: var(--shadow); padding: 28px 24px; text-align: center; border-top: 3px solid var(--blue-accent); transition: transform var(--transition), box-shadow var(--transition); display: flex; flex-direction: column; align-items: center; }
.kontakt-info-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.kontakt-info-icon { font-size: 2.2rem; margin-bottom: 12px; }
.kontakt-info-card h3 { font-family: 'Barlow Condensed', sans-serif; font-weight: 800; font-size: 1.1rem; color: var(--blue-mid); margin-bottom: 8px; }
.kontakt-info-card p { font-size: .88rem; color: var(--gray-600); line-height: 1.6; margin-bottom: 14px; flex: 1; }
.kontakt-info-link { font-size: .85rem; font-weight: 700; color: var(--blue-accent); transition: color var(--transition); }
.kontakt-info-link:hover { color: var(--blue-mid); }
.kontakt-social-links { display: flex; flex-direction: column; gap: 8px; width: 100%; }
.kontakt-social-btn { display: block; padding: 8px 16px; border-radius: 7px; font-size: .85rem; font-weight: 700; color: var(--white); text-align: center; transition: opacity var(--transition); }
.kontakt-social-btn:hover { opacity: .85; color: var(--white); }
.kontakt-social-btn--fb { background: #1877f2; }
.kontakt-social-btn--ig { background: linear-gradient(45deg, #f09433, #e6683c, #dc2743, #cc2366, #bc1888); }

/* Formular Bereich */
.kontakt-formular-wrap { display: grid; grid-template-columns: 1.2fr 1fr; gap: 60px; align-items: center; }
.kontakt-formular-text p { font-size: .97rem; color: var(--gray-600); line-height: 1.75; margin-bottom: 24px; }
.kontakt-hinweise { list-style: none; display: flex; flex-direction: column; gap: 10px; }
.kontakt-hinweise li { font-size: .88rem; color: var(--gray-600); display: flex; align-items: flex-start; gap: 8px; }
.kontakt-hinweise a { color: var(--blue-accent); text-decoration: underline; }

/* CF7 Styling */
.kontakt-formular-box { background: var(--white); border-radius: var(--radius); box-shadow: var(--shadow); padding: 32px; border: 1px solid var(--gray-200); }
.kontakt-formular-box .wpcf7-form { display: flex; flex-direction: column; gap: 0; }
.kontakt-formular-box .wpcf7-form p { margin: 0 0 16px 0; }
.kontakt-formular-box .wpcf7-form p:last-child { margin-bottom: 0; }
.kontakt-formular-box label { display: block; font-size: .78rem !important; font-weight: 700 !important; color: var(--blue-mid) !important; margin-bottom: 0 !important; margin-top: 0 !important; letter-spacing: .06em !important; text-transform: uppercase !important; cursor: default !important; padding-top: 16px !important; padding-bottom: 10px !important; }
.kontakt-formular-box input[type="text"],
.kontakt-formular-box input[type="email"],
.kontakt-formular-box input[type="tel"],
.kontakt-formular-box select,
.kontakt-formular-box textarea { width: 100%; padding: 10px 14px; border: 1.5px solid var(--gray-200); border-radius: 7px; font-family: 'Barlow', sans-serif; font-size: .92rem; color: var(--gray-800); background: var(--gray-50); outline: none; transition: border-color var(--transition), background var(--transition), box-shadow var(--transition); }
.kontakt-formular-box input[type="text"]:focus,
.kontakt-formular-box input[type="email"]:focus,
.kontakt-formular-box input[type="tel"]:focus,
.kontakt-formular-box textarea:focus { border-color: var(--blue-accent); background: var(--white); box-shadow: 0 0 0 3px rgba(74,144,217,.1); }
.kontakt-formular-box textarea { min-height: 80px !important; max-height: 160px !important; resize: vertical; }
.kontakt-formular-box input[type="submit"],
.kontakt-formular-box .wpcf7-submit { width: 100%; padding: 12px 24px; background: var(--blue-mid); color: var(--white); border: none; border-radius: 7px; font-family: 'Barlow', sans-serif; font-size: .95rem; font-weight: 700; cursor: pointer; margin-top: 4px; transition: background var(--transition), transform var(--transition); }
.kontakt-formular-box input[type="submit"]:hover,
.kontakt-formular-box .wpcf7-submit:hover { background: var(--blue-light); transform: translateY(-1px); }
.kontakt-formular-box .wpcf7-not-valid-tip { font-size: .75rem; color: #e53e3e; margin-top: 4px; display: block; }
.kontakt-formular-box .wpcf7-response-output { margin-top: 16px; padding: 12px 16px; border-radius: 7px; font-size: .88rem; border: none !important; }
.kontakt-formular-box .wpcf7-mail-sent-ok { background: #f0fff4; color: #276749; }
.kontakt-formular-box .wpcf7-validation-errors { background: #fff5f5; color: #c53030; }
.kontakt-formular-box .wpcf7-form-control-wrap { display: block; }

/* CF7 Acceptance Checkbox */
.kontakt-formular-box .wpcf7-acceptance { display: block; margin-top: 8px; }
.kontakt-formular-box .wpcf7-acceptance .wpcf7-list-item { margin: 0; }
.kontakt-formular-box .wpcf7-acceptance .wpcf7-list-item-label { font-size: .85rem !important; font-weight: 400 !important; color: var(--gray-600) !important; text-transform: none !important; letter-spacing: 0 !important; line-height: 1.6 !important; cursor: pointer; }
.kontakt-formular-box .wpcf7-acceptance a { color: var(--blue-accent) !important; font-weight: 600 !important; text-decoration: underline !important; transition: color var(--transition) !important; }
.kontakt-formular-box .wpcf7-acceptance a::after { content: ' 🔗'; font-size: .75rem; }
.kontakt-formular-box .wpcf7-acceptance a:hover { color: var(--blue-mid) !important; }
.kontakt-formular-box .wpcf7-acceptance input[type="checkbox"] { margin-right: 8px; accent-color: var(--blue-accent); width: 15px; height: 15px; cursor: pointer; }
.kontakt-cf7-hinweis { display: flex; gap: 16px; align-items: flex-start; background: var(--gray-50); border-radius: var(--radius); padding: 24px; border: 2px dashed var(--gray-200); }
.kontakt-cf7-hinweis span { font-size: 2rem; flex-shrink: 0; }
.kontakt-cf7-hinweis strong { display: block; font-weight: 700; color: var(--gray-800); margin-bottom: 6px; }
.kontakt-cf7-hinweis p { font-size: .88rem; color: var(--gray-600); margin: 0; line-height: 1.6; }
.kontakt-cf7-hinweis code { background: var(--gray-100); padding: 2px 6px; border-radius: 4px; font-size: .82rem; }

/* Anfahrt */
.kontakt-anfahrt-grid { display: grid; grid-template-columns: 1fr 1.4fr; gap: 48px; align-items: start; margin-top: 32px; }
.anfahrt-item { display: flex; gap: 16px; align-items: flex-start; padding: 16px 0; border-bottom: 1px solid var(--gray-100); }
.anfahrt-item:last-of-type { border-bottom: none; }
.anfahrt-icon { font-size: 1.6rem; flex-shrink: 0; }
.anfahrt-item strong { display: block; font-weight: 700; font-size: .95rem; color: var(--gray-800); margin-bottom: 4px; }
.anfahrt-item p { font-size: .88rem; color: var(--gray-600); line-height: 1.6; margin: 0; }
.kontakt-map-wrap { border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-lg); }
.kontakt-map-hinweis { font-size: .75rem; color: var(--gray-400); margin-top: 10px; line-height: 1.5; }
.kontakt-map-hinweis a { color: var(--blue-accent); text-decoration: underline; }

/* Responsive */
@media (max-width: 900px) {
  .kontakt-info-grid { grid-template-columns: repeat(2, 1fr); }
  .kontakt-formular-wrap { grid-template-columns: 1fr; gap: 32px; }
  .kontakt-anfahrt-grid { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
  .kontakt-info-grid { grid-template-columns: 1fr; }
}

/* ─────────────────────────────────────────────────
   SPONSOREN
───────────────────────────────────────────────── */
.sponsoren-intro { font-size: .97rem; color: var(--gray-600); line-height: 1.75; max-width: 720px; margin-bottom: 40px; }

/* Badges */
.sponsoren-badge { display: inline-block; font-size: .72rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; padding: 4px 12px; border-radius: 20px; margin-bottom: 10px; }
.sponsoren-badge--gold   { background: #f5c842; color: #6b4c00; }
.sponsoren-badge--silver { background: var(--silver); color: var(--blue-mid); }

/* Hauptsponsoren */
.hauptsponsoren-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.hauptsponsor-card { background: var(--white); border-radius: var(--radius); box-shadow: var(--shadow); overflow: hidden; display: flex; flex-direction: column; transition: transform var(--transition), box-shadow var(--transition); border: 1px solid var(--gray-200); }
.hauptsponsor-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); border-color: var(--blue-accent); }
.hauptsponsor-logo-wrap { height: 160px; background: var(--gray-50); display: flex; align-items: center; justify-content: center; padding: 24px; border-bottom: 1px solid var(--gray-100); }
.hauptsponsor-logo-wrap img { max-height: 100%; max-width: 100%; object-fit: contain; }
.sponsoren-logo-placeholder { font-family: 'Barlow Condensed', sans-serif; font-weight: 800; font-size: 1.1rem; color: var(--gray-400); text-align: center; }
.hauptsponsor-info { padding: 24px; flex: 1; display: flex; flex-direction: column; }
.hauptsponsor-info h3 { font-family: 'Barlow Condensed', sans-serif; font-weight: 800; font-size: 1.2rem; color: var(--gray-800); margin-bottom: 8px; }
.hauptsponsor-info p { font-size: .88rem; color: var(--gray-600); line-height: 1.6; flex: 1; margin-bottom: 16px; }
.sponsoren-link { display: inline-flex; align-items: center; gap: 6px; font-size: .85rem; font-weight: 600; color: var(--blue-accent); transition: gap var(--transition); margin-top: auto; }
.sponsoren-link:hover { gap: 10px; }

/* Partner Grid */
.partner-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.partner-card { background: var(--white); border-radius: var(--radius); box-shadow: var(--shadow); overflow: hidden; display: flex; flex-direction: column; transition: transform var(--transition), box-shadow var(--transition); }
.partner-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); }
.partner-logo-wrap { height: 120px; background: var(--gray-50); display: flex; align-items: center; justify-content: center; padding: 16px; border-bottom: 1px solid var(--gray-100); }
.partner-logo-wrap img { max-height: 100%; max-width: 100%; object-fit: contain; }
.partner-logo-placeholder { width: 60px; height: 60px; background: linear-gradient(135deg, var(--blue) 0%, var(--blue-accent) 100%); border-radius: 12px; display: flex; align-items: center; justify-content: center; font-family: 'Barlow Condensed', sans-serif; font-weight: 900; font-size: 1.3rem; color: var(--white); }
.partner-info { padding: 16px 20px; flex: 1; }
.partner-info h4 { font-family: 'Barlow Condensed', sans-serif; font-weight: 800; font-size: 1rem; color: var(--gray-800); margin-bottom: 2px; }
.partner-info span { font-size: .8rem; color: var(--gray-400); display: block; margin-bottom: 8px; }
.partner-web { display: inline-flex; align-items: center; gap: 5px; font-size: .8rem; font-weight: 600; color: var(--blue-accent); transition: gap var(--transition); }
.partner-web:hover { gap: 8px; }

/* Sponsor werden */
.sponsor-werden-wrap { display: grid; grid-template-columns: 1fr 200px; gap: 48px; align-items: center; }
.sponsor-werden-text p { font-size: .97rem; color: var(--gray-600); line-height: 1.75; margin-bottom: 20px; }
.sponsor-vorteile { list-style: none; display: flex; flex-direction: column; gap: 8px; margin-bottom: 24px; }
.sponsor-vorteile li { font-size: .93rem; color: var(--gray-700); }
.sponsor-werden-deko { display: flex; align-items: center; justify-content: center; font-size: 8rem; opacity: .15; }

/* Responsive Sponsoren */
@media (max-width: 900px) {
  .hauptsponsoren-grid { grid-template-columns: 1fr; }
  .partner-grid { grid-template-columns: repeat(2, 1fr); }
  .sponsor-werden-wrap { grid-template-columns: 1fr; }
  .sponsor-werden-deko { display: none; }
}
@media (max-width: 600px) {
  .partner-grid { grid-template-columns: 1fr; }
}

/* ─────────────────────────────────────────────────
   GYMNASTIK
───────────────────────────────────────────────── */
.gym-angebote-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 40px;
}
.gym-angebot-card {
  background: var(--white);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 32px 24px;
  text-align: center;
  transition: transform var(--transition), box-shadow var(--transition);
  border-top: 3px solid var(--blue-accent);
}
.gym-angebot-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
}
.gym-angebot-icon {
  font-size: 2.4rem;
  display: block;
  margin-bottom: 14px;
}
.gym-angebot-card h3 {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--blue);
  margin-bottom: 10px;
}
.gym-angebot-card p {
  font-size: .93rem;
  color: var(--gray-600);
  line-height: 1.55;
  margin: 0;
}
.gym-pdf-link {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-top: 24px;
  padding: 12px 20px;
  background: var(--blue-light);
  color: var(--white);
  border-radius: var(--radius);
  font-weight: 600;
  font-size: .95rem;
  text-decoration: none;
  transition: background var(--transition);
}
.gym-pdf-link:hover {
  background: var(--blue-mid);
  color: var(--white);
}

/* ─────────────────────────────────────────────────
   RESPONSIVE
───────────────────────────────────────────────── */
@media (max-width: 900px) {
  .main-nav { display: none; }
  .header-cta { display: none; }
  .hamburger { display: flex; }
  .matchday-grid, .news-grid { grid-template-columns: 1fr; }
  .abt-grid { grid-template-columns: 1fr 1fr; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .mannschaft-grid { grid-template-columns: 1fr; }
  .ueber-grid { grid-template-columns: 1fr; }
  .fahnen-grid { grid-template-columns: 1fr; }
  .sportheim-grid { grid-template-columns: 1fr; }
  .werte-grid { grid-template-columns: 1fr; }
  .fakten-box { position: static; }
}
@media (max-width: 900px) {
  .gym-angebote-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .footer-grid { grid-template-columns: 1fr; }
  .abt-grid { grid-template-columns: 1fr 1fr; }
  .jugend-grid { grid-template-columns: 1fr 1fr; }
  .gym-angebote-grid { grid-template-columns: 1fr; }
}