/*
Theme Name: BVB-Theme 2.0
Theme URI: https://bvb-spielplan.de
Author: BVB-Spielplan.de
Description: BVB-Theme 2.0 – Editorial Dark Mode Redesign. Playfair Display + Barlow, klare Typografie-Hierarchie, gelber Datums-Akzent, moderne Spielplan-Zeilen.
Version: 5.0.5
Changelog 5.0.0:
  - Komplettes Redesign: Editorial Dark Mode (Mockup 3)
  - Neue Schriften: Playfair Display (Headings/Zahlen) + Barlow (Body)
  - Neue Design-Tokens: --bvb-accent-bar, --radius-* überarbeitet
  - Header: BVB-Gelb Masthead + schwarze Subnavigation
  - Spielplan-Rows: Datum-Block mit gelbem Left-Border, KW-Gruppen
  - Match-Cards: entfernt, ersetzt durch .match-row (Zeilen-Layout)
  - TV-Badges: dunklere Varianten für Dark-Background (keine Änderung an Shortcode-API)
  - Footer: CTA-Strip mit Kalender-Abo-Button
  - Alle bestehenden Shortcode-Klassen (.bvbsp-*, .btf-*, .tv-badge--*) bleiben kompatibel
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: bvb-theme
*/

/* ===========================================
   GOOGLE FONTS
   =========================================== */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@700&family=Barlow:wght@400;500;600&display=swap');

/* ===========================================
   TOKENS
   =========================================== */
:root {
  /* BVB-Farben */
  --bvb-yellow:       #FDE100;
  --bvb-yellow-dark:  #D4BC00;
  --bvb-yellow-light: #FFF176;
  --bvb-black:        #111111;

  /* Dark Theme (Standard – kein Media Query nötig) */
  --bg-body:          #0d0d0d;
  --bg-card:          #1a1a1a;
  --bg-surface:       #222222;
  --bg-pill:          #2a2a2a;
  --text-1:           #eeeeee;
  --text-2:           #aaaaaa;
  --text-3:           #666666;
  --border:           rgba(255,255,255,0.08);
  --border-hover:     rgba(255,255,255,0.15);
  --shadow-card:      0 1px 3px rgba(0,0,0,0.4);

  /* Sender-Farben */
  --sky-blue:         #0064A4;
  --dazn-black:       #1a1a1a;
  --rtl-red:          #E3000B;
  --ard-blue:         #004E8A;
  --live-red:         #E24B4A;
  --win-green:        #1D9E75;
  --loss-red:         #d32f2f;
  --draw-gray:        #888;

  /* TV-Badge Tokens (unveränderter Shortcode-API) */
  --tv-sky:           var(--sky-blue);
  --tv-dazn-bg:       #00e5a0;
  --tv-dazn-fg:       #000;
  --tv-rtl:           var(--rtl-red);
  --tv-ard:           var(--ard-blue);
  --tv-sportschau:    var(--ard-blue);
  --tv-zdf:           #FA7D19;
  --tv-pluto:         #6236FF;
  --tv-youtube:       #FF0000;
  --tv-staige:        #612A6F;
  --tv-leagues-bg:    #48EDDD;
  --tv-leagues-fg:    #111;
  --tv-dyn-bg:        #00C8FF;
  --tv-dyn-fg:        #111;
  --tv-sporteurope:   #1B3A6B;
  --tv-prime:         #00A8E0;

  /* Typografie – NEU in 2.0 */
  --font:             'Barlow', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-heading:     'Playfair Display', Georgia, serif;

  /* Layout */
  --radius-sm:        4px;
  --radius-md:        8px;
  --radius-lg:        12px;
  --radius-full:      99px;
  --container:        560px;
  --nav-h:            52px;

  /* NEU 2.0: Akzent-Balken für Datum-Blocks */
  --accent-bar:       2px solid var(--bvb-yellow);
}

@media(min-width:768px){
  :root{--container:820px}
}

/* ===========================================
   RESET
   =========================================== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{font-family:var(--font);background:var(--bg-body);color:var(--text-1);line-height:1.75;font-size:16px;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
ul,ol{list-style:none}
button{font-family:inherit}

/* ===========================================
   LAYOUT
   =========================================== */
.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 16px}
.page-content > *,.single-content > *{max-width:100%}
.wp-block-group,.wp-block-columns,.wp-block-table,.wp-block-cover{max-width:100%!important}
body .is-layout-constrained > :where(:not(.alignleft):not(.alignright):not(.alignfull)){max-width:var(--container)!important}
body .is-layout-constrained > .alignwide{max-width:var(--container)!important}

/* ===========================================
   HEADER – 2.0: Gelbe Masthead + schwarze SubNav
   =========================================== */

/* Masthead (gelber Streifen oben) */
.topbar{
  background:var(--bvb-yellow);
  padding:0 16px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  height:48px;
}
.topbar-logo{
  font-family:var(--font-heading);
  font-size:20px;
  font-weight:700;
  color:#111;
  letter-spacing:-0.3px;
}
.topbar-logo span{
  font-family:var(--font);
  font-size:13px;
  font-weight:600;
  color:#333;
  margin-left:8px;
}
.topbar-right{
  display:flex;gap:6px;
}
.topbar-link{
  font-size:12px;font-weight:600;color:#111;
  background:rgba(0,0,0,0.1);
  padding:4px 12px;border-radius:var(--radius-full);
  transition:background .2s;
}
.topbar-link:hover{background:rgba(0,0,0,0.2)}
.topbar-link--active{background:#111;color:var(--bvb-yellow);}
.topbar-link--active:hover{background:#222;color:var(--bvb-yellow);}
/* Mobile: Topbar ausblenden */
@media(max-width:639px){.topbar{display:none}}

/* Header (schwarze Subnavigation) */
.site-header{
  position:sticky;top:0;z-index:100;
  background:var(--bvb-black);
  border-bottom:1px solid rgba(253,225,0,0.15);
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:var(--nav-h);
  max-width:var(--container);margin:0 auto;padding:0 16px;
}
/* Logo bleibt im header für mobile */
.site-logo{
  font-family:var(--font-heading);
  font-size:18px;font-weight:700;color:#fff;
  white-space:nowrap;flex-shrink:0;
  display:none; /* auf Desktop versteckt, sichtbar auf Mobile */
}
.site-logo span{color:var(--bvb-yellow)}
@media(max-width:639px){.site-logo{display:block}}

.header-right{display:flex;align-items:center;gap:8px}

/* Social icons */
.social-row{display:flex;gap:5px;align-items:center}
.social-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-sm);background:rgba(255,255,255,0.07);transition:background .2s}
.social-icon svg{transition:fill .2s,stroke .2s}
.social-icon:hover{background:rgba(253,225,0,0.15)}
.social-icon:hover svg{fill:var(--bvb-yellow);stroke:var(--bvb-yellow)}

.support-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-sm);background:rgba(253,225,0,0.15);transition:background .2s}
.support-btn:hover{background:rgba(253,225,0,0.3)}
.support-btn svg{fill:var(--bvb-yellow)}

/* Hamburger */
.nav-toggle{display:flex;flex-direction:column;gap:4px;background:0;border:0;cursor:pointer;padding:8px;z-index:200}
.nav-toggle span{display:block;width:18px;height:2px;background:#fff;border-radius:1px;transition:all .3s}
.nav-toggle.active span:nth-child(1){transform:rotate(45deg) translate(4px,4px)}
.nav-toggle.active span:nth-child(2){opacity:0}
.nav-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(4px,-4px)}

/* Mobile nav — Bottom Sheet */
.nav-backdrop{position:fixed;inset:0;background:rgba(0,0,0,0.5);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:89;opacity:0;pointer-events:none;transition:opacity .3s}
.nav-backdrop.open{opacity:1;pointer-events:auto}

