/* ═══════════════════════════════════════════════════════════════════════════
   LIQUID GLASS DESIGN SYSTEM — GENTE DO BARRA
   Standardized components for Tables, Matches and Cards.
   ═══════════════════════════════════════════════════════════════════════════ */

:root {

    /* APPLE LIQUID TOKENS */
    --glass-bg:
        linear-gradient(180deg,
            rgba(255, 255, 255, 0.12) 0%,
            rgba(255, 255, 255, 0.06) 100%);

    --glass-bg-strong:
        linear-gradient(180deg,
            rgba(255, 255, 255, 0.18) 0%,
            rgba(255, 255, 255, 0.08) 100%);

    --glass-border:
        rgba(255, 255, 255, 0.12);

    --glass-highlight:
        rgba(255, 255, 255, 0.28);

    --glass-shadow:
        0 8px 32px rgba(0, 0, 0, 0.28);

    --glass-shadow-hover:
        0 18px 48px rgba(0, 0, 0, 0.35);

    --glass-blur:
        blur(24px) saturate(180%);

    --glass-radius:
        28px;

    --glass-radius-sm:
        20px;

    --accent-blue:
        #7bb0ff;

    --text-primary:
        rgba(255, 255, 255, 0.96);

    --text-secondary:
        rgba(255, 255, 255, 0.58);

    /* Layout tokens — desktop defaults (≤1024px overridden by front-page.css) */
    --gap:          clamp(24px, 3vw, 48px);
    --card-gap:     clamp(20px, 2vw, 32px);
    --section-gap:  clamp(80px, 8vw, 160px);
}

/* ─── GLOBAL OVERRIDES ─── */
body.liquid-glass-active {
    background:
        radial-gradient(circle at top,
            #10131a 0%,
            #050608 45%,
            #000 100%);
    color: #fff;
    font-family: 'Vinila Variable', sans-serif;
    width: 100% !important;
}

#page {
    width: 100% !important;
    position: relative;
}

/* Custom Scrollbar */
::-webkit-scrollbar {
    width: 8px;
}

::-webkit-scrollbar-track {
    background: #000;
}

::-webkit-scrollbar-thumb {
    background: var(--accent-blue);
    border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
    background: #4590e6;
}

/* ─── 1. CORE GLASS PANEL ──────────────────────────────────────────────────── */
.liquid-glass-panel {
    position: relative;
    overflow: hidden;
    background: var(--glass-bg);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);

    /* Specular lighting: border-top is lighter */
    border-top: 1px solid rgba(255, 255, 255, 0.22) !important;
    border-left: 1px solid rgba(255, 255, 255, 0.12) !important;
    border-right: 1px solid rgba(0, 0, 0, 0.4) !important;
    border-bottom: 1px solid rgba(0, 0, 0, 0.4) !important;

    border-radius: var(--glass-radius);

    /* Depth: Outer Shadow + Inset specular highlights */
    box-shadow:
        var(--glass-shadow),
        inset 0 1px 1px rgba(255, 255, 255, 0.1),
        inset 0 0 30px rgba(255, 255, 255, 0.02) !important;

    padding:
        clamp(20px, 3vw, 32px);

    isolation: isolate;

    transition:
        transform .45s cubic-bezier(.16, 1, .3, 1),
        box-shadow .45s cubic-bezier(.16, 1, .3, 1),
        background .45s ease;
}

/* Material Texture: Subtle noise overlay */
.liquid-glass-panel::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: -1;
    opacity: 0.04;
    pointer-events: none;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E");
}

/* Specular Glint: Floating radial light */
.liquid-glass-panel::before {
    content: '';
    position: absolute;
    top: -15%;
    left: -15%;
    width: 60%;
    height: 60%;
    background: radial-gradient(circle, rgba(255, 255, 255, 0.05) 0%, transparent 70%);
    pointer-events: none;
    z-index: 0;
}

.hide-mobile {
    display: none !important;
}

/* ─── 2. STANDARDIZED HEADER ───────────────────────────────────────────────── */
.liquid-glass-card__header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
    padding-bottom: 1rem;
    margin-bottom: 1.5rem;
}

.liquid-glass-card__title {
    margin: 0;
    color: #fff !important;
    font-size: 1rem !important;
    font-weight: 900 !important;
    font-family: 'Vinila Variable', sans-serif !important;
    text-transform: uppercase;
    letter-spacing: 2px;
}

.liquid-glass-card__badge {
    background: rgba(255, 255, 255, 0.05);
    padding: 0.35rem 0.75rem;
    border-radius: 100px;
    font-family: 'Vinila Variable', sans-serif;
    font-size: 0.6rem;
    font-weight: 800;
    color: var(--accent-blue);
    text-transform: uppercase;
    letter-spacing: 1px;
}

/* ─── 3. STANDINGS TABLE ───────────────────────────────────────────────────── */
.vision-standings-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    margin: 0;
    width: 100%;
}

.vision-standings {
    width: 100%;
    border-collapse: collapse;
    font-family: "Vinila Variable", sans-serif;
    table-layout: fixed;
}

