﻿/* =========================================================
   RACE PAGE (PREMIUM) - ISOLATED
   Fixes:
   - Adds safe top spacing for fixed navbar
   - Normalizes font size to match site
   - Keeps hero big, body readable
========================================================= */

.race-premium {
    --glass: rgba(0,0,0,.44);
    --glass2: rgba(0,0,0,.32);
    --b: rgba(255,255,255,.16);
    --b2: rgba(255,255,255,.10);
    --txt: rgba(255,255,255,.92);
    --muted: rgba(255,255,255,.72);
    --mx: 50;
    --my: 35;
    color: var(--txt);
    /* ✅ Don't override the whole site typography */
    font-family: inherit;
    font-size: 16px;
    line-height: 1.6;
}

/* ✅ Safe spacing because navbar is fixed-top */
.race-premium {
    padding-top: 50px; /* adjust if your navbar is taller/shorter */
}

@media (max-width: 991px) {
    .race-premium {
        padding-top: 86px;
    }
}

.race-premium, .race-premium * {
    box-sizing: border-box;
}

    /* Kill default white buttons */
    .race-premium button {
        -webkit-appearance: none;
        appearance: none;
        border: 0;
        background: none;
        padding: 0;
        margin: 0;
        color: inherit;
        font: inherit;
        text-align: inherit;
        cursor: pointer;
    }

    /* ---------------------------
   HERO
--------------------------- */
    .race-premium .race-hero {
        position: relative;
        padding: 56px 0 52px;
        /* Page hero background */
        background-image: url("../img/pages/chooseyourrace.png");
        background-size: cover;
        background-position: center;
        background-repeat: no-repeat;
        background-color: #000;
        overflow: hidden;
    }

        .race-premium .race-hero::before {
            content: "";
            position: absolute;
            inset: 0;
            background: radial-gradient(circle at 50% 10%, rgba(255,255,255,.20), transparent 55%), radial-gradient(circle at 15% 90%, rgba(94,187,217,.16), transparent 55%), radial-gradient(circle at 85% 80%, rgba(141,193,53,.14), transparent 55%), linear-gradient(180deg, var(--aa-page-overlay-top, rgba(7, 10, 18, .50)), var(--aa-page-overlay-mid, rgba(7, 10, 18, .62)) 45%, var(--aa-page-overlay-bottom, rgba(7, 10, 18, .80)));
            backdrop-filter: blur(var(--aa-page-backdrop-blur, 2px));
            -webkit-backdrop-filter: blur(var(--aa-page-backdrop-blur, 2px));
            pointer-events: none;
        }

    .race-premium .race-hero-inner {
        position: relative;
        max-width: 980px;
        margin: 0 auto;
        text-align: center;
    }

    .race-premium .race-hero-kicker {
        font-weight: 800;
        letter-spacing: 2px;
        text-transform: uppercase;
        opacity: .85;
        font-size: 12px;
    }

    .race-premium .race-hero-title {
        margin-top: 10px;
        font-family: "Cinzel", serif; /* ✅ only hero uses Cinzel */
        font-size: clamp(34px, 4.6vw, 62px);
        font-weight: 900;
        letter-spacing: 1.2px;
        text-transform: uppercase;
        text-shadow: 0 18px 55px rgba(0,0,0,.7);
    }

    .race-premium .race-hero-sub {
        margin: 14px auto 0;
        max-width: 900px;
        opacity: .94;
        line-height: 1.75;
        font-size: 16px;
    }

    .race-premium .race-hero-badges {
        display: flex;
        justify-content: center;
        gap: 10px;
        margin-top: 18px;
        flex-wrap: wrap;
    }

    .race-premium .race-chip {
        padding: 9px 12px;
        border-radius: 999px;
        border: 1px solid rgba(255,255,255,.16);
        background: rgba(0,0,0,.32);
        font-weight: 800;
        letter-spacing: .7px;
        text-transform: uppercase;
        font-size: 12px;
    }

    /* ---------------------------
   STAGE
--------------------------- */
    .race-premium .race-stage-section {
        position: relative;
        padding: 44px 0 54px;
        background-image: url("../img/bg/abyss.jpg");
        background-size: cover;
        background-position: center;
        overflow: hidden;
    }

        .race-premium .race-stage-section::before {
            content: "";
            position: absolute;
            inset: 0;
            background: radial-gradient(circle at 50% 30%, rgba(255,255,255,.12), transparent 60%), linear-gradient(180deg, var(--aa-page-overlay-top, rgba(7, 10, 18, .50)), var(--aa-page-overlay-mid, rgba(7, 10, 18, .62)) 45%, var(--aa-page-overlay-bottom, rgba(7, 10, 18, .80)));
            backdrop-filter: blur(var(--aa-page-backdrop-blur, 2px));
            -webkit-backdrop-filter: blur(var(--aa-page-backdrop-blur, 2px));
            pointer-events: none;
        }

    .race-premium .race-stage-head {
        position: relative;
        display: flex;
        align-items: flex-end;
        justify-content: space-between;
        gap: 12px;
        flex-wrap: wrap;
        margin-bottom: 14px;
    }

    .race-premium .race-stage-kicker {
        font-size: 12px;
        font-weight: 800;
        letter-spacing: 2px;
        text-transform: uppercase;
        opacity: .86;
    }

    .race-premium .race-stage-title {
        margin: 8px 0 0;
        font-family: "Cinzel", serif;
        font-size: clamp(22px, 3vw, 32px);
        font-weight: 900;
        text-transform: uppercase;
        letter-spacing: 1px;
    }

    .race-premium .race-stage-pill {
        display: inline-flex;
        align-items: center;
        gap: 10px;
        padding: 10px 14px;
        border-radius: 999px;
        border: 1px solid rgba(255,255,255,.16);
        background: rgba(0,0,0,.38);
        backdrop-filter: blur(10px);
        font-size: 13px;
    }

    .race-premium .race-stage-pill-dot {
        width: 10px;
        height: 10px;
        border-radius: 50%;
        background: rgba(255,255,255,.55);
        box-shadow: 0 0 0 3px rgba(255,255,255,.08);
    }

    .race-premium[data-selected="elyos"] .race-stage-pill-dot {
        background: rgba(var(--race-elyos-rgb), .95);
        box-shadow: 0 0 0 3px rgba(var(--race-elyos-rgb), .14);
    }

    .race-premium[data-selected="asmodians"] .race-stage-pill-dot {
        background: rgba(var(--race-asmodians-rgb), .95);
        box-shadow: 0 0 0 3px rgba(var(--race-asmodians-rgb), .14);
    }

    .race-premium .race-stage-shell {
        position: relative;
        overflow: hidden;
        border-radius: 22px;
        border: 1px solid rgba(255,255,255,.16);
        background: rgba(0,0,0,.26);
        backdrop-filter: blur(12px);
        box-shadow: 0 28px 80px rgba(0,0,0,.65);
        padding: 18px;
        z-index: 1;
    }

    .race-premium .race-stars {
        position: absolute;
        inset: 0;
        width: 100%;
        height: 100%;
        opacity: .9;
    }

    .race-premium .race-spotlight {
        position: absolute;
        inset: -2px;
        background: radial-gradient(circle at calc(var(--mx) * 1%) calc(var(--my) * 1%), rgba(255,255,255,.18), transparent 40%), radial-gradient(circle at 20% 85%, rgba(94,187,217,.12), transparent 55%), radial-gradient(circle at 80% 75%, rgba(141,193,53,.10), transparent 55%);
        pointer-events: none;
        mix-blend-mode: screen;
        opacity: .85;
    }

    .race-premium .race-runelines {
        position: absolute;
        inset: 0;
        background-image: linear-gradient(90deg, rgba(255,255,255,.10) 0%, transparent 45%, rgba(255,255,255,.08) 100%);
        mask-image: radial-gradient(circle at 50% 50%, rgba(0,0,0,1) 0%, rgba(0,0,0,0) 65%);
        opacity: .14;
        pointer-events: none;
    }

    .race-premium .race-split {
        position: relative;
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 16px;
        z-index: 2;
    }

    .race-premium .race-tile {
        position: relative;
        display: grid;
        grid-template-rows: 1fr auto auto;
        min-height: 360px;
        padding: 18px;
        border-radius: 18px;
        border: 1px solid rgba(255,255,255,.14);
        background: linear-gradient(180deg, rgba(0,0,0,.58), rgba(0,0,0,.26)) !important;
        color: var(--txt) !important;
        overflow: hidden;
        outline: none;
        transition: transform .24s ease, filter .24s ease, opacity .24s ease, box-shadow .24s ease;
    }

    .race-premium .race-tile-name {
        font-family: "Cinzel", serif;
        font-size: 18px;
        font-weight: 900;
        letter-spacing: 1px;
        text-transform: uppercase;
    }

    .race-premium .race-tile-tag {
        margin-top: 4px;
        opacity: .86;
        letter-spacing: .4px;
        font-size: 13px;
    }

    .race-premium .race-tile-action {
        margin-top: 14px;
        padding-top: 12px;
        border-top: 1px solid rgba(255,255,255,.10);
        display: flex;
        align-items: center;
        justify-content: space-between;
        font-weight: 900;
        letter-spacing: .6px;
        text-transform: uppercase;
        font-size: 12px;
        opacity: .95;
    }

    .race-premium .race-tile-logoWrap {
        display: flex;
        align-items: center;
        justify-content: center;
        padding: 12px 10px 0;
    }

    .race-premium .race-tile-logo {
        width: 100%;
        max-width: 560px;
        max-height: 240px;
        object-fit: contain;
        filter: drop-shadow(0 18px 42px rgba(0,0,0,.70));
        transition: transform .28s ease;
    }

    .race-premium .race-tile:hover {
        transform: translateY(-3px);
    }

        .race-premium .race-tile:hover .race-tile-logo {
            transform: translateY(-4px) scale(1.01);
        }

    /* Selected layout: push aside */
    .race-premium[data-selected="elyos"] .race-split {
        grid-template-columns: 1.25fr .55fr;
    }

    .race-premium[data-selected="asmodians"] .race-split {
        grid-template-columns: .55fr 1.25fr;
    }

    .race-premium[data-selected="elyos"] .race-tile.asmodians,
    .race-premium[data-selected="asmodians"] .race-tile.elyos {
        opacity: .44;
        filter: saturate(.9) contrast(.98);
    }

    .race-premium[data-selected="elyos"] .race-tile.asmodians {
        transform: translateX(28px) scale(.96);
    }

    .race-premium[data-selected="asmodians"] .race-tile.elyos {
        transform: translateX(-28px) scale(.96);
    }

    .race-premium[data-selected="elyos"] .race-tile.elyos,
    .race-premium[data-selected="asmodians"] .race-tile.asmodians {
        opacity: 1;
        filter: saturate(1.06) contrast(1.02);
        box-shadow: 0 0 0 2px rgba(var(--race-rgb), .22), 0 26px 80px rgba(0,0,0,.65);
    }

    .race-premium .race-stage-foot {
        position: relative;
        z-index: 2;
        display: flex;
        justify-content: space-between;
        gap: 12px;
        margin-top: 14px;
        flex-wrap: wrap;
        align-items: center;
    }

    .race-premium .race-stage-hint {
        display: flex;
        gap: 6px;
        align-items: center;
        opacity: .88;
        font-size: 13px;
    }

    .race-premium .race-kbd {
        padding: 6px 10px;
        border-radius: 10px;
        border: 1px solid rgba(255,255,255,.14);
        background: rgba(0,0,0,.35);
        font-weight: 900;
        letter-spacing: .6px;
        font-size: 12px;
    }

    /* ---------------------------
   DETAILS
--------------------------- */
    .race-premium .race-details-section {
        position: relative;
        padding: 54px 0 70px;
        background-image: url("../img/bg/pack.jpg");
        background-size: cover;
        background-position: center;
    }

        .race-premium .race-details-section::before {
            content: "";
            position: absolute;
            inset: 0;
            background: linear-gradient(180deg, rgba(0,0,0,.72), rgba(0,0,0,.62));
            pointer-events: none;
        }

        .race-premium .race-details-section .container {
            position: relative;
            z-index: 1;
        }

    .race-premium .race-panel {
        border: 1px solid rgba(255,255,255,.16);
        border-radius: 22px;
        background: rgba(0,0,0,.55);
        backdrop-filter: blur(10px);
        padding: 18px;
        box-shadow: 0 28px 90px rgba(0,0,0,.65);
        overflow: hidden;
        margin-bottom: 18px;
    }

    .race-premium .race-panel-title {
        margin-top: 10px;
        font-family: "Cinzel", serif;
        font-size: clamp(22px, 2.6vw, 34px);
        font-weight: 900;
        letter-spacing: .6px;
        text-transform: uppercase;
    }

    .race-premium .race-panel-sub {
        margin: 10px 0 0;
        opacity: .92;
        line-height: 1.75;
        max-width: 980px;
        font-size: 15.5px;
    }

    .race-premium .race-tabs {
        display: flex;
        flex-wrap: wrap;
        gap: 10px;
        margin-top: 12px;
    }

    .race-premium .race-tab {
        border: 1px solid rgba(255,255,255,.14);
        background: rgba(0,0,0,.34);
        color: rgba(255,255,255,.88);
        padding: 10px 12px;
        border-radius: 999px;
        font-weight: 900;
        letter-spacing: .8px;
        text-transform: uppercase;
        font-size: 12px;
        transition: background .2s ease, border-color .2s ease, transform .2s ease;
    }

        .race-premium .race-tab:hover {
            transform: translateY(-1px);
        }

        .race-premium .race-tab.active {
            background: rgba(var(--race-rgb), .16);
            border-color: rgba(var(--race-rgb), .35);
            color: rgba(var(--race-rgb), .95);
        }

    .race-premium .race-tabpanels {
        margin-top: 14px;
    }

    .race-premium .race-tabpanel {
        display: none;
    }

        .race-premium .race-tabpanel.active {
            display: block;
        }

    .race-premium .race-grid {
        display: grid;
        grid-template-columns: 1fr;
        gap: 16px;
    }

