/*
Theme Name: BVB Spielplan Theme
Theme URI: https://bvb-spielplan.de
Author: BVB-Spielplan.de
Description: Mobile-first, utility-fokussiertes WordPress Theme für BVB-Spielplan.de.
Version: 4.0.1
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
*/

/* ===========================================
   TOKENS
   =========================================== */
:root {
  --bvb-yellow: #FDE100;
  --bvb-yellow-dark: #D4BC00;
  --bvb-yellow-light: #FFF176;
  --bvb-black: #1a1a1a;

  --bg-body: #f4f4f4;
  --bg-card: #fff;
  --bg-surface: #fafafa;
  --bg-pill: #f0f0f0;
  --text-1: #1a1a1a;
  --text-2: #555;
  --text-3: #999;
  --border: rgba(0,0,0,0.08);
  --border-hover: rgba(0,0,0,0.15);
  --shadow-card: 0 1px 3px rgba(0,0,0,0.08);

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

  --font: 'Open Sans', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-heading: 'Montserrat', sans-serif;
  --radius-sm: 6px;
  --radius-md: 10px;
  --radius-lg: 14px;
  --radius-full: 99px;
  --container: 560px;
  --nav-h: 52px;
}

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

@media (prefers-color-scheme: dark) {
  :root {
    --bg-body: #0d0d0d;
    --bg-card: #161616;
    --bg-surface: #1c1c1c;
    --bg-pill: #222;
    --text-1: #eee;
    --text-2: #aaa;
    --text-3: #666;
    --border: rgba(255,255,255,0.07);
    --border-hover: rgba(255,255,255,0.13);
    --shadow-card: 0 1px 3px rgba(0,0,0,0.3);
    --dazn-black: #f0f0f0;
  }
}

/* ===========================================
   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}

/* Override WordPress block editor width constraints */
.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
   =========================================== */
/* Topbar */
.topbar{height:4px;background:var(--bvb-yellow)}

/* Header */
.site-header{position:sticky;top:0;z-index:100;background:var(--bvb-black);border-bottom:none}
.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}
.site-logo{font-family:var(--font-heading);font-size:1.15rem;font-weight:800;color:#fff;white-space:nowrap;flex-shrink:0}
.site-logo span{color:var(--bvb-yellow)}
.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 heart */
.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}
}

/* ===========================================
   TEAM TABS
   =========================================== */
.team-tabs{display:flex;gap:5px;overflow-x:auto;scrollbar-width:none;padding:20px 0 4px;-webkit-overflow-scrolling:touch}
.team-tabs::-webkit-scrollbar{display:none}
.team-tab{padding:6px 14px;border-radius:var(--radius-full);font-size:12px;font-weight:500;white-space:nowrap;background:var(--bg-pill);color:var(--text-2);border:0;cursor:pointer;transition:all .2s;flex-shrink:0}
.team-tab:hover{background:var(--bg-surface);color:var(--text-1)}
.team-tab.active{background:var(--bvb-black);color:var(--bvb-yellow)}
@media(prefers-color-scheme:dark){
  .team-tab.active{background:var(--bvb-yellow);color:var(--bvb-black)}
}

/* ===========================================
   SECTION LABELS
   =========================================== */
.section-label{font-size:11px;color:var(--text-3);font-weight:600;letter-spacing:.3px;margin:20px 0 8px;text-transform:uppercase}
.section-label:first-child{margin-top:0}

/* ===========================================
   MATCH CARDS
   =========================================== */
.match-list{display:flex;flex-direction:column;gap:4px}

.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:500;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{text-align:right;flex-shrink:0;margin-left:12px}
.match-card__comp{font-size:10px;color:var(--text-3)}

