/* ═══════════════════════════════════════════════════════════════════════════
   ClutchMX — Tema visual por categoría de temporada (DB → LeagueSeasonDto.Categoria)
   Ancestro: .cat-scope.cat-scope--femenil | --varonil | --mixto | --juvenil
   ═══════════════════════════════════════════════════════════════════════════ */

.cat-scope {
    --cat-accent: var(--accent, #f5b100);
    --cat-accent-dim: rgba(245, 177, 0, 0.12);
    --cat-glow: rgba(245, 177, 0, 0.22);
}

/* ── Femenil — identidad rosa / magenta / morado (app deportiva) ─────────── */
.cat-scope--femenil {
    --cat-accent: #f472b6;
    --cat-accent-2: #a855f7;
    --cat-accent-dim: rgba(244, 114, 182, 0.14);
    --cat-glow: rgba(236, 72, 153, 0.45);
    --cat-surface: linear-gradient(165deg, rgba(88, 28, 72, 0.35) 0%, rgba(15, 10, 18, 0.96) 42%, #06060a 100%);
    --cat-border-glow: rgba(244, 114, 182, 0.55);
    --cat-inner-glow: 0 0 42px rgba(168, 85, 247, 0.12);
}

.cat-scope--femenil .esn-league-banner {
    position: relative;
    background: var(--cat-surface);
    border-bottom: 1px solid rgba(244, 114, 182, 0.22);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
    overflow: hidden;
}

.cat-scope--femenil .esn-league-banner::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse 90% 70% at 85% 20%, rgba(236, 72, 153, 0.18) 0%, transparent 55%),
        radial-gradient(ellipse 60% 50% at 10% 90%, rgba(168, 85, 247, 0.12) 0%, transparent 50%);
    pointer-events: none;
}

.cat-scope--femenil .esn-banner-inner {
    position: relative;
    z-index: 1;
}

/* Hero “cover” Femenil (imagen + overlay; copy space a la izquierda) */
.cat-scope--femenil .esn-league-banner--femenil-pro {
    position: relative;
    overflow: hidden;
    min-height: min(52vw, 300px);
    max-height: 380px;
    background: #0a0308;
    border-bottom: 1px solid rgba(244, 114, 182, 0.28);
    box-shadow: 0 12px 48px rgba(60, 0, 40, 0.45);
    animation: cat-hero-fade-in 0.7s ease both;
}

.cat-scope--femenil .esn-league-banner--femenil-pro::before {
    display: none;
}

.cat-scope--femenil .esn-league-banner--femenil-pro .esn-hero-canvas {
    position: absolute;
    inset: 0;
    z-index: 0;
    background:
        url("/images/league-hero-femenil.png?v=2") no-repeat 72% 100% / cover;
    opacity: 0.92;
    transform: scale(1.02);
    animation: cat-hero-pan 18s ease-in-out infinite alternate;
}

.cat-scope--femenil .esn-league-banner--femenil-pro::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
    background:
        linear-gradient(90deg, rgba(10, 3, 8, 0.94) 0%, rgba(60, 20, 48, 0.65) 40%, rgba(88, 28, 72, 0.32) 72%, rgba(5, 3, 8, 0.48) 100%),
        linear-gradient(180deg, rgba(15, 5, 12, 0.12) 0%, rgba(10, 3, 8, 0.88) 100%);
}

.cat-scope--femenil .esn-league-banner--femenil-pro .esn-banner-inner--hero {
    position: relative;
    z-index: 2;
    align-items: flex-end;
    padding-bottom: 26px;
    max-width: 1000px;
}

.cat-scope--femenil .esn-league-banner--femenil-pro .esn-banner-logo {
    box-shadow: 0 0 0 1px rgba(244, 114, 182, 0.35), 0 8px 32px rgba(168, 85, 247, 0.22);
}

.cat-scope--femenil .esn-league-banner--femenil-pro .esn-banner-title {
    text-shadow: 0 2px 28px rgba(0, 0, 0, 0.65);
}

.cat-scope--femenil .esn-banner-label {
    color: #f9a8d4;
    text-shadow: 0 0 20px rgba(244, 114, 182, 0.35);
}

.cat-scope--femenil .cat-banner-badge--femenil {
    background: linear-gradient(135deg, rgba(244, 114, 182, 0.25) 0%, rgba(168, 85, 247, 0.2) 100%);
    border: 1px solid rgba(244, 114, 182, 0.45);
    color: #fce7f3;
    box-shadow: 0 0 20px rgba(236, 72, 153, 0.25), inset 0 1px 0 rgba(255, 255, 255, 0.08);
    font-weight: 900;
    letter-spacing: 0.06em;
}