@media(min-width: 992px) {
    .race-premium .race-grid {
        grid-template-columns: 1fr 1fr;
    }
}

.race-premium .race-card {
    border: 1px solid rgba(255,255,255,.12);
    background: rgba(0,0,0,.35);
    border-radius: 18px;
    padding: 16px;
    box-shadow: 0 14px 36px rgba(0,0,0,.45);
}

.race-premium .race-card-title {
    font-size: 12px;
    font-weight: 900;
    letter-spacing: 2px;
    text-transform: uppercase;
    opacity: .78;
    margin-bottom: 10px;
}

.race-premium .race-card-text {
    opacity: .93;
    line-height: 1.7;
    font-size: 15px;
}

.race-premium .race-card-media {
    position: relative;
    min-height: 320px;
    background-size: cover;
    background-position: center;
    padding: 0;
    overflow: hidden;
}

.race-premium .race-card-media-overlay {
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 50% 10%, rgba(255,255,255,.18), transparent 55%), linear-gradient(180deg, rgba(0,0,0,.55), rgba(0,0,0,.62));
    pointer-events: none;
}

.race-premium .race-card-media-content {
    position: relative;
    padding: 16px;
    height: 100%;
    display: grid;
    align-content: end;
    gap: 12px;
}

.race-premium .race-list {
    margin: 0;
    padding-left: 18px;
    opacity: .95;
    font-size: 14.8px;
}

    .race-premium .race-list li {
        margin: 8px 0;
    }