.vision-standings th,
.vision-standings td {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Colunas fixas para economizar espaço no mobile */
.vision-standings th:first-child, 
.vision-standings td:first-child { 
    width: 34px; 
}
.vision-standings th.th-time, 
.vision-standings td:nth-child(2) { 
    width: auto; 
    text-align: left;
}
.vision-standings th:not(.th-time):not(:first-child),
.vision-standings td:not(:nth-child(2)):not(:first-child) {
    width: 35px;
}

@media (max-width: 480px) {
    .vision-standings th:not(.th-time):not(:first-child),
    .vision-standings td:not(:nth-child(2)):not(:first-child) {
        width: 30px;
    }
    /* A coluna de sequência precisa de um pouco mais de espaço para os 3 dots */
    .vision-standings th:last-child,
    .vision-standings td:last-child {
        width: 45px;
    }
}

.vision-standings td {
    padding: 6px 4px;
    text-align: center;
    color: #fff !important;
    font-size: 0.65rem;
    font-weight: 600;
    border-bottom: 1px solid rgba(255, 255, 255, 0.03) !important;
}

@media (max-width: 480px) {
    .vision-standings td { padding: 6px 2px; }
    .vision-team-cell { gap: 4px !important; padding-left: 2px !important; }
}

.vision-pos-box {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 20px;
    height: 20px;
    border-radius: 4px;
    font-size: 0.6rem;
    font-weight: 900;
    background: rgba(255, 255, 255, 0.05);
    color: #fff;
}

.vision-pos-box--top {
    background: #16a34a !important;
}

.vision-pos-box--playoff {
    background: #0e4993 !important;
}

.vision-pos-box--bottom {
    background: #dc2626 !important;
}

.vision-team-cell {
    display: flex;
    align-items: center;
    text-align: left;
    gap: 8px;
    padding-left: 4px;
}

.vision-team-crest {
    width: 20px !important;
    height: 20px !important;
    object-fit: contain;
    flex-shrink: 0;
}

.vision-team-name {
    color: #fff !important;
    font-weight: 800 !important;
    font-size: 0.75rem !important;
    text-transform: uppercase;
    letter-spacing: 0.3px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    min-width: 0;
}

/* Mobile & Compact Table Adjustments */
@media (max-width: 768px) {
    .vision-standings td,
    .vision-standings th {
        padding: 6px 3px !important;
        font-size: 0.6rem !important;
    }

    .show-mobile { display: inline-block !important; }
    .hide-mobile { display: none !important; }

    @media (max-width: 400px) {
        .hide-small { display: none !important; }
        .vision-standings td, 
        .vision-standings th {
            padding: 6px 2px !important;
            font-size: 0.58rem !important;
        }
        .vision-team-cell {
            gap: 2px !important;
            padding-left: 0 !important;
        }
        .vision-team-name {
            max-width: 45px !important;
            font-size: 0.62rem !important;
        }
        .vision-pts {
            font-size: 0.65rem !important;
        }
        .vision-pos-box {
            width: 17px !important;
            height: 17px !important;
            font-size: 0.52rem !important;
        }
        .vision-team-crest {
            width: 15px !important;
            height: 15px !important;
        }
        .vision-form {
            gap: 2px !important;
        }
        .form-dot {
            width: 4px !important;
            height: 4px !important;
        }
    }
}

.show-mobile { display: none !important; }

.vision-standings--compact th,
.vision-standings--compact td {
    padding: 6px 4px !important;
    font-size: 0.65rem !important;
}

.vision-standings--compact .vision-team-name {
    font-size: 0.68rem !important;
    max-width: 140px;
    overflow: hidden;
    text-overflow: ellipsis;
}

.vision-standings--compact .vision-team-crest {
    width: 16px !important;
    height: 16px !important;
}

.vision-pts {
    color: var(--accent-blue) !important;
    font-weight: 900 !important;
    font-size: 0.85rem !important;
}

.vision-form {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 3px;
}

.form-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    display: inline-block;
}

.form-dot.form-w {
    background: #1b8b3b;
}

.form-dot.form-l {
    background: #d32f2f;
}

.form-dot.form-d {
    background: #9ca3af;
}

/* Desktop Standings Expand */
@media (min-width: 769px) {
    .vision-standings {
        min-width: 0;
    }

    .vision-standings th {
        padding: 12px 8px !important;
        font-size: 0.65rem !important;
    }

    .vision-standings td {
        padding: 12px 8px !important;
        font-size: 0.85rem !important;
    }

    .vision-pos-box {
        width: 24px !important;
        height: 24px !important;
        font-size: 0.75rem !important;
    }

    .vision-team-cell {
        gap: 10px;
    }

    .vision-team-crest {
        width: 28px !important;
        height: 28px !important;
    }

    .vision-team-name {
        font-size: 0.85rem !important;
    }

    .vision-pts {
        font-size: 1.05rem !important;
    }

    .form-dot {
        width: 8px;
        height: 8px;
    }

    .hide-mobile {
        display: table-cell !important;
    }
}

/* ─── 4. MATCH CARDS ───────────────────────────────────────────────────────── */
.matches-archive {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    width: 100%;
}

.matches-archive.is-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
}

@media (min-width: 768px) {
    .matches-archive.is-grid {
        grid-template-columns: 1fr 1fr;
    }
}

@media (max-width: 1024px) {
    .comp-page__grid {
        grid-template-columns: 1fr !important;
        display: flex !important;
        flex-direction: column !important;
        padding: 0 20px !important;
    }
    
    .comp-page__main-container {
        padding: 0 !important;
    }
}

.vision-match-card {
    background: rgba(255, 255, 255, 0.03) !important;
    border: 1px solid rgba(255, 255, 255, 0.08) !important;
    border-radius: 16px;
    padding: 1rem 1.25rem !important;
    margin-bottom: 8px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    transition: all 0.3s ease;
    text-decoration: none;
    font-family: "Vinila Variable", sans-serif !important;
    width: 100% !important;
    box-sizing: border-box;
}