.cat-scope--femenil .cat-banner-emoji {
    margin-right: 4px;
    filter: drop-shadow(0 0 6px rgba(244, 114, 182, 0.8));
}

/* Chips de temporada — activa tipo “premium” */
.cat-scope--femenil .category-selector-container {
    background: linear-gradient(180deg, #050308 0%, #0a0610 100%);
    border-bottom-color: rgba(168, 85, 247, 0.15);
}

.cat-scope--femenil .category-chip--femenil.active {
    background: linear-gradient(145deg, #ec4899 0%, #a855f7 55%, #7c3aed 100%);
    border-color: rgba(255, 255, 255, 0.2);
    color: #fff;
    box-shadow:
        0 0 0 1px rgba(244, 114, 182, 0.35),
        0 4px 22px rgba(236, 72, 153, 0.35),
        0 0 40px rgba(168, 85, 247, 0.2);
    transform: translateY(-1px);
}

.cat-scope--femenil .category-chip--femenil:not(.active) {
    border-color: rgba(244, 114, 182, 0.22);
    background: rgba(244, 114, 182, 0.06);
    color: #e9d5ff;
}

.cat-scope--femenil .category-chip--femenil:not(.active):hover {
    border-color: rgba(244, 114, 182, 0.45);
    box-shadow: 0 0 18px rgba(236, 72, 153, 0.15);
}

.cat-scope--femenil .category-chip--femenil.is-active-season:not(.active) {
    border-color: rgba(244, 114, 182, 0.35);
    box-shadow: 0 0 16px rgba(168, 85, 247, 0.12);
}

/* Pestañas de sección (Portada, Calendario, …) — acento rosa */
.cat-scope--femenil .clutch-tab.active {
    color: #fce7f3 !important;
    border-bottom-color: #ec4899 !important;
    box-shadow: 0 8px 24px rgba(236, 72, 153, 0.12);
}

.cat-scope--varonil .clutch-tab.active {
    color: #e0f2fe !important;
    border-bottom-color: #38bdf8 !important;
}

/* Cards calendario / resultados — más glow */
.cat-scope--femenil .cal-game-card[data-cat="femenil"] {
    border-color: rgba(244, 114, 182, 0.38) !important;
    box-shadow:
        0 0 0 1px rgba(168, 85, 247, 0.12) inset,
        0 6px 28px rgba(236, 72, 153, 0.12);
    background: linear-gradient(155deg, rgba(88, 28, 72, 0.2) 0%, var(--bg-card, #111118) 52%) !important;
}

.cat-scope--femenil .cal-game-card[data-cat="femenil"]:hover {
    border-color: rgba(244, 114, 182, 0.55) !important;
    box-shadow: 0 10px 36px rgba(236, 72, 153, 0.22);
    transform: translateY(-3px);
}

/* PartidoCard (portada / listas) */
.cat-scope--femenil a.pc-card[data-cat="femenil"] {
    box-shadow: 0 0 0 1px rgba(244, 114, 182, 0.15) inset, 0 8px 32px rgba(236, 72, 153, 0.14);
}

.cat-scope--femenil a.pc-card[data-cat="femenil"]:hover {
    box-shadow: 0 0 0 1px rgba(244, 114, 182, 0.35) inset, 0 12px 40px rgba(236, 72, 153, 0.22);
}

/* ── Varonil — identidad azul / cian (NBA-style, hero Pro) ───────────────── */
.cat-scope--varonil {
    --cat-accent: #38bdf8;
    --cat-accent-2: #2563eb;
    --cat-glow: rgba(56, 189, 248, 0.45);
    --cat-surface: linear-gradient(165deg, rgba(15, 40, 72, 0.4) 0%, rgba(10, 12, 18, 0.96) 45%, #06060a 100%);
}

/* Hero tipo “cover” con imagen + overlay (fallback SVG ligero en /images/) */
.cat-scope--varonil .esn-league-banner--varonil-pro {
    position: relative;
    overflow: hidden;
    min-height: min(52vw, 300px);
    max-height: 380px;
    background: #020617;
    border-bottom: 1px solid rgba(56, 189, 248, 0.28);
    box-shadow: 0 12px 48px rgba(0, 20, 60, 0.45);
    animation: cat-hero-fade-in 0.7s ease both;
}

@keyframes cat-hero-fade-in {
    from { opacity: 0.88; filter: saturate(0.9); }
    to { opacity: 1; filter: saturate(1); }
}

.cat-scope--varonil .esn-hero-canvas {
    position: absolute;
    inset: 0;
    z-index: 0;
    background:
        url("/images/league-hero-varonil.png?v=2") no-repeat 72% 100% / cover;
    opacity: 0.92;
    transform: scale(1.02);
    animation: cat-hero-pan 18s ease-in-out infinite alternate;
}

@keyframes cat-hero-pan {
    from { transform: scale(1.02) translateX(0); }
    to { transform: scale(1.05) translateX(-1.5%); }
}

.cat-scope--varonil .esn-league-banner--varonil-pro::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
    background:
        linear-gradient(90deg, rgba(2, 6, 23, 0.94) 0%, rgba(15, 23, 42, 0.72) 38%, rgba(30, 58, 138, 0.35) 72%, rgba(2, 6, 23, 0.5) 100%),
        linear-gradient(180deg, rgba(2, 6, 23, 0.1) 0%, rgba(2, 6, 23, 0.85) 100%);
}

.cat-scope--varonil .esn-banner-inner--hero {
    position: relative;
    z-index: 2;
    align-items: flex-end;
    padding-bottom: 26px;
    max-width: 1000px;
}

.cat-scope--varonil .esn-league-banner--varonil-pro .esn-banner-logo {
    box-shadow: 0 0 0 1px rgba(56, 189, 248, 0.35), 0 8px 32px rgba(37, 99, 235, 0.25);
}

.cat-scope--varonil .esn-banner-label {
    color: #7dd3fc;
    text-shadow: 0 0 24px rgba(56, 189, 248, 0.35);
}

.cat-scope--varonil .esn-banner-title {
    text-shadow: 0 2px 28px rgba(0, 0, 0, 0.65);
}

.cat-scope--varonil .cat-banner-badge--varonil {
    background: linear-gradient(135deg, rgba(14, 165, 233, 0.35) 0%, rgba(37, 99, 235, 0.3) 100%);
    border: 1px solid rgba(125, 211, 252, 0.45);
    color: #e0f2fe;
    box-shadow: 0 0 22px rgba(56, 189, 248, 0.25), inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

.cat-scope--varonil .cat-banner-emoji {
    margin-right: 4px;
    filter: drop-shadow(0 0 8px rgba(56, 189, 248, 0.75));
}

.cat-scope--varonil .category-selector-container {
    background: linear-gradient(180deg, #020617 0%, #0a0f1a 100%);
    border-bottom-color: rgba(56, 189, 248, 0.18);
}

.cat-scope--varonil .category-chip--varonil.active {
    background: linear-gradient(145deg, #0ea5e9 0%, #2563eb 55%, #1d4ed8 100%);
    border-color: rgba(186, 230, 253, 0.45);
    color: #fff;
    box-shadow:
        0 0 0 1px rgba(56, 189, 248, 0.4),
        0 6px 26px rgba(37, 99, 235, 0.45),
        0 0 40px rgba(14, 165, 233, 0.2);
    transform: translateY(-1px);
}

.cat-scope--varonil .category-chip--varonil:not(.active) {
    border-color: rgba(56, 189, 248, 0.28);
    background: rgba(15, 40, 72, 0.35);
    color: #bae6fd;
}

.cat-scope--varonil .category-chip--varonil:not(.active):hover {
    border-color: rgba(125, 211, 252, 0.5);
    box-shadow: 0 0 22px rgba(37, 99, 235, 0.2);
}

/* CTA video hero (sin autoplay; el &lt;video&gt; solo existe al expandir) */
.cat-scope--varonil .esn-hero-cta {
    margin-top: 14px;
}

.cat-scope--varonil .esn-hero-anim-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 16px;
    border-radius: 999px;
    font-size: 0.72rem;
    font-weight: 900;
    letter-spacing: 0.06em;
    cursor: pointer;
    border: 1px solid rgba(56, 189, 248, 0.45);
    color: #e0f2fe;
    background: rgba(15, 40, 72, 0.55);
    box-shadow: 0 0 20px rgba(37, 99, 235, 0.2);
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.cat-scope--varonil .esn-hero-anim-btn:hover {
    transform: translateY(-2px);
    border-color: rgba(125, 211, 252, 0.65);
    box-shadow: 0 8px 28px rgba(37, 99, 235, 0.35);
}

.cat-scope--varonil .esn-hero-video-shell {
    margin-top: 14px;
    border-radius: 14px;
    overflow: hidden;
    border: 1px solid rgba(56, 189, 248, 0.3);
    background: #020617;
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.5);
}

.cat-scope--varonil .esn-hero-video {
    display: block;
    width: 100%;
    max-height: min(42vh, 320px);
    background: #000;
}

.cat-scope--varonil .esn-hero-video-hint {
    margin: 0;
    padding: 8px 12px 10px;
    font-size: 0.62rem;
    color: #64748b;
    line-height: 1.35;
}

.cat-scope--varonil .esn-hero-video-hint code {
    font-size: 0.58rem;
    color: #94a3b8;
}

/* Cards partidos — glow azul bajo vista Varonil */
.cat-scope--varonil .cal-game-card[data-cat="varonil"] {
    border-color: rgba(56, 189, 248, 0.4) !important;
    box-shadow:
        0 0 0 1px rgba(37, 99, 235, 0.12) inset,
        0 8px 32px rgba(37, 99, 235, 0.14);
    background: linear-gradient(155deg, rgba(15, 40, 72, 0.28) 0%, var(--bg-card, #111118) 52%) !important;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.cat-scope--varonil .cal-game-card[data-cat="varonil"]:hover {
    border-color: rgba(125, 211, 252, 0.55) !important;
    box-shadow: 0 14px 42px rgba(37, 99, 235, 0.28);
    transform: translateY(-3px);
}

.cat-scope--varonil a.pc-card[data-cat="varonil"] {
    box-shadow: 0 0 0 1px rgba(56, 189, 248, 0.12) inset, 0 10px 36px rgba(37, 99, 235, 0.12);
}

.cat-scope--varonil a.pc-card[data-cat="varonil"]:hover {
    box-shadow: 0 0 0 1px rgba(56, 189, 248, 0.28) inset, 0 14px 44px rgba(37, 99, 235, 0.22);
}

@media (prefers-reduced-motion: reduce) {
    .cat-scope--varonil .esn-hero-canvas,
    .cat-scope--femenil .esn-league-banner--femenil-pro .esn-hero-canvas {
        animation: none;
    }
    .cat-scope--varonil .esn-league-banner--varonil-pro,
    .cat-scope--femenil .esn-league-banner--femenil-pro {
        animation: none;
    }
}

/* Hero Pro: muy compacto en móvil (priorizar calendario / contenido) */
@media (max-width: 900px) {
    .cat-scope--varonil .esn-league-banner--varonil-pro,
    .cat-scope--femenil .esn-league-banner--femenil-pro {
        min-height: min(16vh, 104px);
        max-height: min(24vh, 156px);
    }
    .cat-scope--varonil .esn-hero-canvas,
    .cat-scope--femenil .esn-league-banner--femenil-pro .esn-hero-canvas {
        opacity: 0.58;
    }
    .cat-scope--varonil .esn-league-banner--varonil-pro::after,
    .cat-scope--femenil .esn-league-banner--femenil-pro::after {
        box-shadow: inset 0 -28px 64px rgba(0, 0, 0, 0.62);
    }
    .cat-scope--varonil .esn-banner-inner--hero,
    .cat-scope--femenil .esn-banner-inner--hero {
        align-items: center;
        padding-bottom: 8px;
        gap: 8px;
    }
    .cat-scope--varonil .esn-league-banner--varonil-pro .esn-banner-label,
    .cat-scope--femenil .esn-league-banner--femenil-pro .esn-banner-label {
        display: none;
    }
    .cat-scope--varonil .esn-league-banner--varonil-pro .esn-banner-logo,
    .cat-scope--femenil .esn-league-banner--femenil-pro .esn-banner-logo {
        width: 40px;
        height: 40px;
        padding: 4px;
        border-radius: 10px;
    }
    .cat-scope--varonil .esn-league-banner--varonil-pro .esn-banner-title,
    .cat-scope--femenil .esn-league-banner--femenil-pro .esn-banner-title {
        font-size: clamp(0.82rem, 3.6vw, 1.1rem);
        margin-bottom: 2px;
        line-height: 1.1;
    }
    .cat-scope--varonil .esn-banner-season,
    .cat-scope--femenil .esn-banner-season {
        font-size: 0.68rem;
    }
    .cat-scope--varonil .cat-banner-badge--varonil,
    .cat-scope--femenil .cat-banner-badge--femenil {
        font-size: 0.5rem;
        padding: 2px 7px;
        border-radius: 999px;
        letter-spacing: 0.06em;
    }
}

@media (max-width: 640px) {
    .cat-scope--varonil .esn-hero-canvas,
    .cat-scope--femenil .esn-league-banner--femenil-pro .esn-hero-canvas {
        background-position: 58% 100%;
    }
}

/* Mixto / Juvenil — banners suaves */
.cat-scope--mixto .esn-league-banner {
    background: linear-gradient(165deg, rgba(76, 29, 120, 0.25) 0%, #080810 100%);
    border-bottom-color: rgba(167, 139, 250, 0.2);
}

.cat-scope--juvenil .esn-league-banner {
    background: linear-gradient(165deg, rgba(22, 80, 50, 0.3) 0%, #080810 100%);
    border-bottom-color: rgba(74, 222, 128, 0.2);
}

/* ══ Vista pública de partido (.pv-theme = mismo bloque cat-scope) ═════════ */
.pv-theme.cat-scope--femenil .pv-hero {
    background: #030105;
    border-bottom: 1px solid rgba(244, 114, 182, 0.18);
}

.pv-theme.cat-scope--femenil .pv-hero-bg {
    background:
        radial-gradient(ellipse 100% 80% at 50% 120%, rgba(236, 72, 153, 0.14) 0%, transparent 55%),
        radial-gradient(ellipse 70% 50% at 10% 0%, rgba(168, 85, 247, 0.1) 0%, transparent 45%);
}

.pv-theme.cat-scope--femenil .pv-hero-card {
    padding: 18px 16px 20px;
    border-radius: 18px;
    border: 1px solid rgba(244, 114, 182, 0.28);
    background: linear-gradient(165deg, rgba(60, 20, 48, 0.45) 0%, rgba(8, 6, 12, 0.92) 55%);
    box-shadow:
        0 0 0 1px rgba(168, 85, 247, 0.08) inset,
        0 12px 40px rgba(0, 0, 0, 0.45),
        0 0 48px rgba(236, 72, 153, 0.08);
}

.pv-theme.cat-scope--femenil .pv-liga-tag {
    border-color: rgba(244, 114, 182, 0.35);
    color: #fbcfe8;
    background: rgba(244, 114, 182, 0.08);
}

.pv-theme.cat-scope--femenil .pv-pill-upcoming {
    border-color: rgba(244, 114, 182, 0.35);
    color: #f9a8d4;
    background: rgba(88, 28, 72, 0.35);
}

.pv-theme.cat-scope--femenil .pv-score-win {
    color: #f472b6;
    text-shadow: 0 0 24px rgba(244, 114, 182, 0.35);
}

.pv-cat-pill {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 0.62rem;
    font-weight: 900;
    letter-spacing: 0.1em;
    padding: 5px 12px;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.12);
    background: rgba(255, 255, 255, 0.05);
    color: #e5e5e5;
}

.pv-cat-pill--femenil {
    background: linear-gradient(135deg, rgba(244, 114, 182, 0.2) 0%, rgba(168, 85, 247, 0.16) 100%);
    border-color: rgba(244, 114, 182, 0.4);
    color: #fce7f3;
    box-shadow: 0 0 18px rgba(236, 72, 153, 0.15);
}

.pv-cat-pill--varonil {
    background: linear-gradient(135deg, rgba(56, 189, 248, 0.22) 0%, rgba(37, 99, 235, 0.16) 100%);
    border-color: rgba(125, 211, 252, 0.4);
    color: #e0f2fe;
    box-shadow: 0 0 18px rgba(37, 99, 235, 0.18);
}

.pv-cat-pill--mixto {
    background: rgba(167, 139, 250, 0.12);
    border-color: rgba(167, 139, 250, 0.35);
    color: #e9d5ff;
}

.pv-cat-pill--juvenil {
    background: rgba(74, 222, 128, 0.1);
    border-color: rgba(74, 222, 128, 0.3);
    color: #bbf7d0;
}

.pv-theme.cat-scope--varonil .pv-hero {
    background: #030810;
    border-bottom: 1px solid rgba(56, 189, 248, 0.15);
}

.pv-theme.cat-scope--varonil .pv-hero-bg {
    background:
        radial-gradient(ellipse 90% 70% at 70% 110%, rgba(37, 99, 235, 0.12) 0%, transparent 55%);
}

.pv-theme.cat-scope--varonil .pv-hero-card {
    padding: 18px 16px 20px;
    border-radius: 18px;
    border: 1px solid rgba(56, 189, 248, 0.35);
    background: linear-gradient(165deg, rgba(15, 45, 80, 0.5) 0%, rgba(6, 8, 14, 0.96) 55%);
    box-shadow:
        0 0 0 1px rgba(56, 189, 248, 0.1) inset,
        0 12px 44px rgba(0, 0, 0, 0.45),
        0 0 48px rgba(37, 99, 235, 0.12);
}