.race-premium .race-note {
    margin-top: 10px;
    padding: 12px;
    border-radius: 16px;
    border: 1px solid rgba(255,255,255,.12);
    background: rgba(0,0,0,.30);
    opacity: .88;
    font-size: 14.5px;
}

/* Mobile */
@media(max-width: 991px) {
    .race-premium .race-stage-shell {
        padding: 14px;
    }

    .race-premium .race-split {
        grid-template-columns: 1fr;
    }

    .race-premium .race-tile {
        min-height: 330px;
    }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
    .race-premium * {
        transition: none !important;
        animation: none !important;
    }
}
/* =========================================================
   DETAILS / CARDS UPGRADE (PREMIUM OVERRIDES)
   Paste this at the END of race-premium.css
========================================================= */

.race-premium {
    --race-elyos-rgb: 145, 210, 90;
    --race-asmodians-rgb: 90, 185, 230;
    --card-bg-a: rgba(0,0,0,.58);
    --card-bg-b: rgba(0,0,0,.34);
    --card-stroke: rgba(255,255,255,.12);
    --card-stroke-2: rgba(255,255,255,.08);
    --shadow-soft: 0 18px 55px rgba(0,0,0,.55);
    --shadow-hard: 0 30px 90px rgba(0,0,0,.68);
}

    .race-premium .race-details-section .container {
        max-width: 1120px;
    }

    /* Set accent per panel */
    .race-premium .race-panel[data-race="elyos"] {
        --race-rgb: var(--race-elyos-rgb);
    }

    .race-premium .race-panel[data-race="asmodians"] {
        --race-rgb: var(--race-asmodians-rgb);
    }

    /* Panel shell */
    .race-premium .race-panel {
        position: relative;
        border-radius: 24px;
        border: 1px solid transparent;
        background: radial-gradient(circle at 15% 20%, rgba(var(--race-rgb), .12), transparent 45%), linear-gradient(180deg, rgba(0,0,0,.62), rgba(0,0,0,.44)) padding-box, linear-gradient(135deg, rgba(var(--race-rgb), .45), rgba(255,255,255,.12), rgba(255,255,255,.06), rgba(var(--race-rgb), .18) ) border-box;
        box-shadow: var(--shadow-hard);
        overflow: hidden;
        padding: 18px;
    }

        .race-premium .race-panel::after {
            content: "";
            position: absolute;
            inset: -2px;
            background: radial-gradient(circle at 50% 0%, rgba(255,255,255,.18), transparent 45%), radial-gradient(circle at 80% 70%, rgba(var(--race-rgb), .10), transparent 55%);
            pointer-events: none;
            opacity: .55;
        }

    /* Badge */
    .race-premium .race-badge {
        display: inline-flex;
        align-items: center;
        gap: 10px;
        padding: 9px 12px;
        border-radius: 999px;
        border: 1px solid rgba(255,255,255,.14);
        background: rgba(0,0,0,.35);
        backdrop-filter: blur(10px);
        font-weight: 900;
        letter-spacing: 1.8px;
        font-size: 12px;
        text-transform: uppercase;
        color: rgba(255,255,255,.92);
    }

        .race-premium .race-badge::before {
            content: "";
            width: 10px;
            height: 10px;
            border-radius: 50%;
            background: rgba(var(--race-rgb), .95);
            box-shadow: 0 0 0 3px rgba(var(--race-rgb), .14);
        }

    /* Titles / text */
    .race-premium .race-panel-title {
        margin-top: 12px;
        letter-spacing: .9px;
    }

    .race-premium .race-panel-sub {
        font-size: 15.5px;
        opacity: .92;
        max-width: 980px;
    }

    /* Tabs: better premium pills */
    .race-premium .race-tabs {
        margin-top: 14px;
        gap: 10px;
    }

    .race-premium .race-tab {
        position: relative;
        padding: 10px 14px;
        border-radius: 999px;
        border: 1px solid rgba(255,255,255,.14);
        background: rgba(0,0,0,.30);
        color: rgba(255,255,255,.86);
        box-shadow: 0 10px 26px rgba(0,0,0,.28);
    }

        .race-premium .race-tab:hover {
            border-color: rgba(var(--race-rgb), .32);
            background: rgba(var(--race-rgb), .08);
        }

        .race-premium .race-tab.active {
            background: linear-gradient(180deg, rgba(var(--race-rgb), .22), rgba(0,0,0,.28));
            border-color: rgba(var(--race-rgb), .40);
            color: rgba(255,255,255,.96);
            box-shadow: 0 16px 40px rgba(0,0,0,.35);
        }

    /* Grid spacing */
    .race-premium .race-grid {
        gap: 18px;
    }

    /* Card: gem border + glass + hover */
    .race-premium .race-card {
        position: relative;
        border-radius: 20px;
        border: 1px solid transparent;
        background: linear-gradient(180deg, var(--card-bg-a), var(--card-bg-b)) padding-box, linear-gradient(135deg, rgba(var(--race-rgb), .40), rgba(255,255,255,.12), rgba(255,255,255,.06), rgba(var(--race-rgb), .18) ) border-box;
        box-shadow: var(--shadow-soft);
        overflow: hidden;
        padding: 18px;
        transition: transform .18s ease, box-shadow .18s ease, filter .18s ease;
    }

        .race-premium .race-card::before {
            content: "";
            position: absolute;
            inset: 0;
            background: radial-gradient(circle at 18% 10%, rgba(255,255,255,.16), transparent 40%), radial-gradient(circle at 80% 70%, rgba(var(--race-rgb), .10), transparent 55%);
            opacity: .55;
            pointer-events: none;
        }

        .race-premium .race-card:hover {
            transform: translateY(-2px);
            box-shadow: 0 26px 78px rgba(0,0,0,.62);
            filter: saturate(1.03) contrast(1.02);
        }

    /* Card titles / text */
    .race-premium .race-card-title {
        position: relative;
        margin-bottom: 10px;
        font-weight: 900;
        letter-spacing: 2px;
        text-transform: uppercase;
        font-size: 12px;
        opacity: .78;
        padding-bottom: 10px;
    }

        .race-premium .race-card-title::after {
            content: "";
            position: absolute;
            left: 0;
            right: 0;
            bottom: 0;
            height: 1px;
            background: linear-gradient(90deg, rgba(var(--race-rgb), .42), rgba(255,255,255,.10), transparent );
            opacity: .75;
        }

    .race-premium .race-card-text {
        position: relative;
        font-size: 15.2px;
        opacity: .92;
        line-height: 1.75;
    }

    /* Timeline: premium pills */
    .race-premium .race-timeline {
        position: relative;
        display: flex;
        gap: 8px;
        margin-top: 14px;
        padding-bottom: 6px;
        overflow: auto;
        scrollbar-width: thin;
    }

    .race-premium .race-step {
        flex: 0 0 auto;
        padding: 9px 12px;
        border-radius: 999px;
        border: 1px solid rgba(255,255,255,.14);
        background: rgba(0,0,0,.28);
        color: rgba(255,255,255,.86);
        font-weight: 900;
        letter-spacing: 1.2px;
        text-transform: uppercase;
        font-size: 11px;
        transition: transform .16s ease, border-color .16s ease, background .16s ease;
    }

        .race-premium .race-step:hover {
            transform: translateY(-1px);
            border-color: rgba(var(--race-rgb), .35);
        }

        .race-premium .race-step.active {
            background: rgba(var(--race-rgb), .18);
            border-color: rgba(var(--race-rgb), .42);
            color: rgba(255,255,255,.98);
            box-shadow: 0 14px 35px rgba(0,0,0,.35);
        }

    /* Step text: inset “lore panel” */
    .race-premium .race-steptext {
        margin-top: 12px;
        padding: 14px 14px;
        border-radius: 16px;
        border: 1px solid rgba(255,255,255,.10);
        background: rgba(0,0,0,.26);
        box-shadow: 0 12px 34px rgba(0,0,0,.35);
        font-size: 15px;
        line-height: 1.75;
        opacity: .94;
    }

    /* Media card */
    .race-premium .race-card-media {
        padding: 0 !important;
        border-color: rgba(255,255,255,.10) !important;
    }

    .race-premium .race-card-media-content {
        padding: 18px !important;
    }

    /* Stat row */
    .race-premium .race-statrow {
        display: grid;
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 10px;
    }