.vision-match-card:hover {
    background: rgba(255, 255, 255, 0.06) !important;
    transform: translateY(-3px);
    border-color: rgba(255, 255, 255, 0.15) !important;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2);
}

.vision-match-card.is-live {
    border-color: rgba(255, 59, 48, 0.3) !important;
    background: linear-gradient(180deg, rgba(255, 59, 48, 0.08), rgba(255, 59, 48, 0.03)) !important;
}

.vision-match-card.is-waiting {
    border-color: rgba(245, 158, 11, 0.3) !important;
    background: rgba(245, 158, 11, 0.02) !important;
}

/* 🔥 DESTAQUE BARRA FC (VIP) */
.vision-match-card.is-highlight.is-live,
.vision-match-card.is-highlight.is-waiting {
    border-color: #2a85ff !important;
    border-width: 1.5px !important;
    background: linear-gradient(135deg, rgba(42, 133, 255, 0.15), rgba(42, 133, 255, 0.02)) !important;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.4), 0 0 25px rgba(42, 133, 255, 0.2) !important;
    animation: barra-live-pulse 2s cubic-bezier(0.4, 0, 0.2, 1) infinite !important;
}

@keyframes barra-live-pulse {
    0% { box-shadow: 0 0 15px rgba(42, 133, 255, 0.2); }
    50% { box-shadow: 0 0 45px rgba(42, 133, 255, 0.5); }
    100% { box-shadow: 0 0 15px rgba(42, 133, 255, 0.2); }
}

@keyframes live-card-pulse {
    0% {
        box-shadow: 0 0 10px rgba(255, 59, 48, 0.1);
    }

    50% {
        box-shadow: 0 0 25px rgba(255, 59, 48, 0.3);
    }

    100% {
        box-shadow: 0 0 10px rgba(255, 59, 48, 0.1);
    }
}

.vision-match-meta {
    text-align: center;
    text-transform: uppercase;
    font-size: 0.6rem !important;
    color: rgba(255, 255, 255, 0.4) !important;
    letter-spacing: 1px;
}

/* 🔵 BARRA FC LIVE PULSE */
.vision-match-card.is-highlight .live-dot-pulse {
    background: #2a85ff !important;
    animation: dot-pulse-blue 1.5s infinite !important;
}

@keyframes dot-pulse-blue {
    0% { transform: scale(0.95); box-shadow: 0 0 0 0 rgba(42, 133, 255, 0.7); }
    70% { transform: scale(1); box-shadow: 0 0 0 10px rgba(42, 133, 255, 0); }
    100% { transform: scale(0.95); box-shadow: 0 0 0 0 rgba(42, 133, 255, 0); }
}

.vision-matchup {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
    align-items: center;
    gap: 12px;
}

@media (max-width: 480px) {
    .vision-matchup {
        gap: 6px;
    }

    .vision-team {
        gap: 6px;
    }

    .vision-team-crest {
        width: 24px !important;
        height: 24px !important;
    }

    .vision-team .team-name-short {
        font-size: 0.65rem !important;
    }

    .vision-score {
        font-size: 0.9rem !important;
        gap: 3px;
        min-width: 50px !important;
    }
    
    .vision-score-val {
        font-size: 1.1rem !important;
    }

    .vision-match-card {
        padding: 12px 10px !important;
        border-radius: 12px;
    }
}

.vision-team {
    display: flex;
    align-items: center;
    gap: 10px;
    min-width: 0;
}

.vision-team--home {
    justify-content: flex-end;
}

.vision-team--home .vision-team-name {
    text-align: right;
}

/* team-name-full / team-name-short are the actual spans output by gdb_render_team_name */
.vision-team .team-name-full,
.vision-team .team-name-short {
    color: #fff;
    font-size: 0.75rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    min-width: 0;
    display: block;
    max-width: 100%;
}

.vision-team--home .team-name-full,
.vision-team--home .team-name-short {
    text-align: right;
}

/* On mobile, show abbreviation only */
@media (max-width: 640px) {
    .vision-team .team-name-full { display: none !important; }
    .vision-team .team-name-short { display: block !important; }
}

.vision-team--away {
    justify-content: flex-start;
}

.vision-team-crest {
    width: 32px;
    height: 32px;
    object-fit: contain;
    flex-shrink: 0;
}

.vision-team-name {
    color: #fff !important;
    font-size: 0.75rem !important;
    font-weight: 800 !important;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    min-width: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.vision-score {
    font-size: 1.25rem !important;
    font-weight: 900 !important;
    color: #fff !important;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    font-family: "Vinila Variable", sans-serif !important;
}

.vision-score-sep {
    color: rgba(255, 255, 255, 0.2);
    font-weight: 400;
}

.vision-match-cta {
    margin-top: 4px;
    padding-top: 10px;
    border-top: 1px solid rgba(255, 255, 255, 0.05);
    text-align: center;
    font-size: 0.65rem !important;
    font-weight: 900 !important;
    text-transform: uppercase;
    color: var(--accent-blue) !important;
    letter-spacing: 1px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
}

/* ─── 5. NAVIGATION / TABS ─────────────────────────────────────────────────── */
.liquid-glass-nav {
    display: flex;
    gap: 0.5rem;
}

.liquid-glass-nav__btn {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    border: 1px solid rgba(255, 255, 255, 0.1);
    background: rgba(255, 255, 255, 0.05);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
    cursor: pointer;
}

.liquid-glass-nav__btn:hover {
    background: var(--accent-blue);
    border-color: var(--accent-blue);
    color: #091d3d;
}

.liquid-glass-nav__btn svg {
    width: 16px;
    height: 16px;
    stroke-width: 2.5;
}

/* Group Headers for Standings */
.gdb-grupos-grid {
    display: flex;
    flex-direction: column;
    gap: 2rem;
}

.gdb-grupo-card__title {
    font-family: "Vinila Variable", sans-serif !important;
    font-size: 0.85rem !important;
    font-weight: 900 !important;
    color: #fff !important;
    text-transform: uppercase;
    letter-spacing: 2px;
    margin-bottom: 1rem;
    padding-left: 0.5rem;
    border-left: 3px solid var(--accent-blue);
}

/* ─── 6. HERO MATCH CARD (Singular) ────────────────────────────────────────── */
.glass-hero-match {
    display: block;
    background: var(--glass-bg) !important;
    backdrop-filter: var(--glass-blur) !important;
    -webkit-backdrop-filter: var(--glass-blur) !important;
    border: 1px solid var(--glass-border) !important;
    border-radius: 24px !important;
    padding: 2rem !important;
    text-decoration: none !important;
    transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1) !important;
    color: #fff !important;
    position: relative;
    overflow: hidden;
}

