/* Veltrion Web Platform Phase 23: class/ranking/boss/economy competition UX */
:root {
    --v23-bg: rgba(8, 7, 6, .88);
    --v23-deep: rgba(3, 3, 3, .94);
    --v23-line: rgba(221, 171, 83, .24);
    --v23-line-strong: rgba(221, 171, 83, .42);
    --v23-gold: #e7bd72;
    --v23-red: #a92318;
    --v23-text: #eadfc8;
    --v23-muted: #988b76;
}

.vweb-competition {
    position: relative;
    margin: 12px 0 22px;
    padding: 18px;
    border: 1px solid rgba(221, 171, 83, .18);
    background:
        radial-gradient(circle at 20% 0%, rgba(160, 31, 22, .20), transparent 32%),
        radial-gradient(circle at 84% 4%, rgba(221, 171, 83, .12), transparent 28%),
        linear-gradient(180deg, rgba(12, 10, 8, .72), rgba(3, 3, 3, .88));
    box-shadow: inset 0 0 60px rgba(0,0,0,.58), 0 22px 70px rgba(0,0,0,.28);
    overflow: hidden;
}

.vweb-competition::before,
.vweb-competition::after {
    content: "";
    position: absolute;
    left: 14px;
    right: 14px;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(231,189,114,.42), transparent);
    pointer-events: none;
}
.vweb-competition::before { top: 0; }
.vweb-competition::after { bottom: 0; opacity: .58; }

.vweb-competition__head {
    position: relative;
    z-index: 2;
    display: flex;
    justify-content: space-between;
    gap: 18px;
    align-items: flex-start;
    margin-bottom: 14px;
}

.vweb-competition__head small,
.vweb-competition-panel header small {
    display: block;
    margin-bottom: 4px;
    color: rgba(231, 189, 114, .78);
    font-size: 10px;
    font-weight: 900;
    letter-spacing: .16em;
}

.vweb-competition__head h2 {
    margin: 0;
    color: #f3dfba;
    font-size: 27px;
    letter-spacing: -.055em;
    text-shadow: 0 2px 0 #000, 0 0 28px rgba(231, 189, 114, .11);
}

.vweb-competition__head p {
    margin: 7px 0 0;
    color: #a89a82;
    font-size: 13px;
    line-height: 1.55;
}

.vweb-competition__head nav {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 8px;
    min-width: 300px;
}

.vweb-competition__head nav a {
    min-height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 13px;
    color: #e7d7b8;
    text-decoration: none;
    font-size: 12px;
    font-weight: 900;
    border: 1px solid rgba(231, 189, 114, .22);
    background: rgba(0,0,0,.28);
}

.vweb-competition__grid {
    position: relative;
    z-index: 2;
    display: grid;
    grid-template-columns: 1.05fr 1.28fr;
    grid-template-areas:
        "classes ranking"
        "boss boss"
        "economy economy";
    gap: 10px;
}

.vweb-competition-panel {
    position: relative;
    overflow: hidden;
    min-height: 210px;
    padding: 15px;
    border: 1px solid var(--v23-line);
    background:
        linear-gradient(180deg, rgba(18, 15, 12, .88), rgba(5, 4, 3, .93)),
        radial-gradient(circle at 92% 0%, rgba(169, 35, 24, .18), transparent 38%);
    box-shadow: inset 0 0 38px rgba(0,0,0,.45);
}

.vweb-competition-panel::after {
    content: "";
    position: absolute;
    inset: auto 0 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(231, 189, 114, .32), transparent);
}

.vweb-competition-panel--classes { grid-area: classes; }
.vweb-competition-panel--ranking { grid-area: ranking; }
.vweb-competition-panel--boss { grid-area: boss; }
.vweb-competition-panel--economy { grid-area: economy; }

.vweb-competition-panel header {
    position: relative;
    z-index: 2;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 12px;
}

.vweb-competition-panel header h3 {
    margin: 0;
    color: var(--v23-text);
    font-size: 18px;
    letter-spacing: -.045em;
}

.vweb-competition-panel header time {
    color: #7f735f;
    font-size: 11px;
    font-weight: 800;
}

.vweb-competition-classes {
    position: relative;
    z-index: 2;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 9px;
}

.vweb-competition-class {
    position: relative;
    min-height: 116px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 12px;
    color: var(--v23-text);
    text-decoration: none;
    border: 1px solid rgba(255,255,255,.08);
    background: linear-gradient(180deg, rgba(255,255,255,.045), rgba(0,0,0,.22));
    overflow: hidden;
    transition: transform .18s ease, border-color .18s ease, background .18s ease;
}

.vweb-competition-class:hover {
    transform: translateY(-2px);
    border-color: rgba(231,189,114,.32);
    background: linear-gradient(180deg, rgba(231,189,114,.08), rgba(0,0,0,.24));
}

.vweb-competition-class::before {
    content: "";
    position: absolute;
    right: -10px;
    bottom: -12px;
    width: 100px;
    height: 130px;
    opacity: .68;
    background: radial-gradient(circle at 50% 9%, rgba(255,235,184,.42), transparent 12%), linear-gradient(180deg, rgba(164, 125, 79, .78), rgba(14, 13, 12, .98));
    clip-path: polygon(48% 0, 64% 18%, 76% 44%, 95% 100%, 5% 100%, 24% 44%, 36% 18%);
}