@media(max-width: 520px) {
    .race-premium .race-statrow {
        grid-template-columns: 1fr;
    }
}

.race-premium .race-stat {
    border-radius: 16px;
    border: 1px solid rgba(255,255,255,.12);
    background: rgba(0,0,0,.30);
    backdrop-filter: blur(8px);
    padding: 12px;
    box-shadow: 0 12px 30px rgba(0,0,0,.35);
}

.race-premium .race-stat-num {
    font-weight: 900;
    font-size: 22px;
    letter-spacing: .5px;
    color: rgba(255,255,255,.96);
}

.race-premium .race-stat-label {
    margin-top: 2px;
    font-size: 12px;
    letter-spacing: 1.6px;
    text-transform: uppercase;
    opacity: .72;
}

/* Quote */
.race-premium .race-quote {
    margin-top: 14px;
    padding: 12px 14px;
    border-radius: 16px;
    border: 1px solid rgba(var(--race-rgb), .24);
    background: rgba(var(--race-rgb), .08);
    color: rgba(255,255,255,.92);
    box-shadow: 0 14px 34px rgba(0,0,0,.30);
    font-style: italic;
    line-height: 1.65;
}

    .race-premium .race-quote::before {
        content: "";
        display: block;
        width: 46px;
        height: 3px;
        border-radius: 999px;
        background: rgba(var(--race-rgb), .70);
        margin-bottom: 10px;
    }