.glass-hero-match:hover {
    background: rgba(255, 255, 255, 0.06) !important;
    border-color: rgba(255, 255, 255, 0.15) !important;
    transform: translateY(-5px);
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.4);
}

.glass-hero-match.is-live {
    border-color: #ff3b30 !important;
    box-shadow: 0 0 20px rgba(255, 59, 48, 0.2);
}

.glass-hero-match__meta {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: rgba(255, 255, 255, 0.4);
    margin-bottom: 2rem;
}

.glass-hero-match__live {
    color: #ff3b30;
    display: flex;
    align-items: center;
    gap: 6px;
}

.pulse-live {
    width: 8px;
    height: 8px;
    background: #ff3b30;
    border-radius: 50%;
    animation: pulse-live-anim 1.5s infinite;
}

@keyframes pulse-live-anim {
    0% {
        transform: scale(0.9);
        opacity: 1;
    }

    50% {
        transform: scale(1.2);
        opacity: 0.5;
    }

    100% {
        transform: scale(0.9);
        opacity: 1;
    }
}

.live-badge-anim--waiting {
    background: #f59e0b !important;
    box-shadow: 0 0 10px rgba(245, 158, 11, 0.3) !important;
}

.live-badge-anim--waiting::after {
    background: #f59e0b !important;
}

.glass-hero-match__teams {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    margin-bottom: 2rem;
}

.glass-hero-match__team {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    text-align: center;
}

.glass-hero-match__crest {
    width: 64px;
    height: 64px;
    object-fit: contain;
}