.vweb-competition-class--elf::before { background: radial-gradient(circle at 50% 9%, rgba(214,255,194,.34), transparent 12%), linear-gradient(180deg, rgba(72, 112, 64, .78), rgba(11, 14, 10, .98)); }
.vweb-competition-class--mage::before { background: radial-gradient(circle at 50% 9%, rgba(198,187,255,.36), transparent 12%), linear-gradient(180deg, rgba(80, 70, 145, .78), rgba(13, 11, 20, .98)); }
.vweb-competition-class--tracker::before { background: radial-gradient(circle at 50% 9%, rgba(255,190,179,.34), transparent 12%), linear-gradient(180deg, rgba(126, 35, 27, .78), rgba(14, 7, 7, .98)); }

.vweb-competition-class__crest,
.vweb-competition-class strong,
.vweb-competition-class em,
.vweb-competition-class b {
    position: relative;
    z-index: 2;
}

.vweb-competition-class__crest {
    width: max-content;
    min-width: 38px;
    height: 24px;
    display: inline-grid;
    place-items: center;
    margin-bottom: 12px;
    color: var(--v23-gold);
    font-size: 11px;
    font-weight: 900;
    border: 1px solid rgba(231,189,114,.27);
    background: rgba(0,0,0,.28);
}

.vweb-competition-class strong {
    font-size: 20px;
    letter-spacing: -.05em;
    text-shadow: 0 2px 0 #000;
}

.vweb-competition-class em {
    margin-top: 5px;
    color: #9e927d;
    font-style: normal;
    font-size: 12px;
    font-weight: 800;
}

.vweb-competition-class b {
    width: max-content;
    margin-top: 8px;
    padding: 4px 7px;
    color: #f0c579;
    font-size: 10px;
    border: 1px solid rgba(231,189,114,.22);
    background: rgba(231,189,114,.045);
}

.vweb-rank-columns,
.vweb-economy-grid {
    position: relative;
    z-index: 2;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 9px;
}

.vweb-boss-arena {
    position: relative;
    z-index: 2;
    display: grid;
    grid-template-columns: .85fr 1fr 1fr;
    gap: 9px;
}

.vweb-boss-arena__feature {
    min-height: 188px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 16px;
    border: 1px solid rgba(255,255,255,.08);
    background:
        radial-gradient(circle at 70% 24%, rgba(169,35,24,.34), transparent 30%),
        linear-gradient(135deg, rgba(36, 14, 11, .92), rgba(4,4,4,.98));
}

.vweb-boss-arena__feature span {
    width: max-content;
    padding: 4px 7px;
    color: #f0c579;
    font-size: 10px;
    font-weight: 900;
    letter-spacing: .12em;
    border: 1px solid rgba(231,189,114,.22);
}

.vweb-boss-arena__feature strong {
    margin-top: 12px;
    color: #f2dfbd;
    font-size: 26px;
    letter-spacing: -.06em;
    text-shadow: 0 2px 0 #000, 0 0 24px rgba(169,35,24,.28);
}

.vweb-boss-arena__feature em {
    margin-top: 7px;
    color: #9e927d;
    font-style: normal;
    font-size: 12px;
    line-height: 1.45;
}

.vweb-rank-box {
    min-height: 188px;
    padding: 12px;
    border: 1px solid rgba(255,255,255,.075);
    background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(0,0,0,.18));
}

.vweb-rank-box h4 {
    margin: 0 0 10px;
    color: #e8d7b8;
    font-size: 14px;
    letter-spacing: -.035em;
}

.vweb-rank-box ol {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 7px;
}

.vweb-rank-box li {
    min-height: 34px;
    display: grid;
    grid-template-columns: 28px minmax(0, 1fr) auto;
    gap: 8px;
    align-items: center;
    color: #d9cab0;
    font-size: 12px;
    border-bottom: 1px solid rgba(255,255,255,.055);
}

.vweb-rank-box li:last-child { border-bottom: 0; }

.vweb-rank-num {
    display: inline-grid;
    place-items: center;
    width: 24px;
    height: 24px;
    color: #f0c579;
    font-weight: 900;
    border: 1px solid rgba(231,189,114,.22);
    background: rgba(0,0,0,.26);
}

.vweb-rank-name {
    min-width: 0;
}

.vweb-rank-name b {
    display: block;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    color: #f0dfc2;
    font-size: 12px;
}

.vweb-rank-name em {
    display: block;
    margin-top: 2px;
    color: #827764;
    font-style: normal;
    font-size: 10px;
    font-weight: 800;
}

.vweb-rank-score {
    color: #e7bd72;
    font-size: 11px;
    font-weight: 900;
    white-space: nowrap;
}

@media (max-width: 1160px) {
    .vweb-competition__grid {
        grid-template-columns: 1fr;
        grid-template-areas:
            "classes"
            "ranking"
            "boss"
            "economy";
    }
}

@media (max-width: 860px) {
    .vweb-competition__head {
        display: block;
    }
    .vweb-competition__head nav {
        justify-content: flex-start;
        min-width: 0;
        margin-top: 14px;
    }
    .vweb-boss-arena,
    .vweb-rank-columns,
    .vweb-economy-grid {
        grid-template-columns: 1fr;
    }
    .vweb-boss-arena__feature,
    .vweb-rank-box {
        min-height: auto;
    }
}

@media (max-width: 560px) {
    .vweb-competition {
        padding: 12px;
    }
    .vweb-competition__head h2 {
        font-size: 22px;
    }
    .vweb-competition-classes {
        grid-template-columns: 1fr;
    }
    .vweb-rank-box li {
        grid-template-columns: 26px minmax(0, 1fr);
    }
    .vweb-rank-score {
        grid-column: 2;
    }
}