/* CTA row spacing + subtle button polish inside this page only */
.race-premium .race-ctaRow {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    align-items: center;
    margin-top: 12px;
}

    .race-premium .race-ctaRow .btn {
        border-radius: 14px;
        padding: 10px 14px;
    }

        .race-premium .race-ctaRow .btn.btn-primary {
            box-shadow: 0 18px 40px rgba(0,0,0,.35);
        }

            .race-premium .race-ctaRow .btn.btn-primary:hover {
                box-shadow: 0 24px 70px rgba(0,0,0,.55);
            }

/* Lists: better bullets */
.race-premium .race-list {
    padding-left: 0;
    list-style: none;
    margin: 0;
}

    .race-premium .race-list li {
        position: relative;
        padding-left: 18px;
        margin: 10px 0;
        opacity: .93;
        line-height: 1.7;
        font-size: 14.9px;
    }

        .race-premium .race-list li::before {
            content: "";
            position: absolute;
            left: 0;
            top: .62em;
            width: 8px;
            height: 8px;
            border-radius: 50%;
            background: rgba(var(--race-rgb), .85);
            box-shadow: 0 0 0 3px rgba(var(--race-rgb), .14);
        }

/* Ordered steps */
.race-premium .race-steps {
    counter-reset: step;
    margin: 10px 0 0;
    padding: 0;
    list-style: none;
}

    .race-premium .race-steps li {
        counter-increment: step;
        display: flex;
        gap: 12px;
        align-items: flex-start;
        padding: 12px 12px;
        border-radius: 16px;
        border: 1px solid rgba(255,255,255,.10);
        background: rgba(0,0,0,.22);
        margin-top: 10px;
    }

        .race-premium .race-steps li::before {
            content: counter(step);
            flex: 0 0 auto;
            width: 34px;
            height: 34px;
            border-radius: 12px;
            display: grid;
            place-items: center;
            font-weight: 900;
            color: rgba(255,255,255,.96);
            background: rgba(var(--race-rgb), .18);
            border: 1px solid rgba(var(--race-rgb), .32);
            box-shadow: 0 12px 28px rgba(0,0,0,.28);
        }