.glass-hero-match__name {
    font-size: 0.9rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.glass-hero-match__score {
    font-size: 2.5rem;
    font-weight: 900;
    letter-spacing: -2px;
    display: flex;
    align-items: center;
    gap: 15px;
}

.glass-hero-match__score em {
    font-style: normal;
    color: rgba(255, 255, 255, 0.1);
}

.glass-hero-match__vs {
    font-size: 1.2rem;
    font-weight: 900;
    color: rgba(255, 255, 255, 0.2);
    letter-spacing: 4px;
}

.glass-hero-match__venue {
    text-align: center;
    font-size: 0.75rem;
    color: rgba(255, 255, 255, 0.4);
    margin-bottom: 1.5rem;
}

.glass-hero-match__cta {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding-top: 1.5rem;
    border-top: 1px solid rgba(255, 255, 255, 0.05);
    color: var(--accent-blue);
    font-size: 0.75rem;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 1px;
}

/* ─── 7. ATMOSPHERE & GLOWS ────────────────────────────────────────────────── */
.site-atmosphere {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 0;
}

.site-glows {
    display: none !important;
}

.glow-blob {
    display: none !important;
}

.glow-blob--mouse {
    display: none !important;
}

/* ─── 8. COMPETITION HERO ──────────────────────────────────────────────────── */
.comp-hero {
    position: relative;
    padding: 180px 20px 60px;
    text-align: center;
    z-index: 10;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.comp-hero__badge {
    background: rgba(255, 255, 255, 0.1);
    backdrop-filter: blur(20px);
    border: 1px solid rgba(255, 255, 255, 0.2);
    padding: 6px 16px;
    border-radius: 100px;
    font-size: 0.75rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 2px;
    margin-bottom: 20px;
}

.comp-hero__title {
    font-family: 'Vinila Variable', sans-serif;
    font-size: clamp(2.5rem, 8vw, 70px);
    font-weight: 900;
    text-transform: uppercase;
    line-height: 1;
    margin: 0 0 20px;
    display: flex;
    align-items: center;
    gap: 20px;
}

.comp-hero__crest {
    height: clamp(50px, 8vw, 80px);
    width: auto;
    object-fit: contain;
}

/* ─── 9. TIE CARDS (Bracket/Mata-mata) ─────────────────────────────────────── */
.tie-card {
    background: var(--glass-bg);
    backdrop-filter: var(--glass-blur);
    border: 1px solid var(--glass-border);
    border-radius: 28px;
    overflow: hidden;
    margin-bottom: 2rem;
    box-shadow: 0 30px 60px rgba(0, 0, 0, 0.3);
}

.tie-card__head {
    background: rgba(255, 255, 255, 0.03);
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
    padding: 1.25rem 2rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.tie-card__head-label {
    color: var(--accent-blue);
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 2px;
    font-size: 0.75rem;
}

.tie-card__head-meta {
    color: rgba(255, 255, 255, 0.4);
    font-size: 0.7rem;
    font-weight: 700;
}

.tie-card__leg {
    padding: 2rem;
    position: relative;
}

.tie-card__matchup {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 2rem;
    text-decoration: none;
}

.tie-card__team {
    display: flex;
    align-items: center;
    gap: 1rem;
    flex: 1;
}

.tie-card__team--home {
    flex-direction: row-reverse;
    text-align: right;
}

.tie-card__team-name {
    color: #fff;
    font-weight: 900;
    font-size: 1rem;
    text-transform: uppercase;
}

.tie-card__crest {
    width: 48px;
    height: 48px;
    object-fit: contain;
}

.tie-card__score-center {
    background: rgba(255, 255, 255, 0.05);
    padding: 0.6rem 1.5rem;
    border-radius: 12px;
    display: flex;
    align-items: center;
    gap: 10px;
}

.tie-card__score {
    color: #fff;
    font-size: 2rem;
    font-weight: 900;
}

.tie-card__sep {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem 2rem;
    background: rgba(255, 255, 255, 0.03);
    border-top: 1px solid rgba(255, 255, 255, 0.05);
}

.tie-card__agg {
    background: var(--accent-blue);
    color: #000;
    padding: 4px 12px;
    border-radius: 6px;
    font-weight: 900;
    font-size: 0.85rem;
}

/* ─── 10. MATCH DETAIL (Timeline, Stats) ───────────────────────────────────── */
.liquid-match-stats {
    background: rgba(255, 255, 255, 0.02);
    border-radius: 16px;
    border: 1px solid rgba(255, 255, 255, 0.05);
    overflow: hidden;
}

.liquid-match-stats__row {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    padding: 1rem 1.5rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.03);
}

.liquid-match-stats__val {
    font-size: 1.25rem;
    font-weight: 900;
    color: #fff;
}

.liquid-match-stats__val--home {
    text-align: right;
}

.liquid-match-stats__val--away {
    text-align: left;
}

.liquid-match-stats__label {
    font-size: 0.65rem;
    font-weight: 800;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.4);
    text-align: center;
    min-width: 120px;
}

.liquid-timeline {
    position: relative;
    padding: 2rem 0;
}

.liquid-timeline::before {
    content: '';
    position: absolute;
    left: 50%;
    top: 0;
    bottom: 0;
    width: 1px;
    background: rgba(255, 255, 255, 0.1);
    transform: translateX(-50%);
}

.liquid-timeline__event {
    display: grid;
    grid-template-columns: 1fr 60px 1fr;
    align-items: center;
    margin-bottom: 1.5rem;
    position: relative;
}

.liquid-timeline__side {
    padding: 0 1.5rem;
}

.liquid-timeline__side--home {
    text-align: right;
}

.liquid-timeline__side--away {
    text-align: left;
}

.liquid-timeline__mid {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 5px;
    z-index: 2;
}

.liquid-timeline__min {
    background: var(--accent-blue);
    color: #000;
    font-size: 0.7rem;
    font-weight: 900;
    padding: 2px 6px;
    border-radius: 4px;
}

.liquid-timeline__icon {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
}

.liquid-timeline__title {
    font-size: 0.9rem;
    font-weight: 800;
    color: #fff;
    margin-bottom: 2px;
}

.liquid-timeline__desc {
    font-size: 0.75rem;
    color: rgba(255, 255, 255, 0.5);
}

/* ─── 11. FICHA TÉCNICA & ESCALAÇÃO ───────────────────────────────────────── */
.liquid-ficha-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1px;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.05);
    border-radius: 16px;
    overflow: hidden;
}

.liquid-ficha-item {
    background: rgba(255, 255, 255, 0.02);
    padding: 1.5rem;
    text-align: center;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.liquid-ficha-label {
    font-size: 0.65rem;
    font-weight: 800;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.4);
    letter-spacing: 1px;
}

.liquid-ficha-val {
    font-size: 1.1rem;
    font-weight: 900;
    color: #fff;
}

.liquid-lineup-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 30px;
}

/* ─── 12. LIQUID SQUARE NEWS GRID & CARDS ──────────────────────────────────── */
.liquid-square-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 32px;
    width: 100%;
    margin: 40px 0;
}

.liquid-square-card {
    position: relative;
    aspect-ratio: 1 / 1;
    border-radius: var(--glass-radius);
    overflow: hidden;
    background: var(--glass-bg);
    border: 1px solid var(--glass-border) !important;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    text-decoration: none;
    transition: all 0.5s cubic-bezier(0.16, 1, 0.3, 1);
    box-shadow: var(--glass-shadow);
    isolation: isolate;
}

.liquid-square-card img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: -1;
    transition: transform 0.8s cubic-bezier(0.16, 1, 0.3, 1);
    filter: brightness(0.8);
}

.liquid-square-card:hover {
    transform: translateY(-8px) scale(1.02);
    border-color: rgba(255, 255, 255, 0.3) !important;
    box-shadow: var(--glass-shadow-hover);
    background: var(--glass-bg-strong);
}

.liquid-square-card:hover img {
    transform: scale(1.1);
    filter: brightness(0.9);
}

.liquid-square-card__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, 
        rgba(0, 0, 0, 0.95) 0%, 
        rgba(0, 0, 0, 0.4) 40%, 
        transparent 100%);
    z-index: 0;
}