/* TV Badges */
.tv-badges{display:flex;gap:4px;justify-content:flex-start;margin-top:4px;flex-wrap:wrap}
.tv-badge{padding:2px 8px!important;border-radius:4px!important;font-size:11px!important;font-weight:600!important;color:#fff!important;text-decoration:none!important;display:inline-block!important;transition:opacity .2s!important;background:var(--bg-surface)!important}
.tv-badge:hover{opacity:.8!important}
.tv-badge--sky{background:var(--sky-blue)!important;color:#fff!important}
.tv-badge--dazn{background:var(--dazn-black)!important;color:#fff!important}
@media(prefers-color-scheme:dark){.tv-badge--dazn{background:#f0f0f0!important;color:#111!important}}
.tv-badge--rtl{background:var(--rtl-red)!important;color:#fff!important}
.tv-badge--ard{background:var(--ard-blue)!important;color:#fff!important}
.tv-badge--zdf{background:#FA7D19!important;color:#fff!important}
.tv-badge--sportschau{background:var(--ard-blue)!important;color:#fff!important}
.tv-badge--pluto{background:#6236FF!important;color:#fff!important}
.tv-badge--youtube{background:#FF0000!important;color:#fff!important}
.tv-badge--staige{background:#612A6F!important;color:#fff!important}
.tv-badge--leagues{background:#48eDDD!important;color:#111!important}
.tv-badge--default{background:var(--bg-surface)!important;color:var(--text-2)!important}
.tv-badge--dyn{background:#00C8FF!important;color:#111!important}
.tv-badge--sportseurope{background:#1B3A6B!important;color:#fff!important}

/* ===========================================
   BLOG LIST
   =========================================== */
.blog-section{padding:24px 0 0;border-top:1px solid var(--border);margin-top:24px}

.blog-list{display:flex;flex-direction:column;gap:0}

.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-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-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:var(--bvb-black);color:var(--bvb-yellow);font-size:0.65rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;padding:3px 10px;border-radius:3px;margin-bottom:8px}
@media(prefers-color-scheme:dark){.single-cat{color:var(--bvb-yellow)}}
.single-title{font-family:var(--font-heading);font-size:1.6rem;font-weight:800;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 #e0e0e0}
.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:800;color:#1e3a5f;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:#333}
.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{color:#1a73e8;text-decoration:none}
.single-content a:hover{text-decoration:underline}
.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}

/* Tables in content — card-style */
.single-content table,.page-content table{width:100%;border-collapse:separate;border-spacing:0 4px;margin:16px 0 24px;font-size:14px}
.single-content thead,.page-content thead{display:none}
.single-content tr,.page-content tr{background:var(--bg-card);border-radius:var(--radius-md);transition:border-color .2s}
.single-content td,.page-content td{padding:10px 14px;border-top:1px solid var(--border);border-bottom:1px solid var(--border);color:var(--text-1);font-size:13px;vertical-align:middle}
.single-content td:first-child,.page-content td:first-child{border-left:1px solid var(--border);border-radius:var(--radius-md) 0 0 var(--radius-md)}
.single-content td:last-child,.page-content td:last-child{border-right:1px solid var(--border);border-radius:0 var(--radius-md) var(--radius-md) 0}
.single-content tr:hover td,.page-content tr:hover td{border-color:var(--border-hover)}

/* Responsive: stack table on small screens */
@media(max-width:480px){
  .single-content table,.page-content table{font-size:12px}
  .single-content td,.page-content td{padding:8px 10px;font-size:12px}
}

/* Table with visible header (add .has-header to table or use thead) */
.single-content table.has-header thead,.page-content table.has-header thead,
.single-content .wp-block-table.is-style-stripes thead,.page-content .wp-block-table.is-style-stripes thead{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;background:transparent;border:0}

/* Links in tables */
.single-content td a,.page-content td a{color:var(--bvb-yellow-dark);font-weight:500;transition:color .2s}
.single-content td a:hover,.page-content td a:hover{color:var(--bvb-yellow)}
@media(prefers-color-scheme:dark){
  .single-content td a,.page-content td a{color:var(--bvb-yellow)}
}

/* ===========================================
   PAGE
   =========================================== */
.page-header{padding:24px 0 16px}
.page-title{font-family:var(--font-heading);font-size:1.6rem;font-weight:800;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:#333}
.page-content h2{font-family:var(--font-heading);font-size:1.2rem;font-weight:800;color:#1e3a5f;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{color:#1a73e8;text-decoration:none}
.page-content a:hover{text-decoration:underline}

/* Contact form */
.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:var(--bvb-yellow)}
.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
   =========================================== */
.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-size:15px;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)}

/* Support CTA in footer */
.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)}

/* ===========================================
   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);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:var(--bvb-black);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-radius:var(--radius-md);margin-bottom:12px}
.comment-author{font-weight:600;font-size:14px;margin-bottom:4px}
.comment-content{font-size:14px;color:var(--text-2)}

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

/* ===========================================
   SOCIAL CTA (end of article)
   =========================================== */
.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)}

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

/* ===========================================
   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}

/* ===========================================
   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)}

/* ===========================================
   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)}

/* ===========================================
   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}

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

/* ===========================================
   BVB 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,
.bvb-support-buttons a:focus,
.bvb-support-buttons a:active {
  background: #FDE100;
  color: #111111;
  text-decoration: none;
  transform: none;
  opacity: 1;
}
@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;
  }
}

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

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

/* ===========================================
   INFO BOX (yellow left border)
   =========================================== */
.ucl-info-box{background:#f8f9fa;border-left:4px solid #FFD900;padding:1rem 1.25rem;margin:1.25rem 0 1.5rem;border-radius:0 8px 8px 0;font-size:14px;line-height:1.7;color:#333}
.ucl-info-box strong{color:var(--text-1)}

/* ===========================================
   KEY FACTS GRID
   =========================================== */
.ucl-keyfacts{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid #e5e5e5;border-radius:10px;overflow:hidden;margin:1.25rem 0 1.75rem}
.ucl-keyfact{padding:1rem 1.25rem;border-right:1px solid #e5e5e5;background:#fafafa}
.ucl-keyfact:last-child{border-right:none}
.ucl-keyfact-label{font-size:11px;text-transform:uppercase;letter-spacing:1.5px;color:#999;font-weight:600;margin-bottom:2px}
.ucl-keyfact-value{font-size:15px;font-weight:700;color:#0C447C}
@media(max-width:540px){.ucl-keyfacts{grid-template-columns:1fr 1fr}.ucl-keyfact{border-bottom:1px solid #e5e5e5}}

/* ===========================================
   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}

/* ===========================================
   QUALIFICATION GRID
   =========================================== */
.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:#fff;border:1px solid #e5e5e5;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:#E6F1FB;color:#0C447C;border-bottom:1px solid #B5D4F4}
.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:#fff;color:#0C447C;border:1px solid #B5D4F4;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:#1a1a1a;padding:7px 14px;border-bottom:1px solid #f0f0f0;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:#aaa;font-style:italic}
.ucl-pot-badge{font-size:10px;background:#E6F1FB;color:#0C447C;border:1px solid #B5D4F4;border-radius:3px;padding:1px 5px;margin-left:auto;white-space:nowrap;font-weight:400}
.ucl-bvb-badge{font-size:10px;background:#FFD900;color:#1a1a1a;border-radius:3px;padding:1px 6px;margin-left:auto;letter-spacing:0.3px;font-weight:600}
.ucl-q-note{font-size:12px;color:#888;margin-top:14px;line-height:1.6}
@media(max-width:540px){.ucl-q-grid{grid-template-columns:1fr}}

/* ===========================================
   MODUS FLOW
   =========================================== */
.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:#fff;border:1px solid #e5e5e5}
.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:#0C447C;border-color:#0C447C}
.ucl-modus-num{font-size:20px;font-weight:800;color:#0C447C}
.ucl-modus-label{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:#999;font-weight:600}
.ucl-modus-step.ucl-active .ucl-modus-num{color:#FFD900}
.ucl-modus-step.ucl-active .ucl-modus-label{color:rgba(255,255,255,0.7)}
.ucl-modus-arrow{display:flex;align-items:center;color:#ccc;font-size:16px;padding:0 2px}
@media(max-width:540px){.ucl-modus-flow{flex-direction:column}.ucl-modus-step{border-radius:0!important}.ucl-modus-step:first-child{border-radius:8px 8px 0 0!important}.ucl-modus-step:last-child{border-radius:0 0 8px 8px!important}.ucl-modus-arrow{justify-content:center;transform:rotate(90deg)}}

/* ===========================================
   POTS
   =========================================== */
.ucl-pots-wrap{padding:1.25rem 0}
.ucl-pots{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.ucl-pot{background:#fff;border:1px solid #e5e5e5;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:#E6F1FB;color:#0C447C;border-bottom:1px solid #B5D4F4}.ucl-pot.p1 .ucl-dot{background:#185FA5}
.ucl-pot.p2 .ucl-pot-header{background:#EAF3DE;color:#27500A;border-bottom:1px solid #C0DD97}.ucl-pot.p2 .ucl-dot{background:#3B6D11}
.ucl-pot.p3 .ucl-pot-header{background:#FAEEDA;color:#633806;border-bottom:1px solid #FAC775}.ucl-pot.p3 .ucl-dot{background:#854F0B}
.ucl-pot.p4 .ucl-pot-header{background:#FAECE7;color:#712B13;border-bottom:1px solid #F5C4B3}.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:#1a1a1a;padding:7px 14px;border-bottom:1px solid #f0f0f0;display:flex;align-items:center;gap:8px}
.ucl-pot-teams li:last-child{border-bottom:none}
.ucl-note{font-size:12px;color:#888;margin-top:12px}
@media(max-width:540px){.ucl-pots{grid-template-columns:1fr}}

/* ===========================================
   TIMELINE
   =========================================== */
.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:#e5e5e5}
.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:#FFD900;border:2px solid #0C447C;z-index:1}
.ucl-tl-date{font-weight:700;font-size:13px;color:#0C447C;min-width:155px;flex-shrink:0}
.ucl-tl-text{font-size:14px;color:#666}
.ucl-tl-item.ucl-tl-finale .ucl-tl-date{color:#1a1a1a}
.ucl-tl-item.ucl-tl-finale .ucl-tl-text{color:#1a1a1a;font-weight:600}
@media(max-width:540px){.ucl-tl-item{flex-direction:column;gap:1px}.ucl-tl-date{min-width:unset}}

/* ===========================================
   TV GRID
   =========================================== */
.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:#fff;border:1px solid #e5e5e5;border-radius:10px;padding:1rem 1.25rem}
.ucl-tv-provider{font-size:15px;font-weight:700;color:#1a1a1a;margin-bottom:4px}
.ucl-tv-detail{font-size:13px;color:#888;line-height:1.6}

/* ===========================================
   ARTICLE FOOTER
   =========================================== */
.article-footer{margin-top:2rem;padding-top:1rem;border-top:1px solid #e0e0e0;font-size:0.8rem;color:#999}

/* ===========================================
   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:800;color:#999;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:800;color:var(--text-1);margin-bottom:0.75rem;line-height:1.3}
.bvb-support-page__sub{font-size:0.95rem;color:#555;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:#fafafa;border:1px solid #e5e5e5;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:800;color:var(--text-1);margin-bottom:0.5rem}
.bvb-support-option__desc{font-size:0.875rem;color:#666;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}
.bvb-btn--full{width:100%}