/* Meter */
.race-premium .race-meter {
    margin-top: 12px;
    height: 10px;
    border-radius: 999px;
    background: rgba(255,255,255,.10);
    border: 1px solid rgba(255,255,255,.10);
    overflow: hidden;
}

.race-premium .race-meter-bar {
    height: 100%;
    border-radius: 999px;
    background: linear-gradient(90deg, rgba(var(--race-rgb), .75), rgba(var(--race-rgb), .35) );
    box-shadow: 0 0 0 3px rgba(var(--race-rgb), .10);
}

.race-premium .race-meter-meta {
    margin-top: 10px;
    opacity: .88;
    font-size: 14.6px;
    line-height: 1.65;
}

/* Mobile: reduce padding a bit */
@media(max-width: 991px) {
    .race-premium .race-panel {
        padding: 14px;
    }

    .race-premium .race-card {
        padding: 14px;
    }
}
/* =========================================================
   SINGLE BACKGROUND + DETAILS CLEANUP (PASTE AT THE END)
========================================================= */

/* 1) One single background image for the whole page */
.race-premium {
    position: relative;
    /* one image + overlays (overlays are fine; only one IMAGE) */
    background: radial-gradient(circle at 50% 0%, rgba(255,255,255,.12), transparent 45%), linear-gradient(180deg, rgba(0,0,0,.78), rgba(0,0,0,.62)), url("/img/bg/atreia.jpg");
    background-size: cover;
    background-position: center top;
    background-repeat: no-repeat;
}