.liquid-square-card__content {
    position: relative;
    z-index: 1;
    padding: 24px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.liquid-square-card__date {
    font-size: 0.6rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: var(--accent-blue);
    opacity: 0.9;
}

.liquid-square-card__title {
    font-family: 'Vinila Variable', sans-serif !important;
    font-size: 1.15rem !important;
    font-weight: 900 !important;
    line-height: 1.1;
    color: #fff !important;
    margin: 0 !important;
    text-transform: uppercase;
    letter-spacing: -0.01em;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

@media (max-width: 768px) {
    .liquid-lineup-grid {
        grid-template-columns: 1fr;
    }

    .liquid-timeline::before {
        left: 30px;
    }

    .liquid-timeline__event {
        grid-template-columns: 60px 1fr;
        grid-template-areas: "mid content";
    }

    .liquid-timeline__mid {
        grid-area: mid;
    }

    .liquid-timeline__side {
        grid-area: content;
        padding: 0;
        text-align: left !important;
    }

    /* Global Container Adjustments */
    .container {
        max-width: 1200px !important;
        margin: 0 auto !important;
        padding-left: 20px !important;
        padding-right: 20px !important;
    }

    /* Hero Adjustments */
    .comp-hero {
        padding: 120px 20px 40px;
    }

    .comp-hero__title {
        font-size: 2.5rem;
    }

    /* Grid Adjustments */
    .liquid-square-grid {
        grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)) !important;
        gap: 12px !important;
        margin: 20px 0 !important;
    }

    .liquid-square-card {
        border-radius: 20px !important;
    }

    .liquid-square-card__content {
        padding: 16px !important;
    }

    .liquid-square-card__title {
        font-size: 0.95rem !important;
    }

    /* Standings Mobile */
    .vision-standings {
        font-size: 0.8rem;
    }

    .th-time {
        min-width: 120px;
    }

    /* Match cards compactos no mobile */
    .vision-match-card {
        max-width: 100% !important;
        margin: 0 0 10px 0 !important;
        padding: 12px !important;
    }

    .vision-score {
        font-size: 1.1rem !important;
    }
}

/* Utility for mobile-only or desktop-only */
@media (max-width: 767px) {
    .hide-mobile {
        display: none !important;
    }
}

@media (min-width: 768px) {
    .show-mobile {
        display: none !important;
    }
}

/* ─── 12. GLOBAL LIVE NOTIFICATIONS ────────────────────────────────────────── */
.gdb-notifications-container {
    position: fixed;
    top: 24px;
    right: 24px;
    z-index: 10000;
    display: flex;
    flex-direction: column;
    gap: 12px;
    width: 320px;
    pointer-events: none;
}

.gdb-popup {
    background: rgba(13, 13, 13, 0.85);
    backdrop-filter: blur(20px) saturate(180%);
    -webkit-backdrop-filter: blur(20px) saturate(180%);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 18px;
    padding: 16px;
    display: flex;
    align-items: center;
    gap: 14px;
    color: #fff;
    box-shadow: 0 15px 35px rgba(0, 0, 0, 0.5), 0 0 0 1px rgba(255, 255, 255, 0.05);
    pointer-events: all;
    transform: translateX(400px);
    transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.4s ease;
    opacity: 0;
    position: relative;
    overflow: hidden;
}

.gdb-popup.is-visible {
    transform: translateX(0);
    opacity: 1;
}

.gdb-popup--barra {
    border-color: rgba(42, 133, 255, 0.4);
    background: linear-gradient(135deg, rgba(13, 13, 13, 0.9) 0%, rgba(9, 29, 61, 0.95) 100%);
}

.gdb-popup--barra::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 4px;
    height: 100%;
    background: var(--accent-blue);
    box-shadow: 0 0 15px var(--accent-blue);
}