.nav-main{position:fixed;left:0;right:0;bottom:0;background:var(--bvb-black);border-top:2px solid var(--bvb-yellow);border-radius:20px 20px 0 0;transform:translateY(100%);transition:transform .35s cubic-bezier(.32,.72,0,1);z-index:90;overflow-y:auto;max-height:80vh;padding:8px 24px 32px;overscroll-behavior:contain}
.nav-main.open{transform:translateY(0)}
.nav-handle{width:36px;height:4px;background:rgba(255,255,255,0.2);border-radius:2px;margin:0 auto 20px}
.nav-main li{border-bottom:1px solid rgba(255,255,255,0.06)}
.nav-main li:last-child{border-bottom:0}
.nav-main a{display:flex;align-items:center;padding:16px 0;color:#ccc;font-size:16px;font-weight:500;transition:color .2s}
.nav-main a:hover,.nav-main .current-menu-item a{color:var(--bvb-yellow)}
.nav-sheet-social{display:flex;gap:8px;justify-content:center;padding:20px 0 0;margin-top:8px;border-top:1px solid rgba(255,255,255,0.06)}
.nav-sheet-social .header-social__icon{width:40px;height:40px;border-radius:var(--radius-md)}
.nav-sheet-social .header-social__icon svg{width:20px;height:20px}

@media(min-width:640px){
  .nav-backdrop{display:none}
  .nav-toggle{display:none}
  .nav-main{position:static;transform:none;background:0;border:0;border-radius:0;padding:0;overflow:visible;max-height:none;flex:1;display:flex;justify-content:center}
  .nav-handle{display:none}
  .nav-main ul{display:flex;gap:2px}
  .nav-main li{border:0}
  .nav-main a{padding:5px 10px;font-size:13px;border-radius:var(--radius-full);color:#aaa}
  .nav-main a:hover,.nav-main .current-menu-item a{background:rgba(253,225,0,0.1);color:var(--bvb-yellow)}
  .nav-sheet-social{display:none}
}

/* ===========================================
   SECTION BAR (Team-Tabs, 2.0: schlanker)
   =========================================== */
.team-tabs{
  display:flex;gap:0;
  background:var(--bvb-black);
  border-bottom:1px solid var(--border);
  overflow-x:auto;scrollbar-width:none;
  -webkit-overflow-scrolling:touch;
}
.team-tabs::-webkit-scrollbar{display:none}
.team-tab{
  padding:9px 18px;
  font-size:12px;font-weight:600;
  white-space:nowrap;
  color:var(--text-3);
  background:0;border:0;cursor:pointer;
  letter-spacing:0.5px;
  border-right:1px solid var(--border);
  transition:color .2s;
  flex-shrink:0;
}
.team-tab:hover{color:var(--text-1)}
.team-tab.active{color:var(--bvb-yellow)}

/* Sticky Tabs */
.team-tabs--sticky{
  position:sticky;top:var(--nav-h);z-index:50;
  margin-left:-16px;margin-right:-16px;
  padding-left:16px;padding-right:16px;
}

/* ===========================================
   SECTION LABELS
   =========================================== */
.section-label{font-size:10px;color:var(--text-3);font-weight:600;letter-spacing:2px;margin:20px 0 12px;text-transform:uppercase}
.section-label:first-child{margin-top:0}
.section-label-row{display:flex;align-items:center;justify-content:space-between;margin:20px 0 12px}
.section-label-row .section-label{margin:0}
.section-label-link{font-size:11px;color:var(--text-3);text-decoration:none;transition:color .2s}
.section-label-link:hover{color:var(--bvb-yellow)}

/* ===========================================
   MATCH ROWS – 2.0: Editorial Zeilen-Layout
   (ersetzt match-cards als primäres Layout)
   =========================================== */
.match-list{
  display:flex;flex-direction:column;gap:0;
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  overflow:hidden;
}

/* KW-Trennlabel */
.match-week-label{
  font-size:10px;font-weight:600;
  color:var(--text-3);
  text-transform:uppercase;letter-spacing:2px;
  padding:10px 16px 6px;
  background:var(--bg-body);
  border-bottom:1px solid var(--border);
}

/* Einzel-Zeile */
.match-row{
  display:grid;
  grid-template-columns:56px 1fr auto;
  gap:0 16px;
  align-items:center;
  padding:13px 16px;
  border-bottom:1px solid var(--border);
  transition:background .15s;
  text-decoration:none;color:inherit;
}
.match-row:last-child{border-bottom:none}
.match-row:hover{background:rgba(255,255,255,0.03)}
.match-row--next{
  border-left:3px solid var(--bvb-yellow);
  background:linear-gradient(90deg,rgba(253,225,0,0.05) 0%,transparent 35%);
}

/* Datum-Block (gelber Akzentbalken) */
.match-row__date{
  text-align:center;
  border-right:var(--accent-bar);
  padding-right:14px;
}
.match-row__day{
  font-size:10px;font-weight:600;
  color:var(--text-3);text-transform:uppercase;letter-spacing:0.5px;
}
.match-row__num{
  font-family:var(--font-heading);
  font-size:22px;font-weight:700;
  color:var(--text-1);line-height:1;
}

/* Match-Info */
.match-row__info{}
.match-row__teams{
  font-size:14px;font-weight:600;color:var(--text-1);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.match-row__teams .is-bvb{color:var(--bvb-yellow)}
.match-row__meta{font-size:11px;color:var(--text-3);margin-top:2px}

/* Rechte Seite */
.match-row__right{text-align:right;flex-shrink:0}
.match-row__kickoff{
  font-family:var(--font-heading);
  font-size:18px;font-weight:700;color:var(--text-1);
  line-height:1;
}
.match-row__tv{display:flex;gap:4px;justify-content:flex-end;margin-top:5px;flex-wrap:wrap}

/* Abgedimmte vergangene Spiele */
.match-row--past{opacity:0.45}
.match-row--past:hover{opacity:0.7}

/* BVB-Name Hervorhebung in match-row */
.match-row__bvb{color:var(--bvb-yellow);font-weight:600}

/* Fix 1: Tabs nahtlos an Match-List – kein Radius oben */
.team-tabs + .match-list{border-top:none;border-radius:0 0 var(--radius-lg) var(--radius-lg)}
.team-tabs--sticky{border-radius:0}

/* Fix 2: Datum-Block kompakter */
.match-row{grid-template-columns:44px 1fr auto}
.match-row__date{padding-right:10px}
.match-row__num{font-size:20px}

/* Fix 4: Hover klarer sichtbar */
.match-row:hover{background:rgba(255,255,255,0.04)}
.match-row--next:hover{background:linear-gradient(90deg,rgba(253,225,0,0.08) 0%,rgba(255,255,255,0.02) 40%)}

/* Fix 6: Spielplan-Hint als visuelle Fortsetzung der Match-List */
.match-list + .spielplan-hint{
  margin-top:0;
  border:1px solid var(--border);
  border-top:none;
  border-radius:0 0 var(--radius-lg) var(--radius-lg);
  padding:10px 16px;
  text-align:center;
}
.match-list + .spielplan-hint a{
  font-size:12px;color:var(--text-3);
  border:none;padding:0;border-radius:0;
}
.match-list + .spielplan-hint a:hover{color:var(--bvb-yellow);background:none}

/* Mobile */
@media(max-width:480px){
  .match-row{grid-template-columns:40px 1fr auto;gap:0 10px;padding:11px 12px}
  .match-row__num{font-size:17px}
  .match-row__teams{font-size:13px;white-space:normal;line-height:1.3}
  .match-row__kickoff{font-size:14px}
}

/* ===========================================
   MATCH CARDS (Legacy, kompatibel)
   =========================================== */
.match-card{display:flex;justify-content:space-between;align-items:flex-start;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px 14px;transition:border-color .2s;text-decoration:none;color:inherit}
.match-card:hover{border-color:var(--border-hover)}
.match-card--next{border:1.5px solid rgba(253,225,0,0.4)}
.match-card--next:hover{border-color:rgba(253,225,0,0.6)}
.match-card__left{min-width:0;flex:1}
.match-card__teams{font-size:13px;font-weight:600;color:var(--text-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.match-card--next .match-card__teams{font-size:14px}
.match-card__date{font-size:11px;color:var(--text-2);margin-top:3px}
.match-card__right{display:flex;flex-direction:column;align-items:flex-end;flex-shrink:0;margin-left:12px}
.match-card__comp{font-size:10px;color:var(--text-3);text-align:right;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}

/* ===========================================
   TV BADGES
   =========================================== */
.tv-badges{display:flex;gap:4px;justify-content:flex-start;margin-top:4px;flex-wrap:wrap}
a.tv-badge,.tv-badge{
  display:inline-block;padding:3px 8px;border-radius:var(--radius-sm);
  font-size:.75rem;font-weight:700;letter-spacing:.04em;
  text-decoration:none;line-height:1.5;transition:opacity .15s;
  background:var(--bg-surface);color:var(--text-2);
}
a.tv-badge + a.tv-badge,.tv-badge + .tv-badge{margin-left:4px}
a.tv-badge:hover,.tv-badge:hover{opacity:.82;text-decoration:none}

a.tv-badge--sky,.tv-badge--sky{background:#e3051b;color:#fff}
a.tv-badge--dazn,.tv-badge--dazn{background:#00d94f;color:#000}
a.tv-badge--ard,.tv-badge--ard{background:#003d82;color:#fff}
a.tv-badge--sportschau,.tv-badge--sportschau{background:#003d82;color:#fff}
a.tv-badge--zdf,.tv-badge--zdf{background:#f4a000;color:#000}
a.tv-badge--prime,.tv-badge--prime{background:#00a8e0;color:#fff}
a.tv-badge--youtube,.tv-badge--youtube{background:#ff0000;color:#fff}
a.tv-badge--dyn,.tv-badge--dyn{background:#ff4800;color:#fff}
a.tv-badge--staige,.tv-badge--staige{background:#7c3aed;color:#fff}
a.tv-badge--plutotv,.tv-badge--plutotv{background:#6236ff;color:#fff}
a.tv-badge--leagues,.tv-badge--leagues{background:#1a1a1a;color:#FDE100;border:1px solid #333}
a.tv-badge--sporteurope,.tv-badge--sporteurope{background:#0a5c99;color:#fff}
a.tv-badge--rtl,.tv-badge--rtl{background:#E3000B;color:#fff}
a.tv-badge--default,.tv-badge--default{background:var(--bg-surface);color:var(--text-2)}

/* TV-Filter btf-broadcaster (Shortcode) – unveränderter API */
.btf-broadcaster{display:inline-block;font-size:11px;font-weight:700;padding:4px 8px;border-radius:4px;background:var(--bg-surface);color:var(--text-2);text-decoration:none;text-transform:uppercase;letter-spacing:.04em;transition:filter .15s}
.btf-broadcaster:hover{filter:brightness(.82);text-decoration:none}
.btf-broadcaster--sky{background:#e3051b;color:#fff}
.btf-broadcaster--dazn{background:#00d94f;color:#000}
.btf-broadcaster--ard{background:#003d82;color:#fff}
.btf-broadcaster--sportschau{background:#003d82;color:#fff}
.btf-broadcaster--zdf{background:#f4a000;color:#000}
.btf-broadcaster--rtl{background:#E3000B;color:#fff}
.btf-broadcaster--prime{background:#00a8e0;color:#fff}
.btf-broadcaster--youtube{background:#ff0000;color:#fff}
.btf-broadcaster--dyn{background:#ff4800;color:#fff}
.btf-broadcaster--staige{background:#7c3aed;color:#fff}
.btf-broadcaster--pluto{background:#6236ff;color:#fff}
.btf-broadcaster--leagues{background:#1a1a1a;color:#FDE100;border:1px solid #333}
.btf-broadcaster--sporteurope{background:#0a5c99;color:#fff}
.btf-broadcaster--default{background:var(--bg-surface);color:var(--text-2)}

/* ===========================================
   NEXT GAME HERO – 2.0: Datum-Block integriert
   =========================================== */
.next-game-hero{
  margin:16px 0 0;
  background:#161616;
  border-radius:var(--radius-lg);
  padding:18px 18px 16px;
  color:#fff;
  border:1px solid rgba(253,225,0,0.2);
  overflow:hidden;position:relative;min-height:180px;
}
.next-game-hero:not(.next-game-hero--ready){visibility:hidden}
.next-game-hero::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--bvb-yellow)}
.next-game-hero--live::before{background:var(--live-red);animation:pulse-bg 1.6s ease-in-out infinite}
.next-game-hero__inner{display:flex;flex-direction:column;gap:8px}
.next-game-hero__status{font-family:var(--font-heading);font-size:10px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--bvb-yellow);display:flex;align-items:center;gap:6px}
.next-game-hero__status--live{color:#fff}
.live-dot{display:inline-block;width:8px;height:8px;background:var(--live-red);border-radius:50%;animation:pulse-dot 1.4s ease-in-out infinite}
@keyframes pulse-dot{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:.6}}
@keyframes pulse-bg{0%,100%{opacity:1}50%{opacity:.5}}
.next-game-hero__teams{font-family:var(--font-heading);font-size:22px;font-weight:700;line-height:1.3;color:#fff}
.next-game-hero__teams .is-bvb{color:var(--bvb-yellow)}
.next-game-hero__vs{color:#999;margin:0 6px;font-weight:400}
.next-game-hero__date{font-size:13px;color:#ccc}
.next-game-hero__countdown{display:flex;gap:8px;margin:4px 0 2px}
.cd-block{display:flex;flex-direction:column;align-items:center;background:rgba(255,255,255,0.08);border-radius:var(--radius-sm);padding:6px 10px;min-width:44px}
.cd-block strong{font-family:var(--font-heading);font-size:18px;font-weight:700;color:var(--bvb-yellow);line-height:1}
.cd-block span{font-size:9px;color:#aaa;text-transform:uppercase;letter-spacing:0.5px;margin-top:2px}
.next-game-hero__meta{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin-top:4px}
.next-game-hero__comp{font-size:11px;color:#aaa;font-weight:600}
.next-game-hero__empty{color:#aaa;font-size:13px;text-align:center;padding:20px 0}

@media(min-width:640px){
  .next-game-hero{padding:24px 24px 20px}
  .next-game-hero__teams{font-size:26px}
  .cd-block{padding:8px 12px;min-width:56px}
  .cd-block strong{font-size:22px}
}

/* ===========================================
   STICKY MINI-BAR
   =========================================== */
.next-game-bar{position:fixed;top:var(--nav-h);left:0;right:0;background:var(--bvb-black);border-bottom:1px solid rgba(253,225,0,0.4);transform:translateY(-100%);transition:transform .3s cubic-bezier(.32,.72,0,1);z-index:95;color:#fff}
.next-game-bar--visible{transform:translateY(0)}
.next-game-bar__inner{max-width:var(--container);margin:0 auto;padding:8px 16px;display:flex;align-items:center;gap:10px;font-size:12px;overflow-x:auto;scrollbar-width:none;white-space:nowrap}
.next-game-bar__inner::-webkit-scrollbar{display:none}
.next-game-bar__when{color:var(--bvb-yellow);font-family:var(--font-heading);font-weight:700;font-size:11px;letter-spacing:0.5px;flex-shrink:0}
.next-game-bar__live{display:flex;align-items:center;gap:5px;color:#fff;font-family:var(--font-heading);font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:0.5px;flex-shrink:0}
.next-game-bar__pairing{font-weight:600;color:#fff;flex-shrink:0}
.next-game-bar .tv-badges{margin:0;flex-shrink:0}
.next-game-bar__sentinel{height:1px;margin-top:-1px;pointer-events:none}

/* ===========================================
   SAISON-COCKPIT
   =========================================== */
.season-cockpit{margin:24px 0 0}
.cockpit__inner{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:14px 16px 12px}
.cockpit__head{margin-bottom:12px}
.cockpit__head .section-label{margin:0}
.cockpit__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}
.cockpit__cell{display:flex;flex-direction:column;align-items:flex-start;min-width:0}
.cockpit__value{font-family:var(--font-heading);font-size:22px;font-weight:700;color:var(--text-1);line-height:1}
.cockpit__value--split{font-size:18px;display:flex;align-items:baseline;gap:2px}
.cockpit__sep{color:var(--text-3);font-weight:400}
.cockpit__total{font-size:13px;color:var(--text-3);font-weight:600}
.cockpit__label{font-size:10px;color:var(--text-3);text-transform:uppercase;letter-spacing:0.5px;margin-top:4px;font-weight:600}
.cockpit__loading{color:var(--text-3);font-size:12px}
.cockpit__progress{height:4px;background:var(--bg-pill);border-radius:2px;overflow:hidden}
.cockpit__bar{height:100%;width:0;background:var(--bvb-yellow);transition:width .6s ease-out}
.cockpit__scale{position:relative;height:14px;margin-top:5px;font-family:var(--font-heading);font-size:10px;font-weight:700;letter-spacing:.3px;color:var(--text-3)}
.cockpit__scale-tick{position:absolute;top:0;white-space:nowrap;line-height:1}
.cockpit__scale-tick--start{left:0}
.cockpit__scale-tick--end{right:0}
.cockpit__scale-tick--current{color:var(--text-1);font-weight:700;transform:translateX(-50%)}
.season-cockpit--hidden{display:none}

/* Cockpit im Hero */
.next-game-hero__cockpit{border-top:1px solid rgba(255,255,255,0.08);margin-top:12px;padding-top:12px}
.next-game-hero__cockpit .cockpit__head .section-label{margin:0 0 10px;font-size:10px}
.next-game-hero__cockpit .cockpit__grid{margin-bottom:10px}
.next-game-hero__cockpit .cockpit__inner{background:transparent;border:none;border-radius:0;padding:0}

/* Cockpit-Karten */
.cockpit__cards{display:grid;grid-template-columns:1fr;gap:10px;margin-top:12px}
.cockpit__card{background:rgba(255,255,255,0.04);border:1px solid var(--border);border-radius:var(--radius-md);padding:14px 14px 12px;min-width:0}
.cockpit__label-card{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--bvb-yellow);margin-bottom:12px}
.cockpit__sub{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-3);margin:8px 0 6px}
.cockpit__divider{border-top:1px solid var(--border);margin:10px 0}
.cockpit__empty{font-size:12px;color:var(--text-3);font-style:italic}
.cockpit__error{font-size:12px;color:var(--loss-red)}

.cockpit__grid--four{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-bottom:10px}
.cockpit__grid--four .cockpit__cell{display:flex;flex-direction:column}
.cockpit__grid--four .cockpit__value{font-family:var(--font-heading);font-size:17px;font-weight:700;color:var(--text-1);line-height:1}
.cockpit__grid--four .cockpit__label{font-size:9px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);margin-top:4px}

.stat__sun-w{color:var(--win-green);font-weight:700}
.stat__sun-d{color:var(--text-2)}
.stat__sun-l{color:var(--loss-red);font-weight:700}
.stat__sun-sep{color:var(--text-3);font-weight:400;font-size:12px}

.cockpit__card .cockpit__progress{height:3px;background:rgba(255,255,255,0.1);border-radius:2px;overflow:hidden;margin-top:4px}
.cockpit__card .cockpit__bar{height:100%;background:var(--bvb-yellow);border-radius:2px;transition:width .6s ease-out}
.cockpit__card .cockpit__scale{position:relative;height:16px;margin-top:4px;font-size:9px;font-weight:600;color:var(--text-3);letter-spacing:.03em}
.cockpit__card .cockpit__scale-tick{position:absolute;top:0;white-space:nowrap}
.cockpit__card .cockpit__scale-tick--start{left:0}
.cockpit__card .cockpit__scale-tick--end{right:0}
.cockpit__card .cockpit__scale-tick--current{color:var(--text-2);font-weight:700;transform:translateX(-50%)}

/* Runden-Strang */
.cockpit__rounds{display:flex;align-items:flex-start;gap:0;position:relative;padding:6px 0 4px;overflow-x:auto;scrollbar-width:none}
.cockpit__rounds::-webkit-scrollbar{display:none}
.cockpit__round{display:flex;flex-direction:column;align-items:center;flex:1;min-width:0;position:relative}
.cockpit__round:not(:last-child)::after{content:'';position:absolute;top:10px;left:50%;width:100%;height:2px;background:var(--border);z-index:0}
.cockpit__round-dot{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid var(--border);background:var(--bg-surface);position:relative;z-index:1;flex-shrink:0}
.cockpit__round-dot--win{background:var(--win-green);border-color:var(--win-green)}
.cockpit__round-dot--loss{background:var(--loss-red);border-color:var(--loss-red)}
.cockpit__round-dot--draw{background:var(--text-3);border-color:var(--text-3)}
.cockpit__round-dot--open{background:var(--bg-surface);border-color:rgba(255,255,255,0.15)}
.cockpit__round-lbl{font-size:8px;text-align:center;margin-top:5px;line-height:1.25;padding:0 1px;color:var(--text-3);text-transform:uppercase;letter-spacing:.03em;width:100%;word-break:break-word;hyphens:manual}
.cockpit__round-lbl--active{color:var(--text-1);font-weight:700}
.cockpit__round-lbl--open{color:var(--text-3)}
.cockpit__round--out .cockpit__round-dot{opacity:.3}
.cockpit__round--out .cockpit__round-lbl{opacity:.3}
.cockpit__round--out::after{opacity:.2}

/* ===========================================
   BLOG LIST
   =========================================== */
.blog-section{padding:24px 0 0;border-top:1px solid var(--border);margin-top:24px}
.blog-section--top{border-top:none;margin-top:0;padding-top:0}
.blog-list{display:flex;flex-direction:column;gap:0}
.blog-list--card{border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}
.blog-item{display:flex;gap:12px;padding:14px 0;border-bottom:1px solid var(--border);text-decoration:none;color:inherit;transition:opacity .2s}
.blog-item:last-child{border-bottom:0}
.blog-item:hover{opacity:.8}
.blog-item--card{display:flex;gap:0;padding:0;border-bottom:1px solid var(--border);position:relative;transition:background .15s}
.blog-item--card:last-child{border-bottom:none}
.blog-item--card:hover{opacity:1;background:rgba(255,255,255,0.03)}
.blog-item--card:hover .blog-title{color:var(--bvb-yellow)}
.blog-item--card .blog-title{transition:color .15s}
.blog-accent{width:3px;flex-shrink:0;background:transparent}
.blog-item--top .blog-accent{background:var(--bvb-yellow)}
.blog-item--new .blog-accent{background:#3b82f6}
.blog-item--card .blog-thumb{width:72px;height:auto;min-height:68px;border-radius:0;flex-shrink:0}
.blog-item--card .blog-thumb img{height:100%;min-height:68px}
.blog-item--card .blog-body{padding:10px 12px;flex:1;min-width:0}
.blog-thumb{width:72px;height:52px;border-radius:var(--radius-sm);background:var(--bg-surface);flex-shrink:0;overflow:hidden}
.blog-thumb img{width:100%;height:100%;object-fit:cover}
.blog-body{min-width:0;flex:1}
.blog-title{font-size:14px;font-weight:500;color:var(--text-1);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.blog-excerpt{font-size:12px;color:var(--text-2);margin-top:3px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}
.blog-meta{font-size:11px;color:var(--text-3);margin-top:2px}
.blog-cat{font-size:9px;letter-spacing:1.2px;text-transform:uppercase;color:var(--text-3);font-weight:600;margin-bottom:3px}
.blog-badge{position:absolute;top:8px;right:8px;font-size:8px;font-weight:700;letter-spacing:0.4px;padding:2px 6px;border-radius:3px;text-transform:uppercase;line-height:1.4}
.blog-badge--top{background:var(--bvb-yellow);color:#000}
.blog-badge--new{background:#3b82f6;color:#fff}
.blog-more{display:block;text-align:center;margin-top:16px}
.blog-more span{font-size:13px;font-weight:500;color:var(--text-2);padding:8px 20px;border:1px solid var(--border);border-radius:var(--radius-full);display:inline-block;transition:all .2s}
.blog-more:hover span{border-color:var(--bvb-yellow);color:var(--bvb-yellow)}

/* ===========================================
   SINGLE POST
   =========================================== */
.single-header{padding:24px 0 16px}
.single-cat{display:inline-block;background:rgba(253,225,0,0.12);color:var(--bvb-yellow);border:1px solid rgba(253,225,0,0.2);font-size:0.65rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;padding:3px 10px;border-radius:3px;margin-bottom:8px}
.single-title{font-family:var(--font-heading);font-size:1.6rem;font-weight:700;color:var(--text-1);line-height:1.3;margin-bottom:0.75rem}
@media(min-width:480px){.single-title{font-size:1.8rem}}
.single-meta{font-size:0.8rem;color:var(--text-3);margin-bottom:1.75rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}
.single-image{border-radius:var(--radius-sm) var(--radius-sm) 0 0;overflow:hidden;margin-bottom:1.5rem}
.single-content{font-size:0.975rem;line-height:1.75}
.single-content h2{font-family:var(--font-heading);font-size:1.2rem;font-weight:700;color:var(--text-1);margin:2.25rem 0 1rem;padding-bottom:0.4rem;border-bottom:2px solid var(--bvb-yellow)}
.single-content h3{font-family:var(--font-heading);font-size:1rem;font-weight:700;margin:1.5rem 0 0.5rem;color:var(--text-1)}
.single-content p{margin-bottom:1.25rem;color:var(--text-2)}
.single-content ul,.single-content ol{margin:0 0 1.25rem 1.5rem;font-size:0.975rem;list-style:disc}
.single-content ol{list-style:decimal}
.single-content li{margin-bottom:0.3rem}
.single-content a:not(.tv-badge):not(.bvbsp-btn){color:var(--bvb-yellow);text-decoration:underline;text-decoration-color:rgba(253,225,0,0.35);text-underline-offset:2px}
.single-content a:not(.tv-badge):not(.bvbsp-btn):hover{color:#fff;text-decoration-color:rgba(255,255,255,0.4)}
.single-content blockquote{border-left:3px solid var(--bvb-yellow);padding-left:16px;margin:24px 0;color:var(--text-2);font-style:italic}
.single-content img{border-radius:var(--radius-md);margin:24px 0}

/* Tabellen */
.single-content table,.page-content table{width:100%;border-collapse:collapse;margin:16px 0 24px;font-size:14px}
.single-content thead,.page-content thead{background:var(--bg-surface);display:table-header-group}
.single-content th,.page-content th{padding:8px 14px;font-size:11px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.3px;text-align:left;border-bottom:1px solid var(--border)}
.single-content td,.page-content td{padding:11px 14px;vertical-align:middle;color:var(--text-1);border-bottom:1px solid var(--border)}
/* Letzte Zeile: untere Linie beibehalten (Tabellenrahmen-Abschluss) */
.single-content tr:hover td,.page-content tr:hover td{background:rgba(253,225,0,0.04)}
.single-content td a:not(.btf-broadcaster),.page-content td a:not(.btf-broadcaster){color:var(--bvb-yellow);font-weight:500}
.single-content td a:not(.btf-broadcaster):hover,.page-content td a:not(.btf-broadcaster):hover{color:#fff}

/* ===========================================
   PAGE
   =========================================== */
.page-header{padding:24px 0 16px}
.page-title{font-family:var(--font-heading);font-size:1.6rem;font-weight:700;line-height:1.3;color:var(--text-1)}
@media(min-width:480px){.page-title{font-size:1.8rem}}
.page-content{padding-bottom:48px;font-size:0.975rem;line-height:1.75}
.page-content p{margin-bottom:1.25rem;color:var(--text-2)}
.page-content h2{font-family:var(--font-heading);font-size:1.2rem;font-weight:700;color:var(--text-1);margin:2.25rem 0 1rem;padding-bottom:0.4rem;border-bottom:2px solid var(--bvb-yellow)}
.page-content h3{font-family:var(--font-heading);font-size:1rem;font-weight:700;margin:1.5rem 0 0.5rem;color:var(--text-1)}
.page-content a:not(.tv-badge):not(.bvbsp-btn){color:var(--bvb-yellow);text-decoration:underline;text-underline-offset:2px}
.page-content a:not(.tv-badge):not(.bvbsp-btn):hover{color:#fff}

/* Kontaktformular */
.contact-form{max-width:420px}
.contact-form label{display:block;font-size:13px;font-weight:600;color:var(--text-2);margin-bottom:4px}
.contact-form input,.contact-form textarea{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-surface);color:var(--text-1);font-family:var(--font);font-size:14px;margin-bottom:14px;transition:border-color .2s}
.contact-form input:focus,.contact-form textarea:focus{outline:0;border-color:rgba(253,225,0,0.4)}
.contact-form textarea{min-height:120px;resize:vertical}

.btn{display:inline-block;padding:10px 24px;background:var(--bvb-yellow);color:var(--bvb-black);font-weight:700;font-size:14px;border:0;border-radius:var(--radius-full);cursor:pointer;transition:background .2s,transform .1s}
.btn:hover{background:var(--bvb-yellow-light);color:var(--bvb-black)}
.btn:active{transform:scale(.98)}

/* ===========================================
   FOOTER – 2.0: CTA-Strip + Grid
   =========================================== */

/* CTA-Strip direkt vor dem Footer */
.footer-cta-strip{
  background:var(--bg-card);
  border-top:1px solid var(--border);
  padding:14px 24px;
  display:flex;align-items:center;justify-content:space-between;
  gap:12px;flex-wrap:wrap;
}
.footer-cta-strip p{font-size:13px;color:var(--text-3)}
.footer-cta-btn{
  font-size:13px;font-weight:700;
  background:var(--bvb-yellow);color:#111;
  border:none;padding:8px 20px;
  border-radius:var(--radius-sm);cursor:pointer;
  white-space:nowrap;transition:opacity .2s;
}
.footer-cta-btn:hover{opacity:.85}

.site-footer{background:var(--bvb-black);border-top:2px solid var(--bvb-yellow);padding:32px 0 24px;margin-top:48px}
.site-footer .container{max-width:var(--container)}
.footer-grid{display:grid;grid-template-columns:1fr;gap:24px}
@media(min-width:480px){.footer-grid{grid-template-columns:2fr 1fr}}

.footer-brand{font-family:var(--font-heading);font-size:16px;font-weight:700;color:#fff;margin-bottom:6px}
.footer-brand span{color:var(--bvb-yellow)}
.footer-desc{font-size:13px;color:#777;line-height:1.5}
.footer-heading{font-size:12px;font-weight:700;color:#888;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}
.footer-links li{margin-bottom:6px}
.footer-links a{color:#777;font-size:13px;transition:color .2s}
.footer-links a:hover{color:var(--bvb-yellow)}

.footer-support{margin-top:20px;padding:14px 16px;background:rgba(253,225,0,0.06);border:1px solid rgba(253,225,0,0.12);border-radius:var(--radius-md)}
.footer-support__text{font-size:13px;color:#999;line-height:1.5;margin-bottom:8px}
.footer-support__link{font-size:13px;font-weight:600;color:var(--bvb-yellow);transition:opacity .2s}
.footer-support__link:hover{opacity:.8}
.footer-support__link svg{vertical-align:middle;margin-right:4px}

.footer-bottom{margin-top:24px;padding-top:16px;border-top:1px solid rgba(255,255,255,0.06);display:flex;flex-wrap:wrap;justify-content:space-between;gap:8px;font-size:12px;color:#555}
.footer-bottom a{color:#666;transition:color .2s}
.footer-bottom a:hover{color:var(--bvb-yellow)}

/* ===========================================
   HEADER SOCIAL
   =========================================== */
.header-social{display:flex;align-items:center;gap:4px}
@media(min-width:640px){.header-social{display:none}}
.header-social__icon{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:var(--radius-sm);background:rgba(255,255,255,0.07);transition:background .2s}
.header-social__icon svg{width:18px;height:18px;transition:fill .2s,stroke .2s}
.header-social__icon:hover{background:rgba(253,225,0,0.15)}
.header-social__icon:hover svg{fill:var(--bvb-yellow);stroke:var(--bvb-yellow)}
.header-social__icon--support{background:rgba(253,225,0,0.12)}
.header-social__icon--support svg{fill:var(--bvb-yellow);width:16px;height:16px}
.header-social__icon--support:hover{background:rgba(253,225,0,0.25)}

/* ===========================================
   PAGINATION
   =========================================== */
.pagination{display:flex;justify-content:center;gap:6px;padding:24px 0}
.pagination a,.pagination span{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 10px;border:1px solid var(--border);background:var(--bg-surface);border-radius:var(--radius-md);font-size:14px;font-weight:500;color:var(--text-2);transition:all .2s}
.pagination a:hover{border-color:var(--bvb-yellow);color:var(--bvb-yellow)}
.pagination .current{background:var(--bvb-yellow);border-color:var(--bvb-yellow);color:#111;font-weight:700}

/* ===========================================
   COMMENTS
   =========================================== */
.comments-area{margin-top:32px;padding-top:24px;border-top:1px solid var(--border)}
.comments-title{font-size:18px;font-weight:700;margin-bottom:20px}
.comment-list{list-style:none}
.comment-body{padding:14px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:12px}
.comment-author{font-weight:600;font-size:14px;margin-bottom:4px}
.comment-author .fn{color:var(--text-1)}
.comment-metadata,.comment-metadata a{color:var(--text-3);font-size:12px}
.comment-content p{color:var(--text-2);font-size:14px;line-height:1.7}

/* ===========================================
   404
   =========================================== */
.page-404{text-align:center;padding:64px 0}

/* ===========================================
   SOCIAL CTA
   =========================================== */
.social-cta{margin:32px 0 0;padding:20px 24px;background:var(--bvb-black);border-left:3px solid var(--bvb-yellow);border-radius:var(--radius-md)}
.social-cta__text{display:block;font-size:14px;font-weight:700;color:var(--bvb-yellow);margin-bottom:10px}
.social-cta__links{display:flex;gap:8px;flex-wrap:wrap}
.social-cta__link{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:600;color:#fff;background:rgba(255,255,255,0.08);border-radius:var(--radius-full);transition:all .2s;white-space:nowrap}
.social-cta__link svg{width:16px;height:16px;fill:#fff;stroke:#fff}
.social-cta__link:hover{background:var(--bvb-yellow);color:var(--bvb-black)}
.social-cta__link:hover svg{fill:var(--bvb-black);stroke:var(--bvb-black)}

/* ===========================================
   BREADCRUMB
   =========================================== */
.breadcrumb{font-size:12px;color:var(--text-3);padding:16px 0 0}
.breadcrumb a{color:var(--text-3);transition:color .2s}
.breadcrumb a:hover{color:var(--bvb-yellow)}
.breadcrumb span{margin:0 6px}

/* ===========================================
   INFO BOX
   =========================================== */
.ucl-info-box{background:var(--bg-surface);border-left:4px solid var(--bvb-yellow);padding:1rem 1.25rem;margin:1.25rem 0 1.5rem;border-radius:0 var(--radius-md) var(--radius-md) 0;font-size:14px;line-height:1.7;color:var(--text-2);border-top:1px solid var(--border);border-right:1px solid var(--border);border-bottom:1px solid var(--border)}
.ucl-info-box strong{color:var(--text-1)}
.ucl-info-box a{color:var(--bvb-yellow);text-decoration:underline;text-decoration-color:rgba(253,225,0,0.35)}
.ucl-info-box a:hover{color:#fff}

/* ===========================================
   FAQ ACCORDION
   =========================================== */
.bvb-faq-wrap{max-width:100%;margin:2em 0 1em}
.bvb-faq-heading{font-family:var(--font-heading);font-size:1.15rem;font-weight:700;color:var(--text-1);margin:0 0 .8em;padding-bottom:.35em;border-bottom:3px solid var(--bvb-yellow)}
.bvb-faq-item{border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:8px;overflow:hidden}
.bvb-faq-question{width:100%;background:var(--bg-surface);border:none;padding:14px 16px;text-align:left;font-family:var(--font);font-size:.92rem;font-weight:600;color:var(--text-1);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:12px;transition:background .14s}
.bvb-faq-question:hover{background:var(--bg-pill)}
.bvb-faq-question[aria-expanded="true"]{background:rgba(253,225,0,0.08)}
.bvb-faq-icon{font-size:1.1rem;font-weight:400;color:var(--text-3);flex-shrink:0;transition:transform .2s;line-height:1}
.bvb-faq-question[aria-expanded="true"] .bvb-faq-icon{transform:rotate(45deg);color:var(--text-1)}
.bvb-faq-answer{padding:0 16px 14px;font-size:.88rem;color:var(--text-2);line-height:1.6;background:rgba(253,225,0,0.08);border-top:1px solid rgba(253,225,0,0.2);display:none}
.bvb-faq-answer.open{display:block}
.bvb-faq-item--plain .bvb-faq-answer{background:transparent;border-top:1px solid var(--border)}
.bvb-faq-item--plain .bvb-faq-question[aria-expanded="true"]{background:transparent}
.bvb-faq-answer a{color:var(--bvb-yellow);font-weight:600;text-decoration:underline}
.bvb-faq-answer a:hover{color:var(--text-1)}

/* ===========================================
   CONTENT CARD
   =========================================== */
.content-card{background:var(--bg-card);border-radius:var(--radius-sm);box-shadow:none;border:1px solid var(--border);padding:2rem 2.25rem}
@media(max-width:600px){.content-card{padding:1.25rem 1rem}}

/* ===========================================
   SUPPORT BOX
   =========================================== */
.bvb-support-box{margin:40px 0 24px;background:#111111;border-radius:10px;padding:24px 28px;border-left:4px solid #FDE100;box-sizing:border-box}
.bvb-support-inner{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.bvb-support-text{flex:1;min-width:200px}
.bvb-support-text strong{display:block;font-size:15px;font-weight:700;color:#FDE100;margin-bottom:5px}
.bvb-support-text span{font-size:13px;color:rgba(255,255,255,0.7);line-height:1.55}
.bvb-support-buttons{display:flex;gap:8px;flex-wrap:wrap;flex-shrink:0}
.bvb-support-buttons a{display:inline-flex;align-items:center;justify-content:center;padding:10px 18px;border-radius:6px;font-size:14px;font-weight:600;text-decoration:none;background:#FDE100;color:#111111;border:none;white-space:nowrap}
.bvb-support-buttons a:hover{background:#FDE100;color:#111111;text-decoration:none;opacity:.88}
@media(max-width:600px){.bvb-support-inner{flex-direction:column;align-items:flex-start;gap:14px}.bvb-support-buttons{width:100%}.bvb-support-buttons a{flex:1;text-align:center}}

/* ===========================================
   TAGS
   =========================================== */
.tags{display:flex;gap:0.5rem;margin-bottom:1rem;flex-wrap:wrap}
.tag{font-size:0.65rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;padding:3px 10px;border-radius:3px;color:#fff}
.tag-cl{background:#1e3a5f}
.tag-bvb{background:var(--bvb-black);color:var(--bvb-yellow)}
.tag-tv{background:#6c757d}
.tag-bl{background:#d4001a}
.tag-dfb{background:#2d6a4f}

/* ===========================================
   COMPETITION BADGES
   =========================================== */
.comp-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;color:#fff;text-decoration:none;white-space:nowrap}
.comp-badge--bundesliga{background:#d4001a}
.comp-badge--dfb{background:#2d6a4f}
.comp-badge--ucl{background:#1e3a5f}
.comp-badge--testspiel{background:#888}

/* ===========================================
   LAST UPDATED
   =========================================== */
.last-updated{font-size:small;text-transform:uppercase;color:#ffd900!important}

/* ===========================================
   TAXONOMY (Single Post)
   =========================================== */
.single-taxonomy{margin-top:24px;padding-top:16px;border-top:1px solid var(--border)}
.single-taxonomy__row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:8px}
.single-taxonomy__items{display:flex;gap:6px;flex-wrap:wrap}
.single-taxonomy__label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-3)}
.single-taxonomy__tag{display:inline-block;font-size:12px;font-weight:600;padding:3px 10px;border-radius:var(--radius-full);background:var(--bg-surface);color:var(--text-2);border:1px solid var(--border);text-decoration:none;transition:all .2s}
.single-taxonomy__tag:hover{border-color:var(--bvb-yellow);color:var(--bvb-yellow)}
.single-taxonomy__tag--outline{background:transparent}

/* ===========================================
   ARCHIVE
   =========================================== */
.archive-desc{font-size:0.9rem;color:var(--text-2);margin-top:0.5rem;line-height:1.6}

/* ===========================================
   SPIELPLAN-SHORTCODE (bvbsp-*)
   Vollständig kompatibel, kein API-Bruch
   =========================================== */
.bvbsp-wrap{font-size:15px;color:var(--text-1);max-width:100%;margin:0 auto 2em;line-height:1.5}
.bvbsp-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:1.4em}
.bvbsp-table{width:100%;border-collapse:collapse;font-size:.9rem;background:var(--bg-card)}
.bvbsp-table thead{background:var(--bg-surface)}
.bvbsp-table thead th{color:var(--text-3);font-size:.75rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;padding:10px 14px;text-align:left;white-space:nowrap;border-bottom:1px solid var(--border)}
.bvbsp-table tbody tr{border-bottom:1px solid var(--border);transition:background .14s}
.bvbsp-table tbody tr:last-child{border-bottom:none}
.bvbsp-table tbody tr:nth-child(even){background:var(--bg-surface)}
.bvbsp-table tbody tr:hover{background:rgba(253,225,0,0.05)}
.bvbsp-table td{padding:11px 14px;vertical-align:middle;white-space:nowrap;color:var(--text-1)}
.bvbsp-td-date{font-weight:700;color:var(--text-1);min-width:96px;font-size:.88rem}
.bvbsp-td-time{color:var(--text-3);font-size:.85rem;min-width:68px}
.bvbsp-match{display:flex;align-items:center;gap:8px;flex-wrap:wrap;min-width:230px}
.bvbsp-team{font-weight:600;font-size:.92rem;color:var(--text-1)}
.bvbsp-team-bvb{color:var(--bvb-yellow);font-weight:700}
.bvbsp-vs{font-size:.7rem;font-weight:700;color:var(--text-3);letter-spacing:.06em;flex-shrink:0}
.bvbsp-td-tv{font-size:.82rem;font-weight:600;color:var(--text-2);white-space:nowrap}
.bvbsp-legend{display:flex;gap:14px;flex-wrap:wrap;margin:.6em 0 1.4em;padding:8px 12px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm)}
.bvbsp-legend[hidden]{display:none}
.bvbsp-legend-item{display:flex;align-items:center;gap:6px;font-size:.76rem;color:var(--text-2);font-weight:500}
.bvbsp-dot{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0}
.bvbsp-dot.dot-bl{background:var(--bvb-yellow);border:1px solid rgba(255,255,255,.2)}
.bvbsp-dot.dot-ucl{background:#4a90e2}
.bvbsp-dot.dot-dfb{background:#d32f2f}
.bvbsp-dot.dot-dfl{background:#8800ff}
.bvbsp-dot.dot-rel{background:var(--text-3)}
.bvbsp-dot.dot-test{background:#666}
.bvbsp-dot.dot-default{background:var(--text-3)}
.bvbsp-cal-box{background:var(--bg-surface);border:1px solid var(--border);border-left:4px solid var(--bvb-yellow);border-radius:var(--radius-md);padding:16px 18px;margin:1.4em 0 0;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:14px}
.bvbsp-cal-box__text{flex:1;min-width:240px}
.bvbsp-cal-box__text p{margin:0;font-size:.88rem;color:var(--text-2);line-height:1.5}
.bvbsp-cal-box__text strong{color:var(--text-1)}
.bvbsp-btn-group{display:flex;gap:8px;flex-wrap:wrap}
.bvbsp-btn{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border-radius:var(--radius-sm);font-size:.82rem;font-weight:700;letter-spacing:.02em;text-decoration:none;transition:opacity .15s,transform .15s;white-space:nowrap;cursor:pointer}
.bvbsp-btn:hover{opacity:.88;transform:translateY(-1px)}
.bvbsp-btn-primary{background:var(--bvb-yellow);color:#111;border:2px solid transparent}
.bvbsp-btn-secondary{background:transparent;color:var(--bvb-yellow);border:2px solid var(--bvb-yellow)}
.bvbsp-section-heading{font-family:var(--font-heading);font-size:1.2rem;font-weight:700;color:var(--text-1);margin:2rem 0 1rem;padding-bottom:.4rem;border-bottom:2px solid var(--bvb-yellow)}
.bvbsp-source{font-size:.74rem;color:var(--text-3);margin:.6em 0 0;text-align:right}
.bvbsp-source a{color:var(--text-3);text-decoration:underline}
.bvbsp-loading{padding:20px 14px;color:var(--text-3);font-size:.88rem}
.bvbsp-updated{font-size:.74rem;color:var(--text-3);margin:.6em 0 0;text-align:right}
.bvbsp-list .match-card__teams .bvb-name{color:var(--bvb-yellow);font-weight:700}
.bvbsp-list .bvbsp-loading{color:var(--text-3);font-size:13px;padding:16px 0}

@media(max-width:600px){
  .bvbsp-table-wrap{border:none;border-radius:0}
  .bvbsp-table thead{display:none}
  .bvbsp-table,.bvbsp-table tbody{display:block}
  .bvbsp-table tbody tr{display:block;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:8px;padding:10px 12px}
  .bvbsp-table tbody tr:nth-child(even),.bvbsp-table tbody tr:hover{background:var(--bg-card)}
  .bvbsp-table td{display:block;padding:0;white-space:normal;border:none}
  .bvbsp-table td+td{margin-top:4px}
  .bvbsp-td-date,.bvbsp-td-time{display:inline;font-size:.78rem}
  .bvbsp-td-time{margin-left:4px}
  .bvbsp-match{min-width:0;font-size:.88rem}
  .bvbsp-td-tv{font-size:.8rem}
  .bvbsp-cal-box{flex-direction:column;align-items:flex-start}
}

/* ===========================================
   TV-FILTER (btf-*)
   =========================================== */
.bvb-tv-filter{font-family:inherit;color:var(--text-1)}
.btf-controls{display:flex;flex-wrap:wrap;gap:16px;align-items:center;margin-bottom:16px;padding:16px;background:var(--bg-surface);border-radius:var(--radius-md)}
.btf-group{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.btf-pill{appearance:none;background:transparent;border:1px solid var(--border-hover);color:var(--text-2);padding:7px 14px;border-radius:var(--radius-full);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;font-family:inherit}
.btf-pill:hover{border-color:var(--text-1);color:var(--text-1)}
.btf-pill.is-active{background:var(--bvb-yellow);color:#111;border-color:var(--bvb-yellow);font-weight:700}
.btf-select{appearance:none;-webkit-appearance:none;background:var(--bg-card) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23666' d='M6 8L0 0h12z'/%3E%3C/svg%3E") no-repeat right 12px center;border:1px solid var(--border-hover);color:var(--text-1);padding:8px 32px 8px 12px;border-radius:var(--radius-sm);font-size:13px;font-family:inherit;cursor:pointer}
.btf-toggle{display:inline-flex;align-items:center;gap:8px;cursor:pointer;font-size:13px;user-select:none;color:var(--text-2)}
.btf-toggle input{width:16px;height:16px;accent-color:var(--bvb-yellow)}
.btf-meta{font-size:12px;color:var(--text-3);margin-bottom:8px;text-transform:uppercase;letter-spacing:.05em}
.btf-table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius-md)}
.btf-table{width:100%;border-collapse:collapse;font-size:14px}
.btf-table th{text-align:left;padding:12px 16px;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-3);background:var(--bg-surface);border-bottom:1px solid var(--border);white-space:nowrap}
.btf-table td{padding:14px 16px;border-bottom:1px solid var(--border);vertical-align:middle;color:var(--text-1)}
.btf-table tr:last-child td{border-bottom:none}
.btf-table tr:hover td{background:rgba(253,225,0,0.04)}
.btf-date{font-variant-numeric:tabular-nums;font-weight:600;white-space:nowrap;color:var(--text-1)}
.btf-kickoff{color:var(--text-3);font-size:13px;margin-top:2px}
.btf-fixture{font-weight:500;color:var(--text-1)}
.btf-fixture strong{font-weight:700}
.btf-broadcasters{display:flex;flex-wrap:wrap;gap:6px}
.bvb-tv-filter .btf-th-team,.bvb-tv-filter .btf-cell-team,.bvb-tv-filter .btf-team-tag{display:none}
.btf-loading{text-align:center;padding:32px;color:var(--text-3)}
.btf-error-row td{text-align:center;padding:24px;background:rgba(220,38,38,0.1);color:#f87171;font-weight:600}
.btf-empty{text-align:center;padding:40px 16px;color:var(--text-3)}
.btf-empty p{margin:0 0 12px}
.btf-reset{appearance:none;background:var(--bvb-yellow);color:#111;border:none;padding:8px 16px;border-radius:var(--radius-sm);font-size:13px;font-weight:700;cursor:pointer;font-family:inherit}

@media(max-width:640px){
  .btf-controls{flex-direction:column;align-items:stretch}
  .btf-group{width:100%}
  .btf-select{flex:1}
  .btf-table-wrap{overflow-x:visible;border:none;border-radius:0;background:transparent}
  .btf-table{display:block;font-size:14px}
  .btf-table thead{display:none}
  .btf-table tbody{display:block}
  .btf-table tr{display:block;background:var(--bg-card);border:1px solid var(--border);border-top:3px solid var(--bvb-yellow);border-radius:var(--radius-md);padding:14px 16px;margin-bottom:14px}
  .btf-table tr:hover td{background:transparent}
  .bvb-tv-filter .btf-table td{display:block;padding:6px 0;border:none;border-radius:0;background:transparent}
  .bvb-tv-filter .btf-table td:first-child{padding-top:0;padding-bottom:10px;margin-bottom:10px;border-bottom:1px solid var(--border)}
  .btf-table tr:last-child{margin-bottom:0}
}

/* ===========================================
   SAISON-STATISTIK (bvbst-*)
   =========================================== */
.bvbst-toggle-row{display:flex;gap:4px;margin-bottom:16px}
.bvbst-tog{font-size:12px;font-weight:600;padding:6px 16px;border-radius:var(--radius-full);border:1px solid var(--border);color:var(--text-2);cursor:pointer;background:transparent;font-family:var(--font);transition:all .15s}
.bvbst-tog--active{background:rgba(253,225,0,0.12);border-color:rgba(253,225,0,0.3);color:var(--bvb-yellow)}
.bvbst-more-link{display:block;text-align:center;padding:12px;font-size:12px;font-weight:600;color:var(--text-2);border-top:1px solid var(--border);margin-top:4px;text-decoration:none;transition:color .2s}
.bvbst-more-link:hover{color:var(--bvb-yellow)}
.bvbst-divider{border-top:2px solid var(--bvb-yellow);margin:28px 0 0}
.bvbst-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:8px;margin-bottom:20px}
.bvbst-stat-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px}
.bvbst-stat-val{font-family:var(--font-heading);font-size:22px;font-weight:700;color:var(--text-1);line-height:1}
.bvbst-stat-lbl{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-3);margin-top:5px}
.bvbst-stat-prev{font-size:11px;color:var(--text-3);margin-top:4px;display:flex;align-items:center;gap:5px;flex-wrap:wrap}
.bvbst-arrow--up{display:inline-block;width:0;height:0;flex-shrink:0;border-left:5px solid transparent;border-right:5px solid transparent;border-bottom:7px solid var(--win-green)}
.bvbst-arrow--down{display:inline-block;width:0;height:0;flex-shrink:0;border-left:5px solid transparent;border-right:5px solid transparent;border-top:7px solid var(--loss-red)}
.bvbst-arrow--neu{display:inline-block;width:8px;height:2px;background:var(--text-3);flex-shrink:0}
.bvbst-trend--up{color:var(--win-green)}
.bvbst-trend--down{color:var(--loss-red)}
.bvbst-result{font-size:12px;font-weight:700;padding:2px 8px;border-radius:4px;display:inline-block}
.result-w{background:rgba(29,158,117,0.15);color:#4caf50}
.result-u{background:rgba(100,100,100,0.2);color:var(--text-3)}
.result-n{background:rgba(211,47,47,0.15);color:#ef5350}
.bvbst-chart-section{margin-bottom:20px}
.bvbst-chart-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-3);margin-bottom:10px}
.bvbst-bar-row{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.bvbst-bar-key{font-size:11px;color:var(--text-2);width:110px;flex-shrink:0;text-align:right;line-height:1.3}
.bvbst-bar-wrap{flex:1;background:var(--bg-pill);border-radius:2px;height:20px;overflow:hidden}
.bvbst-bar-fill{height:100%;border-radius:2px;background:var(--bvb-yellow);display:flex;align-items:center;padding-left:6px;min-width:24px;transition:width .5s ease-out}
.bvbst-bar-fill span{font-size:11px;font-weight:700;color:#000}
.bvbst-bar-val{font-size:12px;color:var(--text-2);width:28px;flex-shrink:0}
.bvbst-sender-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:8px}
.bvbst-sender-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:10px 12px;display:flex;align-items:center;gap:10px}
.bvbst-sender-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.bvbst-sender-name{font-size:12px;font-weight:600;color:var(--text-1);flex:1}
.bvbst-sender-count{font-size:13px;font-weight:700;color:var(--bvb-yellow)}
.bvbst-disclaimer{font-size:11px;color:var(--text-3);margin-top:16px;padding-top:12px;border-top:1px solid var(--border);line-height:1.5}

/* ===========================================
   SPIELPLAN HINT
   =========================================== */
.spielplan-hint{margin-top:12px;text-align:center}
.spielplan-hint a{font-size:13px;font-weight:500;color:var(--text-2);padding:8px 20px;border:1px solid var(--border);border-radius:var(--radius-full);display:inline-block;transition:all .2s}
.spielplan-hint a:hover{border-color:var(--bvb-yellow);color:var(--bvb-yellow)}

/* ===========================================
   TV-BRIEFING
   =========================================== */
.bvb-tv-briefing{background:#161616;border-top:4px solid var(--bvb-yellow);border-radius:var(--radius-md);padding:24px;margin:24px 0;font-family:var(--font);color:var(--text-1);line-height:1.5}
.bvb-tv-header{margin-bottom:20px}
.bvb-tv-meta{font-size:11px;letter-spacing:1.5px;color:var(--text-3);text-transform:uppercase;margin:0 0 6px}
.bvb-tv-title{font-family:var(--font-heading);font-size:22px;font-weight:700;color:var(--text-1);margin:0;padding-bottom:8px;border-bottom:3px solid var(--bvb-yellow);display:inline-block}
.bvb-tv-strip{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-bottom:24px}
.bvb-day{text-align:center;padding:10px 4px;border-radius:4px;background:var(--bg-surface)}
.bvb-day--game{background:var(--bvb-yellow)}
.bvb-day__name{display:block;font-size:10px;font-weight:600;letter-spacing:0.5px;color:var(--text-3)}
.bvb-day__date{display:block;font-family:var(--font-heading);font-size:14px;color:var(--text-3);margin-top:2px}
.bvb-day--game .bvb-day__name,.bvb-day--game .bvb-day__date{color:#111}
.bvb-day--game .bvb-day__date{font-weight:700}
.bvb-day__dots{display:flex;justify-content:center;gap:3px;margin-top:4px}
.bvb-dot{width:5px;height:5px;background:#111;border-radius:50%}
.bvb-tv-games{list-style:none;margin:0;padding:0}
.bvb-game{display:flex;gap:14px;align-items:center;padding:12px 0;border-bottom:1px solid var(--border)}
.bvb-game:last-child{border-bottom:none;padding-bottom:0}
.bvb-game__when{background:var(--bg-surface);color:var(--text-1);padding:8px 10px;border-radius:4px;min-width:64px;text-align:center;flex-shrink:0;border:1px solid var(--border)}
.bvb-game__day{display:block;font-size:10px;letter-spacing:0.5px;color:var(--text-3);opacity:.85}
.bvb-game__time{display:block;font-family:var(--font-heading);font-size:14px;font-weight:700;margin-top:2px;color:var(--text-1)}
.bvb-game__main{flex:1;min-width:0}
.bvb-game__pairing{font-size:15px;font-weight:600;color:var(--text-1);margin:0 0 5px}
.bvb-game__tags{display:flex;flex-wrap:wrap;gap:6px;margin:0}
.bvb-tag{display:inline-block;font-size:11px;padding:2px 8px;border-radius:3px;font-weight:500;line-height:1.5}
.bvb-tag--comp{background:#444;color:#fff}
.bvb-tag--bl{background:#D3091F;color:#fff}
.bvb-tag--cl{background:#0D2240;color:#fff}
.bvb-tag--pokal{background:#333;color:#fff}
.bvb-tag--test{background:#6f7d8a;color:#fff}
.bvb-tag--sky{background:#0089D4;color:#fff}
.bvb-tag--dazn{background:#000;color:#FDE100}
.bvb-tag--magenta{background:#E20074;color:#fff}
.bvb-tag--rtl{background:#ED1C24;color:#fff}
.bvb-tag--ard{background:#001E78;color:#fff}
.bvb-tag--zdf{background:#DC6800;color:#fff}
.bvb-tag--prime{background:#00A8E1;color:#fff}
.bvb-tag--dfbtv{background:#444;color:#fff}

/* ===========================================
   UCL COMPONENTS (CL-Artikel)
   =========================================== */
.ucl-keyfacts{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--border);border-radius:10px;overflow:hidden;margin:1.25rem 0 1.75rem}
.ucl-keyfact{padding:1rem 1.25rem;border-right:1px solid var(--border);background:var(--bg-surface)}
.ucl-keyfact:last-child{border-right:none}
.ucl-keyfact-label{font-size:11px;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-3);font-weight:600;margin-bottom:2px}
.ucl-keyfact-value{font-family:var(--font-heading);font-size:15px;font-weight:700;color:var(--bvb-yellow)}
@media(max-width:540px){.ucl-keyfacts{grid-template-columns:1fr 1fr}.ucl-keyfact{border-bottom:1px solid var(--border)}}

.ucl-modus-flow{display:flex;align-items:stretch;margin:1.5rem 0;gap:2px}
.ucl-modus-step{flex:1;text-align:center;padding:14px 8px;background:var(--bg-surface);border:1px solid var(--border)}
.ucl-modus-step:first-child{border-radius:8px 0 0 8px}
.ucl-modus-step:last-child{border-radius:0 8px 8px 0}
.ucl-modus-step.ucl-active{background:var(--bvb-black);border-color:var(--bvb-yellow)}
.ucl-modus-num{font-family:var(--font-heading);font-size:20px;font-weight:700;color:var(--text-2)}
.ucl-modus-label{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--text-3);font-weight:600}
.ucl-modus-step.ucl-active .ucl-modus-num{color:var(--bvb-yellow)}
.ucl-modus-step.ucl-active .ucl-modus-label{color:rgba(255,255,255,0.7)}
.ucl-modus-arrow{display:flex;align-items:center;color:var(--text-3);font-size:16px;padding:0 2px}
@media(max-width:540px){.ucl-modus-flow{flex-direction:column}.ucl-modus-step{border-radius:0}.ucl-modus-step:first-child{border-radius:8px 8px 0 0}.ucl-modus-step:last-child{border-radius:0 0 8px 8px}.ucl-modus-arrow{justify-content:center;transform:rotate(90deg)}}

.ucl-timeline{position:relative;margin:1.25rem 0 1.75rem;padding-left:1.5rem}
.ucl-timeline::before{content:'';position:absolute;left:5px;top:4px;bottom:4px;width:2px;background:var(--border)}
.ucl-tl-item{position:relative;padding-bottom:0.85rem;display:flex;gap:0.75rem;align-items:baseline}
.ucl-tl-item::before{content:'';position:absolute;left:-1.5rem;top:6px;width:8px;height:8px;border-radius:50%;background:var(--bvb-yellow);border:2px solid var(--bg-body);z-index:1}
.ucl-tl-date{font-weight:700;font-size:13px;color:var(--bvb-yellow);min-width:155px;flex-shrink:0}
.ucl-tl-text{font-size:14px;color:var(--text-2)}
.ucl-tl-item.ucl-tl-finale .ucl-tl-date{color:var(--text-1)}
.ucl-tl-item.ucl-tl-finale .ucl-tl-text{color:var(--text-1);font-weight:600}
@media(max-width:540px){.ucl-tl-item{flex-direction:column;gap:1px}.ucl-tl-date{min-width:unset}}

.ucl-tv-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin:1rem 0 1.5rem}
.ucl-tv-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:10px;padding:1rem 1.25rem}
.ucl-tv-provider{font-size:15px;font-weight:600;color:var(--text-1);margin-bottom:4px}
.ucl-tv-detail{font-size:13px;color:var(--text-2);line-height:1.6}

.ucl-q-wrap{padding:1.25rem 0}
.ucl-q-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.ucl-q-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:10px;overflow:hidden}
.ucl-q-header{padding:9px 14px;font-size:13px;font-weight:500;display:flex;align-items:center;justify-content:space-between;background:var(--bg-pill);color:var(--text-1);border-bottom:1px solid var(--border)}
.ucl-q-header .ucl-q-flag{font-size:15px;line-height:1;flex-shrink:0}
.ucl-q-header .ucl-q-nation{flex:1;margin-left:8px}
.ucl-q-progress{font-size:11px;font-weight:500;background:transparent;color:var(--text-2);border:1px solid var(--border);border-radius:3px;padding:1px 6px;white-space:nowrap}
.ucl-q-teams{list-style:none;margin:0;padding:0}
.ucl-q-teams li{font-size:13px;color:var(--text-1);padding:7px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px}
.ucl-q-teams li:last-child{border-bottom:none}
.ucl-q-teams li.ucl-confirmed{font-weight:500}
.ucl-q-placeholder{color:var(--text-3);font-style:italic}
.ucl-pot-badge{font-size:10px;background:var(--bg-card);color:var(--text-2);border:1px solid var(--border);border-radius:3px;padding:1px 5px;margin-left:auto;white-space:nowrap;font-weight:400}
.ucl-bvb-badge{font-size:10px;background:var(--bvb-yellow);color:#111;border-radius:3px;padding:1px 6px;margin-left:auto;letter-spacing:0.3px;font-weight:600}
.ucl-q-note{font-size:12px;color:var(--text-3);margin-top:14px;line-height:1.6}
@media(max-width:540px){.ucl-q-grid{grid-template-columns:1fr}}

.ucl-pots-wrap{padding:1.25rem 0}
.ucl-pots{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.ucl-pot{background:var(--bg-surface);border:1px solid var(--border);border-radius:10px;overflow:hidden}
.ucl-pot-header{padding:9px 14px;font-size:13px;font-weight:500;display:flex;align-items:center;gap:8px}
.ucl-pot-header .ucl-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.ucl-pot.p1 .ucl-pot-header{background:rgba(24,95,165,0.15);color:#5b9bd5;border-bottom:1px solid rgba(24,95,165,0.2)}.ucl-pot.p1 .ucl-dot{background:#185FA5}
.ucl-pot.p2 .ucl-pot-header{background:rgba(59,109,17,0.15);color:#4ade80;border-bottom:1px solid rgba(59,109,17,0.2)}.ucl-pot.p2 .ucl-dot{background:#3B6D11}
.ucl-pot.p3 .ucl-pot-header{background:rgba(133,79,11,0.15);color:#fbbf24;border-bottom:1px solid rgba(133,79,11,0.2)}.ucl-pot.p3 .ucl-dot{background:#854F0B}
.ucl-pot.p4 .ucl-pot-header{background:rgba(153,60,29,0.15);color:#f87171;border-bottom:1px solid rgba(153,60,29,0.2)}.ucl-pot.p4 .ucl-dot{background:#993C1D}
.ucl-pot-teams{list-style:none;margin:0;padding:0}
.ucl-pot-teams li{font-size:13px;color:var(--text-1);padding:7px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px}
.ucl-pot-teams li:last-child{border-bottom:none}
.ucl-note{font-size:12px;color:var(--text-3);margin-top:12px}
@media(max-width:540px){.ucl-pots{grid-template-columns:1fr}}

/* ===========================================
   SUPPORT PAGE
   =========================================== */
.bvb-support-page__hero{text-align:center;padding:2rem 0 1.5rem}
.bvb-support-page__logo{font-family:var(--font-heading);font-size:0.85rem;font-weight:700;color:var(--text-3);text-transform:uppercase;letter-spacing:2px;margin-bottom:0.75rem}
.bvb-support-page__headline{font-family:var(--font-heading);font-size:1.6rem;font-weight:700;color:var(--text-1);margin-bottom:0.75rem;line-height:1.3}
.bvb-support-page__sub{font-size:0.95rem;color:var(--text-2);max-width:480px;margin:0 auto;line-height:1.7}
.bvb-support-page__options{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:1.5rem}
@media(max-width:540px){.bvb-support-page__options{grid-template-columns:1fr}}
.bvb-support-option{background:var(--bg-surface);border:1px solid var(--border);border-radius:10px;padding:1.5rem;text-align:center}
.bvb-support-option__icon{font-size:2rem;margin-bottom:0.5rem}
.bvb-support-option__title{font-family:var(--font-heading);font-size:1.05rem;font-weight:700;color:var(--text-1);margin-bottom:0.5rem}
.bvb-support-option__desc{font-size:0.875rem;color:var(--text-2);line-height:1.65;margin-bottom:1.25rem}
.bvb-btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 24px;border-radius:6px;font-size:14px;font-weight:700;text-decoration:none;transition:opacity .2s}
.bvb-btn:hover{opacity:.85;text-decoration:none}
.bvb-btn--yellow{background:#FDE100;color:#111}
.bvb-btn--dark{background:#1a1a1a;color:#fff;border:1px solid var(--border)}
.bvb-btn--full{width:100%}

/* ===========================================
   ARTIKEL-FOOTER
   =========================================== */
.article-footer{margin-top:2rem;padding-top:1rem;border-top:1px solid var(--border);font-size:0.8rem;color:var(--text-3)}

/* ===========================================
   VERGANGENE SPIELE (auto-dimmed)
   =========================================== */
tr.match-past td{opacity:.4}
tr.match-past:hover td{opacity:.7}

/* ===========================================
   LEGEND
   =========================================== */
.bvbsp-legend{display:flex;gap:16px;margin:12px 0;font-size:14px}
.bvbsp-legend-item{display:inline-flex;align-items:center;gap:6px}

/* ===========================================
   CSS KEEPALIVE (WP Rocket)
   =========================================== */
.bvbsp-css-keepalive{position:absolute;width:0;height:0;overflow:hidden;pointer-events:none}

/* ===========================================
   UTILITIES
   =========================================== */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
.alignleft{float:left;margin-right:16px}
.alignright{float:right;margin-left:16px}
.aligncenter{display:block;margin:0 auto}