@media (min-width: 992px) {
    .race-premium {
        background-attachment: fixed;
    }
}

/* 2) Remove per-section background images (stage/details become transparent) */
.race-premium .race-stage-section,
.race-premium .race-details-section {
    background: transparent !important;
    background-image: none !important;
}

    /* keep your overlays */
    .race-premium .race-hero::before,
    .race-premium .race-stage-section::before,
    .race-premium .race-details-section::before {
        /* keep existing overlays; no change needed */
    }

/* 3) Media cards: stop depending on missing images.
      Give them a premium gradient by race instead. */
.race-premium .race-panel[data-race="elyos"] .race-card-media {
    background: radial-gradient(circle at 25% 10%, rgba(var(--race-elyos-rgb), .22), transparent 55%), radial-gradient(circle at 70% 80%, rgba(255,255,255,.08), transparent 60%), linear-gradient(180deg, rgba(0,0,0,.55), rgba(0,0,0,.35)) !important;
    background-size: cover;
    background-position: center;
}

.race-premium .race-panel[data-race="asmodians"] .race-card-media {
    background: radial-gradient(circle at 25% 10%, rgba(var(--race-asmodians-rgb), .22), transparent 55%), radial-gradient(circle at 70% 80%, rgba(255,255,255,.08), transparent 60%), linear-gradient(180deg, rgba(0,0,0,.55), rgba(0,0,0,.35)) !important;
    background-size: cover;
    background-position: center;
}

/* 4) Kill the “half bar” (meter) completely (in case markup still exists) */
.race-premium .race-meter,
.race-premium .race-meter-meta {
    display: none !important;
}
/* =========================================================
   VERTICAL TIMELINE (Starting Path) - Premium + Animations
   Paste at the END of race-premium.css
========================================================= */

.race-premium .race-vtimeline {
    position: relative;
    display: grid;
    gap: 14px;
    margin-top: 12px;
}

    /* vertical line */
    .race-premium .race-vtimeline::before {
        content: "";
        position: absolute;
        left: 16px;
        top: 6px;
        bottom: 6px;
        width: 2px;
        background: linear-gradient( 180deg, rgba(var(--race-rgb), .55), rgba(255,255,255,.10), rgba(var(--race-rgb), .18) );
        opacity: .75;
        transform-origin: top;
    }

/* item */
.race-premium .race-vtitem {
    position: relative;
    display: grid;
    grid-template-columns: 34px 1fr;
    gap: 12px;
    align-items: start;
}