.gdb-popup__icon {
    font-size: 24px;
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    background: rgba(255, 255, 255, 0.05);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.gdb-popup--barra .gdb-popup__icon {
    background: rgba(88, 161, 255, 0.1);
    border: 1px solid rgba(88, 161, 255, 0.2);
}

.gdb-popup__body {
    flex: 1;
    min-width: 0;
}

.gdb-popup__title {
    font-weight: 900;
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-bottom: 2px;
    color: var(--accent-blue);
}

.gdb-popup__msg {
    font-size: 0.75rem;
    font-weight: 600;
    color: rgba(255, 255, 255, 0.8);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.gdb-popup__close {
    background: none;
    border: none;
    color: rgba(255, 255, 255, 0.3);
    font-size: 14px;
    cursor: pointer;
    padding: 4px;
    transition: color 0.2s;
}

/* ─── 13. COMPREHENSIVE MOBILE REFINEMENTS (Restoring lost appearance) ──────── */
@media (max-width: 768px) {
    .liquid-glass-panel {
        padding: 1.25rem 1rem !important;
        margin: 1.5rem 0 !important;
        border-radius: 20px !important;
    }

    .liquid-glass-card__header {
        margin-bottom: 1rem !important;
        flex-direction: row !important;
        align-items: center !important;
    }

    .liquid-glass-card__title {
        font-size: 0.85rem !important;
        letter-spacing: 1px !important;
    }

    /* Standings Table Mobile Excellence */
    .vision-standings-wrap {
        margin: 0 -0.5rem;
        padding: 0 0.5rem;
        overflow-x: auto;
    }

    .vision-standings {
        min-width: 0 !important;
        font-size: 0.75rem !important;
        width: 100% !important;
    }

    .vision-standings th,
    .vision-standings td {
        padding: 11px 5px !important;
        font-size: 0.75rem !important;
    }

    .vision-team-name {
        max-width: 120px !important;
        font-size: 0.75rem !important;
    }

    /* Match Cards optimization */
    .vision-match-card {
        padding: 1rem !important;
        border-radius: 14px !important;
    }

    .vision-score {
        font-size: 1.25rem !important;
        gap: 8px !important;
    }

    .vision-match-meta {
        font-size: 0.55rem !important;
        margin-bottom: 4px !important;
    }

    .vision-team-crest {
        width: 24px !important;
        height: 24px !important;
    }

    /* Fix navigation buttons size */
    .liquid-glass-nav {
        gap: 6px !important;
    }

    .liquid-glass-nav__btn {
        width: 32px !important;
        height: 32px !important;
    }
}

/* ─── 14. GLOBAL CONTAINER PAD FIX ─── */
@media (max-width: 1024px) {
    .container {
        padding-inline: 16px !important;
    }
}

.gdb-popup__close:hover {
    color: #fff;
}

@media (max-width: 480px) {
    .gdb-notifications-container {
        top: auto;
        bottom: 24px;
        right: 16px;
        left: 16px;
        width: auto;
    }

    .gdb-popup {
        transform: translateY(100px);
    }

    .gdb-popup.is-visible {
        transform: translateY(0);
    }
}

.liquid-glass-panel::before {

    content: '';

    position: absolute;
    inset: 0;

    border-radius: inherit;

    background:
        linear-gradient(180deg,
            rgba(255, 255, 255, 0.18) 0%,
            rgba(255, 255, 255, 0.03) 38%,
            transparent 100%);

    pointer-events: none;

    z-index: 1;
}

.liquid-glass-panel::after {

    content: '';

    position: absolute;

    top: -40%;
    left: -20%;

    width: 60%;
    height: 120%;

    background:
        radial-gradient(circle,
            rgba(255, 255, 255, 0.14) 0%,
            transparent 72%);

    transform: rotate(-18deg);

    pointer-events: none;

    z-index: 1;
}

.liquid-glass-panel:hover {

    transform:
        translateY(-2px) scale(1.01);

    box-shadow:
        inset 0 1px 1px rgba(255, 255, 255, 0.14),
        inset 0 -1px 1px rgba(255, 255, 255, 0.06),
        var(--glass-shadow-hover);

    background: var(--glass-bg-strong);
}

.vision-match-card {

    background:
        linear-gradient(180deg,
            rgba(255, 255, 255, 0.08),
            rgba(255, 255, 255, 0.03)) !important;

    border:
        1px solid rgba(255, 255, 255, 0.06) !important;

    border-radius: 22px;

    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.08),
        0 6px 24px rgba(0, 0, 0, 0.22);

    backdrop-filter:
        blur(20px) saturate(180%);

    transition:
        transform .45s cubic-bezier(.16, 1, .3, 1),
        box-shadow .45s ease,
        border-color .35s ease;
}

.vision-match-card:hover {

    transform:
        translateY(-4px);

    border-color:
        rgba(255, 255, 255, 0.12) !important;

    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.12),
        0 16px 42px rgba(0, 0, 0, 0.34);
}

.liquid-glass-card__title {

    font-size: 0.95rem !important;

    font-weight: 700 !important;

    letter-spacing: 0.12em;

    color:
        rgba(255, 255, 255, 0.92) !important;

    text-transform: uppercase;
}

.liquid-glass-card__badge {

    background:
        rgba(255, 255, 255, 0.08);

    border:
        1px solid rgba(255, 255, 255, 0.06);

    backdrop-filter:
        blur(12px);

    color:
        rgba(255, 255, 255, 0.82);

    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.08);

    border-radius: 999px;
}