.race-premium .race-vticon {
    width: 34px;
    height: 34px;
    border-radius: 12px;
    display: grid;
    place-items: center;
    background: rgba(var(--race-rgb), .14);
    border: 1px solid rgba(var(--race-rgb), .28);
    box-shadow: 0 12px 28px rgba(0,0,0,.28);
    color: rgba(255,255,255,.92);
}

    .race-premium .race-vticon svg {
        width: 18px;
        height: 18px;
        display: block;
        opacity: .95;
    }

.race-premium .race-vtbody {
    padding: 12px 12px;
    border-radius: 16px;
    border: 1px solid rgba(255,255,255,.10);
    background: rgba(0,0,0,.22);
    box-shadow: 0 12px 34px rgba(0,0,0,.30);
}

.race-premium .race-vtlabel {
    font-weight: 900;
    letter-spacing: .8px;
    color: rgba(255,255,255,.96);
    margin-bottom: 6px;
}

.race-premium .race-vttext {
    font-size: 14.8px;
    line-height: 1.7;
    opacity: .92;
}

/* small meta tag */
.race-premium .race-vttag {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-top: 10px;
    padding: 7px 10px;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.12);
    background: rgba(0,0,0,.22);
    font-size: 11px;
    letter-spacing: 1.4px;
    text-transform: uppercase;
    opacity: .85;
}

    .race-premium .race-vttag::before {
        content: "";
        width: 8px;
        height: 8px;
        border-radius: 50%;
        background: rgba(var(--race-rgb), .85);
        box-shadow: 0 0 0 3px rgba(var(--race-rgb), .12);
    }

/* micro animations when the tab becomes active */
@media (prefers-reduced-motion: no-preference) {
    .race-premium .race-tabpanel.active .race-vtimeline::before {
        animation: raceLineIn .55s ease both;
    }

    .race-premium .race-tabpanel.active .race-vtitem {
        animation: raceItemIn .45s ease both;
        animation-delay: calc(var(--i, 0) * 80ms);
    }

    .race-premium .race-tabpanel.active .race-vticon {
        animation: raceIconPop .45s ease both;
        animation-delay: calc(var(--i, 0) * 80ms + 60ms);
    }

    @keyframes raceLineIn {
        from {
            transform: scaleY(0);
            opacity: 0;
        }

        to {
            transform: scaleY(1);
            opacity: .75;
        }
    }

    @keyframes raceItemIn {
        from {
            transform: translateY(10px);
            opacity: 0;
        }

        to {
            transform: translateY(0);
            opacity: 1;
        }
    }

    @keyframes raceIconPop {
        0% {
            transform: scale(.85);
            filter: saturate(.9);
        }

        100% {
            transform: scale(1);
            filter: saturate(1.05);
        }
    }
}
/* =========================================================
   Beritra Focus Highlight (premium pulse + glow)
========================================================= */

.race-premium .race-beritra-focus {
    position: relative;
    border-color: rgba(var(--race-rgb), .55) !important;
    box-shadow: 0 28px 90px rgba(0,0,0,.65), 0 0 0 1px rgba(var(--race-rgb), .18) inset !important;
}

    .race-premium .race-beritra-focus::after {
        content: "";
        position: absolute;
        inset: -2px;
        border-radius: 18px;
        pointer-events: none;
        background: radial-gradient(circle at 40% 10%, rgba(255,255,255,.18), transparent 40%), radial-gradient(circle at 70% 75%, rgba(var(--race-rgb), .22), transparent 55%);
        opacity: .7;
        filter: blur(.2px);
    }

@media (prefers-reduced-motion: no-preference) {
    .race-premium .race-beritra-focus {
        animation: beritraPulse 1.25s ease-in-out 0s 2;
    }

    @keyframes beritraPulse {
        0% {
            transform: translateY(0);
            filter: saturate(1);
        }

        50% {
            transform: translateY(-2px);
            filter: saturate(1.06);
        }

        100% {
            transform: translateY(0);
            filter: saturate(1);
        }
    }
}
/* Beritra CTA inside step text */
.race-premium .race-beritra-ctaWrap {
    margin-top: 12px;
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.race-premium .race-beritra-ctaBtn {
    border: 1px solid rgba(255,255,255,.14);
    background: rgba(0,0,0,.28);
    color: rgba(255,255,255,.92);
    border-radius: 14px;
    padding: 10px 14px;
    font-weight: 900;
    letter-spacing: .6px;
    cursor: pointer;
    transition: transform .16s ease, border-color .16s ease, background .16s ease;
}

    .race-premium .race-beritra-ctaBtn:hover {
        transform: translateY(-1px);
        border-color: rgba(var(--race-rgb), .35);
        background: rgba(var(--race-rgb), .10);
    }