/* 📱 RESPONSIVE SHORTCODES & CONTENT */
@media (max-width: 768px) {
    .article-content {
        word-wrap: break-word;
        overflow-wrap: break-word;
        font-size: 1rem;
        line-height: 1.6;
    }

    .article-content p, 
    .article-content ul, 
    .article-content ol {
        margin-bottom: 1.25rem;
    }

    .gdb-shortcode-matches {
        margin: 1rem 0 !important;
    }

    .matches-archive.is-grid {
        display: flex;
        flex-direction: column;
        gap: 10px;
    }

    .gt-table-wrap {
        margin: 0;
        padding: 0;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    /* Prevents the 'sticky' menu in shortcodes from breaking on small screens */
    .liquid-glass-nav {
        gap: 5px;
    }
    
    .liquid-glass-nav__btn {
        width: 32px;
        height: 32px;
    }
}

/* ─── VISION-STANDINGS: override article-content card-table on mobile ─── */
@media (max-width: 768px) {
    .vision-standings-wrap table { display: table !important; }
    .vision-standings-wrap thead { display: table-header-group !important; }
    .vision-standings-wrap tbody { display: table-row-group !important; }
    .vision-standings-wrap tr {
        display: table-row !important;
        background: transparent !important;
        border: none !important;
        border-radius: 0 !important;
        margin-bottom: 0 !important;
        padding: 0 !important;
    }
    .vision-standings-wrap td {
        display: table-cell !important;
    }
    .vision-standings-wrap td::before { content: none !important; }
}

/* Shortcode wrappers: dark-theme enforcement on light pages (page.php = .static-page) */
.static-page .gdb-shortcode-standings,
.static-page .gdb-shortcode-matches {
    background: rgba(10, 12, 22, 0.92) !important;
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
    border: 1px solid rgba(255, 255, 255, 0.10) !important;
    border-radius: 20px;
    padding: 1.25rem !important;
    color: #fff;
}

/* Match cards: more contrast against dark shortcode background (static pages only) */
.static-page .gdb-shortcode-matches .vision-match-card {
    background: rgba(255, 255, 255, 0.07) !important;
    border-color: rgba(255, 255, 255, 0.15) !important;
}
.static-page .gdb-shortcode-matches .vision-match-card:hover {
    background: rgba(255, 255, 255, 0.12) !important;
}

/* Mobile padding tightening for shortcodes on static pages */
@media (max-width: 768px) {
    .static-page .gdb-shortcode-standings,
    .static-page .gdb-shortcode-matches {
        padding: 1rem !important;
        border-radius: 16px;
    }
    .static-page .gdb-shortcode-standings .liquid-glass-card__header,
    .static-page .gdb-shortcode-matches .liquid-glass-card__header {
        margin-bottom: 0.75rem !important;
    }
    /* Null out the negative margin bleed inside the overflow:hidden shortcode wrapper */
    .static-page .gdb-shortcode-standings .vision-standings-wrap {
        margin: 0 !important;
        padding: 0 !important;
    }
}

.is-hidden { display: none !important; }

/* --- 7. PREMIUM MATCH TIMELINE (Glassmorphism) --- */
.timeline-premium {
    position: relative;
    padding: 20px 0;
    width: 100%;
    max-width: 800px;
    margin: 0 auto;
    font-family: 'Vinila Variable', sans-serif;
}

/* Vertical Line */
.timeline-premium::before {
    content: '';
    position: absolute;
    top: 0;
    left: 45px;
    bottom: 0;
    width: 2px;
    background: linear-gradient(to bottom, 
        rgba(255, 255, 255, 0) 0%, 
        rgba(255, 255, 255, 0.15) 10%, 
        rgba(255, 255, 255, 0.15) 90%, 
        rgba(255, 255, 255, 0) 100%);
    z-index: 1;
}

.timeline-event {
    position: relative;
    display: flex;
    align-items: center;
    gap: 20px;
    margin-bottom: 16px;
    z-index: 2;
    transition: transform 0.3s ease;
}

.timeline-event:hover {
    transform: translateX(4px);
}

.timeline-minute {
    flex-shrink: 0;
    width: 45px;
    text-align: right;
    font-weight: 900;
    font-size: 1rem;
    color: var(--accent-blue);
    position: relative;
    letter-spacing: -0.5px;
}

/* The node on the line */
.timeline-minute::after {
    content: '';
    position: absolute;
    right: -14px;
    top: 50%;
    transform: translateY(-50%);
    width: 10px;
    height: 10px;
    background: #050608;
    border: 2px solid var(--accent-blue);
    border-radius: 50%;
    z-index: 3;
    box-shadow: 0 0 10px rgba(123, 176, 255, 0.4);
}

.timeline-card {
    flex: 1;
    background: rgba(255, 255, 255, 0.04);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border: 1px solid rgba(255, 255, 255, 0.1); /* Inner Glow */
    border-radius: 18px;
    padding: 12px 20px;
    display: flex;
    align-items: center;
    gap: 16px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
    position: relative;
    overflow: hidden;
}

/* Subtle light refraction on the card */
.timeline-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.1), transparent);
}

.timeline-icon {
    flex-shrink: 0;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.05);
}

.timeline-icon svg {
    width: 18px;
    height: 18px;
    filter: drop-shadow(0 0 8px currentColor);
}

.timeline-info {
    flex: 1;
    display: flex;
    flex-direction: column;
}

.timeline-player {
    font-weight: 800;
    font-size: 0.95rem;
    color: #fff;
    line-height: 1.2;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.timeline-detail {
    font-size: 0.72rem;
    font-weight: 500;
    color: rgba(255, 255, 255, 0.5);
    margin-top: 2px;
}

/* Side indicator (Small colored dot to show which team) */
.timeline-side-indicator {
    width: 4px;
    height: 24px;
    border-radius: 100px;
    background: rgba(255, 255, 255, 0.1);
    position: absolute;
    right: 12px;
}

.side-casa .timeline-side-indicator { background: var(--accent-blue); }
.side-visitante .timeline-side-indicator { background: #fff; }

/* Functional Colors for Icons */
.icon-goal { color: #10b981 !important; }       /* Emerald Green */
.icon-card-yellow { color: #facc15 !important; } /* Neon Yellow */
.icon-card-red { color: #ef4444 !important; }    /* Red */
.icon-sub { color: #60a5fa !important; }        /* Blueish */

/* Timeline Divider (First/Second Half) */
.timeline-divider-premium {
    position: relative;
    padding: 30px 0;
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 2;
}

.timeline-divider-premium::before {
    content: '';
    position: absolute;
    left: 45px;
    width: 2px;
    height: 100%;
    background: rgba(255, 255, 255, 0.05);
}

.timeline-divider-premium span {
    background: rgba(15, 20, 30, 0.8);
    backdrop-filter: blur(12px);
    border: 1px solid rgba(255, 255, 255, 0.1);
    padding: 6px 20px;
    border-radius: 100px;
    font-size: 0.7rem;
    font-weight: 900;
    color: rgba(255, 255, 255, 0.6);
    text-transform: uppercase;
    letter-spacing: 2px;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.5);
}

/* Mobile specific tweaks */
@media (max-width: 480px) {
    .timeline-premium {
        padding: 10px 0;
    }
    .timeline-event {
        gap: 12px;
    }
    .timeline-minute {
        width: 40px;
        font-size: 0.85rem;
    }
    .timeline-premium::before,
    .timeline-divider-premium::before {
        left: 40px;
    }
    .timeline-minute::after {
        right: -13px;
    }
    .timeline-card {
        padding: 10px 14px;
        gap: 12px;
    }
    .timeline-player {
        font-size: 0.8rem;
    }
}

