:root {
    --portal-bg: #f5f7fb;
    --portal-panel: #ffffff;
    --portal-panel-muted: #f8fafc;
    --portal-line: #d8dee8;
    --portal-text: #1f2937;
    --portal-muted: #64748b;
    --portal-accent: #2563eb;
    --portal-accent-dark: #1d4ed8;
    --portal-link: #1d4ed8;
    --portal-public-bg: linear-gradient(180deg, #eef4ff 0, #f7f9fc 260px);
    --portal-nav-bg: rgba(255,255,255,.9);
    --portal-subnav-bg: rgba(255,255,255,.92);
    --portal-subnav-link: #475569;
    --portal-subnav-active-bg: #dbeafe;
    --portal-glass-bg: rgba(255,255,255,.82);
    --portal-hero-bg: linear-gradient(135deg, #f8fafc 0, #eef6ff 58%, #ecfdf5 100%);
    --portal-shadow: 0 10px 24px rgba(15, 23, 42, .08);
    --portal-card-shadow: 0 1px 2px rgba(15, 23, 42, .04);
    --portal-control-bg: #ffffff;
    --portal-control-border: #dbe4f0;
    --portal-table-head-bg: #f8fafc;
    --portal-table-head-text: #475569;
    --portal-table-hover: #f8fbff;
    --portal-primary-soft: #eff6ff;
    --portal-success-bg: #dcfce7;
    --portal-success-text: #166534;
    --portal-warning-bg: #fef3c7;
    --portal-warning-text: #92400e;
    --portal-danger-bg: #fee2e2;
    --portal-danger-text: #991b1b;
    --portal-info-bg: #dbeafe;
    --portal-info-text: #1e40af;
    --portal-neutral-bg: #f1f5f9;
    --portal-neutral-text: #475569;
    --portal-neutral-border: #cbd5e1;
    --portal-danger-zone-bg: #fff7ed;
    --portal-danger-zone-border: #fed7aa;
    --portal-sidebar: #172033;
    --portal-sidebar-active: #263750;
    --cod-color-0: #4b5563;
    --cod-color-1: #dc2626;
    --cod-color-2: #16a34a;
    --cod-color-3: #ca8a04;
    --cod-color-4: #2563eb;
    --cod-color-5: #06b6d4;
    --cod-color-6: #c026d3;
    --cod-color-7: #f8fafc;
    --cod-color-8: #6b7280;
    --cod-color-9: #f97316;
}

:root[data-theme="dark"],
:root[data-resolved-theme="dark"] {
    --portal-bg: #0f172a;
    --portal-panel: #111827;
    --portal-panel-muted: #1e293b;
    --portal-line: #334155;
    --portal-text: #e5e7eb;
    --portal-muted: #a7b0c0;
    --portal-accent: #60a5fa;
    --portal-accent-dark: #93c5fd;
    --portal-link: #93c5fd;
    --portal-public-bg: linear-gradient(180deg, #111827 0, #0f172a 260px);
    --portal-nav-bg: rgba(15,23,42,.9);
    --portal-subnav-bg: rgba(17,24,39,.92);
    --portal-subnav-link: #cbd5e1;
    --portal-subnav-active-bg: #1e3a5f;
    --portal-glass-bg: rgba(30,41,59,.82);
    --portal-hero-bg: linear-gradient(135deg, #111827 0, #172033 58%, #123026 100%);
    --portal-shadow: 0 10px 24px rgba(0, 0, 0, .28);
    --portal-card-shadow: 0 1px 2px rgba(0, 0, 0, .24);
    --portal-control-bg: #0f172a;
    --portal-control-border: #475569;
    --portal-table-head-bg: #1e293b;
    --portal-table-head-text: #cbd5e1;
    --portal-table-hover: #172033;
    --portal-primary-soft: #172554;
    --portal-success-bg: #123524;
    --portal-success-text: #86efac;
    --portal-warning-bg: #3a2b0d;
    --portal-warning-text: #fde68a;
    --portal-danger-bg: #421c1c;
    --portal-danger-text: #fca5a5;
    --portal-info-bg: #172554;
    --portal-info-text: #bfdbfe;
    --portal-neutral-bg: #1e293b;
    --portal-neutral-text: #cbd5e1;
    --portal-neutral-border: #475569;
    --portal-danger-zone-bg: #2b2118;
    --portal-danger-zone-border: #9a6a39;
    --portal-sidebar: #0b1120;
    --portal-sidebar-active: #1e293b;
    --cod-color-0: #cbd5e1;
    --cod-color-1: #f87171;
    --cod-color-2: #4ade80;
    --cod-color-3: #facc15;
    --cod-color-4: #60a5fa;
    --cod-color-5: #22d3ee;
    --cod-color-6: #e879f9;
    --cod-color-7: #f8fafc;
    --cod-color-8: #d1d5db;
    --cod-color-9: #fb923c;
}

@media (prefers-color-scheme: dark) {
    :root[data-theme="system"] {
        --portal-bg: #0f172a;
        --portal-panel: #111827;
        --portal-panel-muted: #1e293b;
        --portal-line: #334155;
        --portal-text: #e5e7eb;
        --portal-muted: #a7b0c0;
        --portal-accent: #60a5fa;
        --portal-accent-dark: #93c5fd;
        --portal-link: #93c5fd;
        --portal-public-bg: linear-gradient(180deg, #111827 0, #0f172a 260px);
        --portal-nav-bg: rgba(15,23,42,.9);
        --portal-subnav-bg: rgba(17,24,39,.92);
        --portal-subnav-link: #cbd5e1;
        --portal-subnav-active-bg: #1e3a5f;
        --portal-glass-bg: rgba(30,41,59,.82);
        --portal-hero-bg: linear-gradient(135deg, #111827 0, #172033 58%, #123026 100%);
        --portal-shadow: 0 10px 24px rgba(0, 0, 0, .28);
        --portal-card-shadow: 0 1px 2px rgba(0, 0, 0, .24);
        --portal-control-bg: #0f172a;
        --portal-control-border: #475569;
        --portal-table-head-bg: #1e293b;
        --portal-table-head-text: #cbd5e1;
        --portal-table-hover: #172033;
        --portal-primary-soft: #172554;
        --portal-success-bg: #123524;
        --portal-success-text: #86efac;
        --portal-warning-bg: #3a2b0d;
        --portal-warning-text: #fde68a;
        --portal-danger-bg: #421c1c;
        --portal-danger-text: #fca5a5;
        --portal-info-bg: #172554;
        --portal-info-text: #bfdbfe;
        --portal-neutral-bg: #1e293b;
        --portal-neutral-text: #cbd5e1;
        --portal-neutral-border: #475569;
        --portal-danger-zone-bg: #2b2118;
        --portal-danger-zone-border: #9a6a39;
        --portal-sidebar: #0b1120;
        --portal-sidebar-active: #1e293b;
        --cod-color-0: #cbd5e1;
        --cod-color-1: #f87171;
        --cod-color-2: #4ade80;
        --cod-color-3: #facc15;
        --cod-color-4: #60a5fa;
        --cod-color-5: #22d3ee;
        --cod-color-6: #e879f9;
        --cod-color-7: #f8fafc;
        --cod-color-8: #d1d5db;
        --cod-color-9: #fb923c;
    }
}

body {
    color: var(--portal-text);
    background: var(--portal-bg);
    font-family: "Segoe UI", system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
    letter-spacing: 0;
}

a {
    color: var(--portal-link);
    text-decoration: none;
}

.sr-only,
.visually-hidden {
    border: 0 !important;
    clip: rect(0, 0, 0, 0) !important;
    height: 1px !important;
    margin: -1px !important;
    overflow: hidden !important;
    padding: 0 !important;
    position: absolute !important;
    white-space: nowrap !important;
    width: 1px !important;
}

.public-shell {
    background: var(--portal-public-bg);
}

.public-shell:has(.public-main:not(.public-landing-main)) {
    background: #05080c;
    min-height: 100vh;
}

.public-nav {
    background: var(--portal-nav-bg);
    border-bottom: 1px solid var(--portal-line);
    backdrop-filter: blur(10px);
}

.public-header-actions {
    align-items: center;
    display: flex;
    justify-content: flex-end;
    min-width: 0;
}

.public-actions-menu {
    background: var(--portal-panel);
    border-color: var(--portal-line);
    box-shadow: var(--portal-shadow);
    color: var(--portal-text);
    min-width: 14rem;
}

.public-actions-menu .dropdown-item {
    color: var(--portal-text);
    font-weight: 650;
}

.public-actions-menu .dropdown-item:hover,
.public-actions-menu .dropdown-item:focus {
    background: var(--portal-table-hover);
    color: var(--portal-text);
}

.public-actions-theme {
    border-bottom: 1px solid var(--portal-line);
    margin-bottom: 4px;
    padding: 8px 12px;
}

.public-actions-theme .theme-toggle-form {
    align-items: stretch;
    display: grid;
    gap: 5px;
    width: 100%;
}

.public-actions-theme .theme-toggle-label {
    color: var(--portal-muted);
    font-size: .76rem;
    font-weight: 750;
}

.public-actions-theme .theme-toggle-select {
    width: 100%;
}

.public-actions-menu .dropdown-item-form {
    margin: 0;
}

.public-actions-menu .dropdown-item-form .dropdown-item {
    text-align: left;
    width: 100%;
}

.public-main {
    max-width: 1180px;
    padding: 28px 20px 48px;
}

.public-landing-main {
    max-width: none;
    padding-left: 14px;
    padding-right: 14px;
}

.public-stats-subnav {
    background: var(--portal-subnav-bg);
    border: 1px solid var(--portal-line);
    border-radius: 8px;
    margin-bottom: 22px;
    padding: 7px;
}

.public-stats-subnav-toggle {
    align-items: center;
    background: var(--portal-panel);
    border: 1px solid var(--portal-line);
    border-radius: 6px;
    color: var(--portal-text);
    display: none;
    font-weight: 750;
    justify-content: space-between;
    min-height: 38px;
    padding: 7px 10px;
    width: 100%;
}

.public-stats-subnav-list {
    display: flex;
    flex-wrap: nowrap;
    gap: 6px;
    justify-content: flex-start;
    min-width: 0;
    overflow: hidden;
    white-space: nowrap;
}

.public-stats-subnav a {
    flex: 0 0 auto;
    border-radius: 6px;
    color: var(--portal-subnav-link);
    font-size: .88rem;
    font-weight: 650;
    padding: 7px 10px;
    white-space: nowrap;
}

.admin-nav-link {
    opacity: .9;
}

.public-stats-subnav a:hover,
.public-stats-subnav a.active {
    background: var(--portal-subnav-active-bg);
    color: var(--portal-accent-dark);
}

.public-stats-subnav a:focus-visible,
.public-actions-toggle:focus-visible,
.public-stats-subnav-toggle:focus-visible {
    box-shadow: 0 0 0 .2rem color-mix(in srgb, var(--portal-accent) 25%, transparent);
    outline: 2px solid var(--portal-accent);
    outline-offset: 2px;
}

.public-page-header {
    align-items: flex-start;
    display: flex;
    gap: 18px;
    justify-content: space-between;
    margin-bottom: 18px;
}

.public-page-header h1 {
    font-size: clamp(1.8rem, 3vw, 2.5rem);
    font-weight: 750;
    letter-spacing: 0;
    line-height: 1.08;
    margin: 4px 0 8px;
    overflow-wrap: anywhere;
}

.public-page-header p {
    color: var(--portal-muted);
    margin: 0 0 10px;
    max-width: 760px;
}

.public-hero {
    align-items: flex-start;
    display: flex;
    gap: 20px;
    justify-content: space-between;
    margin-bottom: 24px;
}

.public-hero h1 {
    font-size: clamp(2rem, 4vw, 3.2rem);
    font-weight: 750;
    letter-spacing: 0;
    line-height: 1.05;
    margin: 4px 0 10px;
}

.public-hero p {
    color: var(--portal-muted);
    font-size: 1.05rem;
    margin: 0;
    max-width: 680px;
}

.server-profile-hero {
    background: var(--portal-panel);
    border: 1px solid var(--portal-line);
    border-radius: 8px;
    box-shadow: var(--portal-shadow);
    display: grid;
    gap: 22px;
    grid-template-columns: minmax(0, 1.55fr) minmax(280px, .8fr);
    margin-bottom: 18px;
    overflow: hidden;
}

.server-profile-main {
    background: var(--portal-hero-bg);
    padding: 28px;
}

.server-title-row {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

.server-title-row h1 {
    font-size: clamp(2rem, 5vw, 3.4rem);
    font-weight: 800;
    letter-spacing: 0;
    line-height: 1;
    margin: 4px 0;
    overflow-wrap: anywhere;
}

.server-tagline {
    color: var(--portal-muted);
    font-size: 1.05rem;
    margin: 10px 0 0;
    max-width: 760px;
}

.server-join-row {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 22px;
}

.server-address-box {
    background: var(--portal-glass-bg);
    border: 1px solid var(--portal-control-border);
    border-radius: 8px;
    min-width: min(100%, 300px);
    padding: 10px 12px;
}

.server-address-box span,
.server-profile-side span,
.quick-stat-strip span,
.map-flow-item span {
    color: var(--portal-muted);
    display: block;
    font-size: .76rem;
    font-weight: 750;
    text-transform: uppercase;
}

.server-address-box strong {
    display: block;
    font-size: 1.05rem;
    overflow-wrap: anywhere;
}

.server-profile-side {
    display: grid;
    gap: 1px;
    padding: 14px;
}

.server-profile-side > div {
    background: var(--portal-panel-muted);
    border: 1px solid var(--portal-line);
    border-radius: 8px;
    padding: 12px;
}

.server-profile-side strong {
    display: block;
    font-size: 1.25rem;
    line-height: 1.2;
    margin-top: 3px;
    overflow-wrap: anywhere;
}

.server-profile-side small,
.map-flow-item small {
    color: var(--portal-muted);
    display: block;
    margin-top: 4px;
    overflow-wrap: anywhere;
}

.quick-stat-strip {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    margin-bottom: 2px;
}

.quick-stat-strip > div {
    background: var(--portal-panel);
    border: 1px solid var(--portal-line);
    border-radius: 8px;
    padding: 14px;
}

.quick-stat-strip strong {
    display: block;
    font-size: 1.45rem;
    line-height: 1.2;
    margin-top: 3px;
}

.map-flow-card .portal-card-body {
    display: grid;
    gap: 10px;
}

.map-flow-item {
    border: 1px solid var(--portal-line);
    border-radius: 8px;
    padding: 12px;
}

.map-flow-item.current {
    background: var(--portal-primary-soft);
    border-color: var(--portal-accent);
}

.map-flow-item strong {
    display: block;
    font-size: 1.1rem;
    margin-top: 3px;
    overflow-wrap: anywhere;
}

.map-image-shell {
    background:
        linear-gradient(135deg, rgba(15, 23, 42, .92), rgba(37, 99, 235, .34)),
        linear-gradient(45deg, #111827, #334155);
    border: 1px solid rgba(148, 163, 184, .28);
    border-radius: 8px;
    overflow: hidden;
    position: relative;
}

.map-image-shell::after {
    background: linear-gradient(180deg, rgba(255,255,255,.12), rgba(15,23,42,.16));
    content: "";
    inset: 0;
    pointer-events: none;
    position: absolute;
}

.map-image {
    display: block;
    height: 100%;
    object-fit: cover;
    width: 100%;
}

.map-image-current,
.map-image-wide {
    aspect-ratio: 16 / 7;
    margin: 8px 0;
    min-height: 90px;
}

.map-image-hero {
    aspect-ratio: 16 / 7;
    min-height: 180px;
}

.map-image-round,
.map-image-admin {
    aspect-ratio: 16 / 7;
    min-height: 160px;
}

.map-image-thumb {
    aspect-ratio: 16 / 10;
    flex: 0 0 66px;
    height: 42px;
}

.map-hero-panel {
    align-items: center;
    background: #0f172a;
    border: 1px solid #1e293b;
    border-radius: 8px;
    color: #e5eefc;
    display: grid;
    gap: 18px;
    grid-template-columns: minmax(280px, .82fr) minmax(0, 1fr);
    margin-bottom: 18px;
    padding: 14px;
}

.map-hero-panel h2 {
    font-size: 1.75rem;
    font-weight: 750;
    line-height: 1.1;
    margin: 4px 0 8px;
    overflow-wrap: anywhere;
}

.map-hero-panel p {
    color: #cbd5e1;
    margin: 0;
}

.map-list-item,
.map-list-primary,
.map-table-cell,
.round-context-body,
.map-admin-detail {
    align-items: center;
    display: flex;
    gap: 10px;
    min-width: 0;
}

.map-list-primary,
.map-table-cell {
    min-width: 0;
}

.map-list-primary > span:last-child,
.map-table-cell > span:last-child {
    min-width: 0;
    overflow-wrap: anywhere;
}

.stat-with-icon,
.award-card-name,
.kill-feed-combatant {
    align-items: center;
    display: inline-flex;
    gap: 8px;
    min-width: 0;
}

.stat-with-icon > span,
.award-card-name > a,
.kill-feed-combatant > span {
    min-width: 0;
    overflow-wrap: anywhere;
}

.game-icon {
    background: var(--portal-panel-muted);
    border: 1px solid var(--portal-line);
    border-radius: 6px;
    flex: 0 0 auto;
    height: 34px;
    object-fit: contain;
    padding: 3px;
    width: 44px;
}

.game-icon-sm {
    height: 28px;
    width: 38px;
}

.game-icon-medal {
    height: 42px;
    width: 42px;
}

.game-icon-detail {
    height: 58px;
    width: 76px;
}

.dimension-title-row {
    align-items: center;
    display: flex;
    gap: 14px;
    min-width: 0;
}

.dimension-title-row > div {
    min-width: 0;
}

.public-data-panel {
    overflow: hidden;
}

.public-data-toolbar {
    align-items: end;
    display: grid;
    gap: 12px;
    grid-template-columns: minmax(220px, 1fr) repeat(auto-fit, minmax(150px, max-content));
}

.public-filter-actions,
.public-sort-pills,
.public-pager {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.public-sort-pills {
    margin-top: 12px;
}

.public-table-shell {
    border-top: 1px solid var(--glance-line-soft, var(--portal-line));
    max-height: min(680px, 76vh);
    overflow: auto;
    overscroll-behavior: contain;
}

.public-table-shell .stats-table {
    min-width: 760px;
}

.public-table-shell thead th {
    position: sticky;
    top: 0;
    z-index: 2;
}

.public-table-shell .map-table-cell {
    min-width: 250px;
}

.public-table-primary {
    display: grid;
    gap: 2px;
    min-width: 0;
}

.public-table-primary > a,
.public-table-primary > span:first-child {
    color: var(--glance-gold, var(--portal-link));
    font-weight: 900;
    overflow-wrap: anywhere;
}

.public-table-primary small,
.public-table-secondary {
    color: var(--glance-muted, var(--portal-muted));
    display: block;
    font-size: .78rem;
    font-weight: 750;
    overflow-wrap: anywhere;
}

.public-card-list {
    display: none;
}

.public-data-panel .public-card-list {
    display: none;
}

.public-data-card {
    border-bottom: 1px solid var(--glance-line-soft, var(--portal-line));
    display: grid;
    gap: 12px;
    padding: 14px 16px;
}

.public-data-card:last-child {
    border-bottom: 0;
}

.public-data-card-head {
    align-items: flex-start;
    display: flex;
    gap: 12px;
    justify-content: space-between;
    min-width: 0;
}

.public-data-card-title {
    display: grid;
    gap: 3px;
    min-width: 0;
}

.public-data-card-title a,
.public-data-card-title strong {
    color: var(--glance-gold, var(--portal-link));
    font-size: 1rem;
    font-weight: 900;
    line-height: 1.2;
    overflow-wrap: anywhere;
}

.public-data-card-title small,
.public-data-card-meta {
    color: var(--glance-muted, var(--portal-muted));
    font-size: .78rem;
    font-weight: 750;
}

.public-data-card-meta {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 7px 10px;
}

.public-data-card-grid {
    display: grid;
    gap: 8px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.public-data-card-grid > div {
    background: rgba(255, 255, 255, .04);
    border: 1px solid var(--glance-line-soft, var(--portal-line));
    border-radius: 8px;
    min-width: 0;
    padding: 8px;
}

.public-data-card-grid span {
    color: var(--glance-muted, var(--portal-muted));
    display: block;
    font-size: .68rem;
    font-weight: 900;
    letter-spacing: .06em;
    line-height: 1.1;
    text-transform: uppercase;
}

.public-data-card-grid strong {
    color: #fff;
    display: block;
    font-size: 1rem;
    font-variant-numeric: tabular-nums;
    line-height: 1.15;
    margin-top: 4px;
    overflow-wrap: anywhere;
}

.public-data-card-actions {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.public-section-grid {
    align-items: start;
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.public-section-stack {
    display: grid;
    gap: 16px;
}

@media (max-width: 760px) {
    .public-data-toolbar {
        grid-template-columns: minmax(0, 1fr);
    }

    .public-filter-actions,
    .public-pager {
        align-items: stretch;
    }

    .public-filter-actions .btn,
    .public-pager .btn-group,
    .public-pager .btn {
        width: 100%;
    }

    .public-data-panel .public-table-shell.has-mobile-cards {
        display: none;
    }

    .public-data-panel .public-card-list {
        display: grid;
    }

    .rounds-table-shell {
        border-top: 0;
        max-height: none;
        overflow: visible;
    }

    .rounds-table-shell .rounds-table {
        display: block;
        margin-bottom: 0;
        min-width: 0;
        width: 100%;
    }

    .rounds-table-shell .rounds-table thead {
        display: none;
    }

    .rounds-table-shell .rounds-table tbody {
        display: grid;
        gap: 12px;
        padding: 12px;
        width: 100%;
    }

    .rounds-table-shell .rounds-table tr {
        background: rgba(255, 255, 255, .025);
        border-bottom: 1px solid var(--glance-line-soft, var(--portal-line));
        box-sizing: border-box;
        display: grid;
        gap: 9px;
        padding: 14px 16px;
        width: 100%;
    }

    .rounds-table-shell .rounds-table td {
        align-items: center;
        border: 0;
        box-sizing: border-box;
        color: #fff;
        display: flex;
        flex-wrap: wrap;
        gap: 6px 10px;
        justify-content: space-between;
        padding: 0;
        width: 100%;
    }

    .rounds-table-shell .rounds-table td::before {
        color: var(--glance-muted, var(--portal-muted));
        content: attr(data-label);
        flex: 0 0 auto;
        font-size: .72rem;
        font-weight: 900;
        letter-spacing: 0;
        text-transform: uppercase;
    }

    .rounds-table-shell .rounds-table .rounds-map-cell {
        display: block;
    }

    .rounds-table-shell .rounds-table .rounds-map-cell::before {
        content: none;
    }

    .rounds-table-shell .rounds-table .map-table-cell {
        align-items: flex-start;
    }

    .public-data-card-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .public-section-grid {
        grid-template-columns: minmax(0, 1fr);
    }
}

@media (max-width: 430px) {
    .public-data-card-head,
    .public-data-card-actions,
    .public-pager {
        align-items: stretch;
        flex-direction: column;
    }

    .public-data-card-grid {
        grid-template-columns: minmax(0, 1fr);
    }
}

.kill-feed-list {
    display: grid;
    gap: 8px;
}

.kill-feed-item {
    align-items: center;
    border: 1px solid var(--portal-line);
    border-radius: 8px;
    display: grid;
    gap: 10px;
    grid-template-columns: auto minmax(0, 1fr) auto;
    padding: 10px;
}

.kill-feed-main {
    min-width: 0;
}

.kill-feed-line {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.compact-kill-feed .kill-feed-item {
    padding: 8px 10px;
}

.kill-feed-meta {
    min-width: 86px;
}

.session-timeline-card {
    overflow: visible;
}

.timeline-summary-strip {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    margin-bottom: 14px;
}

.timeline-summary-card {
    background: var(--portal-glass-bg);
    border: 1px solid var(--portal-line);
    border-radius: 8px;
    min-width: 0;
    padding: 12px;
}

.timeline-summary-card span {
    color: var(--portal-muted);
    display: block;
    font-size: .72rem;
    font-weight: 800;
    text-transform: uppercase;
}

.timeline-summary-card strong {
    display: block;
    font-size: 1.05rem;
    font-weight: 800;
    line-height: 1.2;
    margin-top: 4px;
    overflow-wrap: anywhere;
}

.timeline-summary-card small {
    color: var(--portal-muted);
    display: block;
    margin-top: 4px;
    overflow-wrap: anywhere;
}

.timeline-summary-muted {
    opacity: .82;
}

.timeline-note-row {
    align-items: center;
    background: var(--portal-panel-muted);
    border: 1px solid var(--portal-line);
    border-radius: 8px;
    color: var(--portal-muted);
    display: flex;
    flex-wrap: wrap;
    gap: 8px 14px;
    font-size: .88rem;
    margin-bottom: 16px;
    padding: 10px 12px;
}

.timeline-highlight-section,
.timeline-group-section {
    display: grid;
    gap: 12px;
    margin-top: 18px;
}

.timeline-section-heading {
    align-items: flex-end;
    display: flex;
    gap: 12px;
    justify-content: space-between;
}

.timeline-section-heading h3 {
    font-size: 1rem;
    font-weight: 750;
    margin: 0 0 3px;
}

.timeline-section-heading p {
    color: var(--portal-muted);
    margin: 0;
}

.timeline-highlight-grid {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.timeline-highlight-card {
    background: var(--portal-glass-bg);
    border: 1px solid var(--portal-line);
    border-left-width: 4px;
    border-radius: 8px;
    min-width: 0;
    padding: 12px;
}

.timeline-highlight-meta {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 9px;
}

.timeline-highlight-card h4 {
    font-size: .98rem;
    font-weight: 800;
    line-height: 1.22;
    margin: 0;
    overflow-wrap: anywhere;
}

.timeline-highlight-card p {
    color: var(--portal-muted);
    margin: 7px 0 0;
}

.timeline-player-row {
    align-items: center;
    color: var(--portal-muted);
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 9px;
    min-width: 0;
}

.timeline-player-row a {
    font-weight: 750;
    overflow-wrap: anywhere;
}

.timeline-clock {
    color: var(--portal-muted);
    font-family: ui-monospace, SFMono-Regular, Consolas, "Liberation Mono", monospace;
    font-size: .78rem;
    font-weight: 800;
    white-space: nowrap;
}

.timeline-group-list {
    display: grid;
    gap: 10px;
}

.timeline-group > summary {
    align-items: flex-start;
    display: grid;
    gap: 8px 12px;
    grid-template-columns: minmax(0, 1fr) auto;
}

.timeline-group-summary-main,
.timeline-group-summary-meta {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    min-width: 0;
}

.timeline-group-title {
    font-weight: 800;
    overflow-wrap: anywhere;
}

.timeline-group-clock {
    color: var(--portal-muted);
    font-size: .86rem;
    font-weight: 700;
}

.timeline-group-preview {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    grid-column: 1 / -1;
    min-width: 0;
}

.timeline-group-preview span {
    background: var(--portal-panel-muted);
    border: 1px solid var(--portal-line);
    border-radius: 999px;
    color: var(--portal-muted);
    font-size: .78rem;
    font-weight: 700;
    max-width: 100%;
    overflow-wrap: anywhere;
    padding: 4px 8px;
}

.timeline-group-body {
    display: grid;
    gap: 0;
}

.timeline-event-row {
    display: grid;
    gap: 12px;
    grid-template-columns: 18px 72px minmax(0, 1fr);
    min-width: 0;
    padding: 12px 0;
}

.timeline-event-row + .timeline-event-row {
    border-top: 1px solid var(--portal-line);
}

.timeline-event-spine {
    display: flex;
    justify-content: center;
    position: relative;
}

.timeline-event-spine::before {
    background: var(--portal-line);
    bottom: -12px;
    content: "";
    position: absolute;
    top: -12px;
    width: 2px;
}

.timeline-event-spine span {
    background: var(--portal-panel);
    border: 2px solid var(--portal-muted);
    border-radius: 999px;
    height: 12px;
    margin-top: 5px;
    position: relative;
    width: 12px;
    z-index: 1;
}

.timeline-event-time {
    min-width: 0;
}

.timeline-time-note {
    color: var(--portal-muted);
    display: block;
    font-size: .72rem;
    font-weight: 700;
    margin-top: 4px;
}

.timeline-event-main {
    min-width: 0;
}

.timeline-event-title-row {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 7px;
    min-width: 0;
}

.timeline-event-title-row strong {
    font-size: .98rem;
    font-weight: 800;
    line-height: 1.25;
    min-width: min(100%, 18rem);
    overflow-wrap: anywhere;
}

.timeline-event-main p {
    color: var(--portal-muted);
    margin: 7px 0 0;
}

.timeline-event-meta {
    align-items: center;
    color: var(--portal-muted);
    display: flex;
    flex-wrap: wrap;
    gap: 7px 10px;
    margin-top: 9px;
    min-width: 0;
}

.timeline-event-meta > span {
    align-items: center;
    background: var(--portal-panel-muted);
    border: 1px solid var(--portal-line);
    border-radius: 999px;
    display: inline-flex;
    gap: 5px;
    max-width: 100%;
    min-width: 0;
    padding: 4px 8px;
}

.timeline-event-meta > span > span {
    color: var(--portal-muted);
    font-size: .72rem;
    font-weight: 800;
    text-transform: uppercase;
}

.timeline-event-meta a,
.timeline-event-meta strong {
    font-size: .84rem;
    font-weight: 800;
    min-width: 0;
    overflow-wrap: anywhere;
}

.timeline-category-objective {
    border-left-color: var(--portal-warning-text);
}

.timeline-category-combat {
    border-left-color: var(--portal-info-text);
}

.timeline-category-presence {
    border-left-color: var(--portal-muted);
}

.timeline-category-session {
    border-left-color: var(--portal-neutral-border);
}

.timeline-category-result {
    border-left-color: var(--portal-success-text);
}

.timeline-event-row.timeline-category-objective .timeline-event-spine span,
.timeline-highlight-card.timeline-category-objective {
    border-color: var(--portal-warning-text);
}

.timeline-event-row.timeline-category-combat .timeline-event-spine span,
.timeline-highlight-card.timeline-category-combat {
    border-color: var(--portal-info-text);
}

.timeline-event-row.timeline-category-result .timeline-event-spine span,
.timeline-highlight-card.timeline-category-result {
    border-color: var(--portal-success-text);
}

.timeline-event-row.is-highlight {
    background: linear-gradient(90deg, rgba(37, 99, 235, .08), transparent);
    margin-left: -10px;
    margin-right: -10px;
    padding-left: 10px;
    padding-right: 10px;
}

.timeline-importance-critical {
    box-shadow: inset 0 0 0 1px rgba(220, 38, 38, .24);
}

.timeline-importance-high {
    box-shadow: inset 0 0 0 1px rgba(37, 99, 235, .16);
}

.timeline-empty-compact {
    padding: 12px;
}

@media (max-width: 1100px) {
    .timeline-summary-strip {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .timeline-highlight-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 575px) {
    .timeline-summary-strip,
    .timeline-highlight-grid {
        grid-template-columns: 1fr;
    }

    .timeline-section-heading,
    .timeline-group-summary-meta {
        align-items: flex-start;
        flex-direction: column;
    }

    .timeline-group > summary {
        grid-template-columns: 1fr;
    }

    .timeline-event-row {
        grid-template-columns: 16px minmax(0, 1fr);
    }

    .timeline-event-time {
        align-items: center;
        display: flex;
        flex-wrap: wrap;
        gap: 6px;
        grid-column: 2;
        grid-row: 1;
    }

    .timeline-event-main {
        grid-column: 2;
    }

    .timeline-event-title-row strong {
        min-width: 100%;
    }
}

.round-context-body,
.map-admin-detail {
    align-items: flex-start;
}

.round-context-body .map-image-round,
.map-admin-detail .map-image-admin {
    flex: 0 0 min(38%, 420px);
}

.portal-frame {
    display: grid;
    grid-template-columns: 260px minmax(0, 1fr);
    min-height: 100vh;
}

.portal-sidebar {
    background: var(--portal-sidebar);
    color: #e5eefc;
    display: flex;
    flex-direction: column;
    position: sticky;
    top: 0;
    height: 100vh;
}

.portal-sidebar-header {
    align-items: center;
    display: flex;
    justify-content: center;
    padding: 24px 20px 18px;
}

.portal-brand {
    align-items: center;
    color: #fff;
    display: flex;
    font-weight: 700;
    justify-content: center;
}

.portal-brand:hover { color: #fff; }

.portal-brand .brand-logo-image,
.portal-brand .brand-mark {
    border-radius: 10px;
    font-size: 1rem;
    height: auto;
    max-height: 68px;
    padding: 6px;
    width: auto;
    max-width: 68px;
}

.portal-sidebar-close {
    align-items: center;
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.18);
    border-radius: 8px;
    color: #fff;
    display: none;
    font-size: 1.5rem;
    height: 40px;
    justify-content: center;
    line-height: 1;
    width: 40px;
}

.portal-sidebar-close:hover,
.portal-sidebar-close:focus {
    background: rgba(255,255,255,.16);
    color: #fff;
}

.brand-identity {
    align-items: center;
    display: inline-flex;
    gap: 10px;
    min-width: 0;
}

.brand-text {
    overflow-wrap: anywhere;
}

.brand-logo-image,
.brand-logo-fallback,
.brand-mark {
    align-items: center;
    border-radius: 6px;
    display: inline-flex;
    flex: 0 0 auto;
    height: auto;
    max-height: 34px;
    justify-content: center;
    width: auto;
    max-width: 42px;
}

.brand-logo-image {
    background: var(--portal-panel);
    border: 1px solid var(--portal-control-border);
    display: block;
    object-fit: contain;
    padding: 3px;
}

.brand-logo-image-dark {
    background: rgba(255,255,255,.92);
    border-color: rgba(255,255,255,.25);
}

.brand-logo-fallback {
    background: #172033;
    color: #fff;
    font-size: .78rem;
    font-weight: 800;
}

.brand-mark {
    background: #3b82f6;
    font-size: .78rem;
}

.brand-logo-fallback-lg,
.brand-preview-logo {
    height: 64px;
    width: 64px;
}

.brand-logo-fallback-lg {
    border-radius: 8px;
    font-size: 1rem;
}

.brand-preview-logo {
    background: var(--portal-panel);
    border: 1px solid var(--portal-control-border);
    border-radius: 8px;
    object-fit: contain;
    padding: 6px;
}

.brand-preview-panel,
.auth-brand-panel {
    align-items: center;
    display: flex;
    gap: 14px;
}

.account-auth-brand-banner {
    background: linear-gradient(130deg, var(--portal-accent), var(--portal-accent-dark));
    border-bottom: 1px solid rgba(255, 255, 255, .24);
    display: grid;
    gap: 10px;
    justify-items: center;
    justify-content: center;
    padding: 20px 16px;
    text-align: center;
}

.brand-preview-panel {
    background: var(--portal-panel-muted);
    border: 1px solid var(--portal-line);
    border-radius: 8px;
    padding: 14px;
}

.brand-preview-panel strong,
.brand-preview-panel span,
.auth-brand-panel strong,
.auth-brand-panel span {
    display: block;
    overflow-wrap: anywhere;
}

.brand-preview-panel span,
.auth-brand-panel span {
    color: var(--portal-muted);
}

.social-preview-card {
    align-items: center;
    background: var(--portal-panel-muted);
    border: 1px solid var(--portal-line);
    border-radius: 8px;
    display: grid;
    gap: 12px;
    grid-template-columns: 72px minmax(0, 1fr);
    padding: 12px;
}

.social-preview-card img {
    background: #050505;
    border-radius: 8px;
    height: 72px;
    object-fit: cover;
    width: 72px;
}

.social-preview-card strong,
.social-preview-card span,
.social-preview-card small {
    display: block;
    overflow-wrap: anywhere;
}

.social-preview-card span {
    color: var(--portal-muted);
    font-size: .92rem;
}

.social-preview-card small {
    color: var(--portal-muted);
    margin-top: 4px;
}

.account-auth-brand-banner .brand-preview-logo,
.account-auth-brand-banner .brand-logo-fallback-lg {
    border-color: rgba(255, 255, 255, .18);
    border-radius: 14px;
    flex: 0 0 auto;
    height: clamp(88px, 20vw, 124px);
    width: clamp(88px, 20vw, 124px);
}

.account-auth-brand-banner .brand-preview-logo {
    background: rgba(255, 255, 255, .09);
    object-fit: contain;
    padding: 10px;
}

.account-auth-brand-banner .brand-logo-fallback-lg {
    background: rgba(255, 255, 255, .1);
    color: #fff;
    font-size: clamp(1.45rem, 4vw, 2rem);
}

.account-auth-brand-banner strong {
    color: #fff;
    font-size: 1.1rem;
}

.account-auth-brand-banner span {
    color: rgba(255, 255, 255, .85);
}

.auth-brand-panel {
    border-bottom: 1px solid var(--portal-line);
    padding: 16px;
}

.auth-brand-panel.account-auth-brand-banner {
    display: grid;
    gap: 10px;
    justify-content: center;
    justify-items: center;
    padding: 20px 16px;
    text-align: center;
}

.external-login-stack {
    display: grid;
    gap: 10px;
}

.external-login-link-form {
    display: inline-block;
    margin: 0 8px 8px 0;
}

.external-login-btn {
    align-items: center;
    background: var(--portal-panel);
    border-color: var(--portal-control-border);
    color: var(--portal-text);
    display: inline-flex;
    gap: 10px;
    justify-content: center;
    min-height: 42px;
    overflow-wrap: anywhere;
}

.external-login-btn:hover,
.external-login-btn:focus {
    background: var(--portal-panel-muted);
    border-color: var(--portal-accent);
    color: var(--portal-text);
}

.external-login-btn.external-login-discord {
    background: rgba(88, 101, 242, .15);
    border-color: rgba(88, 101, 242, .58);
    color: #fff;
}

.external-login-btn.external-login-discord:hover,
.external-login-btn.external-login-discord:focus {
    background: rgba(88, 101, 242, .24);
    border-color: rgba(125, 137, 255, .88);
    color: #fff;
}

.external-login-btn.external-login-discord .external-login-icon {
    align-items: center;
    background: #fff;
    border-color: transparent;
    color: #5865f2;
    height: 28px;
    width: 28px;
}

.external-login-btn.external-login-discord .external-login-icon .empire-icon {
    --empire-icon-size: 18px;
    display: block;
}

.external-login-icon {
    align-items: center;
    background: var(--portal-panel-muted);
    border: 1px solid var(--portal-line);
    border-radius: 6px;
    display: inline-flex;
    flex: 0 0 24px;
    font-size: .78rem;
    font-weight: 700;
    height: 24px;
    justify-content: center;
    line-height: 1;
    width: 24px;
}

.portal-nav {
    display: grid;
    gap: 12px;
    padding: 0 12px;
    overflow-y: auto;
}

.portal-nav-group {
    display: grid;
    gap: 2px;
}

.portal-nav-heading {
    color: #93a4bd;
    font-size: .68rem;
    font-weight: 800;
    letter-spacing: .08em;
    padding: 8px 12px 2px;
    text-transform: uppercase;
}

.portal-nav a {
    border-radius: 6px;
    color: #cbd5e1;
    font-size: .94rem;
    padding: 8px 12px;
}

.portal-nav a:hover,
.portal-nav a.active {
    background: var(--portal-sidebar-active);
    color: #fff;
}

.portal-sidebar-footer {
    border-top: 1px solid rgba(255,255,255,.12);
    display: grid;
    gap: 12px;
    margin-top: auto;
    padding: 16px;
}

.portal-sidebar-footer a { color: #bfdbfe; }

.portal-main { min-width: 0; }

.portal-backdrop,
.admin-menu-button,
.admin-topbar-brand {
    display: none;
}

.portal-topbar {
    align-items: center;
    background: var(--portal-panel);
    border-bottom: 1px solid var(--portal-line);
    display: flex;
    justify-content: space-between;
    min-height: 78px;
    padding: 16px 28px;
}

.portal-topbar-title {
    align-items: center;
    display: flex;
    gap: 12px;
    min-width: 0;
}

.portal-topbar-heading {
    min-width: 0;
}

.admin-menu-button {
    align-items: center;
    background: var(--portal-panel-muted);
    border: 1px solid var(--portal-control-border);
    border-radius: 8px;
    color: var(--portal-text);
    height: 42px;
    justify-content: center;
    width: 42px;
}

.admin-menu-button:hover,
.admin-menu-button:focus {
    border-color: var(--portal-accent);
    color: var(--portal-accent-dark);
}

.admin-menu-icon,
.admin-menu-icon::before,
.admin-menu-icon::after {
    background: currentColor;
    border-radius: 999px;
    content: "";
    display: block;
    height: 2px;
    width: 18px;
}

.admin-menu-icon {
    position: relative;
}

.admin-menu-icon::before,
.admin-menu-icon::after {
    left: 0;
    position: absolute;
}

.admin-menu-icon::before { top: -6px; }
.admin-menu-icon::after { top: 6px; }

.admin-topbar-brand {
    align-items: center;
    flex: 0 0 auto;
    justify-content: center;
}

.admin-topbar-logo {
    background: var(--portal-panel);
    border: 1px solid var(--portal-control-border);
    border-radius: 8px;
    display: block;
    height: auto;
    max-height: 42px;
    object-fit: contain;
    padding: 4px;
    width: auto;
    max-width: 170px;
}

.admin-topbar-logo-fallback {
    align-items: center;
    background: #3b82f6;
    color: #fff;
    font-size: .76rem;
    font-weight: 800;
    justify-content: center;
}

.portal-topbar h1 {
    font-size: 1.35rem;
    font-weight: 650;
    margin: 0;
    overflow-wrap: anywhere;
}

.eyebrow {
    color: var(--portal-muted);
    font-size: .76rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.topbar-user {
    color: var(--portal-muted);
    font-size: .92rem;
}

.topbar-cluster,
.admin-page-actions {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: flex-end;
}

.theme-toggle-form {
    align-items: center;
    display: inline-flex;
    gap: 8px;
}

.theme-toggle-label {
    color: var(--portal-muted);
    font-size: .76rem;
    font-weight: 700;
}

.theme-toggle-select {
    background-color: var(--portal-control-bg);
    border-color: var(--portal-control-border);
    color: var(--portal-text);
    min-width: 7rem;
}

.theme-toggle-public .theme-toggle-label {
    width: 1px;
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    white-space: nowrap;
}

.theme-toggle-profile {
    max-width: 22rem;
}

.portal-content {
    padding: 24px 28px 48px;
}

.admin-page-header {
    align-items: flex-start;
    display: flex;
    gap: 18px;
    justify-content: space-between;
    margin-bottom: 18px;
}

.admin-page-header h2 {
    font-size: 1.65rem;
    font-weight: 750;
    letter-spacing: 0;
    line-height: 1.1;
    margin: 4px 0 8px;
}

.admin-page-header p {
    color: var(--portal-muted);
    margin: 0;
    max-width: 780px;
}

.mode-banner {
    align-items: center;
    border: 1px solid;
    border-radius: 8px;
    display: flex;
    gap: 14px;
    justify-content: space-between;
    margin-bottom: 18px;
    padding: 12px 14px;
}

.mode-banner > div {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.mode-banner span:last-child {
    color: var(--portal-muted);
}

.mode-banner-live {
    background: var(--portal-danger-zone-bg);
    border-color: var(--portal-danger-zone-border);
}

.mode-banner-dry {
    background: var(--portal-primary-soft);
    border-color: var(--portal-accent);
}

.metric-grid {
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.compact-metrics {
    gap: 12px;
}

.metric-card,
.portal-card {
    background: var(--portal-panel);
    border: 1px solid var(--portal-line);
    border-radius: 8px;
    box-shadow: var(--portal-card-shadow);
}

.metric-card {
    padding: 16px;
}

.metric-label {
    color: var(--portal-muted);
    font-size: .78rem;
    font-weight: 700;
    text-transform: uppercase;
}

.metric-value {
    font-size: 1.6rem;
    font-weight: 700;
    line-height: 1.2;
    margin-top: 4px;
    overflow-wrap: anywhere;
}

.metric-subtext,
.empty-state,
.help-text {
    color: var(--portal-muted);
}

.portal-card {
    margin-top: 18px;
}

.portal-card-header {
    align-items: center;
    border-bottom: 1px solid var(--portal-line);
    display: flex;
    justify-content: space-between;
    padding: 14px 16px;
}

.portal-card-header h2,
.portal-card-header h3 {
    font-size: 1rem;
    font-weight: 650;
    margin: 0;
}

.portal-card-body {
    padding: 16px;
}

.detail-hero {
    background: var(--portal-hero-bg);
    border: 1px solid var(--portal-line);
    border-radius: 8px;
    box-shadow: var(--portal-card-shadow);
    display: grid;
    gap: 16px;
    grid-template-columns: minmax(0, 1fr) minmax(280px, .62fr);
    margin-bottom: 16px;
    padding: 18px;
}

.detail-hero h2 {
    font-size: clamp(1.5rem, 3vw, 2.25rem);
    font-weight: 750;
    line-height: 1.08;
    margin: 4px 0 8px;
    overflow-wrap: anywhere;
}

.detail-hero p {
    color: var(--portal-muted);
    margin: 0 0 12px;
}

.detail-hero-side,
.health-summary-grid,
.top-player-strip {
    display: grid;
    gap: 10px;
}

.detail-hero-side {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.detail-hero-side > div,
.health-summary-grid > div,
.insight-card,
.top-player-card {
    background: var(--portal-glass-bg);
    border: 1px solid var(--portal-line);
    border-radius: 8px;
    min-width: 0;
    padding: 12px;
}

.detail-hero-side span,
.health-summary-grid span,
.insight-card > span,
.top-player-card > span {
    color: var(--portal-muted);
    display: block;
    font-size: .72rem;
    font-weight: 800;
    text-transform: uppercase;
}

.detail-hero-side strong,
.health-summary-grid strong,
.insight-card strong,
.top-player-card strong {
    display: block;
    font-size: 1.08rem;
    line-height: 1.2;
    margin-top: 4px;
    overflow-wrap: anywhere;
}

.detail-hero-side small,
.insight-card small,
.top-player-card small {
    color: var(--portal-muted);
    display: block;
    margin-top: 4px;
    overflow-wrap: anywhere;
}

.detail-section-grid {
    align-items: start;
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.insight-grid {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.insight-card strong {
    align-items: center;
    display: flex;
    gap: 8px;
}

.player-insights-section {
    display: grid;
    gap: 16px;
    margin: 18px 0;
}

.player-insights-heading {
    align-items: flex-end;
    border-bottom: 1px solid var(--portal-line);
    display: flex;
    gap: 16px;
    justify-content: space-between;
    padding-bottom: 14px;
}

.player-insights-heading h2 {
    font-size: 1.35rem;
    font-weight: 800;
    line-height: 1.15;
    margin: 4px 0 6px;
}

.player-insights-heading p,
.player-insights-block-header p {
    color: var(--portal-muted);
    margin: 0;
}

.player-insights-block {
    display: grid;
    gap: 12px;
}

.player-insights-block-header {
    align-items: center;
    display: flex;
    gap: 12px;
    justify-content: space-between;
}

.player-insights-block-header h3,
.relationship-list-heading h4,
.relationship-card h4 {
    margin: 0;
}

.player-insights-block-header h3 {
    font-size: 1rem;
    font-weight: 750;
}

.player-results-strip {
    margin-bottom: 0;
}

.metric-card-muted {
    opacity: .78;
}

.player-insights-note {
    align-items: center;
    color: var(--portal-muted);
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    font-size: .88rem;
}

.player-insight-empty {
    border: 1px dashed var(--portal-line);
    border-radius: 8px;
    padding: 14px;
}

.relationship-spotlight-grid {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.relationship-card,
.relationship-list-panel {
    background: var(--portal-glass-bg);
    border: 1px solid var(--portal-line);
    border-radius: 8px;
    min-width: 0;
}

.relationship-card {
    display: grid;
    gap: 10px;
    padding: 14px;
}

.relationship-card.is-limited {
    opacity: .88;
}

.relationship-card-header,
.relationship-card-meta,
.relationship-list-heading,
.relationship-list-item {
    align-items: center;
    display: flex;
    gap: 10px;
    justify-content: space-between;
    min-width: 0;
}

.relationship-card-header > span:first-child {
    color: var(--portal-muted);
    font-size: .72rem;
    font-weight: 800;
    text-transform: uppercase;
}

.relationship-card h4 {
    font-size: 1.08rem;
    font-weight: 800;
    overflow-wrap: anywhere;
}

.relationship-card p,
.relationship-card small,
.relationship-card-meta {
    color: var(--portal-muted);
}

.relationship-card p {
    margin: 0;
}

.relationship-card-metrics,
.relationship-detail-grid {
    display: grid;
    gap: 10px;
}

.relationship-card-metrics {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.relationship-card-metrics > div {
    background: var(--portal-panel-muted);
    border: 1px solid var(--portal-line);
    border-radius: 8px;
    padding: 9px 10px;
}

.relationship-card-metrics span {
    color: var(--portal-muted);
    display: block;
    font-size: .72rem;
    font-weight: 800;
    text-transform: uppercase;
}

.relationship-card-metrics strong {
    display: block;
    font-size: 1rem;
    line-height: 1.15;
    margin-top: 3px;
    overflow-wrap: anywhere;
}

.relationship-detail-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.relationship-list-panel {
    padding: 14px;
}

.relationship-list-heading {
    margin-bottom: 10px;
}

.relationship-list-heading h4 {
    font-size: .94rem;
    font-weight: 800;
}

.relationship-list {
    display: grid;
    gap: 8px;
}

.relationship-list-item {
    background: var(--portal-panel-muted);
    border: 1px solid var(--portal-line);
    border-radius: 8px;
    color: var(--portal-text);
    padding: 10px;
    text-decoration: none;
}

.relationship-list-item strong,
.relationship-list-item small {
    display: block;
    overflow-wrap: anywhere;
}

.relationship-list-item small {
    color: var(--portal-muted);
    margin-top: 2px;
}

.relationship-list-item:hover,
.relationship-list-item:focus {
    background: var(--portal-table-hover);
    color: var(--portal-text);
}

.player-matchup-details {
    margin-top: 2px;
}

.relationship-matchup-table .stat-primary {
    max-width: 22rem;
}

/* Public round recap */
.round-recap-shell {
    --portal-text: #eef4ff;
    --portal-muted: #9aa8bd;
    --round-blue: #4a8cff;
    --round-red: #ff4d3d;
    --round-gold: #ffcc00;
    --round-green: #57e36c;
    --round-panel: rgba(9, 14, 22, .72);
    --round-panel-strong: rgba(14, 22, 34, .9);
    display: grid;
    gap: 18px;
    max-width: 1680px;
    margin: 0 auto;
    color: var(--portal-text);
}

.round-recap-shell a {
    color: inherit;
}

.round-recap-crumbs {
    margin-bottom: 0;
}

.round-recap-hero {
    position: relative;
    display: grid;
    align-items: stretch;
    grid-template-columns: minmax(430px, .5fr) minmax(0, 1fr) minmax(260px, .36fr);
    gap: clamp(16px, 2vw, 24px);
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, .09);
    border-radius: 10px;
    padding: clamp(20px, 2.4vw, 30px);
    background:
        linear-gradient(90deg, rgba(5, 8, 13, .99) 0%, rgba(9, 14, 22, .96) 54%, rgba(33, 29, 9, .82) 100%),
        repeating-linear-gradient(0deg, rgba(255, 255, 255, .028) 0, rgba(255, 255, 255, .028) 1px, transparent 1px, transparent 8px),
        radial-gradient(circle at 82% 16%, rgba(255, 204, 0, .14), transparent 30%),
        radial-gradient(circle at 18% 86%, rgba(255, 77, 61, .1), transparent 32%),
        #05080d;
    box-shadow: 0 18px 46px rgba(0, 0, 0, .32);
}

.round-recap-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    border-top: 3px solid var(--round-gold);
    opacity: .8;
}

.round-recap-hero::after {
    background:
        linear-gradient(90deg, transparent, rgba(255, 204, 0, .16), transparent),
        linear-gradient(180deg, transparent, rgba(0, 0, 0, .22));
    content: "";
    inset: 0;
    pointer-events: none;
    position: absolute;
}

.round-recap-hero > * {
    position: relative;
    z-index: 1;
}

.round-recap-hero.round-result-allies::before {
    border-color: var(--round-blue);
}

.round-recap-hero.round-result-axis::before {
    border-color: var(--round-red);
}

.round-recap-map {
    position: relative;
    align-self: stretch;
    min-height: 220px;
    min-width: 0;
    overflow: hidden;
    border-radius: 8px;
    border: 1px solid rgba(255, 255, 255, .14);
    background: #05080d;
    box-shadow: 0 18px 42px rgba(0, 0, 0, .34);
}

.round-recap-map img {
    width: 100%;
    height: 100%;
    min-height: 220px;
    object-fit: cover;
    display: block;
}

.round-recap-map::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(0, 0, 0, 0), rgba(0, 0, 0, .45));
    pointer-events: none;
}

.round-recap-map-empty {
    display: grid;
    min-height: 220px;
    place-items: center;
    padding: 24px;
    color: var(--portal-muted);
    font-size: 1.4rem;
    font-weight: 800;
    text-transform: uppercase;
}

.round-recap-copy {
    display: grid;
    align-content: center;
    gap: 12px;
    min-width: 0;
}

.round-recap-copy h1 {
    margin: 0;
    font-size: clamp(2.55rem, 4.2vw, 4.7rem);
    line-height: .94;
    letter-spacing: 0;
}

.round-recap-copy .player-dossier-kicker {
    color: var(--round-gold);
}

.round-recap-meta {
    justify-content: flex-start;
}

.round-result-panel,
.round-time-panel,
.round-result-note,
.round-scoreboard-panel,
.round-timeline-panel,
.round-key-moments,
.round-event-feed,
.round-awards-panel {
    border: 1px solid rgba(255, 255, 255, .09);
    border-radius: 8px;
    background: var(--round-panel-strong);
    box-shadow: 0 14px 34px rgba(0, 0, 0, .24);
}

.round-result-panel {
    align-items: center;
    align-content: start;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, .06), rgba(255, 255, 255, .022)),
        linear-gradient(135deg, rgba(255, 204, 0, .15), rgba(0, 0, 0, .1));
    border-color: rgba(255, 204, 0, .24);
    box-shadow: 0 18px 38px rgba(0, 0, 0, .22), inset 0 1px 0 rgba(255, 255, 255, .06);
    display: grid;
    gap: 14px;
    grid-template-columns: auto minmax(0, 1fr);
    padding: 16px;
}

.round-result-icon {
    display: block;
    filter: drop-shadow(0 12px 18px rgba(255, 204, 0, .18));
    height: 52px;
    object-fit: contain;
    width: 52px;
}

.round-result-panel span,
.round-time-panel span,
.round-recap-summary-grid > article span {
    color: var(--round-gold);
    text-transform: uppercase;
    letter-spacing: 0;
    font-size: .72rem;
    font-weight: 850;
}

.round-result-panel strong {
    display: block;
    margin-top: 2px;
    font-size: clamp(1.55rem, 2vw, 2.2rem);
    line-height: 1.1;
}

.round-result-panel small {
    display: block;
    margin-top: 4px;
    color: var(--portal-muted);
}

.round-time-panel {
    background:
        linear-gradient(180deg, rgba(255, 255, 255, .055), rgba(255, 255, 255, .02)),
        linear-gradient(135deg, rgba(255, 204, 0, .13), rgba(0, 0, 0, .1));
    border-color: rgba(255, 204, 0, .22);
    box-shadow: 0 18px 38px rgba(0, 0, 0, .22), inset 0 1px 0 rgba(255, 255, 255, .06);
    display: grid;
    align-content: center;
    gap: 12px;
    min-height: 154px;
    padding: 16px;
}

.round-time-panel div {
    display: grid;
    gap: 3px;
}

.round-time-panel-heading {
    border-bottom: 1px solid rgba(255, 204, 0, .18);
    margin-bottom: 2px;
    padding-bottom: 10px;
}

.round-time-panel .round-time-panel-heading strong {
    color: #fff;
    font-size: 1.06rem;
    font-weight: 900;
}

.round-time-panel-heading small {
    color: var(--portal-muted);
    font-size: .8rem;
    font-weight: 720;
}

.round-time-panel strong {
    font-size: .98rem;
    line-height: 1.25;
}

.round-recap-summary-grid {
    border-top: 1px solid rgba(255, 255, 255, .09);
    display: grid;
    grid-column: 1 / -1;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 14px;
    margin-top: 2px;
    padding: 16px 0 0;
    position: relative;
    z-index: 2;
}

.round-recap-summary-grid > article {
    min-height: 132px;
}

.round-result-note {
    padding: 12px 14px;
    color: var(--portal-muted);
}

.round-timeline-panel {
    --timeline-bg: #08111f;
    --timeline-panel: #0b1627;
    --timeline-panel-soft: rgba(11, 22, 39, .74);
    --timeline-line: rgba(82, 96, 122, .46);
    --timeline-line-soft: rgba(82, 96, 122, .24);
    --timeline-allies: #f2b705;
    --timeline-allies-soft: #ffd24a;
    --timeline-axis: #e1493f;
    --timeline-axis-soft: #ff6a5e;
    --timeline-neutral: #d7dce4;
    --timeline-neutral-dim: #8d98aa;
    --timeline-allies-rgb: 242, 183, 5;
    --timeline-axis-rgb: 225, 73, 63;
    --timeline-neutral-rgb: 215, 220, 228;
    color: var(--portal-text);
    display: grid;
    gap: 15px;
    overflow: hidden;
    padding: 20px;
    background:
        linear-gradient(115deg, rgba(242, 183, 5, .055), transparent 34%),
        linear-gradient(245deg, rgba(225, 73, 63, .055), transparent 36%),
        linear-gradient(180deg, rgba(8, 17, 31, .97), rgba(6, 13, 23, .95));
}

.round-timeline-heading,
.round-timeline-toolbar,
.round-timeline-support-grid,
.round-timeline-grid {
    display: grid;
    gap: 14px;
}

.round-timeline-heading {
    align-items: start;
    grid-template-columns: minmax(0, 1fr) auto;
}

.round-timeline-heading span,
.round-key-moments .awards-section-heading span,
.round-event-feed .awards-section-heading span,
.round-awards-panel .awards-section-heading span,
.round-scoreboard-panel .awards-section-heading span {
    color: var(--round-gold);
    font-size: .78rem;
    font-weight: 900;
    letter-spacing: 0;
    text-transform: uppercase;
}

.round-key-moments .awards-section-heading h2,
.round-key-moments .awards-section-heading h3,
.round-event-feed .awards-section-heading h2,
.round-event-feed .awards-section-heading h3,
.round-awards-panel .awards-section-heading h2,
.round-scoreboard-panel .awards-section-heading h2 {
    color: #fff;
    font-size: 1.05rem;
    font-weight: 900;
    line-height: 1.2;
    margin: 2px 0 0;
    text-transform: uppercase;
}

.round-key-moments .awards-section-heading small,
.round-event-feed .awards-section-heading small,
.round-awards-panel .awards-section-heading small,
.round-scoreboard-panel .awards-section-heading small {
    align-self: center;
    color: var(--round-gold);
    flex: 0 0 auto;
    font-size: .82rem;
    font-weight: 800;
}

.round-timeline-heading h2 {
    color: #fff;
    font-size: 1.28rem;
    font-weight: 950;
    line-height: 1.15;
    margin: 2px 0 0;
    text-transform: uppercase;
}

.round-timeline-heading p {
    color: var(--portal-muted);
    font-size: .95rem;
    line-height: 1.45;
    margin: 4px 0 0;
    max-width: 720px;
}

.round-timeline-summary {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: flex-end;
}

.round-timeline-summary span {
    background: rgba(255, 255, 255, .035);
    border: 1px solid var(--timeline-line-soft);
    border-radius: 6px;
    color: var(--portal-text);
    font-size: .8rem;
    padding: 6px 9px;
}

.round-timeline-summary .round-score-summary-pill {
    align-items: center;
    display: inline-flex;
    gap: 6px;
    min-width: 86px;
    justify-content: space-between;
}

.round-score-summary-pill.is-allies {
    border-color: rgba(var(--timeline-allies-rgb), .48);
    color: var(--timeline-allies-soft);
}

.round-score-summary-pill.is-axis {
    border-color: rgba(var(--timeline-axis-rgb), .48);
    color: var(--timeline-axis-soft);
}

.round-timeline-toolbar {
    align-items: center;
    border-bottom: 1px solid var(--timeline-line-soft);
    border-top: 1px solid var(--timeline-line-soft);
    grid-template-columns: minmax(0, 1fr) auto;
    padding: 13px 0;
}

.round-timeline-filters,
.round-timeline-zoom {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.round-timeline-zoom-segments {
    display: inline-flex;
    overflow: hidden;
    border: 1px solid var(--timeline-line-soft);
    border-radius: 6px;
}

.round-timeline-filters button,
.round-timeline-zoom button {
    background: rgba(8, 17, 31, .76);
    border: 1px solid var(--timeline-line-soft);
    border-radius: 6px;
    color: var(--portal-text);
    font-weight: 800;
    min-height: 34px;
    padding: 7px 11px;
}

.round-timeline-zoom-segments button {
    border: 0;
    border-radius: 0;
    min-width: 92px;
}

.round-timeline-zoom-segments button + button {
    border-left: 1px solid var(--timeline-line-soft);
}

.round-timeline-zoom button {
    min-width: 36px;
}

.round-timeline-filters button.is-active,
.round-timeline-zoom button.is-active,
.round-timeline-zoom button:focus-visible {
    background: rgba(var(--timeline-allies-rgb), .13);
    border-color: rgba(var(--timeline-allies-rgb), .8);
    color: var(--timeline-allies-soft);
}

.round-timeline-zoom button:disabled,
.round-timeline-zoom button[aria-disabled="true"] {
    cursor: default;
    opacity: .46;
}

.round-timeline-grid {
    align-items: stretch;
    grid-template-columns: minmax(0, 1fr);
}

.round-timeline-main {
    display: grid;
    gap: 12px;
    min-width: 0;
}

.round-timeline-overview,
.round-timeline-stage,
.round-timeline-legend {
    background:
        linear-gradient(180deg, rgba(255, 255, 255, .035), rgba(255, 255, 255, .008)),
        var(--timeline-panel-soft);
    border: 1px solid var(--timeline-line-soft);
    border-radius: 8px;
}

.round-timeline-overview {
    display: grid;
    gap: 12px;
    grid-template-columns: 176px minmax(0, 1fr);
    padding: 12px 14px 10px;
}

.round-overview-label {
    align-self: center;
    display: grid;
    gap: 3px;
}

.round-overview-label span {
    color: var(--portal-muted);
    font-size: .78rem;
    font-weight: 900;
    text-transform: uppercase;
}

.round-overview-label small {
    color: rgba(215, 220, 228, .62);
    font-size: .7rem;
}

.round-overview-body {
    display: grid;
    gap: 7px;
    min-width: 0;
}

.round-overview-track {
    background:
        linear-gradient(90deg, rgba(215, 220, 228, .13) 1px, transparent 1px) 0 0 / 12.5% 100%,
        linear-gradient(180deg, transparent calc(50% - 1px), rgba(215, 220, 228, .26) calc(50% - 1px), rgba(215, 220, 228, .26) calc(50% + 1px), transparent calc(50% + 1px)),
        rgba(3, 8, 15, .42);
    border-radius: 6px;
    cursor: crosshair;
    min-height: 76px;
    overflow: hidden;
    position: relative;
}

.round-overview-ruler {
    color: var(--portal-muted);
    display: flex;
    font-size: .7rem;
    justify-content: space-between;
}

.round-overview-brush {
    background: rgba(var(--timeline-allies-rgb), .09);
    border: 1px solid rgba(var(--timeline-allies-rgb), .82);
    border-radius: 4px;
    bottom: 4px;
    box-shadow: inset 0 0 0 1px rgba(255, 210, 74, .16);
    color: var(--timeline-allies-soft);
    display: grid;
    font-size: .68rem;
    font-weight: 850;
    left: 0;
    min-width: 44px;
    place-items: center;
    pointer-events: none;
    position: absolute;
    top: 4px;
    width: 100%;
    z-index: 1;
}

.round-overview-brush span {
    display: none;
}

.round-overview-event,
.round-overview-cluster,
.round-timeline-marker,
.round-timeline-cluster {
    --lane-color: var(--timeline-neutral);
    --lane-rgb: var(--timeline-neutral-rgb);
    border: 1px solid rgba(var(--lane-rgb), .55);
    color: var(--lane-color);
    cursor: pointer;
    display: grid;
    left: var(--timeline-pos);
    padding: 0;
    place-items: center;
    position: absolute;
    transform: translate(-50%, -50%);
}

.round-overview-event::before,
.round-overview-cluster::before,
.round-timeline-marker::before,
.round-timeline-cluster::before {
    background: currentColor;
    content: "";
    display: block;
    height: var(--marker-size, 16px);
    width: var(--marker-size, 16px);
    -webkit-mask: var(--marker-icon) center / contain no-repeat;
    mask: var(--marker-icon) center / contain no-repeat;
}

.round-overview-event,
.round-overview-cluster {
    top: 50%;
}

.round-overview-event {
    --marker-size: 13px;
    background: rgba(var(--lane-rgb), .1);
    border-radius: 50%;
    height: 18px;
    width: 18px;
    z-index: 4;
}

.round-overview-event.is-allies {
    top: 31%;
}

.round-overview-event.is-axis {
    top: 69%;
}

.round-overview-event.is-neutral {
    top: 50%;
}

.round-overview-event.is-major,
.round-overview-event.is-highlight {
    --marker-size: 15px;
    height: 22px;
    width: 22px;
}

.round-overview-event.is-critical {
    --marker-size: 18px;
    box-shadow: 0 0 0 3px rgba(var(--lane-rgb), .09), 0 0 16px rgba(var(--lane-rgb), .14);
    height: 26px;
    width: 26px;
    z-index: 6;
}

.round-overview-event.is-allies.is-critical {
    top: 22%;
}

.round-overview-event.is-axis.is-critical {
    top: 78%;
}

.round-overview-cluster {
    --marker-size: 12px;
    align-items: center;
    background: rgba(var(--lane-rgb), .12);
    border-radius: 999px;
    display: inline-grid;
    font-size: .65rem;
    font-weight: 900;
    gap: 3px;
    grid-auto-flow: column;
    height: 21px;
    min-width: 46px;
    padding: 0 6px;
    z-index: 4;
}

.round-overview-cluster.is-allies {
    top: 40%;
}

.round-overview-cluster.is-axis {
    top: 60%;
}

.round-overview-cluster.is-neutral {
    top: 50%;
}

.round-overview-score-chip {
    background: rgba(5, 10, 18, .95);
    border: 1px solid rgba(var(--lane-rgb), .66);
    border-radius: 999px;
    color: var(--lane-color);
    cursor: pointer;
    font-size: .62rem;
    font-weight: 950;
    left: var(--timeline-pos);
    line-height: 1;
    min-height: 20px;
    min-width: 34px;
    padding: 4px 7px;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
    z-index: 7;
}

.round-overview-cluster small,
.round-timeline-cluster small {
    color: rgba(255, 255, 255, .72);
    font-size: .58rem;
    font-weight: 900;
    line-height: 1;
    max-width: 58px;
    overflow: hidden;
    text-overflow: ellipsis;
}

.round-overview-density-cluster,
.round-timeline-dynamic-cluster {
    box-shadow: 0 0 0 2px rgba(var(--lane-rgb), .055);
}

.round-overview-event.is-filtered,
.round-overview-cluster.is-filtered {
    opacity: .22;
}

.round-timeline-stage {
    cursor: grab;
    min-height: 450px;
    overscroll-behavior: contain;
    overflow: visible;
    padding: 42px 16px 16px;
    position: relative;
    touch-action: pan-y;
    user-select: none;
}

.round-timeline-stage.is-panning,
.round-timeline-stage.is-panning * {
    cursor: grabbing;
}

.round-timeline-ruler {
    color: var(--portal-muted);
    font-size: .72rem;
    height: 24px;
    left: 16px;
    position: absolute;
    right: 16px;
    top: 11px;
}

.round-timeline-ruler span {
    position: absolute;
    transform: translateX(-50%);
    white-space: nowrap;
}

.round-timeline-ruler span:last-child {
    transform: none;
}

.round-timeline-field {
    background:
        linear-gradient(90deg, rgba(215, 220, 228, .095) 1px, transparent 1px) 0 0 / 12.5% 100%,
        linear-gradient(180deg, rgba(var(--timeline-allies-rgb), .055), transparent 44%, rgba(215, 220, 228, .03) 44%, rgba(215, 220, 228, .03) 56%, transparent 56%, rgba(var(--timeline-axis-rgb), .055)),
        rgba(3, 8, 15, .36);
    border: 1px solid rgba(255, 255, 255, .06);
    border-radius: 8px;
    height: 360px;
    overflow: hidden;
    position: relative;
}

.round-timeline-field-track {
    inset: 0;
    position: absolute;
    z-index: 2;
}

.round-timeline-gap-break,
.round-overview-gap-break {
    background:
        repeating-linear-gradient(135deg, rgba(215, 220, 228, .22) 0 1px, transparent 1px 6px),
        rgba(4, 9, 16, .5);
    border-left: 1px solid rgba(215, 220, 228, .2);
    border-right: 1px solid rgba(215, 220, 228, .2);
    pointer-events: none;
    position: absolute;
    z-index: 0;
}

.round-timeline-gap-break {
    bottom: 0;
    opacity: .5;
    top: 0;
}

.round-overview-gap-break {
    bottom: 4px;
    opacity: .58;
    top: 4px;
}

.round-timeline-centerline {
    background: linear-gradient(90deg, rgba(var(--timeline-allies-rgb), .78), rgba(var(--timeline-neutral-rgb), .62), rgba(var(--timeline-axis-rgb), .78));
    box-shadow: 0 0 18px rgba(255, 255, 255, .08);
    height: 2px;
    left: 0;
    position: absolute;
    right: 0;
    top: calc(50% - 1px);
    z-index: 1;
}

.round-timeline-team-label {
    align-items: center;
    display: inline-flex;
    gap: 8px;
    font-size: .78rem;
    font-weight: 900;
    left: 12px;
    pointer-events: none;
    position: absolute;
    text-transform: uppercase;
    z-index: 4;
}

.round-timeline-team-label img {
    height: 28px;
    width: 28px;
}

.round-timeline-team-label.is-allies {
    color: var(--timeline-allies);
    top: 18px;
}

.round-timeline-team-label.is-axis {
    bottom: 18px;
    color: var(--timeline-axis-soft);
}

.round-timeline-marker.is-allies,
.round-timeline-cluster.is-allies,
.round-overview-event.is-allies,
.round-overview-cluster.is-allies,
.round-overview-score-chip.is-allies,
.round-objective-state-bar.is-allies,
.round-score-chip.is-allies {
    --lane-color: var(--timeline-allies);
    --lane-rgb: var(--timeline-allies-rgb);
}

.round-timeline-marker.is-axis,
.round-timeline-cluster.is-axis,
.round-overview-event.is-axis,
.round-overview-cluster.is-axis,
.round-overview-score-chip.is-axis,
.round-objective-state-bar.is-axis,
.round-score-chip.is-axis {
    --lane-color: var(--timeline-axis);
    --lane-rgb: var(--timeline-axis-rgb);
}

.round-timeline-marker.is-neutral,
.round-timeline-cluster.is-neutral,
.round-overview-event.is-neutral,
.round-overview-cluster.is-neutral,
.round-overview-score-chip.is-neutral,
.round-score-chip.is-neutral {
    --lane-color: var(--timeline-neutral);
    --lane-rgb: var(--timeline-neutral-rgb);
}

.round-objective-state-bar {
    background:
        linear-gradient(90deg,
            rgba(var(--lane-rgb), 0) 0,
            rgba(var(--lane-rgb), .46) 10%,
            rgba(var(--lane-rgb), .72) 50%,
            rgba(var(--lane-rgb), .46) 90%,
            rgba(var(--lane-rgb), 0) 100%);
    border: 0;
    border-radius: 999px;
    box-shadow: 0 0 9px rgba(var(--lane-rgb), .18);
    color: var(--lane-color);
    height: 5px;
    left: var(--timeline-start);
    overflow: visible;
    position: absolute;
    width: var(--timeline-width);
    z-index: 0;
}

.round-objective-state-bar::before,
.round-objective-state-bar::after {
    background: rgba(var(--lane-rgb), .92);
    border: 1px solid rgba(5, 10, 18, .88);
    border-radius: 50%;
    box-shadow: 0 0 10px rgba(var(--lane-rgb), .22);
    content: "";
    height: 9px;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 9px;
}

.round-objective-state-bar::before {
    left: 0;
}

.round-objective-state-bar::after {
    left: 100%;
}

.round-objective-state-bar.is-scoring-run {
    height: 7px;
    box-shadow: 0 0 14px rgba(var(--lane-rgb), .26), 0 0 28px rgba(var(--lane-rgb), .14);
}

.round-objective-state-bar.is-allies {
    top: calc(50% - 70px);
}

.round-objective-state-bar.is-axis {
    top: calc(50% + 61px);
}

.round-objective-state-bar span {
    color: rgba(255, 255, 255, .84);
    display: block;
    font-size: .58rem;
    font-weight: 850;
    line-height: 1;
    opacity: .78;
    overflow: hidden;
    padding: 11px 6px 0;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.round-objective-state-bar.is-clipped-start {
    border-top-left-radius: 2px;
    border-bottom-left-radius: 2px;
}

.round-objective-state-bar.is-clipped-end {
    border-top-right-radius: 2px;
    border-bottom-right-radius: 2px;
}

.round-objective-state-bar.is-clipped-start::before,
.round-objective-state-bar.is-clipped-end::after {
    background: rgba(255, 255, 255, .62);
    content: "";
    height: 100%;
    position: absolute;
    top: 0;
    width: 1px;
}

.round-objective-state-bar.is-clipped-start::before {
    left: 0;
}

.round-objective-state-bar.is-clipped-end::after {
    right: 0;
}

.round-timeline-marker {
    --marker-size: 17px;
    --stem-length: 48px;
    background: rgba(var(--lane-rgb), .1);
    border-radius: 999px;
    gap: 4px;
    height: 26px;
    min-width: 26px;
    top: 50%;
    z-index: 2;
}

.round-timeline-marker.is-allies {
    top: 34%;
}

.round-timeline-marker.is-axis {
    top: 66%;
}

.round-timeline-marker.is-neutral {
    top: 50%;
}

.round-timeline-marker.is-notable,
.round-timeline-marker.is-major,
.round-timeline-marker.is-critical,
.round-timeline-marker.is-highlight {
    --marker-size: 21px;
    --stem-length: 66px;
    height: 32px;
    min-width: 32px;
}

.round-timeline-marker.is-major,
.round-timeline-marker.is-critical,
.round-timeline-marker.is-highlight {
    background: rgba(var(--lane-rgb), .16);
    box-shadow: 0 0 0 3px rgba(var(--lane-rgb), .08), 0 0 18px rgba(var(--lane-rgb), .1);
}

.round-timeline-marker.is-allies.is-major,
.round-timeline-marker.is-allies.is-critical,
.round-timeline-marker.is-allies.is-highlight {
    top: 21%;
}

.round-timeline-marker.is-axis.is-major,
.round-timeline-marker.is-axis.is-critical,
.round-timeline-marker.is-axis.is-highlight {
    top: 79%;
}

.round-timeline-marker.is-allies.is-notable {
    top: 27%;
}

.round-timeline-marker.is-axis.is-notable {
    top: 73%;
}

.round-timeline-marker.is-critical {
    --marker-size: 25px;
    --stem-length: 90px;
    height: 38px;
    min-width: 38px;
}

.round-timeline-marker.is-allies.is-critical {
    top: 15%;
}

.round-timeline-marker.is-axis.is-critical {
    top: 85%;
}

.round-timeline-marker::after {
    background: linear-gradient(180deg, rgba(var(--lane-rgb), .58), rgba(var(--lane-rgb), .12));
    content: "";
    left: 50%;
    pointer-events: none;
    position: absolute;
    width: 1px;
    z-index: -1;
}

.round-timeline-marker.is-allies::after {
    height: var(--stem-length);
    top: 100%;
}

.round-timeline-marker.is-axis::after {
    bottom: 100%;
    height: var(--stem-length);
}

.round-timeline-marker.is-neutral::after {
    display: none;
}

.round-marker-label {
    background: rgba(5, 10, 18, .86);
    border: 1px solid rgba(var(--lane-rgb), .36);
    border-radius: 4px;
    color: var(--portal-text);
    display: none;
    font-size: .68rem;
    font-weight: 850;
    line-height: 1;
    max-width: 128px;
    overflow: hidden;
    padding: 4px 6px;
    position: absolute;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.round-timeline-marker.is-allies .round-marker-label {
    bottom: calc(100% + 6px);
}

.round-timeline-marker.is-axis .round-marker-label,
.round-timeline-marker.is-neutral .round-marker-label {
    top: calc(100% + 6px);
}

.round-timeline-marker.is-label-visible .round-marker-label,
.round-timeline-marker.is-selected .round-marker-label,
.round-timeline-marker:hover .round-marker-label,
.round-timeline-marker:focus-visible .round-marker-label {
    display: block;
}

.round-timeline-marker.is-label-hidden .round-marker-label {
    display: none;
}

.round-timeline-marker.is-selected {
    background: rgba(var(--timeline-allies-rgb), .16);
    border-color: var(--timeline-allies-soft);
    box-shadow: 0 0 0 3px rgba(var(--timeline-allies-rgb), .12), 0 0 20px rgba(var(--timeline-allies-rgb), .18);
    outline: 1px solid var(--timeline-allies-soft);
    outline-offset: 4px;
    z-index: 6;
}

.round-timeline-cluster {
    --marker-size: 14px;
    align-items: center;
    background: rgba(var(--lane-rgb), .12);
    border-radius: 999px;
    display: inline-grid;
    font-size: .78rem;
    font-weight: 900;
    gap: 4px;
    grid-auto-flow: column;
    height: 27px;
    min-width: 58px;
    padding: 0 8px;
    top: 50%;
    z-index: 1;
}

.round-timeline-cluster.is-allies {
    top: 38%;
}

.round-timeline-cluster.is-axis {
    top: 62%;
}

.round-timeline-cluster.is-neutral {
    top: 50%;
}

.round-timeline-cluster.is-active,
.round-overview-cluster.is-active {
    background: rgba(var(--timeline-allies-rgb), .14);
    border-color: rgba(var(--timeline-allies-rgb), .72);
    outline: 1px solid rgba(var(--timeline-allies-rgb), .82);
    outline-offset: 3px;
}

.round-timeline-cluster.is-related,
.round-overview-cluster.is-related {
    outline: 1px solid rgba(var(--lane-rgb), .28);
    outline-offset: 3px;
}

.round-score-rail {
    align-items: center;
    display: flex;
    left: 0;
    pointer-events: none;
    position: absolute;
    right: 0;
    top: calc(50% - 17px);
    z-index: 3;
}

.round-score-rail > span {
    clip-path: inset(50%);
    height: 1px;
    overflow: hidden;
    position: absolute;
    white-space: nowrap;
    width: 1px;
}

.round-score-chip {
    --lane-color: var(--timeline-neutral);
    --lane-rgb: var(--timeline-neutral-rgb);
    align-items: center;
    background:
        linear-gradient(180deg, rgba(var(--lane-rgb), .28), rgba(var(--lane-rgb), .1)),
        rgba(5, 10, 18, .96);
    border: 1px solid rgba(var(--lane-rgb), .78);
    border-radius: 999px;
    color: var(--lane-color);
    cursor: pointer;
    display: inline-grid;
    font-size: .72rem;
    font-weight: 950;
    gap: 5px;
    grid-auto-flow: column;
    left: var(--timeline-pos);
    min-height: 28px;
    min-width: 44px;
    padding: 4px 8px;
    pointer-events: auto;
    position: absolute;
    box-shadow: 0 0 0 2px rgba(var(--lane-rgb), .07), 0 8px 20px rgba(0, 0, 0, .22);
    transform: translateX(-50%);
}

.round-score-chip::before {
    background: var(--lane-color);
    border-radius: 50%;
    box-shadow: 0 0 10px rgba(var(--lane-rgb), .5);
    content: "";
    height: 7px;
    width: 7px;
}

.round-score-chip.is-allies {
    top: -28px;
}

.round-score-chip.is-axis {
    top: 28px;
}

.round-timeline-guide {
    background: linear-gradient(180deg, transparent, rgba(var(--timeline-allies-rgb), .95) 10%, rgba(var(--timeline-allies-rgb), .95) 90%, transparent);
    bottom: 18px;
    left: var(--timeline-guide-left, 50%);
    pointer-events: none;
    position: absolute;
    top: 45px;
    width: 1px;
    z-index: 4;
}

.round-timeline-guide span {
    background: rgba(8, 17, 31, .96);
    border: 1px solid rgba(var(--timeline-allies-rgb), .86);
    border-radius: 4px;
    color: var(--timeline-allies-soft);
    font-size: .73rem;
    font-weight: 900;
    left: 0;
    padding: 4px 7px;
    position: absolute;
    top: -30px;
    transform: translateX(-50%);
    white-space: nowrap;
}

.round-timeline-guide.is-edge-start span {
    left: -2px;
    transform: translateX(0);
}

.round-timeline-guide.is-edge-end span {
    left: 2px;
    transform: translateX(-100%);
}

.round-event-popover {
    --lane-color: var(--timeline-neutral);
    --lane-rgb: var(--timeline-neutral-rgb);
    background:
        radial-gradient(circle at 12% 0, rgba(var(--lane-rgb), .13), transparent 34%),
        rgba(6, 13, 23, .98);
    border: 1px solid rgba(var(--lane-rgb), .42);
    border-radius: 8px;
    box-sizing: border-box;
    box-shadow: 0 18px 40px rgba(0, 0, 0, .38), 0 0 0 1px rgba(var(--lane-rgb), .06);
    color: var(--portal-text);
    display: grid;
    gap: 12px;
    left: var(--popover-left, 24px);
    max-width: calc(100vw - 24px);
    overflow: visible;
    padding: 14px;
    position: fixed;
    top: var(--popover-top, 64px);
    width: 380px;
    z-index: 20;
}

.round-event-popover[data-side="allies"] {
    --lane-color: var(--timeline-allies);
    --lane-rgb: var(--timeline-allies-rgb);
}

.round-event-popover[data-side="axis"] {
    --lane-color: var(--timeline-axis);
    --lane-rgb: var(--timeline-axis-rgb);
}

.round-event-popover[data-side="neutral"] {
    --lane-color: var(--timeline-neutral);
    --lane-rgb: var(--timeline-neutral-rgb);
}

:is(.round-event-popover, .round-key-moment-list, .round-event-feed-list, .round-scoreboard-table, .round-scoreboard-mobile, .round-award-rail) {
    scrollbar-color: rgba(255, 204, 0, .62) rgba(255, 255, 255, .045);
    scrollbar-gutter: stable;
    scrollbar-width: thin;
}

:is(.round-event-popover, .round-key-moment-list, .round-event-feed-list, .round-scoreboard-table, .round-scoreboard-mobile, .round-award-rail)::-webkit-scrollbar {
    height: 8px;
    width: 8px;
}

:is(.round-event-popover, .round-key-moment-list, .round-event-feed-list, .round-scoreboard-table, .round-scoreboard-mobile, .round-award-rail)::-webkit-scrollbar-track {
    background: rgba(255, 255, 255, .045);
    border-radius: 999px;
}

:is(.round-event-popover, .round-key-moment-list, .round-event-feed-list, .round-scoreboard-table, .round-scoreboard-mobile, .round-award-rail)::-webkit-scrollbar-thumb {
    background: rgba(255, 204, 0, .58);
    border: 2px solid rgba(16, 22, 32, .95);
    border-radius: 999px;
}

:is(.round-event-popover, .round-key-moment-list, .round-event-feed-list, .round-scoreboard-table, .round-scoreboard-mobile, .round-award-rail)::-webkit-scrollbar-thumb:hover {
    background: rgba(255, 204, 0, .78);
}

.round-event-popover[hidden] {
    display: none;
}

.round-popover-close {
    align-items: center;
    background: rgba(255, 255, 255, .04);
    border: 1px solid var(--timeline-line-soft);
    border-radius: 50%;
    color: var(--portal-muted);
    display: grid;
    font-size: 1.1rem;
    height: 28px;
    line-height: 1;
    padding: 0;
    place-items: center;
    position: absolute;
    right: 10px;
    top: 10px;
    width: 28px;
}

.round-popover-close:hover,
.round-popover-close:focus-visible {
    color: var(--lane-color);
    border-color: rgba(var(--lane-rgb), .62);
}

.round-popover-heading {
    align-items: center;
    display: grid;
    gap: 12px;
    grid-template-columns: 58px minmax(0, 1fr);
    padding-right: 30px;
}

.round-popover-icon {
    align-items: center;
    aspect-ratio: 1;
    background: rgba(var(--lane-rgb), .1);
    border: 1px solid rgba(var(--lane-rgb), .72);
    border-radius: 50%;
    display: grid;
    justify-items: center;
    padding: 9px;
    box-shadow: inset 0 0 18px rgba(var(--lane-rgb), .08), 0 0 16px rgba(var(--lane-rgb), .12);
}

.round-popover-icon img {
    height: 36px;
    width: 36px;
}

.round-popover-kicker {
    color: var(--lane-color);
    font-size: .72rem;
    font-weight: 900;
    text-transform: uppercase;
}

.round-event-popover h3 {
    font-size: 1.08rem;
    margin: 0;
}

.round-event-popover p {
    color: var(--portal-muted);
    font-size: .94rem;
    line-height: 1.35;
    margin: 1px 0 0;
}

.round-popover-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 7px;
}

.round-popover-meta span {
    background: rgba(var(--lane-rgb), .09);
    border: 1px solid rgba(var(--lane-rgb), .24);
    border-radius: 999px;
    color: rgba(255, 255, 255, .84);
    font-size: .68rem;
    font-weight: 900;
    line-height: 1;
    padding: 6px 8px;
    text-transform: uppercase;
}

.round-event-popover dl {
    display: grid;
    gap: 0;
    margin: 0;
}

.round-event-popover dl div {
    border-top: 1px solid var(--timeline-line-soft);
    display: grid;
    gap: 10px;
    grid-template-columns: 82px minmax(0, 1fr);
    padding: 8px 0;
}

.round-event-popover dl div[hidden] {
    display: none;
}

.round-event-popover dt {
    color: var(--portal-muted);
    font-size: .7rem;
    text-transform: uppercase;
}

.round-event-popover dd {
    margin: 0;
    min-width: 0;
    overflow-wrap: anywhere;
}

.round-event-popover a {
    color: var(--lane-color);
    text-decoration: none;
}

.round-event-popover a:hover,
.round-event-popover a:focus-visible {
    text-decoration: underline;
}

.round-popover-cluster-list {
    display: grid;
    gap: 7px;
}

.round-popover-cluster-list[hidden] {
    display: none;
}

.round-popover-cluster-list > span {
    color: var(--timeline-neutral-dim);
    font-size: .72rem;
    font-weight: 900;
    text-transform: uppercase;
}

.round-popover-cluster-list p {
    color: var(--portal-muted);
    font-size: .78rem;
    margin: -2px 0 2px;
}

.round-popover-cluster-list button {
    align-items: center;
    background: rgba(255, 255, 255, .035);
    border: 1px solid rgba(255, 255, 255, .08);
    border-radius: 6px;
    color: var(--portal-text);
    display: grid;
    gap: 8px;
    grid-template-columns: 52px minmax(0, 1fr) auto;
    min-height: 36px;
    padding: 7px 9px;
    text-align: left;
}

.round-popover-cluster-list button:hover,
.round-popover-cluster-list button:focus-visible {
    background: rgba(var(--timeline-allies-rgb), .1);
    border-color: rgba(var(--timeline-allies-rgb), .52);
}

.round-popover-cluster-list button span,
.round-popover-cluster-list button small,
.round-popover-cluster-list > small {
    color: var(--portal-muted);
    font-size: .72rem;
}

.round-popover-cluster-list button strong {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.round-timeline-legend {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 12px 18px;
    padding: 10px 14px;
}

.round-timeline-legend > span {
    align-items: center;
    color: var(--portal-muted);
    display: inline-flex;
    font-size: .78rem;
    gap: 7px;
    white-space: nowrap;
}

.round-timeline-legend > span:first-child {
    color: var(--portal-text);
    font-weight: 900;
    text-transform: uppercase;
}

.round-timeline-legend img {
    height: 18px;
    width: 18px;
}

.round-timeline-legend > span.round-spectator-legend {
    background: rgba(var(--timeline-neutral-rgb), .07);
    border: 1px solid rgba(var(--timeline-neutral-rgb), .16);
    border-radius: 999px;
    color: var(--timeline-neutral);
    margin-left: auto;
    padding: 5px 9px;
}

.round-timeline-legend > span.round-spectator-legend strong {
    color: var(--timeline-neutral);
    font-size: .8rem;
    font-weight: 900;
    margin-left: 2px;
}

.round-carry-legend {
    background: rgba(var(--lane-rgb), .3);
    border: 1px solid rgba(var(--lane-rgb), .62);
    border-radius: 999px;
    display: inline-block;
    height: 7px;
    margin-right: -4px;
    width: 18px;
}

.round-carry-legend.is-allies {
    --lane-rgb: var(--timeline-allies-rgb);
}

.round-carry-legend.is-axis {
    --lane-rgb: var(--timeline-axis-rgb);
}

.round-timeline-support-grid {
    align-items: start;
    grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr);
}

.round-key-moments,
.round-event-feed,
.round-awards-panel,
.round-scoreboard-panel {
    padding: 16px;
}

.round-key-moment-list,
.round-event-feed-list {
    display: grid;
    gap: 8px;
}

.round-key-moment-list {
    max-height: 360px;
    overflow: auto;
    padding-right: 4px;
}

.round-event-feed-list {
    max-height: 360px;
    overflow: auto;
    padding-right: 4px;
}

.round-key-moment-list button,
.round-event-feed-list button {
    align-items: center;
    background: rgba(255, 255, 255, .035);
    border: 1px solid rgba(255, 255, 255, .08);
    border-radius: 7px;
    color: var(--portal-text);
    display: grid;
    gap: 10px;
    grid-template-columns: 64px minmax(0, 1fr) auto;
    min-height: 46px;
    padding: 9px 11px;
    text-align: left;
    text-decoration: none;
    width: 100%;
}

.round-key-moment-list button:hover,
.round-key-moment-list button:focus-visible,
.round-event-feed-list button:hover,
.round-event-feed-list button:focus-visible {
    background: rgba(242, 183, 5, .1);
    border-color: rgba(242, 183, 5, .52);
}

.round-key-moment-list span,
.round-event-feed-list span {
    color: var(--portal-muted);
    font-variant-numeric: tabular-nums;
}

.round-key-moment-list strong,
.round-event-feed-list strong {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.round-key-moment-list small,
.round-event-feed-list small {
    color: var(--portal-muted);
}

.round-awards-panel {
    display: grid;
    gap: 14px;
}

.round-awards-empty {
    min-height: 112px;
}

.round-award-rail-shell {
    min-width: 0;
    position: relative;
}

.round-award-rail-shell::after {
    background: linear-gradient(90deg, rgba(14, 22, 34, 0), rgba(14, 22, 34, .96));
    bottom: 0;
    content: "";
    pointer-events: none;
    position: absolute;
    right: 0;
    top: 0;
    width: 48px;
}

.round-award-rail {
    display: grid;
    gap: 12px;
    grid-auto-columns: minmax(250px, 300px);
    grid-auto-flow: column;
    grid-template-columns: none;
    justify-content: start;
    min-width: 0;
    overflow-x: auto;
    overscroll-behavior-inline: contain;
    padding: 0 34px 4px 0;
    scroll-padding-inline: 2px 34px;
    scroll-snap-type: x proximity;
}

.round-award-card {
    align-content: start;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, .052), rgba(255, 255, 255, .02)),
        linear-gradient(135deg, var(--award-accent-soft), transparent 62%);
    border: 1px solid rgba(255, 255, 255, .1);
    border-top: 3px solid var(--award-accent);
    border-radius: 7px;
    color: var(--portal-text);
    display: grid;
    gap: 8px;
    justify-items: center;
    min-height: 214px;
    min-width: 0;
    padding: 14px;
    scroll-snap-align: start;
    text-align: center;
}

.round-award-card:hover {
    background:
        linear-gradient(180deg, rgba(255, 255, 255, .065), rgba(255, 255, 255, .025)),
        linear-gradient(135deg, var(--award-accent-soft), transparent 62%);
    border-color: var(--award-accent);
}

.round-award-card-top {
    align-items: center;
    display: grid;
    gap: 7px;
    justify-items: center;
    min-width: 0;
    width: 100%;
}

.round-award-card-top img {
    filter: drop-shadow(0 12px 22px var(--award-accent-soft));
    height: 72px;
    object-fit: contain;
    width: 72px;
}

.round-award-card-top span,
.round-award-card small,
.round-award-card p {
    color: var(--portal-muted);
    font-size: .78rem;
    overflow-wrap: anywhere;
}

.round-award-card-top span {
    font-weight: 900;
    text-transform: uppercase;
}

.round-award-card strong {
    color: #fff;
    font-size: 1.02rem;
    font-weight: 950;
    line-height: 1.18;
    overflow-wrap: anywhere;
}

.round-award-player {
    color: var(--round-gold);
    font-size: .95rem;
    font-weight: 900;
    line-height: 1.2;
    min-width: 0;
    overflow: hidden;
    max-width: 100%;
    text-decoration: none;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.round-award-subjects {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 3px 7px;
    justify-content: center;
    max-width: 100%;
    min-width: 0;
}

.round-award-subjects > span {
    color: var(--portal-muted);
    font-size: .9rem;
    font-weight: 900;
    line-height: 1;
}

.round-award-subjects .round-award-player {
    flex: 0 1 auto;
    max-width: min(100%, 11rem);
}

.round-award-player:hover,
.round-award-player:focus-visible {
    color: #fff;
    text-decoration: underline;
}

.round-award-metric {
    color: #fff;
    font-size: 1.65rem;
    font-weight: 950;
    line-height: 1;
    overflow-wrap: anywhere;
}

.round-award-card p {
    margin: 0;
}

.round-scoreboard-panel {
    display: grid;
    gap: 14px;
}

.round-scoreboard-table {
    max-height: 520px;
    overflow: auto;
    border: 1px solid rgba(255, 255, 255, .08);
    border-radius: 8px;
}

.round-scoreboard-table .table-hover > tbody > tr:hover > * {
    --bs-table-bg-state: rgba(242, 183, 5, .08);
    --bs-table-color-state: var(--portal-text);
    background-color: rgba(242, 183, 5, .08);
    color: var(--portal-text);
}

.round-scoreboard-table .leader-row > * {
    --bs-table-bg-state: rgba(77, 141, 255, .075);
    background-color: rgba(77, 141, 255, .075);
}

.round-scoreboard-table .leader-row:hover > * {
    --bs-table-bg-state: rgba(242, 183, 5, .11);
    background-color: rgba(242, 183, 5, .11);
}

.round-scoreboard-table thead th {
    position: sticky;
    top: 0;
    z-index: 1;
    background: var(--portal-panel);
}

.round-timeline-panel.is-sparse-timeline .round-timeline-stage {
    min-height: 320px;
}

.round-timeline-panel.is-sparse-timeline .round-timeline-field {
    height: 250px;
}

@media (max-width: 1200px) {
    .round-recap-hero {
        grid-template-columns: minmax(380px, .62fr) minmax(0, 1fr);
    }

    .round-time-panel {
        grid-column: 1 / -1;
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .round-recap-summary-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .round-timeline-support-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 820px) {
    .round-recap-shell {
        gap: 14px;
    }

    .round-recap-hero,
    .round-timeline-heading,
    .round-timeline-toolbar,
    .round-timeline-support-grid,
    .round-timeline-overview {
        grid-template-columns: 1fr;
    }

    .round-recap-hero {
        padding: 12px;
    }

    .round-recap-summary-grid {
        margin-top: 0;
        padding: 12px 0 0;
    }

    .round-recap-map,
    .round-recap-map img,
    .round-recap-map-empty {
        min-height: 156px;
    }

    .round-recap-copy h1 {
        font-size: 2.3rem;
    }

    .round-result-panel {
        align-items: center;
        grid-template-columns: auto minmax(0, 1fr);
    }

    .round-time-panel,
    .round-recap-summary-grid {
        grid-template-columns: 1fr;
    }

    .round-timeline-legend > span.round-spectator-legend {
        margin-left: 0;
    }

    .round-timeline-panel {
        padding: 12px;
    }

    .round-timeline-summary {
        justify-content: flex-start;
    }

    .round-timeline-zoom-segments {
        flex: 1 1 100%;
    }

    .round-timeline-zoom-segments button {
        flex: 1 1 0;
        min-width: 0;
    }

    .round-timeline-stage {
        min-height: 370px;
        padding: 42px 8px 12px;
    }

    .round-timeline-field {
        height: 290px;
    }

    .round-timeline-team-label {
        left: 8px;
    }

    .round-timeline-team-label img {
        height: 24px;
        width: 24px;
    }

    .round-overview-brush span {
        display: none;
    }

    .round-overview-cluster {
        min-width: 42px;
        padding: 0 5px;
    }

    .round-timeline-cluster {
        font-size: .72rem;
        min-width: 50px;
        padding: 0 6px;
    }

    .round-score-rail > span {
        display: none;
    }

    .round-score-chip {
        font-size: .68rem;
        min-width: 38px;
        padding: 3px 7px;
    }

    .round-overview-cluster small,
    .round-timeline-cluster small {
        font-size: .54rem;
        max-width: 48px;
    }

    .round-event-popover {
        bottom: 12px;
        left: 12px !important;
        max-height: 68vh;
        max-width: none;
        overflow: auto;
        position: fixed;
        right: 12px;
        top: auto !important;
        width: auto;
    }

    .round-key-moment-list button,
    .round-event-feed-list button {
        grid-template-columns: 58px minmax(0, 1fr);
    }

    .round-key-moment-list small,
    .round-event-feed-list small {
        grid-column: 2;
    }

    .round-award-rail {
        grid-auto-columns: minmax(250px, 84vw);
        grid-auto-flow: column;
        grid-template-columns: none;
        justify-content: start;
        overflow-x: auto;
        overscroll-behavior-inline: contain;
        padding-right: 28px;
        scroll-padding-inline: 2px 28px;
        scroll-snap-type: x proximity;
    }
}

.player-dossier-shell {
    --player-bg: #05080d;
    --player-panel: #0c121b;
    --player-line: rgba(160, 176, 204, .16);
    --player-line-strong: rgba(255, 255, 255, .14);
    --player-text: #f4f7fb;
    --player-muted: #aab4c2;
    --player-faint: #737f91;
    --player-gold: #ffcc00;
    --player-red: #ff3648;
    --player-blue: #4d82ff;
    --player-green: #45d96a;
    --player-purple: #b45cff;
    --player-cyan: #39c7e6;
    --award-accent: var(--player-gold);
    --award-accent-soft: rgba(255, 204, 0, .15);
    color: var(--player-text);
    display: grid;
    gap: 18px;
    min-width: 0;
}

.player-dossier-shell a {
    color: var(--player-gold);
}

.player-dossier-shell a:hover {
    color: #ffe47a;
}

.player-dossier-shell a:focus-visible,
.player-medal-rail:focus-visible,
.player-detail-accordion > summary:focus-visible {
    box-shadow: 0 0 0 .18rem rgba(255, 204, 0, .22);
    outline: 2px solid var(--player-gold);
    outline-offset: 2px;
}

.player-dossier-crumbs {
    align-items: center;
    background: rgba(5, 8, 13, .72);
    border: 1px solid var(--player-line);
    border-radius: 8px;
    color: var(--player-muted);
    display: flex;
    flex-wrap: wrap;
    font-size: .86rem;
    font-weight: 760;
    gap: 8px;
    min-width: 0;
    padding: 10px 12px;
}

.player-dossier-crumbs > span:last-of-type {
    color: var(--player-text);
    min-width: 0;
    overflow-wrap: anywhere;
}

.player-dossier-return {
    margin-left: auto;
}

.player-dossier-hero,
.player-dossier-callout,
.player-medal-strip,
.player-panel,
.player-details-area {
    background:
        linear-gradient(180deg, rgba(255, 255, 255, .045), rgba(255, 255, 255, .018)),
        var(--player-panel);
    border: 1px solid var(--player-line);
    border-radius: 8px;
    box-shadow: 0 18px 42px rgba(0, 0, 0, .24);
    min-width: 0;
}

.player-dossier-hero {
    background:
        linear-gradient(90deg, rgba(5, 8, 13, .99) 0%, rgba(9, 14, 22, .95) 48%, rgba(40, 31, 7, .76) 100%),
        repeating-linear-gradient(0deg, rgba(255, 255, 255, .028) 0, rgba(255, 255, 255, .028) 1px, transparent 1px, transparent 8px),
        radial-gradient(circle at 83% 14%, rgba(255, 204, 0, .2), transparent 32%),
        radial-gradient(circle at 17% 85%, rgba(255, 54, 72, .16), transparent 34%),
        #05080d;
    overflow: hidden;
    position: relative;
}

.player-dossier-hero::after {
    background:
        linear-gradient(90deg, transparent, rgba(255, 204, 0, .16), transparent),
        linear-gradient(180deg, transparent, rgba(0, 0, 0, .22));
    content: "";
    inset: 0;
    pointer-events: none;
    position: absolute;
}

.player-dossier-stage {
    align-items: stretch;
    display: grid;
    gap: clamp(16px, 2vw, 24px);
    grid-template-columns: minmax(0, 1fr) minmax(280px, 400px);
    padding: clamp(20px, 2.4vw, 30px);
    position: relative;
    z-index: 1;
}

.player-dossier-identity {
    align-items: center;
    display: grid;
    gap: clamp(14px, 1.7vw, 22px);
    grid-template-columns: auto minmax(0, 1fr);
    min-width: 0;
    padding: 0;
    position: relative;
    z-index: 1;
}

.player-crest-frame {
    align-items: center;
    background:
        radial-gradient(circle at 50% 42%, rgba(255, 204, 0, .16), rgba(255, 54, 72, .08) 62%, rgba(0, 0, 0, .18)),
        linear-gradient(180deg, rgba(255, 204, 0, .14), rgba(255, 255, 255, .025));
    border: 1px solid rgba(255, 204, 0, .42);
    border-radius: 8px;
    box-shadow: 0 20px 42px rgba(0, 0, 0, .28), inset 0 1px 0 rgba(255, 255, 255, .08);
    display: grid;
    height: clamp(96px, 9vw, 124px);
    justify-items: center;
    padding: 12px;
    width: clamp(96px, 9vw, 124px);
}

.player-crest-frame img {
    display: block;
    height: clamp(72px, 6.8vw, 96px);
    object-fit: contain;
    width: clamp(72px, 6.8vw, 96px);
}

.player-dossier-kicker,
.player-section-heading span,
.player-stat-card span,
.player-relationship-card > div > span,
.player-favorites-grid h3,
.player-detail-accordion summary small {
    color: var(--player-gold);
    font-size: .72rem;
    font-weight: 850;
    letter-spacing: 0;
    text-transform: uppercase;
}

.player-dossier-title {
    min-width: 0;
}

.player-dossier-title h1 {
    color: #fff;
    font-size: clamp(2.15rem, 4vw, 4.15rem);
    font-weight: 950;
    letter-spacing: 0;
    line-height: .95;
    margin: 4px 0 12px;
    overflow-wrap: anywhere;
}

.player-dossier-meta {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    min-width: 0;
}

.player-dossier-meta span {
    align-items: center;
    background: rgba(0, 0, 0, .26);
    border: 1px solid rgba(255, 255, 255, .11);
    border-radius: 6px;
    color: #dce4ef;
    display: inline-flex;
    font-size: .82rem;
    font-weight: 720;
    gap: 6px;
    min-height: 30px;
    min-width: 0;
    padding: 5px 8px;
}

.player-dossier-meta img,
.player-detail-accordion summary img {
    flex: 0 0 auto;
    height: 18px;
    object-fit: contain;
    width: 18px;
}

.player-dossier-meta .player-dossier-muted {
    color: var(--player-faint);
}

.player-dossier-topline {
    border-top: 1px solid var(--player-line);
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    padding: 0 clamp(16px, 2.4vw, 30px) clamp(16px, 2.4vw, 24px);
    position: relative;
    z-index: 1;
}

.player-stat-card {
    background:
        linear-gradient(180deg, rgba(255, 255, 255, .05), rgba(255, 255, 255, .018)),
        linear-gradient(90deg, var(--award-accent-soft), transparent 64%);
    border: 1px solid var(--player-line-strong);
    border-top: 3px solid var(--award-accent);
    border-radius: 7px;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .035);
    display: grid;
    gap: 6px;
    min-height: 112px;
    min-width: 0;
    padding: 12px;
}

.player-stat-card img {
    filter: drop-shadow(0 10px 22px var(--award-accent-soft));
    height: 36px;
    object-fit: contain;
    width: 36px;
}

.player-stat-card strong {
    color: #fff;
    display: block;
    font-size: clamp(1.55rem, 2vw, 2.25rem);
    font-weight: 950;
    line-height: 1.05;
    overflow-wrap: anywhere;
}

.player-stat-card small {
    color: var(--player-muted);
    font-size: .8rem;
    overflow-wrap: anywhere;
}

.player-stat-card .player-stat-detail {
    color: #c7d4e7;
    font-size: .74rem;
}

.player-known-for {
    display: grid;
    gap: 6px;
    min-width: 0;
}

.player-hero-feature {
    align-content: start;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, .06), rgba(255, 255, 255, .022)),
        linear-gradient(135deg, var(--award-accent-soft), rgba(0, 0, 0, .1));
    border: 1px solid color-mix(in srgb, var(--award-accent) 42%, rgba(255, 255, 255, .14));
    border-radius: 8px;
    box-shadow: 0 18px 38px rgba(0, 0, 0, .22), inset 0 1px 0 rgba(255, 255, 255, .06);
    display: grid;
    gap: 12px;
    grid-template-columns: auto minmax(0, 1fr);
    min-width: 0;
    padding: 14px;
}

.player-hero-feature > img {
    filter: drop-shadow(0 14px 28px var(--award-accent-soft));
    height: 64px;
    object-fit: contain;
    width: 64px;
}

.player-hero-feature .player-known-for {
    align-self: center;
}

.player-known-for > span,
.player-profile-actions a,
.player-dossier-callout a {
    color: var(--player-gold);
    font-size: .72rem;
    font-weight: 850;
    letter-spacing: 0;
    text-transform: uppercase;
}

.player-known-for strong {
    color: #fff;
    font-size: clamp(1.25rem, 2vw, 1.7rem);
    font-weight: 950;
    line-height: 1.15;
    overflow-wrap: anywhere;
}

.player-known-for small {
    color: var(--player-muted);
    display: flex;
    flex-wrap: wrap;
    gap: 6px 14px;
    overflow-wrap: anywhere;
}

.player-profile-actions {
    align-content: stretch;
    display: grid;
    gap: 8px;
    grid-column: 1 / -1;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    min-width: 0;
}

.player-profile-actions a,
.player-dossier-callout a {
    align-items: center;
    background: rgba(255, 204, 0, .06);
    border: 1px solid rgba(255, 204, 0, .22);
    border-radius: 7px;
    display: inline-flex;
    justify-content: center;
    min-height: 38px;
    padding: 7px 10px;
    text-align: center;
}

.player-profile-actions a:hover,
.player-dossier-callout a:hover {
    background: rgba(255, 204, 0, .11);
}

.player-profile-actions .player-cta-primary {
    background: linear-gradient(180deg, #ffe06a, var(--player-gold));
    border-color: rgba(255, 204, 0, .72);
    box-shadow: 0 10px 24px rgba(255, 204, 0, .16);
    color: #05080d;
}

.public-shell .public-main:not(.public-landing-main) .player-profile-actions .player-cta-primary,
.public-shell .public-main:not(.public-landing-main) .player-profile-actions .player-cta-primary:hover,
.public-shell .public-main:not(.public-landing-main) .player-profile-actions .player-cta-primary:focus {
    color: #05080d;
}

.player-dossier-callout {
    align-items: center;
    display: grid;
    gap: 12px;
    grid-template-columns: auto minmax(0, 1fr) auto;
    padding: 14px;
}

.player-dossier-callout img {
    height: 38px;
    object-fit: contain;
    width: 38px;
}

.player-dossier-callout strong {
    color: #fff;
    display: block;
    font-weight: 900;
}

.player-dossier-callout p {
    color: var(--player-muted);
    margin: 2px 0 0;
    overflow-wrap: anywhere;
}

.player-section-heading {
    align-items: flex-start;
    display: flex;
    gap: 14px;
    justify-content: space-between;
    margin-bottom: 14px;
    min-width: 0;
}

.player-section-heading h2 {
    color: #fff;
    font-size: 1.05rem;
    font-weight: 900;
    letter-spacing: 0;
    line-height: 1.2;
    margin: 2px 0 0;
    overflow-wrap: anywhere;
    text-transform: uppercase;
}

.player-section-heading a,
.player-section-heading small {
    align-self: center;
    color: var(--player-gold);
    flex: 0 0 auto;
    font-size: .82rem;
    font-weight: 800;
}

.player-medal-strip,
.player-panel,
.player-details-area {
    padding: 18px;
}

.player-medal-rail-shell {
    min-width: 0;
    position: relative;
}

.player-medal-rail-shell::after {
    background: linear-gradient(90deg, rgba(12, 18, 27, 0), rgba(12, 18, 27, .95));
    bottom: 0;
    content: "";
    pointer-events: none;
    position: absolute;
    right: 0;
    top: 0;
    width: 48px;
}

.player-medal-rail {
    display: grid;
    gap: 12px;
    grid-auto-columns: minmax(220px, calc((100% - 60px) / 6));
    grid-auto-flow: column;
    min-width: 0;
    overflow-x: auto;
    overscroll-behavior-inline: contain;
    padding: 0 34px 4px 0;
    scroll-padding-inline: 2px 34px;
    scroll-snap-type: x proximity;
    scrollbar-color: rgba(255, 204, 0, .46) transparent;
    scrollbar-width: thin;
}

.player-medal-card {
    background:
        linear-gradient(180deg, rgba(255, 255, 255, .052), rgba(255, 255, 255, .02)),
        linear-gradient(135deg, var(--award-accent-soft), transparent 62%);
    border: 1px solid var(--player-line);
    border-top: 3px solid var(--award-accent);
    border-radius: 7px;
    color: var(--player-text);
    display: grid;
    gap: 9px;
    min-height: 214px;
    min-width: 0;
    position: relative;
    padding: 14px;
    scroll-snap-align: start;
}

.player-medal-card:hover,
.player-session-card:hover,
.player-relationship-lists a:hover,
.player-mini-rank-list a:hover,
.player-awards-list a:hover,
.player-detail-link-grid a:hover {
    background: rgba(255, 204, 0, .055);
    border-color: rgba(255, 204, 0, .36);
}

.player-medal-card:hover {
    border-color: var(--award-accent);
}

.player-medal-card-top {
    align-items: start;
    display: flex;
    gap: 12px;
    justify-content: space-between;
    min-width: 0;
}

.player-medal-card img {
    filter: drop-shadow(0 12px 22px var(--award-accent-soft));
    height: 58px;
    object-fit: contain;
    width: 58px;
}

.player-medal-rank,
.player-medal-card small,
.player-medal-duo {
    color: var(--player-muted);
    font-size: .78rem;
    overflow-wrap: anywhere;
}

.player-medal-card strong {
    color: #fff;
    font-size: 1.02rem;
    font-weight: 950;
    line-height: 1.18;
    overflow-wrap: anywhere;
}

.player-medal-card strong a {
    color: #fff;
}

.player-medal-metric {
    color: #fff;
    font-size: 1.65rem;
    font-weight: 950;
    line-height: 1;
    overflow-wrap: anywhere;
}

.player-medal-duo {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
}

.player-empty-panel {
    align-items: center;
    background: rgba(255, 255, 255, .026);
    border: 1px dashed rgba(255, 255, 255, .14);
    border-radius: 7px;
    color: var(--player-muted);
    display: flex;
    gap: 10px;
    min-width: 0;
    padding: 14px;
}

.player-empty-panel img {
    flex: 0 0 auto;
    height: 34px;
    object-fit: contain;
    width: 34px;
}

.player-empty-panel p {
    margin: 0;
    overflow-wrap: anywhere;
}

.player-story-grid {
    align-items: stretch;
    display: grid;
    gap: 18px;
    grid-template-columns: minmax(360px, .84fr) minmax(0, 1.16fr);
}

.player-story-grid > .player-panel {
    min-width: 0;
}

.player-story-side-panel {
    align-content: start;
    display: grid;
    gap: 18px;
    grid-template-rows: auto minmax(0, 1fr);
    height: 100%;
}

.player-alias-block {
    display: grid;
    grid-template-rows: auto minmax(0, 1fr);
    min-height: 0;
}

.player-strengths-block {
    border-top: 1px solid rgba(160, 176, 204, .14);
    display: grid;
    grid-template-rows: auto minmax(0, 1fr);
    min-height: 0;
    padding-top: 18px;
}

.player-favorites-grid section {
    background: linear-gradient(180deg, rgba(255, 255, 255, .036), rgba(255, 255, 255, .018));
    border: 1px solid var(--player-line);
    border-radius: 7px;
    min-width: 0;
    padding: 12px;
}

.player-panel-note,
.player-favorites-grid p {
    color: var(--player-muted);
    font-size: .82rem;
    margin: 0;
    overflow-wrap: anywhere;
}

.player-panel-note {
    margin-top: 12px;
}

.player-relationship-grid {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.player-relationship-card {
    align-items: start;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, .04), rgba(255, 255, 255, .018)),
        linear-gradient(90deg, var(--award-accent-soft), transparent 72%);
    border: 1px solid var(--player-line);
    border-left: 3px solid var(--award-accent);
    border-radius: 7px;
    display: grid;
    gap: 12px;
    grid-template-columns: auto minmax(0, 1fr);
    min-height: 160px;
    min-width: 0;
    padding: 12px;
}

.player-relationship-card > img {
    filter: drop-shadow(0 10px 20px var(--award-accent-soft));
    height: 42px;
    object-fit: contain;
    width: 42px;
}

.player-relationship-card h3 {
    font-size: 1rem;
    font-weight: 900;
    line-height: 1.15;
    margin: 2px 0 4px;
    overflow-wrap: anywhere;
}

.player-relationship-card p {
    color: var(--player-muted);
    font-size: .82rem;
    margin: 0 0 10px;
    overflow-wrap: anywhere;
}

.player-relationship-card dl {
    display: grid;
    gap: 8px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin: 0;
}

.player-relationship-card dl > div {
    background: rgba(0, 0, 0, .2);
    border: 1px solid rgba(255, 255, 255, .08);
    border-radius: 6px;
    min-width: 0;
    padding: 7px;
}

.player-relationship-card dt {
    color: var(--player-muted);
    font-size: .68rem;
    font-weight: 800;
    text-transform: uppercase;
}

.player-relationship-card dd {
    color: #fff;
    font-size: .9rem;
    font-weight: 850;
    margin: 2px 0 0;
    overflow-wrap: anywhere;
}

.player-relationship-lists {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin-top: 12px;
}

.player-relationship-lists section {
    background: rgba(255, 255, 255, .02);
    border: 1px solid var(--player-line);
    border-radius: 7px;
    display: grid;
    align-content: start;
    min-width: 0;
    padding: 12px;
}

.player-relationship-lists h3 {
    color: #fff;
    font-size: .92rem;
    font-weight: 900;
    margin: 0 0 10px;
}

.player-relationship-lists a,
.player-relationship-static,
.player-mini-rank-list a,
.player-detail-link-grid a,
.player-awards-list a {
    background: rgba(255, 255, 255, .025);
    border: 1px solid rgba(255, 255, 255, .08);
    border-radius: 6px;
    display: grid;
    gap: 4px;
    min-width: 0;
    padding: 9px;
}

.player-relationship-lists a + a,
.player-relationship-static + a,
.player-relationship-lists a + .player-relationship-static,
.player-relationship-static + .player-relationship-static,
.player-mini-rank-list a + a,
.player-awards-list a + a {
    margin-top: 8px;
}

.player-relationship-lists strong {
    overflow-wrap: anywhere;
}

.player-relationship-lists span,
.player-mini-rank-list strong,
.player-detail-link-grid a {
    color: var(--player-muted);
    font-size: .8rem;
}

.player-session-list {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.player-session-card {
    background:
        linear-gradient(180deg, rgba(255, 255, 255, .036), rgba(255, 255, 255, .018)),
        rgba(0, 0, 0, .08);
    border: 1px solid var(--player-line);
    border-radius: 7px;
    color: var(--player-text);
    display: grid;
    gap: 0;
    grid-template-rows: auto auto auto 1fr auto;
    min-width: 0;
    overflow: hidden;
    padding: 0;
    position: relative;
    text-decoration: none;
}

.player-session-card .map-image-thumb {
    aspect-ratio: 16 / 9;
    border: 0;
    border-bottom: 1px solid rgba(255, 255, 255, .1);
    border-radius: 0;
    color: #fff;
    display: block;
    height: auto;
    min-height: 92px;
    width: 100%;
}

.player-session-card .map-image-thumb::after {
    background: linear-gradient(180deg, rgba(5, 8, 12, .03), rgba(5, 8, 12, .22));
}

.player-session-card .map-image {
    filter: saturate(1.04) contrast(1.04) brightness(.92);
}

.player-session-card > strong,
.player-session-card > span:not(.map-image-shell) {
    display: block;
    min-width: 0;
    overflow: hidden;
    padding-left: 12px;
    padding-right: 12px;
    position: relative;
    text-overflow: ellipsis;
    white-space: nowrap;
    z-index: 1;
}

.player-session-map {
    color: #fff;
    font-size: .98rem;
    font-weight: 900;
    line-height: 1.2;
    padding-top: 10px;
}

.player-session-context {
    color: #c7d4e7;
    font-size: .78rem;
    padding-top: 3px;
}

.player-session-card .player-session-summary {
    color: #dce4ef;
    font-size: .82rem;
    font-weight: 850;
    padding-top: 7px;
}

.player-session-footer {
    align-items: center;
    color: var(--player-muted);
    display: flex !important;
    font-size: .78rem;
    font-weight: 800;
    gap: 8px;
    justify-content: space-between;
    padding-bottom: 12px;
    padding-top: 10px;
}

.player-session-footer > span:last-child {
    margin-left: auto;
}

.player-result-pill {
    align-self: start;
    border: 1px solid rgba(255, 255, 255, .14);
    border-radius: 5px;
    font-size: .72rem;
    font-weight: 850;
    justify-self: start;
    min-width: auto;
    padding: 3px 7px;
    text-transform: uppercase;
    white-space: nowrap;
}

.player-result-pill.is-win { color: var(--player-green); }
.player-result-pill.is-loss { color: #ff7b86; }
.player-result-pill.is-draw { color: var(--player-blue); }
.player-result-pill.is-unknown { color: var(--player-muted); }

.player-favorites-grid {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.player-favorites-grid h3 {
    color: #fff;
    margin: 0 0 4px;
}

.player-favorites-grid section {
    display: grid;
    grid-template-rows: auto auto auto;
}

.player-favorites-grid ol {
    align-content: start;
    display: grid;
    gap: 8px;
    list-style: none;
    margin: 12px 0;
    padding: 0;
}

.player-favorites-grid li {
    align-items: center;
    display: grid;
    gap: 8px;
    grid-template-columns: minmax(0, 1fr) auto;
    min-width: 0;
}

.player-favorites-grid li > a,
.player-weapon-link {
    min-width: 0;
    overflow-wrap: anywhere;
}

.player-favorites-grid li > span:last-child {
    color: var(--player-muted);
    font-size: .78rem;
    white-space: nowrap;
}

.player-weapon-link {
    align-items: center;
    display: flex;
    gap: 8px;
}

.player-weapon-link img {
    background: rgba(255, 255, 255, .05);
    border: 1px solid rgba(255, 255, 255, .1);
    border-radius: 5px;
    flex: 0 0 auto;
    height: 28px;
    object-fit: contain;
    padding: 2px;
    width: 36px;
}

.player-details-grid {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.player-details-column {
    align-content: start;
    display: grid;
    gap: 10px;
    min-width: 0;
}

.player-detail-accordion {
    background: rgba(255, 255, 255, .025);
    border: 1px solid var(--player-line);
    border-radius: 7px;
    min-width: 0;
    overflow: hidden;
}

.player-matchups-accordion {
    margin-top: 12px;
}

.player-detail-accordion > summary {
    align-items: center;
    cursor: pointer;
    display: flex;
    gap: 10px;
    justify-content: space-between;
    min-height: 46px;
    min-width: 0;
    padding: 10px 12px;
}

.player-detail-accordion > summary::-webkit-details-marker {
    display: none;
}

.player-detail-accordion > summary::after {
    border-bottom: 2px solid currentColor;
    border-right: 2px solid currentColor;
    color: var(--player-muted);
    content: "";
    flex: 0 0 auto;
    height: 8px;
    margin-left: 8px;
    transform: rotate(45deg);
    transition: transform .16s ease;
    width: 8px;
}

.player-detail-accordion[open] > summary::after {
    transform: rotate(-135deg);
}

.player-detail-accordion summary span {
    align-items: center;
    color: #fff;
    display: inline-flex;
    font-weight: 850;
    gap: 8px;
    min-width: 0;
    overflow-wrap: anywhere;
}

.player-detail-accordion summary small {
    color: var(--player-muted);
    flex: 0 0 auto;
    margin-left: auto;
    text-transform: none;
}

.player-detail-table {
    color: var(--portal-text);
    margin-bottom: 0;
}

.player-detail-table td,
.player-detail-table th {
    white-space: nowrap;
}

.player-detail-table td:first-child,
.player-detail-table th:first-child {
    min-width: 170px;
    white-space: normal;
}

.player-detail-table-shell {
    border-top: 1px solid rgba(255, 204, 0, .24);
    max-height: min(480px, 72vh);
    overflow: auto;
    overscroll-behavior: contain;
}

.player-detail-table-shell .player-detail-table thead th {
    background: #0c121b;
    position: sticky;
    top: 0;
    z-index: 2;
}

.player-matchups-table {
    border-top: 1px solid rgba(255, 204, 0, .34);
    max-height: min(420px, 62vh);
    overflow: auto;
    overscroll-behavior: contain;
    scrollbar-color: rgba(255, 204, 0, .62) rgba(255, 255, 255, .045);
    scrollbar-width: thin;
}

.player-matchups-table::-webkit-scrollbar {
    height: 8px;
    width: 8px;
}

.player-matchups-table::-webkit-scrollbar-track {
    background: rgba(255, 255, 255, .045);
    border-radius: 999px;
}

.player-matchups-table::-webkit-scrollbar-thumb {
    background: rgba(255, 204, 0, .58);
    border: 2px solid rgba(16, 22, 32, .95);
    border-radius: 999px;
}

.player-matchups-table::-webkit-scrollbar-thumb:hover {
    background: rgba(255, 204, 0, .78);
}

.player-matchups-table .player-detail-table thead th {
    background: #0c121b;
    box-shadow: 0 1px 0 rgba(255, 204, 0, .22), 0 10px 18px rgba(0, 0, 0, .3);
}

.player-matchups-table .player-detail-table {
    border-collapse: separate;
    border-spacing: 0;
    min-width: 760px;
    table-layout: fixed;
    width: 100%;
}

.player-matchups-table .player-detail-table td,
.player-matchups-table .player-detail-table th {
    white-space: normal;
}

.player-matchups-table .player-detail-table th:first-child,
.player-matchups-table .player-detail-table td:first-child {
    width: 34%;
}

.player-awards-list,
.player-mini-rank-list,
.player-detail-link-grid {
    display: grid;
    gap: 8px;
    padding: 12px;
}

.player-detail-link-grid {
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
}

.player-detail-link-grid a {
    color: var(--player-gold);
    margin: 0;
}

.player-awards-list a {
    align-items: center;
    grid-template-columns: auto minmax(0, 1fr);
}

.player-awards-list img {
    height: 34px;
    object-fit: contain;
    width: 34px;
}

.player-awards-list strong,
.player-mini-rank-list span {
    color: #fff;
    overflow-wrap: anywhere;
}

.player-awards-list small {
    color: var(--player-muted);
    display: block;
}

.player-alias-list {
    align-content: start;
    background: rgba(255, 255, 255, .018);
    border: 1px solid rgba(255, 255, 255, .08);
    border-radius: 7px;
    display: grid;
    gap: 8px;
    list-style: none;
    margin: 0;
    max-height: 220px;
    min-height: 0;
    overflow: auto;
    overscroll-behavior: contain;
    padding: 10px;
    scrollbar-color: rgba(255, 204, 0, .62) rgba(255, 255, 255, .045);
    scrollbar-width: thin;
}

.player-alias-list::-webkit-scrollbar {
    width: 8px;
}

.player-alias-list::-webkit-scrollbar-track {
    background: rgba(255, 255, 255, .045);
    border-radius: 999px;
}

.player-alias-list::-webkit-scrollbar-thumb {
    background: rgba(255, 204, 0, .58);
    border: 2px solid rgba(16, 22, 32, .95);
    border-radius: 999px;
}

.player-alias-list::-webkit-scrollbar-thumb:hover {
    background: rgba(255, 204, 0, .78);
}

.player-alias-list li {
    min-width: 0;
}

.player-alias-list > li > span {
    align-items: center;
    background: rgba(255, 255, 255, .035);
    border: 1px solid rgba(255, 255, 255, .1);
    border-radius: 6px;
    color: #fff;
    display: flex;
    font-weight: 760;
    max-width: 100%;
    min-height: 36px;
    overflow-wrap: anywhere;
    padding: 6px 9px;
}

.player-alias-sort {
    display: flex;
    margin-bottom: 10px;
    width: 100%;
}

.player-alias-sort .btn {
    flex: 1 1 0;
    font-size: .74rem;
    font-weight: 800;
    min-width: 0;
    white-space: normal;
}

.player-alias-table-shell {
    border: 1px solid rgba(255, 255, 255, .08);
    border-radius: 7px;
    max-height: 260px;
    overflow: auto;
}

.player-alias-table {
    min-width: 520px;
}

.player-alias-table th,
.player-alias-table td {
    font-size: .78rem;
}

.player-alias-name {
    color: #fff;
    display: inline-block;
    font-weight: 760;
    max-width: 190px;
    overflow-wrap: anywhere;
}

@media (max-width: 1180px) {
    .player-dossier-stage {
        grid-template-columns: 1fr;
    }

    .player-story-grid {
        grid-template-columns: 1fr;
    }

    .player-dossier-topline {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .player-medal-rail {
        grid-auto-columns: minmax(232px, calc((100% - 24px) / 3));
    }

    .player-favorites-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 900px) {
    .player-story-grid,
    .player-details-grid {
        grid-template-columns: 1fr;
    }

    .player-story-grid {
        align-items: stretch;
        display: flex;
        flex-direction: column;
    }

    .player-story-side-panel {
        background: transparent;
        border: 0;
        box-shadow: none;
        display: contents;
        padding: 0;
    }

    .player-alias-block,
    .player-strengths-block {
        background:
            linear-gradient(180deg, rgba(255, 255, 255, .045), rgba(255, 255, 255, .018)),
            var(--player-panel);
        border: 1px solid var(--player-line);
        border-radius: 8px;
        box-shadow: 0 18px 42px rgba(0, 0, 0, .24);
        min-width: 0;
        padding: 18px;
    }

    .player-alias-block {
        order: 1;
    }

    .player-alias-list {
        max-height: 154px;
    }

    .player-story-grid .player-recent-panel {
        order: 2;
    }

    .player-strengths-block {
        border-top: 1px solid var(--player-line);
        order: 3;
    }

    .player-dossier-topline {
        padding-top: 0;
    }

    .player-favorites-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 680px) {
    .player-dossier-stage {
        padding: 18px;
    }

    .player-dossier-identity {
        align-items: start;
        grid-template-columns: 1fr;
    }

    .player-crest-frame {
        height: 96px;
        width: 96px;
    }

    .player-crest-frame img {
        height: 74px;
        width: 74px;
    }

    .player-dossier-title h1 {
        font-size: 2.35rem;
    }

    .player-dossier-topline {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        padding: 0 10px 10px;
    }

    .player-relationship-lists,
    .player-detail-link-grid {
        grid-template-columns: 1fr;
    }

    .player-relationship-grid,
    .player-session-list {
        grid-template-columns: 1fr;
    }

    .player-hero-feature,
    .player-dossier-callout {
        grid-template-columns: auto minmax(0, 1fr);
    }

    .player-medal-rail {
        grid-auto-columns: minmax(270px, 86vw);
        padding-right: 28px;
    }

    .player-matchups-table {
        max-height: min(360px, 68vh);
        overflow: auto;
        padding: 10px;
    }

    .player-matchups-table .player-detail-table {
        display: block;
        min-width: 0;
    }

    .player-matchups-table .player-detail-table thead {
        display: none;
    }

    .player-matchups-table .player-detail-table tbody,
    .player-matchups-table .player-detail-table tr,
    .player-matchups-table .player-detail-table td {
        display: block;
        width: 100%;
    }

    .player-matchups-table .player-detail-table tr {
        background: rgba(255, 255, 255, .025);
        border: 1px solid rgba(255, 255, 255, .08);
        border-radius: 7px;
        margin-bottom: 8px;
        padding: 10px;
    }

    .player-matchups-table .player-detail-table tr:last-child {
        margin-bottom: 0;
    }

    .player-matchups-table .player-detail-table td {
        align-items: baseline;
        border: 0;
        display: flex;
        gap: 16px;
        justify-content: space-between;
        padding: 4px 0;
        text-align: right !important;
        white-space: normal;
    }

    .player-matchups-table .player-detail-table td::before {
        color: var(--player-muted);
        content: attr(data-label);
        flex: 1 1 auto;
        font-size: .68rem;
        font-weight: 850;
        line-height: 1.2;
        min-width: 0;
        text-align: left;
        text-transform: uppercase;
    }

    .player-matchups-table .player-detail-table td:first-child {
        display: block;
        min-width: 0;
        text-align: left !important;
        width: 100%;
    }

    .player-matchups-table .player-detail-table td:first-child::before {
        display: block;
        margin-bottom: 4px;
    }

    .player-matchups-table .player-detail-table td:first-child a {
        display: block;
        font-size: 1rem;
        overflow-wrap: anywhere;
    }

    .player-dossier-callout a {
        grid-column: 1 / -1;
        justify-self: stretch;
    }

    .player-relationship-card dl {
        grid-template-columns: 1fr;
    }

    .player-dossier-return {
        flex-basis: 100%;
        margin-left: 0;
    }
}

@media (max-width: 430px) {
    .player-dossier-shell {
        gap: 14px;
    }

    .player-dossier-stage {
        gap: 12px;
        padding: 14px;
    }

    .player-dossier-identity {
        gap: 12px;
    }

    .player-crest-frame {
        height: 74px;
        padding: 8px;
        width: 74px;
    }

    .player-crest-frame img {
        height: 56px;
        width: 56px;
    }

    .player-dossier-title h1 {
        font-size: 1.58rem;
        line-height: 1.05;
        margin-bottom: 8px;
    }

    .player-dossier-meta {
        display: none;
        gap: 6px;
    }

    .player-dossier-meta span {
        font-size: .68rem;
        min-height: 24px;
        padding: 3px 6px;
    }

    .player-dossier-meta span:nth-child(n+3) {
        display: none;
    }

    .player-medal-strip,
    .player-panel,
    .player-details-area,
    .player-alias-block,
    .player-strengths-block {
        padding: 14px;
    }

    .player-dossier-topline {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .player-stat-card {
        min-height: 98px;
        padding: 10px;
    }

    .player-stat-card img {
        height: 26px;
        width: 26px;
    }

    .player-stat-card strong {
        font-size: 1.18rem;
    }

    .player-profile-actions {
        grid-template-columns: 1fr;
        order: 0;
    }

    .player-profile-actions a {
        font-size: .68rem;
        min-height: 38px;
    }

    .player-hero-feature {
        grid-template-columns: 1fr;
        padding: 12px;
    }

    .player-hero-feature > img {
        height: 54px;
        width: 54px;
    }

    .player-known-for strong {
        font-size: 1.05rem;
    }

    .player-medal-rail {
        grid-auto-columns: minmax(238px, 88vw);
    }

    .player-section-heading,
    .player-detail-accordion > summary {
        align-items: stretch;
        flex-direction: column;
    }

    .player-section-heading a,
    .player-section-heading small,
    .player-detail-accordion summary small {
        align-self: flex-start;
        margin-left: 0;
    }

    .player-detail-table td,
    .player-detail-table th {
        white-space: normal;
    }
}

.insight-list,
.compact-list {
    display: grid;
    gap: 8px;
}

.insight-list {
    border-top: 1px solid var(--portal-line);
    margin-top: 12px;
    padding-top: 12px;
}

.insight-list a,
.compact-list-item,
.top-player-card {
    color: var(--portal-text);
    text-decoration: none;
}

.insight-list a {
    align-items: center;
    background: var(--portal-panel-muted);
    border: 1px solid var(--portal-line);
    border-radius: 8px;
    display: flex;
    gap: 10px;
    justify-content: space-between;
    padding: 9px 10px;
}

.compact-list-item {
    align-items: center;
    border-bottom: 1px solid var(--portal-line);
    display: flex;
    gap: 12px;
    justify-content: space-between;
    min-width: 0;
    padding: 10px 0;
}

.compact-list-item:last-child {
    border-bottom: 0;
}

.compact-list-item strong,
.compact-list-item small {
    display: block;
    overflow-wrap: anywhere;
}

.compact-list-item small {
    color: var(--portal-muted);
    margin-top: 2px;
}

.health-summary-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.top-player-strip {
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
}

.top-player-card:hover,
.top-player-card:focus,
.insight-list a:hover,
.insight-list a:focus,
.compact-list-item:hover,
.compact-list-item:focus {
    background: var(--portal-table-hover);
    color: var(--portal-text);
}

.detail-accordion-stack {
    display: grid;
    gap: 10px;
    margin-top: 18px;
}

.detail-accordion-stack > h2 {
    font-size: 1.05rem;
    font-weight: 750;
    margin: 0;
}

.detail-accordion {
    background: var(--portal-panel);
    border: 1px solid var(--portal-line);
    border-radius: 8px;
    box-shadow: var(--portal-card-shadow);
    overflow: hidden;
}

.detail-accordion > summary {
    align-items: center;
    cursor: pointer;
    display: flex;
    font-weight: 750;
    gap: 12px;
    justify-content: space-between;
    list-style: none;
    padding: 13px 16px;
}

.detail-accordion > summary::-webkit-details-marker {
    display: none;
}

.detail-accordion > summary::after {
    color: var(--portal-muted);
    content: "+";
    flex: 0 0 auto;
    font-size: 1.1rem;
    font-weight: 750;
}

.detail-accordion[open] > summary::after {
    content: "-";
}

.detail-accordion-body {
    border-top: 1px solid var(--portal-line);
    padding: 16px;
}

.detail-section-actions {
    display: flex;
    justify-content: flex-end;
    margin-bottom: 12px;
}

.alias-chip-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.status-badge {
    border: 1px solid transparent;
    border-radius: 999px;
    display: inline-flex;
    font-size: .76rem;
    font-weight: 700;
    padding: 4px 9px;
}

.status-ok { background: var(--portal-success-bg); color: var(--portal-success-text); }
.status-warn { background: var(--portal-warning-bg); color: var(--portal-warning-text); }
.status-error { background: var(--portal-danger-bg); color: var(--portal-danger-text); }
.status-info { background: var(--portal-info-bg); color: var(--portal-info-text); }
.status-neutral { background: var(--portal-neutral-bg); color: var(--portal-neutral-text); border-color: var(--portal-neutral-border); }
.status-dry { background: var(--portal-info-bg); color: var(--portal-info-text); border-color: var(--portal-accent); }
.status-live { background: var(--portal-danger-bg); color: var(--portal-danger-text); border-color: var(--portal-danger-text); }
.status-disabled { background: var(--portal-neutral-bg); color: var(--portal-muted); border-color: var(--portal-neutral-border); }
.status-cached,
.status-partial { background: var(--portal-warning-bg); color: var(--portal-warning-text); border-color: var(--portal-warning-text); }

.table {
    --bs-table-bg: transparent;
    --bs-table-color: var(--portal-text);
    --bs-table-border-color: var(--portal-line);
    color: var(--portal-text);
    margin-bottom: 0;
}

.table th {
    color: var(--portal-table-head-text);
    font-size: .76rem;
    font-weight: 700;
    text-transform: uppercase;
}

.stats-table {
    table-layout: auto;
}

.stats-table thead th {
    background: var(--portal-table-head-bg);
    border-bottom-color: var(--portal-neutral-border);
    white-space: nowrap;
}

.stats-table td,
.stats-table th {
    padding: .72rem .85rem;
    vertical-align: middle;
}

.player-matchups-table .stats-table thead th {
    overflow-wrap: anywhere;
    white-space: normal !important;
}

.stats-table tbody tr:hover {
    --bs-table-hover-bg: var(--portal-table-hover);
    background: var(--portal-table-hover);
}

.stat-primary {
    color: var(--portal-link);
    display: inline-block;
    font-weight: 700;
    max-width: 34rem;
    overflow-wrap: anywhere;
}

.stat-secondary {
    color: var(--portal-muted);
    font-size: .82rem;
    margin-top: 2px;
    overflow-wrap: anywhere;
}

.stat-number {
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
}

.stat-rank {
    color: var(--portal-muted);
    font-size: .82rem;
    font-weight: 800;
}

.stat-chip-link {
    background: var(--portal-primary-soft);
    border: 1px solid var(--portal-accent);
    border-radius: 999px;
    color: var(--portal-accent-dark);
    display: inline-flex;
    font-size: .78rem;
    font-weight: 700;
    max-width: 18rem;
    overflow-wrap: anywhere;
    padding: 3px 8px;
}

.stat-chip-link:hover {
    background: var(--portal-subnav-active-bg);
    color: var(--portal-accent-dark);
}

.cod-color {
    font-weight: inherit;
}

.cod-color-0 { color: var(--cod-color-0); }
.cod-color-1 { color: var(--cod-color-1); }
.cod-color-2 { color: var(--cod-color-2); }
.cod-color-3 { color: var(--cod-color-3); }
.cod-color-4 { color: var(--cod-color-4); }
.cod-color-5 { color: var(--cod-color-5); }
.cod-color-6 { color: var(--cod-color-6); }
.cod-color-7 { color: var(--cod-color-7); text-shadow: 0 0 1px rgba(15, 23, 42, .9), 0 0 2px rgba(15, 23, 42, .65); }
.cod-color-8 { color: var(--cod-color-8); }
.cod-color-9 { color: var(--cod-color-9); }

.linked-stat-row td:first-child {
    min-width: 210px;
}

.linked-list-row {
    align-items: center;
    display: flex;
    gap: 12px;
    justify-content: space-between;
}

.leader-row {
    background: var(--portal-table-hover);
    box-shadow: inset 3px 0 0 var(--portal-accent);
}

.round-scoreboard-table thead th {
    position: sticky;
    top: 0;
    z-index: 1;
}

.round-scoreboard-mobile {
    display: none;
    max-height: min(620px, 72vh);
    overflow: auto;
    overscroll-behavior: contain;
}

.mobile-stat-card {
    border-bottom: 1px solid var(--portal-line);
    display: grid;
    gap: 12px;
    padding: 14px 16px;
}

.mobile-stat-card:last-child {
    border-bottom: 0;
}

.mobile-stat-card-head,
.mobile-stat-meta {
    align-items: flex-start;
    display: flex;
    gap: 10px;
    justify-content: space-between;
}

.mobile-stat-grid {
    display: grid;
    gap: 8px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.mobile-stat-grid div {
    background: var(--portal-panel-muted);
    border: 1px solid var(--portal-line);
    border-radius: 8px;
    padding: 8px;
}

.mobile-stat-grid span,
.mobile-stat-meta {
    color: var(--portal-muted);
    font-size: .78rem;
}

.mobile-stat-grid strong {
    display: block;
    font-size: 1.05rem;
    font-variant-numeric: tabular-nums;
}

.mobile-stat-meta {
    flex-wrap: wrap;
}

.dimension-table .status-badge,
.compact-stat-table .status-badge {
    max-width: 18rem;
    overflow-wrap: anywhere;
}

.public-main .table th {
    font-size: .8rem;
}

.public-main .stats-table {
    font-size: .92rem;
}

.public-main .stats-table th {
    font-size: .8rem;
}

.public-main .stats-table td,
.public-main .stats-table th,
.public-main .stats-table .stat-secondary,
.public-main .stats-table .stat-number,
.public-main .stats-table .stat-rank,
.public-main .stats-table small {
    font-size: .82rem;
    min-width: 0;
}

.public-main .table-responsive,
.public-main .public-table-shell,
.public-main .dimension-table-responsive,
.public-main .player-matchups-table,
.public-main .player-detail-table-shell {
    max-width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.public-main .public-table-shell .stats-table,
.public-main .table-responsive .stats-table,
.public-main .table-responsive .award-detail-table,
.public-main .table-responsive .dimension-table,
.public-main .player-matchups-table .player-detail-table,
.public-main .player-detail-table-shell .player-detail-table {
    min-width: 720px;
}

@media (max-width: 760px) {
    .public-main .public-data-panel .rounds-table-shell {
        overflow-x: visible;
    }

    .public-main .public-data-panel .rounds-table-shell .rounds-table {
        min-width: 0;
        table-layout: auto;
        width: 100%;
    }
}

.public-main .dimension-table-responsive {
    margin-left: 0;
    margin-right: 0;
    width: 100%;
}

.form-label {
    font-weight: 650;
}

.form-control,
.form-select {
    background-color: var(--portal-control-bg);
    border-color: var(--portal-control-border);
    color: var(--portal-text);
}

.form-control:focus,
.form-select:focus {
    background-color: var(--portal-control-bg);
    border-color: var(--portal-accent);
    color: var(--portal-text);
    box-shadow: 0 0 0 .2rem color-mix(in srgb, var(--portal-accent) 25%, transparent);
}

.form-control::placeholder {
    color: var(--portal-muted);
}

.form-check-input {
    background-color: var(--portal-control-bg);
    border-color: var(--portal-control-border);
}

.form-fieldset {
    border: 0;
    margin: 0;
    min-width: 0;
    padding: 0;
}

.form-legend {
    color: var(--portal-text);
    float: none;
    font-size: .95rem;
    font-weight: 650;
    margin-bottom: .5rem;
    width: auto;
}

.dense-toggle {
    align-items: center;
    cursor: pointer;
    display: inline-flex;
    gap: .45rem;
    min-height: 2rem;
}

.form-check.dense-toggle {
    display: flex;
    padding-left: 0;
}

.form-check.dense-toggle .form-check-input {
    margin-left: 0;
    margin-top: 0;
}

.dense-toggle-input {
    cursor: pointer;
    flex: 0 0 auto;
    height: 1.2rem;
    width: 1.2rem;
}

.dense-toggle .form-check-label {
    cursor: pointer;
}

.rotation-gametype-fieldset {
    border: 0;
    margin: 0;
    min-width: 0;
    padding: 0;
}

.list-group-item {
    background-color: var(--portal-panel);
    border-color: var(--portal-line);
    color: var(--portal-text);
}

.list-group-item-action:hover,
.list-group-item-action:focus {
    background-color: var(--portal-table-hover);
    color: var(--portal-text);
}

.text-muted {
    color: var(--portal-muted) !important;
}

.border-top {
    border-top-color: var(--portal-line) !important;
}

.alert-info {
    background-color: var(--portal-info-bg);
    border-color: var(--portal-accent);
    color: var(--portal-info-text);
}

.alert-success {
    background-color: var(--portal-success-bg);
    border-color: var(--portal-success-text);
    color: var(--portal-success-text);
}

.alert-warning {
    background-color: var(--portal-warning-bg);
    border-color: var(--portal-warning-text);
    color: var(--portal-warning-text);
}

.alert-danger {
    background-color: var(--portal-danger-bg);
    border-color: var(--portal-danger-text);
    color: var(--portal-danger-text);
}

.config-editor {
    font-family: Consolas, "Cascadia Mono", Menlo, monospace;
    font-size: .9rem;
    min-height: 540px;
}

pre.code-panel {
    background: #0f172a;
    border-radius: 8px;
    color: #dbeafe;
    overflow: auto;
    padding: 16px;
}

.action-toolbar {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.setup-stepper {
    display: grid;
    gap: 8px;
    grid-template-columns: repeat(8, minmax(0, 1fr));
    list-style: none;
    margin: 0 0 18px;
    padding: 0;
}

.setup-stepper li {
    align-items: center;
    background: var(--portal-panel-muted);
    border: 1px solid var(--portal-line);
    border-radius: 8px;
    display: flex;
    gap: 8px;
    min-width: 0;
    padding: 8px;
}

.setup-stepper span {
    align-items: center;
    background: var(--portal-neutral-bg);
    border-radius: 999px;
    color: var(--portal-neutral-text);
    display: inline-flex;
    flex: 0 0 26px;
    font-size: .78rem;
    font-weight: 800;
    height: 26px;
    justify-content: center;
}

.setup-stepper strong {
    font-size: .82rem;
    overflow-wrap: anywhere;
}

.setup-stepper li.current {
    background: var(--portal-primary-soft);
    border-color: var(--portal-accent);
}

.setup-stepper li.current span,
.setup-stepper li.complete span {
    background: var(--portal-accent);
    color: #fff;
}

.setup-panel-title {
    font-size: 1rem;
    font-weight: 750;
    margin: 0 0 14px;
}

.setup-intro h3 {
    font-size: 1.35rem;
    font-weight: 750;
    margin-bottom: 8px;
}

.setup-note-grid,
.summary-grid,
.status-strip {
    display: grid;
    gap: 12px;
}

.setup-note-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin-top: 18px;
}

.setup-note-grid > div,
.setup-choice,
.summary-section,
.branding-preview,
.status-strip > div {
    border: 1px solid var(--portal-line);
    border-radius: 8px;
    padding: 12px;
}

.setup-note-grid strong,
.setup-note-grid span,
.setup-choice p,
.branding-preview small,
.status-strip span {
    display: block;
}

.setup-note-grid span,
.setup-choice p,
.branding-preview small {
    color: var(--portal-muted);
    margin: 4px 0 0;
}

.setup-diagnostic-list {
    display: grid;
    gap: 8px;
    list-style: none;
    margin: 0;
    padding: 0;
}

.required-chip,
.optional-chip {
    border-radius: 999px;
    font-size: .68rem;
    font-weight: 800;
    margin-left: 4px;
    padding: 2px 6px;
    text-transform: uppercase;
}

.required-chip {
    background: var(--portal-danger-bg);
    color: var(--portal-danger-text);
}

.optional-chip {
    background: var(--portal-neutral-bg);
    color: var(--portal-muted);
}

.branding-preview {
    align-items: center;
    display: flex;
    gap: 12px;
}

.branding-preview > span {
    align-items: center;
    background: #1e293b;
    border-radius: 8px;
    color: #fff;
    display: inline-flex;
    flex: 0 0 54px;
    font-weight: 800;
    height: 54px;
    justify-content: center;
}

.status-strip {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.status-strip span {
    color: var(--portal-muted);
    font-size: .72rem;
    font-weight: 800;
    text-transform: uppercase;
}

.summary-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.summary-section h4 {
    font-size: .92rem;
    font-weight: 750;
    margin: 0 0 10px;
}

.summary-section dl {
    display: grid;
    gap: 8px 12px;
    grid-template-columns: minmax(120px, .55fr) minmax(0, 1fr);
    margin: 0;
}

.summary-section dt {
    color: var(--portal-muted);
    font-size: .78rem;
    font-weight: 800;
    text-transform: uppercase;
}

.summary-section dd {
    margin: 0;
    overflow-wrap: anywhere;
}

.secret-value {
    font-family: Consolas, "Cascadia Mono", Menlo, monospace;
    letter-spacing: .04em;
}

.wizard-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.stats-filter-bar {
    align-items: end;
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(12, minmax(0, 1fr));
}

.stats-filter-bar .span-2 { grid-column: span 2; }
.stats-filter-bar .span-3 { grid-column: span 3; }
.stats-filter-bar .span-4 { grid-column: span 4; }
.stats-filter-bar .span-6 { grid-column: span 6; }
.stats-filter-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.empty-state {
    border: 1px dashed var(--portal-line);
    border-radius: 8px;
    padding: 24px;
    text-align: center;
}

.award-category {
    margin-top: 18px;
}

.award-category:first-child {
    margin-top: 0;
}

.award-grid {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.award-card {
    border: 1px solid var(--portal-line);
    border-radius: 8px;
    display: grid;
    gap: 12px;
    padding: 14px;
}

.award-card p {
    color: var(--portal-muted);
    margin: 0;
}

.award-card-title,
.award-winner {
    align-items: center;
    display: flex;
    gap: 10px;
    justify-content: space-between;
}

.award-winner {
    border-top: 1px solid var(--portal-line);
    padding-top: 12px;
}

.award-v2-section {
    display: grid;
    gap: 16px;
    margin: 0 0 18px;
}

.award-v2-heading,
.award-v2-group-title,
.award-v2-card-top,
.player-award-badge-heading,
.player-award-badge-top,
.player-award-badge-partner {
    align-items: center;
    display: flex;
    gap: 10px;
    justify-content: space-between;
    min-width: 0;
}

.award-v2-heading {
    border-bottom: 1px solid var(--portal-line);
    padding-bottom: 14px;
}

.award-v2-heading h2 {
    font-size: 1.35rem;
    font-weight: 850;
    line-height: 1.15;
    margin: 4px 0 6px;
}

.award-v2-heading p,
.award-v2-group-title p,
.award-v2-evidence,
.player-award-badge-partner {
    color: var(--portal-muted);
    margin: 0;
}

.award-v2-group-grid {
    display: grid;
    gap: 18px;
}

.award-v2-group {
    display: grid;
    gap: 12px;
    min-width: 0;
}

.award-v2-group-title {
    align-items: flex-end;
}

.award-v2-group-title h3 {
    font-size: 1rem;
    font-weight: 800;
    margin: 0 0 4px;
}

.award-v2-card-grid {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.award-v2-card,
.player-award-badge {
    background: var(--portal-glass-bg);
    border: 1px solid var(--portal-line);
    border-radius: 8px;
    display: grid;
    gap: 10px;
    min-width: 0;
    padding: 14px;
}

.award-v2-card {
    border-top: 3px solid rgba(213, 166, 62, .82);
}

.award-v2-rank {
    color: var(--portal-accent);
    font-size: 1.1rem;
    font-weight: 900;
}

.award-v2-medal span,
.award-v2-subject,
.player-award-badge-top strong {
    color: var(--portal-text);
    font-weight: 850;
    overflow-wrap: anywhere;
}

.award-v2-medal span {
    display: block;
    font-size: .86rem;
    letter-spacing: 0;
    text-transform: uppercase;
}

.award-v2-subject {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    font-size: 1.06rem;
    line-height: 1.2;
}

.award-v2-pair-plus {
    color: var(--portal-muted);
    font-weight: 800;
}

.award-v2-metrics {
    display: grid;
    gap: 8px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.award-v2-metrics > div,
.player-award-badge-metric {
    background: rgba(255, 255, 255, .035);
    border: 1px solid var(--portal-line);
    border-radius: 8px;
    display: grid;
    gap: 2px;
    padding: 9px;
}

.award-v2-metrics span,
.player-award-badge-metric span {
    color: var(--portal-muted);
    font-size: .72rem;
    font-weight: 800;
    text-transform: uppercase;
}

.award-v2-metrics strong,
.player-award-badge-metric strong {
    font-size: 1rem;
    line-height: 1.15;
    overflow-wrap: anywhere;
}

.award-v2-evidence {
    font-size: .86rem;
}

.player-award-badge-strip {
    display: grid;
    gap: 10px;
    margin: 14px 0 18px;
}

.player-award-badge-heading {
    border-bottom: 1px solid var(--portal-line);
    padding-bottom: 8px;
}

.player-award-badge-heading > span {
    color: var(--portal-muted);
    font-size: .78rem;
    font-weight: 850;
    text-transform: uppercase;
}

.player-award-badge-grid {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.player-award-badge {
    padding: 12px;
}

.player-award-badge-top span {
    color: var(--portal-accent);
    font-weight: 900;
}

.player-award-badge-top strong {
    font-size: .92rem;
    text-align: right;
}

.player-award-badge-partner {
    font-size: .86rem;
    justify-content: flex-start;
}

.award-accent-combat { --award-accent: #ff334d; --award-accent-soft: rgba(255, 51, 77, .16); }
.award-accent-objective { --award-accent: #4d8dff; --award-accent-soft: rgba(77, 141, 255, .16); }
.award-accent-support { --award-accent: #48e66b; --award-accent-soft: rgba(72, 230, 107, .15); }
.award-accent-results { --award-accent: #ffcc00; --award-accent-soft: rgba(255, 204, 0, .15); }
.award-accent-teamwork { --award-accent: #b45cff; --award-accent-soft: rgba(180, 92, 255, .16); }
.award-accent-activity { --award-accent: #ff9f00; --award-accent-soft: rgba(255, 159, 0, .15); }
.award-accent-classic { --award-accent: #9aa7b8; --award-accent-soft: rgba(154, 167, 184, .14); }

.awards-dashboard,
.award-detail-dashboard {
    color: var(--glance-text, var(--portal-text));
    display: grid;
    gap: 18px;
    min-width: 0;
}

.awards-dashboard a:focus-visible,
.award-detail-dashboard a:focus-visible,
.awards-feature-rail-track:focus-visible,
.awards-archive-details summary:focus-visible {
    box-shadow: 0 0 0 .18rem rgba(255, 204, 0, .22);
    outline: 2px solid var(--glance-gold, #ffcc00);
    outline-offset: 2px;
}

.awards-hero,
.award-detail-hero {
    background:
        linear-gradient(90deg, rgba(7, 10, 15, .98), rgba(14, 18, 26, .94) 58%, rgba(36, 27, 7, .64)),
        linear-gradient(180deg, rgba(255, 204, 0, .08), rgba(255, 204, 0, 0));
    border: 1px solid var(--glance-line, var(--portal-line));
    border-radius: 8px;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .045), 0 18px 42px rgba(0, 0, 0, .28);
    display: grid;
    gap: 18px;
    grid-template-columns: minmax(0, 1fr) auto;
    min-width: 0;
    overflow: hidden;
    padding: clamp(22px, 3vw, 36px);
}

.awards-hero h1,
.award-detail-hero h1 {
    color: #fff;
    font-size: clamp(2.2rem, 4vw, 4.1rem);
    font-weight: 950;
    letter-spacing: 0;
    line-height: .96;
    margin: 4px 0 10px;
    overflow-wrap: anywhere;
}

.awards-hero p,
.award-detail-hero p {
    color: var(--glance-muted, var(--portal-muted));
    font-size: 1rem;
    margin: 0;
    max-width: 780px;
}

.awards-hero-trophy {
    align-items: center;
    display: grid;
    justify-items: center;
    min-width: clamp(150px, 22vw, 320px);
}

.awards-hero-trophy img {
    filter: drop-shadow(0 18px 34px rgba(255, 204, 0, .28));
    max-height: 168px;
    max-width: min(28vw, 240px);
    object-fit: contain;
    width: 100%;
}

.awards-summary-grid,
.awards-hall-grid,
.awards-archive-grid,
.award-related-grid {
    display: grid;
    gap: 12px;
    min-width: 0;
}

.awards-summary-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.awards-summary-card {
    align-items: center;
    background: linear-gradient(180deg, rgba(255, 255, 255, .05), rgba(255, 255, 255, .02));
    border: 1px solid var(--glance-line, var(--portal-line));
    border-left: 3px solid var(--award-accent);
    border-radius: 8px;
    display: grid;
    gap: 12px;
    grid-template-columns: auto minmax(0, 1fr);
    min-width: 0;
    padding: 14px;
}

.awards-summary-card img,
.awards-feature-rail-title img,
.awards-feature-card-top img,
.awards-archive-group-header img,
.awards-archive-list img,
.award-related-grid img {
    flex: 0 0 auto;
    height: 42px;
    object-fit: contain;
    width: 42px;
}

.awards-summary-card strong {
    color: #fff;
    display: block;
    font-size: 1.55rem;
    font-weight: 950;
    line-height: 1;
}

.awards-summary-card span,
.awards-summary-card small {
    display: block;
    overflow-wrap: anywhere;
}

.awards-summary-card span {
    color: #fff;
    font-weight: 850;
}

.awards-summary-card small {
    color: var(--glance-muted, var(--portal-muted));
}

.awards-category-nav {
    background: rgba(255, 255, 255, .025);
    border: 1px solid var(--glance-line, var(--portal-line));
    border-radius: 8px;
    display: flex;
    gap: 8px;
    min-width: 0;
    overflow-x: auto;
    padding: 10px;
    scrollbar-gutter: stable;
}

.awards-category-nav a {
    align-items: center;
    border: 1px solid var(--glance-line-soft, rgba(255, 255, 255, .08));
    border-radius: 6px;
    color: var(--glance-text, var(--portal-text));
    display: inline-flex;
    flex: 0 0 auto;
    gap: 8px;
    min-height: 38px;
    padding: 7px 11px;
}

.awards-category-nav a:hover,
.awards-category-nav a.active {
    background: rgba(255, 204, 0, .1);
    border-color: rgba(255, 204, 0, .58);
    color: var(--glance-gold, #ffcc00);
}

.awards-category-nav img {
    height: 22px;
    object-fit: contain;
    width: 22px;
}

.awards-panel {
    background: linear-gradient(180deg, rgba(12, 16, 24, .96), rgba(7, 10, 15, .97));
    border: 1px solid var(--glance-line, var(--portal-line));
    border-radius: 8px;
    box-shadow: 0 14px 34px rgba(0, 0, 0, .24);
    display: grid;
    gap: 14px;
    min-width: 0;
    padding: 14px;
}

.awards-section-heading,
.awards-feature-rail-heading,
.award-pagination {
    align-items: center;
    display: flex;
    gap: 12px;
    justify-content: space-between;
    min-width: 0;
}

.awards-section-heading {
    border-bottom: 1px solid var(--glance-line, var(--portal-line));
    padding-bottom: 12px;
}

.awards-section-heading span,
.awards-feature-rail-actions span {
    color: var(--glance-gold, #ffcc00);
    display: block;
    font-size: .78rem;
    font-weight: 900;
    text-transform: uppercase;
}

.awards-section-heading h2,
.awards-feature-rail-title h3 {
    color: #fff;
    font-weight: 950;
    letter-spacing: 0;
    line-height: 1.05;
    margin: 0;
    overflow-wrap: anywhere;
}

.awards-section-heading h2 {
    font-size: 1.2rem;
}

.awards-section-heading small,
.awards-feature-rail-title p {
    color: var(--glance-muted, var(--portal-muted));
    margin: 0;
    overflow-wrap: anywhere;
}

.awards-hall-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.awards-hall-card,
.awards-feature-card,
.awards-archive-group,
.award-related-grid a,
.award-ranking-row,
.award-current-winner {
    background: linear-gradient(180deg, rgba(255, 255, 255, .045), rgba(255, 255, 255, .018));
    border: 1px solid var(--glance-line-soft, rgba(255, 255, 255, .08));
    border-radius: 8px;
    min-width: 0;
}

.awards-hall-card {
    border-top: 3px solid var(--award-accent);
    color: var(--glance-text, var(--portal-text));
    display: grid;
    gap: 5px;
    padding: 14px;
}

.awards-hall-card:hover,
.award-related-grid a:hover,
.awards-archive-list a:hover,
.awards-view-link:hover {
    border-color: var(--award-accent);
    color: #fff;
}

.awards-hall-card img {
    filter: drop-shadow(0 8px 18px var(--award-accent-soft));
    height: 48px;
    object-fit: contain;
    width: 48px;
}

.awards-hall-card span,
.awards-feature-card h4,
.awards-view-link {
    color: var(--award-accent);
    font-weight: 900;
}

.awards-hall-card strong,
.awards-hall-card b,
.awards-winner-name,
.award-ranking-player {
    color: #fff;
    overflow-wrap: anywhere;
}

.awards-hall-card b {
    font-size: 1.35rem;
    line-height: 1;
}

.awards-hall-card small {
    color: var(--glance-muted, var(--portal-muted));
}

.awards-feature-rail {
    border: 1px solid color-mix(in srgb, var(--award-accent) 36%, rgba(255, 255, 255, .1));
    border-radius: 8px;
    display: grid;
    gap: 12px;
    min-width: 0;
    overflow: hidden;
    padding: 12px;
    scroll-margin-top: clamp(92px, 14vh, 140px);
}

#all-awards,
.awards-archive-group {
    scroll-margin-top: clamp(92px, 14vh, 140px);
}

.awards-feature-rail-heading {
    align-items: flex-start;
    flex-wrap: wrap;
}

.awards-feature-rail-title {
    align-items: center;
    display: flex;
    gap: 9px;
    min-width: 0;
}

.awards-feature-rail-title > div {
    display: grid;
    gap: 3px;
    min-width: 0;
}

.awards-feature-rail-actions {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: flex-end;
}

.awards-feature-rail-actions a,
.awards-archive-action {
    border: 1px solid color-mix(in srgb, var(--award-accent) 42%, transparent);
    border-radius: 6px;
    color: var(--award-accent);
    font-size: .85rem;
    font-weight: 850;
    padding: 6px 9px;
}

.awards-rail-shell {
    min-width: 0;
    position: relative;
}

.awards-rail-shell::after {
    background: linear-gradient(90deg, rgba(7, 10, 15, 0), rgba(7, 10, 15, .92));
    bottom: 0;
    content: "";
    pointer-events: none;
    position: absolute;
    right: 0;
    top: 0;
    width: 54px;
}

.awards-feature-rail.is-single .awards-rail-shell::after {
    content: none;
}

.awards-feature-rail.is-sparse .awards-rail-shell {
    max-width: 100%;
}

.awards-feature-rail.is-sparse .awards-rail-shell::after {
    content: none;
}

.awards-feature-rail-track {
    display: grid;
    gap: 12px;
    grid-auto-columns: minmax(255px, calc((100% - 36px) / 4));
    grid-auto-flow: column;
    min-width: 0;
    overflow-x: auto;
    overscroll-behavior-inline: contain;
    padding: 0 34px 4px 0;
    scroll-padding-inline: 2px 34px;
    scroll-snap-type: x proximity;
    scrollbar-width: thin;
    scrollbar-color: color-mix(in srgb, var(--award-accent) 54%, rgba(255, 255, 255, .28)) transparent;
}

.awards-feature-rail.is-sparse .awards-feature-rail-track {
    grid-auto-columns: unset;
    grid-auto-flow: row;
    overflow-x: visible;
    padding: 0;
    scroll-snap-type: none;
}

.awards-feature-rail.is-single .awards-feature-rail-track {
    grid-template-columns: minmax(0, 1fr);
}

.awards-feature-rail.is-pair .awards-feature-rail-track {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.awards-feature-card {
    border-top: 3px solid var(--award-accent);
    display: grid;
    gap: 10px;
    padding: 14px;
    position: relative;
    scroll-snap-align: start;
}

@media (min-width: 1181px) {
    .awards-feature-rail.is-single .awards-feature-card {
        align-items: start;
        column-gap: 16px;
        grid-template-columns: auto minmax(190px, .7fr) minmax(280px, .95fr) minmax(220px, .75fr);
    }

    .awards-feature-rail.is-single .awards-feature-card-top {
        grid-column: 1;
        grid-row: 1 / span 4;
    }

    .awards-feature-rail.is-single .awards-feature-card h4,
    .awards-feature-rail.is-single .awards-feature-card > p,
    .awards-feature-rail.is-single .awards-feature-card > .awards-threshold {
        grid-column: 2;
    }

    .awards-feature-rail.is-single .awards-winner-block {
        grid-column: 3;
        grid-row: 1 / span 4;
    }

    .awards-feature-rail.is-single .awards-compact-ranks {
        grid-column: 4;
        grid-row: 1 / span 3;
    }

    .awards-feature-rail.is-single .awards-view-link {
        grid-column: 4;
        justify-self: start;
    }
}

.awards-feature-card-top {
    align-items: center;
    display: flex;
    gap: 10px;
    justify-content: flex-start;
    min-width: 0;
}

.awards-threshold {
    background: var(--award-accent-soft);
    border: 1px solid color-mix(in srgb, var(--award-accent) 48%, transparent);
    border-radius: 999px;
    color: var(--award-accent);
    font-size: .76rem;
    font-weight: 850;
    line-height: 1.1;
    padding: 5px 8px;
}

.awards-feature-card h4 {
    font-size: 1.05rem;
    letter-spacing: 0;
    margin: 0;
    overflow-wrap: anywhere;
}

.awards-feature-card p,
.awards-empty-mini,
.awards-supporting-metric span,
.awards-archive-group p,
.awards-archive-intro,
.awards-data-note {
    color: var(--glance-muted, var(--portal-muted));
}

.awards-feature-card p,
.awards-archive-intro,
.awards-data-note {
    margin: 0;
}

.awards-empty-mini {
    border: 1px dashed var(--glance-line, var(--portal-line));
    border-radius: 8px;
    padding: 16px;
}

.awards-winner-block {
    background: rgba(0, 0, 0, .16);
    border: 1px solid var(--glance-line-soft, rgba(255, 255, 255, .08));
    border-radius: 8px;
    display: grid;
    gap: 8px;
    padding: 11px;
}

.awards-winner-block > span,
.award-ranking-rank {
    color: var(--award-accent);
    font-weight: 950;
}

.awards-winner-name {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    font-weight: 900;
    line-height: 1.15;
}

.awards-winner-name a,
.award-ranking-player a {
    font-weight: 900;
    overflow-wrap: anywhere;
}

.awards-metric strong,
.awards-supporting-metric strong {
    color: #fff;
    display: block;
    font-size: 1.35rem;
    line-height: 1;
}

.awards-metric span {
    color: var(--glance-muted, var(--portal-muted));
    display: block;
}

.awards-compact-ranks {
    display: grid;
    gap: 6px;
}

.awards-compact-ranks > div {
    align-items: center;
    border-top: 1px solid var(--glance-line-soft, rgba(255, 255, 255, .08));
    display: grid;
    gap: 8px;
    grid-template-columns: auto minmax(0, 1fr) auto;
    padding-top: 6px;
}

.awards-compact-ranks > div > span {
    color: var(--award-accent);
    font-weight: 850;
}

.awards-compact-ranks strong,
.awards-compact-ranks small {
    overflow-wrap: anywhere;
    white-space: normal;
}

.awards-compact-name {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 4px 6px;
    line-height: 1.15;
    min-width: 0;
}

.awards-compact-name a,
.awards-compact-name span {
    min-width: 0;
    overflow-wrap: anywhere;
}

.awards-compact-name .awards-pair-plus {
    color: var(--award-accent);
    flex: 0 0 auto;
}

.awards-pair-fallback {
    color: var(--glance-muted, var(--portal-muted));
    font-weight: 750;
}

.awards-view-link {
    align-self: end;
    border: 1px solid color-mix(in srgb, var(--award-accent) 48%, transparent);
    border-radius: 6px;
    justify-self: start;
    padding: 7px 10px;
}

.awards-archive-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.awards-archive-group {
    display: grid;
    gap: 10px;
    padding: 12px;
}

.awards-archive-group-header {
    align-items: center;
    display: grid;
    gap: 10px;
    grid-template-columns: auto minmax(0, 1fr) auto;
}

.awards-archive-group-header span,
.awards-archive-list span,
.award-related-grid span {
    color: #fff;
    font-weight: 850;
    overflow-wrap: anywhere;
}

.awards-archive-group-header strong {
    color: var(--award-accent);
    font-size: .85rem;
}

.awards-archive-group p,
.awards-archive-examples {
    margin: 0;
}

.awards-archive-examples {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.awards-archive-examples a {
    background: rgba(255, 255, 255, .04);
    border: 1px solid var(--glance-line-soft, rgba(255, 255, 255, .08));
    border-radius: 999px;
    color: var(--glance-muted, var(--portal-muted));
    font-size: .78rem;
    padding: 4px 8px;
}

.awards-archive-details {
    min-width: 0;
}

.awards-archive-details summary {
    color: var(--award-accent);
    cursor: pointer;
    font-weight: 850;
}

.awards-archive-list {
    display: grid;
    gap: 8px;
    margin-top: 9px;
}

.awards-archive-list a,
.award-related-grid a {
    align-items: center;
    border: 1px solid var(--glance-line-soft, rgba(255, 255, 255, .08));
    border-radius: 7px;
    color: var(--glance-text, var(--portal-text));
    display: grid;
    gap: 4px 9px;
    grid-template-columns: auto minmax(0, 1fr);
    min-width: 0;
    padding: 9px;
}

.awards-archive-list small,
.award-related-grid small {
    color: var(--glance-muted, var(--portal-muted));
    grid-column: 2;
}

.awards-archive-action {
    justify-self: start;
}

.award-breadcrumb {
    align-items: center;
    color: var(--glance-muted, var(--portal-muted));
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.award-detail-hero {
    grid-template-columns: auto minmax(0, 1fr) auto;
}

.award-detail-icon {
    align-items: center;
    background: var(--award-accent-soft);
    border: 1px solid color-mix(in srgb, var(--award-accent) 52%, transparent);
    border-radius: 8px;
    display: grid;
    height: 92px;
    justify-items: center;
    width: 92px;
}

.award-detail-icon img {
    height: 74px;
    object-fit: contain;
    width: 74px;
}

.award-detail-actions {
    align-content: start;
    display: grid;
    gap: 8px;
    justify-items: end;
}

.award-current-winner {
    border-left: 4px solid var(--award-accent);
    display: grid;
    gap: 4px;
    padding: 14px;
}

.award-current-winner span,
.award-current-winner em {
    color: var(--glance-muted, var(--portal-muted));
    font-style: normal;
}

.award-current-winner strong,
.award-current-winner b {
    color: #fff;
    overflow-wrap: anywhere;
}

.award-current-winner b {
    font-size: 1.8rem;
    line-height: 1;
}

.award-ranking-list {
    display: grid;
    gap: 8px;
}

.award-ranking-row {
    align-items: center;
    display: grid;
    gap: 10px;
    grid-template-columns: auto minmax(0, 1.3fr) repeat(3, minmax(110px, .45fr));
    padding: 11px;
}

.award-ranking-player {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    font-weight: 850;
}

.award-ranking-metric {
    min-width: 0;
}

.award-ranking-metric strong,
.award-ranking-metric span {
    display: block;
    overflow-wrap: anywhere;
}

.award-ranking-metric strong {
    color: #fff;
    font-weight: 900;
}

.award-ranking-metric span {
    color: var(--glance-muted, var(--portal-muted));
    font-size: .78rem;
}

.award-detail-table {
    color: var(--glance-text, var(--portal-text));
}

.award-pagination {
    border-top: 1px solid var(--glance-line, var(--portal-line));
    padding-top: 12px;
}

.award-related-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.award-category-hero {
    border-top: 3px solid var(--award-accent);
}

.award-category-hero-side {
    align-items: center;
    display: grid;
    gap: 14px;
    justify-items: end;
    min-width: 0;
}

.award-category-hero-side > img {
    filter: drop-shadow(0 14px 28px var(--award-accent-soft));
    height: 96px;
    object-fit: contain;
    width: 96px;
}

.award-category-window-panel {
    overflow: hidden;
    padding: 0;
}

.award-category-window-panel .portal-card-body {
    border-top: 0 !important;
}

.award-category-list-panel .awards-section-heading > a {
    color: var(--award-accent);
    font-weight: 850;
}

.award-category-card-grid {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    min-width: 0;
}

.award-category-card {
    background: linear-gradient(180deg, rgba(255, 255, 255, .045), rgba(255, 255, 255, .018));
    border: 1px solid var(--glance-line-soft, rgba(255, 255, 255, .08));
    border-top: 3px solid var(--award-accent);
    border-radius: 8px;
    display: grid;
    gap: 10px;
    min-width: 0;
    padding: 13px;
}

.award-category-card-header {
    align-items: center;
    display: grid;
    gap: 10px;
    grid-template-columns: auto minmax(0, 1fr);
}

.award-category-card-header img {
    height: 46px;
    object-fit: contain;
    width: 46px;
}

.award-category-card h3 {
    font-size: 1.02rem;
    font-weight: 900;
    letter-spacing: 0;
    line-height: 1.1;
    margin: 0;
    overflow-wrap: anywhere;
}

.award-category-card h3 a {
    color: var(--award-accent);
}

.award-category-card-header span,
.award-category-card p,
.award-category-winner span,
.award-category-winner small {
    color: var(--glance-muted, var(--portal-muted));
}

.award-category-card p {
    margin: 0;
}

.award-category-winner {
    background: rgba(0, 0, 0, .16);
    border: 1px solid var(--glance-line-soft, rgba(255, 255, 255, .08));
    border-radius: 8px;
    display: grid;
    gap: 3px;
    padding: 10px;
}

.award-category-winner a,
.award-category-winner strong {
    color: #fff;
    font-weight: 900;
    overflow-wrap: anywhere;
}

@media (max-width: 1180px) {
    .awards-summary-grid,
    .awards-hall-grid,
    .award-related-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .awards-archive-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .awards-feature-rail-track {
        grid-auto-columns: minmax(280px, calc((100% - 12px) / 2));
    }

    .award-ranking-row {
        grid-template-columns: auto minmax(0, 1fr) repeat(2, minmax(110px, .45fr));
    }
}

@media (max-width: 760px) {
    .awards-hero,
    .award-detail-hero {
        grid-template-columns: 1fr;
    }

    .awards-hero-trophy {
        justify-items: start;
        min-width: 0;
    }

    .awards-hero-trophy img {
        max-width: 150px;
    }

    .awards-summary-grid,
    .awards-hall-grid,
    .awards-archive-grid,
    .award-related-grid {
        grid-template-columns: 1fr;
    }

    .awards-section-heading,
    .awards-feature-rail-heading,
    .award-pagination {
        align-items: flex-start;
        flex-direction: column;
    }

    .awards-feature-rail-actions {
        justify-content: flex-start;
    }

    .awards-feature-rail-track {
        grid-auto-columns: minmax(270px, 82vw);
        padding-right: 44px;
        scroll-padding-inline-end: 44px;
    }

    .awards-feature-rail.is-single .awards-feature-rail-track {
        grid-auto-columns: minmax(0, 100%);
        grid-template-columns: minmax(0, 100%);
    }

    .awards-feature-rail.is-pair .awards-feature-rail-track,
    .award-category-card-grid {
        grid-template-columns: 1fr;
    }

    .award-detail-actions {
        justify-items: stretch;
    }

    .award-category-hero-side {
        justify-items: start;
    }

    .award-ranking-row {
        align-items: start;
        grid-template-columns: auto minmax(0, 1fr);
    }

    .award-ranking-metric {
        grid-column: 2;
    }

    .awards-compact-ranks > div {
        grid-template-columns: auto minmax(0, 1fr);
    }

    .awards-compact-ranks small {
        grid-column: 2;
        white-space: normal;
    }
}

.rotation-toggle-grid,
.rotation-map-grid {
    display: grid;
    gap: 12px;
}

.rotation-toggle-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.rotation-toggle,
.rotation-map-card {
    border: 1px solid var(--portal-line);
    border-radius: 8px;
    padding: 14px;
}

.rotation-toggle-title,
.rotation-map-head,
.rotation-map-meta,
.rotation-bulkbar,
.warning-row {
    align-items: center;
    display: flex;
    gap: 10px;
}

.rotation-toggle-title,
.rotation-map-head,
.rotation-map-meta {
    justify-content: space-between;
}

.rotation-toggle-fields,
.rotation-bulkbar {
    display: grid;
    gap: 10px;
}

.rotation-toggle-fields {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    margin-top: 10px;
}

.rotation-bulkbar {
    grid-template-columns: minmax(150px, 1fr) minmax(150px, 1fr) repeat(4, auto);
    margin-bottom: 14px;
}

.rotation-map-card {
    background: var(--portal-panel);
}

.rotation-map-select {
    align-items: flex-start;
    display: flex;
    gap: 10px;
    min-width: 0;
}

.rotation-map-select small {
    color: var(--portal-muted);
    display: block;
    overflow-wrap: anywhere;
}

.rotation-status-stack,
.badge-row {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.rotation-map-meta {
    border-top: 1px solid var(--portal-line);
    margin-top: 12px;
    padding-top: 12px;
}

.rotation-source {
    color: var(--portal-muted);
    font-size: .86rem;
    overflow-wrap: anywhere;
}

.rotation-map-settings {
    border-top: 1px solid var(--portal-line);
    margin-top: 12px;
    padding-top: 12px;
}

.warning-list {
    display: grid;
    gap: 8px;
}

.warning-row {
    flex-wrap: wrap;
    justify-content: flex-start;
    min-width: 0;
}

.warning-row > span {
    overflow-wrap: anywhere;
}

.forced-candidate-add {
    border-bottom: 1px solid var(--portal-line);
    padding-bottom: 16px;
}

.forced-candidate-actions {
    align-items: end;
    display: flex;
    gap: 12px;
    justify-content: flex-end;
}

.rotation-commandbar {
    background: var(--portal-nav-bg);
    border: 1px solid var(--portal-line);
    border-radius: 8px;
    box-shadow: var(--portal-shadow);
    display: grid;
    gap: 12px;
    margin-bottom: 16px;
    padding: 14px;
    position: sticky;
    top: 10px;
    z-index: 5;
}

.rotation-commandbar-top,
.rotation-command-actions,
.rotation-preset-row,
.rotation-preview-controls,
.rotation-custom-preview,
.rotation-pagination {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.rotation-commandbar-top {
    justify-content: space-between;
}

.rotation-profile-chip {
    background: var(--portal-panel-muted);
    border: 1px solid var(--portal-line);
    border-radius: 8px;
    padding: 8px 10px;
}

.rotation-profile-chip span,
.rotation-command-label,
.rotation-rule-fields span,
.rotation-forced-editor > summary {
    color: var(--portal-muted);
    display: block;
    font-size: .72rem;
    font-weight: 800;
    text-transform: uppercase;
}

.rotation-profile-chip strong {
    display: block;
    font-size: .98rem;
    line-height: 1.2;
    margin-top: 2px;
}

.rotation-command-search {
    align-items: center;
    display: flex;
    flex: 1 1 340px;
    gap: 8px;
    min-width: min(100%, 280px);
}

.rotation-gametype-strip {
    display: grid;
    gap: 8px;
    grid-template-columns: repeat(auto-fit, minmax(108px, 1fr));
}

.rotation-gt-toggle {
    border: 1px solid var(--portal-control-border);
    border-radius: 8px;
    min-width: 0;
    padding: 8px;
}

.rotation-gt-toggle.is-on {
    background: var(--portal-success-bg);
    border-color: var(--portal-success-text);
}

.rotation-gt-toggle.is-off {
    background: var(--portal-panel-muted);
}

.rotation-gt-toggle label {
    align-items: center;
    display: grid;
    gap: 2px 8px;
    grid-template-columns: auto minmax(0, 1fr);
    margin: 0;
}

.rotation-gt-toggle small {
    color: var(--portal-muted);
    font-size: .72rem;
    grid-column: 2;
}

.rotation-preset-row {
    border-top: 1px solid var(--portal-line);
    padding-top: 10px;
}

.rotation-preset-help {
    color: var(--portal-muted);
    font-size: .84rem;
    font-weight: 650;
}

.rotation-summary-strip {
    grid-template-columns: repeat(8, minmax(0, 1fr));
}

.rotation-filter-grid {
    align-items: end;
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(12, minmax(0, 1fr));
}

.rotation-filter-grid .span-2 { grid-column: span 2; }
.rotation-filter-grid .span-3 { grid-column: span 3; }
.rotation-filter-grid .span-4 { grid-column: span 4; }

.rotation-bulkbar {
    align-items: center;
    grid-template-columns: minmax(160px, .8fr) minmax(170px, .8fr) minmax(140px, .75fr) minmax(130px, .75fr) 84px 84px auto;
}

.rotation-bulk-summary {
    background: var(--portal-panel-muted);
    border: 1px solid var(--portal-line);
    border-radius: 8px;
    min-width: 0;
    padding: 8px 10px;
}

.rotation-bulk-summary strong,
.rotation-bulk-summary span {
    display: block;
    line-height: 1.2;
}

.rotation-bulk-summary span {
    color: var(--portal-muted);
    font-size: .78rem;
    margin-top: 2px;
}

.rotation-filter-checks,
.rotation-filter-actions {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

.filter-chips,
.rotation-filter-chips {
    align-items: center;
    border-top: 1px solid var(--portal-line);
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 14px;
    padding-top: 14px;
}

.filter-chip,
.rotation-filter-chip {
    background: var(--portal-primary-soft);
    border: 1px solid var(--portal-accent);
    border-radius: 999px;
    color: var(--portal-accent-dark);
    display: inline-flex;
    align-items: center;
    font-size: .78rem;
    gap: 4px;
    max-width: 22rem;
    overflow-wrap: anywhere;
    padding: 5px 9px;
    text-decoration: none;
}

.filter-chip:hover,
.rotation-filter-chip:hover {
    background: var(--portal-surface);
    color: var(--portal-accent-dark);
}

.rotation-warning-columns {
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.rotation-warning-section {
    background: var(--portal-panel-muted);
    border: 1px solid var(--portal-line);
    border-radius: 8px;
    display: grid;
    gap: 8px;
    padding: 12px;
}

.rotation-warning-section h3 {
    font-size: .92rem;
    font-weight: 750;
    margin: 0;
}

.rotation-warning-group {
    background: var(--portal-panel);
    border: 1px solid var(--portal-line);
    border-radius: 8px;
    display: grid;
    gap: 6px;
    padding: 10px;
}

.rotation-preview-strip {
    align-items: center;
    display: flex;
    gap: 18px;
    justify-content: space-between;
}

.rotation-custom-preview {
    flex-wrap: nowrap;
}

.rotation-custom-preview input {
    width: 8rem;
}

.rotation-rules-panel > summary {
    cursor: pointer;
    list-style: none;
}

.rotation-rules-panel > summary::-webkit-details-marker,
.rotation-map-details > summary::-webkit-details-marker,
.rotation-forced-editor > summary::-webkit-details-marker {
    display: none;
}

.rotation-rule-grid {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.rotation-rule-card {
    border: 1px solid var(--portal-line);
    border-radius: 8px;
    display: grid;
    gap: 10px;
    padding: 12px;
}

.rotation-rule-title {
    align-items: center;
    display: flex;
    gap: 10px;
    justify-content: space-between;
}

.rotation-rule-fields {
    align-items: end;
    display: grid;
    gap: 8px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.rotation-forced-editor {
    display: grid;
    gap: 14px;
}

.rotation-forced-editor > summary {
    cursor: pointer;
}

.rotation-forced-list {
    border-top: 1px solid var(--portal-line);
    display: grid;
    gap: 8px;
    margin-top: 14px;
    padding-top: 14px;
}

.rotation-forced-row {
    align-items: center;
    display: grid;
    gap: 8px;
    grid-template-columns: minmax(150px, 1fr) minmax(120px, .7fr) auto 72px 72px minmax(160px, 1fr) auto auto;
}

.rotation-forced-delete {
    justify-self: end;
}

.rotation-map-list {
    display: grid;
    gap: 12px;
}

.rotation-map-row {
    background: var(--portal-panel);
    border: 1px solid var(--portal-line);
    border-radius: 8px;
    display: grid;
    gap: 12px;
    padding: 14px;
}

.rotation-map-main,
.rotation-map-compact-grid,
.rotation-map-detail-grid {
    align-items: center;
    display: grid;
    gap: 12px;
}

.rotation-map-main {
    grid-template-columns: minmax(260px, 1fr) auto;
}

.rotation-map-actions {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: flex-end;
}

.rotation-map-compact-grid {
    border-top: 1px solid var(--portal-line);
    grid-template-columns: minmax(160px, .85fr) minmax(160px, .85fr) minmax(220px, 1.2fr) minmax(110px, .45fr);
    padding-top: 12px;
}

.rotation-map-warnings {
    border-top: 1px solid var(--portal-line);
    padding-top: 10px;
}

.rotation-map-details {
    border-top: 1px solid var(--portal-line);
    padding-top: 10px;
}

.rotation-map-details > summary {
    color: var(--portal-link);
    cursor: pointer;
    font-weight: 700;
}

.rotation-map-settings {
    margin-top: 12px;
}

.rotation-advanced-backdrop {
    background: rgba(15, 23, 42, .42);
    inset: 0;
    position: fixed;
    z-index: 80;
}

.rotation-advanced-drawer {
    background: var(--portal-panel);
    border-left: 1px solid var(--portal-line);
    bottom: 0;
    box-shadow: -18px 0 38px rgba(15, 23, 42, .18);
    max-width: min(760px, 94vw);
    overflow: auto;
    padding: 18px;
    position: fixed;
    right: 0;
    top: 0;
    width: 760px;
    z-index: 81;
}

.rotation-advanced-header,
.rotation-advanced-actions {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: space-between;
}

.rotation-advanced-header {
    border-bottom: 1px solid var(--portal-line);
    margin-bottom: 14px;
    padding-bottom: 14px;
}

.rotation-advanced-header h2 {
    font-size: 1.2rem;
    font-weight: 750;
    margin: 0;
    overflow-wrap: anywhere;
}

.rotation-advanced-actions {
    border-top: 1px solid var(--portal-line);
    justify-content: flex-end;
    margin-top: 14px;
    padding-top: 14px;
}

.rotation-advanced-loading {
    align-items: center;
    display: flex;
    justify-content: center;
    min-height: 220px;
}

body.rotation-advanced-open {
    overflow: hidden;
}

.rotation-map-detail-grid {
    grid-template-columns: repeat(6, minmax(0, 1fr));
}

.rotation-map-detail-grid > div,
.rotation-map-detail-grid > label {
    grid-column: span 2;
}

.rotation-map-detail-grid .span-3 {
    grid-column: span 6;
}

.rotation-pagination {
    border-top: 1px solid var(--portal-line);
    justify-content: center;
    margin-top: 16px;
    padding-top: 14px;
}

.ops-section-grid {
    display: grid;
    gap: 18px;
    grid-template-columns: minmax(0, 1.25fr) minmax(320px, .75fr);
}

.health-list,
.action-required-list,
.diagnostics-link-grid {
    display: grid;
    gap: 10px;
}

.health-row,
.action-required-item,
.diagnostics-link {
    align-items: flex-start;
    border: 1px solid var(--portal-line);
    border-radius: 8px;
    display: flex;
    gap: 12px;
    justify-content: space-between;
    padding: 12px;
}

.action-required-item {
    background: var(--portal-panel);
}

.action-required-item strong,
.diagnostics-link strong {
    display: block;
}

.action-required-item p,
.diagnostics-link span {
    color: var(--portal-muted);
    margin: 3px 0 0;
}

.danger-zone {
    background: var(--portal-danger-zone-bg);
    border-color: var(--portal-danger-zone-border);
}

.risky-confirmation {
    background: var(--portal-panel);
    border: 1px solid var(--portal-line);
    border-radius: 8px;
    display: grid;
    gap: 12px;
    padding: 14px;
}

.risky-confirmation-live {
    background: var(--portal-danger-zone-bg);
    border-color: var(--portal-danger-zone-border);
}

.risky-confirmation-dry {
    background: var(--portal-panel-muted);
}

.risky-confirmation-header {
    align-items: center;
    display: flex;
    gap: 10px;
    justify-content: space-between;
}

.risky-confirmation-details {
    display: grid;
    gap: 8px;
    margin: 0;
}

.risky-confirmation-details div {
    display: grid;
    gap: 4px;
    grid-template-columns: minmax(8rem, 12rem) minmax(0, 1fr);
}

.risky-confirmation-details dt {
    color: var(--portal-muted);
    font-size: .82rem;
    font-weight: 700;
    text-transform: uppercase;
}

.risky-confirmation-details dd {
    margin: 0;
    min-width: 0;
    overflow-wrap: anywhere;
}

.risky-confirmation-check {
    align-items: flex-start;
    background: rgba(255,255,255,.38);
    border: 1px solid var(--portal-line);
    border-radius: 8px;
    padding: 10px 12px 10px 2.2rem;
}

@media (max-width: 991px) {
    body.admin-nav-open { overflow: hidden; }
    .portal-frame {
        display: block;
        min-height: 100vh;
    }
    .portal-sidebar {
        box-shadow: 18px 0 42px rgba(0,0,0,.28);
        height: 100dvh;
        left: 0;
        max-width: min(88vw, 320px);
        overflow-y: auto;
        position: fixed;
        top: 0;
        transform: translateX(-105%);
        transition: transform .2s ease, visibility .2s ease;
        visibility: hidden;
        width: 320px;
        z-index: 1050;
    }
    body.admin-nav-open .portal-sidebar {
        transform: translateX(0);
        visibility: visible;
    }
    .portal-sidebar-header {
        justify-content: space-between;
        padding: 18px 16px 14px;
    }
    .portal-brand { justify-content: flex-start; }
    .portal-sidebar-close { display: inline-flex; }
    .portal-backdrop {
        background: rgba(15,23,42,.58);
        display: block;
        inset: 0;
        position: fixed;
        z-index: 1040;
    }
    .portal-backdrop[hidden] {
        display: none;
    }
    .portal-nav {
        grid-template-columns: 1fr;
        padding-bottom: 12px;
    }
    .portal-nav-heading { padding-top: 4px; }
    .portal-sidebar-footer { display: grid; }
    .portal-main { min-height: 100vh; }
    .portal-topbar {
        gap: 12px;
        min-height: 72px;
        padding: 12px 16px;
        position: sticky;
        top: 0;
        z-index: 1030;
    }
    .admin-menu-button,
    .admin-topbar-brand {
        display: inline-flex;
    }
    .portal-topbar h1 { font-size: 1.15rem; }
    .eyebrow { font-size: .66rem; }
    .topbar-cluster {
        justify-content: flex-start;
        margin-left: auto;
    }
    .public-nav {
        padding-bottom: 6px;
        padding-top: 6px;
    }
    .public-nav .container-fluid {
        flex-wrap: nowrap;
        gap: 8px;
    }
    .public-brand {
        flex: 1 1 auto;
        gap: 8px;
        min-width: 0;
    }
    .public-brand .brand-logo-image,
    .public-brand .brand-logo-fallback {
        border-radius: 5px;
        height: auto;
        max-height: 30px;
        padding: 2px;
        width: auto;
        max-width: 34px;
    }
    .public-brand .brand-text {
        font-size: 1rem;
        line-height: 1.1;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }
    .public-main {
        padding-top: 12px;
    }
    .public-landing-main {
        padding-left: 10px;
        padding-right: 10px;
    }
    .public-stats-subnav {
        border-left: 0;
        border-radius: 0;
        border-right: 0;
        margin: -2px -20px 16px;
        overflow: visible;
        padding: 6px 20px;
        scroll-padding-inline: 20px;
        scrollbar-width: none;
    }
    .public-stats-subnav::-webkit-scrollbar {
        display: none;
    }
    .public-stats-subnav-toggle {
        display: flex;
    }
    .public-stats-subnav-list {
        display: none;
        gap: 6px;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        margin-top: 6px;
        overflow: visible;
        white-space: normal;
    }
    .public-stats-subnav.is-open .public-stats-subnav-list {
        display: grid;
    }
    .public-stats-subnav a {
        flex: 0 0 auto;
        padding: 7px 12px;
        white-space: normal;
    }
    .glance-nav-shell .public-stats-subnav {
        border: 0;
        overflow: visible;
        margin: 0;
        padding: 0;
    }
    .glance-nav-shell .public-stats-subnav a {
        white-space: nowrap;
    }
    .server-profile-hero {
        gap: 0;
        margin-bottom: 14px;
    }
    .server-profile-main {
        padding: 18px;
    }
    .server-title-row {
        gap: 8px;
    }
    .server-title-row h1 {
        font-size: clamp(1.65rem, 7vw, 2.2rem);
    }
    .server-tagline {
        font-size: .96rem;
        margin-top: 6px;
    }
    .server-join-row {
        margin-top: 14px;
    }
    .metric-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .rotation-summary-strip { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .ops-section-grid { grid-template-columns: 1fr; }
    .server-profile-hero { grid-template-columns: 1fr; }
    .map-hero-panel { grid-template-columns: 1fr; }
    .detail-hero,
    .detail-section-grid { grid-template-columns: 1fr; }
    .health-summary-grid,
    .insight-grid,
    .relationship-spotlight-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .relationship-detail-grid { grid-template-columns: 1fr; }
    .quick-stat-strip { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .rotation-toggle-grid { grid-template-columns: 1fr; }
    .award-v2-card-grid,
    .player-award-badge-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .award-grid { grid-template-columns: 1fr; }
    .rotation-bulkbar { grid-template-columns: 1fr 1fr; }
    .rotation-commandbar { position: static; }
    .rotation-filter-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .rotation-filter-grid .span-2,
    .rotation-filter-grid .span-3,
    .rotation-filter-grid .span-4,
    .rotation-warning-columns,
    .rotation-rule-grid,
    .rotation-map-main,
    .rotation-map-compact-grid,
    .rotation-map-detail-grid,
    .setup-note-grid,
    .summary-grid,
    .rotation-forced-row { grid-template-columns: 1fr; }
    .rotation-filter-grid .span-2,
    .rotation-filter-grid .span-3,
    .rotation-filter-grid .span-4,
    .rotation-map-detail-grid > div,
    .rotation-map-detail-grid > label,
    .rotation-map-detail-grid .span-3 { grid-column: span 1; }
    .rotation-preview-strip { align-items: flex-start; flex-direction: column; }
    .rotation-advanced-drawer {
        border-left: 0;
        max-width: 100vw;
        width: 100vw;
    }
    .stats-filter-bar { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .stats-filter-bar .span-2,
    .stats-filter-bar .span-3,
    .stats-filter-bar .span-4,
    .stats-filter-bar .span-6 { grid-column: span 1; }
    .stats-table td,
    .stats-table th { padding: .62rem .7rem; }
}

@media (max-width: 575px) {
    .portal-content,
    .portal-topbar { padding-left: 16px; padding-right: 16px; }
    .portal-topbar {
        align-items: flex-start;
        flex-direction: column;
    }
    .portal-topbar-title { width: 100%; }
    .topbar-cluster {
        margin-left: 0;
        width: 100%;
    }
    .public-main > .public-server-header {
        margin-bottom: 8px;
    }
    .public-main > .public-server-header .glance-topbar {
        gap: 8px;
        min-height: 0;
        padding-top: 2px;
    }
    .public-main > .public-server-header .glance-brand-link {
        min-width: 0;
    }
    .public-main > .public-server-header .glance-brand-logo,
    .public-main > .public-server-header .glance-brand-logo-fallback {
        max-height: 56px;
        width: auto;
    }
    .public-main { padding: 10px 14px 40px; }
    .public-hero { display: grid; }
    .public-page-header {
        row-gap: 8px;
    }
    .public-page-header h1 {
        font-size: 1.5rem;
        margin-bottom: 6px;
    }
    .public-page-header p {
        font-size: .95rem;
    }
    .public-hero h1 {
        font-size: 1.78rem;
    }
    .public-main .table-responsive,
    .public-main .public-table-shell,
    .public-main .player-matchups-table,
    .public-main .player-detail-table-shell {
        max-width: 100%;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }
    .public-main .public-table-shell .stats-table,
    .public-main .table-responsive .stats-table,
    .public-main .table-responsive .award-detail-table,
    .public-main .table-responsive .dimension-table,
    .public-main .player-matchups-table .player-detail-table,
    .public-main .player-detail-table-shell .player-detail-table {
        width: 100%;
        min-width: 640px;
        table-layout: fixed;
    }
    .public-main .stats-table td,
    .public-main .stats-table th,
    .public-main .stats-table small,
    .public-main .stats-table .stat-secondary,
    .public-main .stats-table .stat-number,
    .public-main .stats-table .stat-rank {
        white-space: normal;
        overflow-wrap: anywhere;
        min-width: 0;
    }
    .public-stats-subnav {
        margin-left: -14px;
        margin-right: -14px;
        margin-bottom: 14px;
        padding-left: 14px;
        padding-right: 14px;
        scroll-padding-inline: 14px;
    }
    .server-profile-main { padding: 16px; }
    .server-join-row .btn,
    .server-address-box { width: 100%; }
    .server-profile-side {
        gap: 8px;
        padding: 10px;
    }
    .server-profile-side > div {
        padding: 10px;
    }
    .quick-stat-strip { grid-template-columns: 1fr; }
    .portal-nav { grid-template-columns: 1fr; }
    .metric-grid { grid-template-columns: 1fr; }
    .rotation-toggle-fields,
    .rotation-bulkbar,
    .rotation-map-meta { grid-template-columns: 1fr; display: grid; }
    .forced-candidate-actions { align-items: flex-start; justify-content: flex-start; }
    .rotation-map-head { align-items: flex-start; }
    .rotation-map-actions { justify-content: flex-start; }
    .public-page-header { display: grid; }
    .public-stats-subnav a { flex: 0 0 auto; text-align: center; }
    .public-stats-subnav-list { grid-template-columns: 1fr; }
    .map-image-hero { min-height: 135px; }
    .detail-hero,
    .detail-hero-side,
    .health-summary-grid,
    .insight-grid,
    .award-v2-card-grid,
    .player-award-badge-grid,
    .player-results-strip,
    .relationship-spotlight-grid,
    .relationship-detail-grid,
    .relationship-card-metrics,
    .top-player-strip { grid-template-columns: 1fr; }
    .player-insights-heading,
    .award-v2-heading,
    .award-v2-group-title,
    .award-v2-card-top,
    .player-award-badge-heading,
    .player-award-badge-top,
    .player-insights-block-header,
    .relationship-card-header,
    .relationship-card-meta,
    .relationship-list-heading,
    .relationship-list-item {
        align-items: flex-start;
        flex-direction: column;
    }
    .compact-list-item,
    .insight-list a {
        align-items: flex-start;
        flex-direction: column;
    }
    .detail-accordion > summary {
        align-items: flex-start;
    }
    .stats-filter-bar { grid-template-columns: 1fr; }
    .portal-card-header { align-items: flex-start; gap: 8px; }
    .portal-card-header,
    .mobile-stat-card-head,
    .linked-list-row,
    .admin-page-header,
    .mode-banner,
    .health-row,
    .action-required-item,
    .diagnostics-link { flex-direction: column; }
    .admin-page-actions,
    .topbar-cluster { justify-content: flex-start; }
    .round-scoreboard-table { display: none; }
    .round-scoreboard-mobile { display: block; }
    .round-context-body,
    .map-admin-detail { display: grid; }
    .round-context-body .map-image-round,
    .map-admin-detail .map-image-admin { flex-basis: auto; width: 100%; }
    .mobile-stat-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .award-card-title,
    .award-winner { align-items: flex-start; flex-direction: column; }
    .dimension-table-responsive {
        margin-left: -16px;
        margin-right: -16px;
        width: calc(100% + 32px);
    }
    .public-main .dimension-table-responsive {
        margin-left: 0;
        margin-right: 0;
        width: 100%;
    }
    .dimension-table .stat-primary,
    .dimension-table .stat-secondary {
        max-width: 46vw;
    }
    .setup-stepper,
    .status-strip {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .summary-section dl {
        grid-template-columns: 1fr;
    }
}

/* Dense public landing dashboard */
.server-glance-dashboard {
    --glance-bg: #070a0f;
    --glance-panel: rgba(12, 16, 24, .94);
    --glance-panel-strong: rgba(18, 23, 33, .98);
    --glance-line: rgba(255, 255, 255, .11);
    --glance-line-hot: rgba(238, 33, 45, .78);
    --glance-text: #f4f6f9;
    --glance-muted: #8f98a8;
    --glance-red: #ee212d;
    --glance-red-deep: #8d1118;
    --glance-green: #49e463;
    --glance-blue: #4fa0ff;
    --home-map-media-height: clamp(200px, 15vw, 270px);
    --glance-warn: #ffcc55;
    background:
        radial-gradient(circle at 18% -10%, rgba(238, 33, 45, .22), transparent 28rem),
        radial-gradient(circle at 85% 8%, rgba(79, 160, 255, .13), transparent 30rem),
        linear-gradient(180deg, #080b11 0%, #06090e 58%, #090d14 100%);
    border: 1px solid rgba(255, 255, 255, .08);
    box-shadow: 0 24px 70px rgba(0, 0, 0, .42);
    color: var(--glance-text);
    display: grid;
    font-family: "Rajdhani", "Bahnschrift", "Agency FB", "Segoe UI", sans-serif;
    gap: 14px;
    letter-spacing: .02em;
    margin: 0 auto 28px;
    max-width: 1480px;
    overflow: hidden;
    padding: 18px;
    position: relative;
}

.server-glance-dashboard::before {
    background:
        linear-gradient(rgba(255, 255, 255, .035) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 255, 255, .026) 1px, transparent 1px);
    background-size: 48px 48px;
    content: "";
    inset: 0;
    pointer-events: none;
    position: absolute;
}

.glance-dashboard-shell .glance-brand-link,
.glance-brand-link {
    align-items: center;
    color: var(--glance-text);
    display: inline-flex;
    gap: 10px;
    min-width: 0;
    text-decoration: none;
}

.glance-brand-link:focus-visible,
.glance-brand-link:hover {
    color: #fff;
}

.glance-brand-logo {
    align-items: center;
    background: rgba(21, 28, 42, .82);
    border: 1px solid rgba(255, 255, 255, .13);
    border-radius: 6px;
    display: inline-flex;
    flex: 0 0 auto;
    height: 58px;
    max-height: 58px;
    justify-content: center;
    max-width: 260px;
    object-fit: contain;
    padding: 5px;
    width: auto;
}

.glance-brand-logo-fallback {
    background: #1d2a44;
    color: #fff;
    font-size: .8rem;
    font-weight: 800;
}

.glance-dashboard-summary {
    display: grid;
    gap: 8px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin-top: 12px;
}

.glance-dashboard-summary div {
    background: rgba(255, 255, 255, .025);
    border: 1px solid rgba(255, 255, 255, .08);
    border-radius: 6px;
    padding: 8px 10px;
}

.glance-dashboard-summary span {
    color: var(--glance-muted);
    display: block;
    font-size: .72rem;
    font-weight: 750;
    letter-spacing: .12em;
    text-transform: uppercase;
}

.glance-dashboard-summary strong {
    color: #fff;
    display: block;
    font-size: 1.08rem;
    font-weight: 800;
    line-height: 1.18;
    margin-top: 5px;
    overflow-wrap: anywhere;
}

.glance-inline-note {
    align-items: center;
    color: var(--glance-muted);
    display: flex;
    flex-wrap: wrap;
    font-size: .8rem;
    gap: 10px 16px;
    margin-top: 10px;
}

.glance-inline-note span {
    color: var(--glance-muted);
}

.glance-brand-meta {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
}

.glance-updated-note {
    color: var(--glance-muted);
    font-size: .78rem;
}

.glance-status-pill {
    border-color: rgba(255, 255, 255, .45) !important;
}

.glance-command-stack-inner {
    display: flex;
    flex-direction: column;
    gap: 10px;
    justify-content: flex-start;
    justify-items: end;
}

.glance-command-stack {
    justify-self: end;
    min-width: 0;
}

.glance-connect-module {
    align-items: center;
    display: flex;
    gap: 10px;
    justify-content: center;
    min-width: 0;
}

.glance-utility-cluster,
.glance-landing-actions {
    align-items: center;
    display: inline-flex;
    flex-wrap: wrap;
    gap: 6px;
    justify-content: flex-end;
}

.glance-landing-actions {
    align-items: center;
    justify-content: flex-end;
}

.glance-address-row {
    align-items: flex-start;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: space-between;
}

.glance-address-row strong {
    min-width: 0;
    overflow-wrap: anywhere;
}

.glance-copy-address {
    flex: 0 0 auto;
    min-height: 30px;
}

.glance-auth-form {
    margin: 0;
}

.glance-auth-form .btn {
    min-height: 34px;
}

.theme-toggle-landing {
    align-items: center;
    border-bottom: 0;
    display: inline-flex;
    gap: 6px;
    justify-content: center;
    padding-bottom: 0;
    width: auto;
}

.theme-toggle-landing .theme-toggle-label {
    color: var(--glance-muted);
    font-size: .75rem;
    font-weight: 750;
}

.theme-toggle-landing .theme-toggle-select {
    min-height: 34px;
    min-width: 8.2rem;
}

.glance-utility-cluster .btn {
    min-height: 34px;
}

.glance-nav-shell {
    background: linear-gradient(180deg, rgba(255, 255, 255, .01), rgba(255, 255, 255, .015));
    border: 1px solid rgba(255, 255, 255, .09);
    border-radius: 8px;
    padding: 8px;
}

.glance-nav-shell .public-stats-subnav {
    background: transparent;
    border: 0;
    gap: 6px;
    overflow: hidden;
    margin: 0;
    padding: 0;
    white-space: nowrap;
}

.glance-nav-shell .public-stats-subnav-list {
    display: flex;
    gap: 6px;
    overflow: hidden;
    white-space: nowrap;
    width: 100%;
}

.glance-nav-shell .public-stats-subnav a {
    align-items: center;
    display: inline-flex;
    border: 1px solid rgba(255, 255, 255, .12);
    border-radius: 6px;
    color: #d7deeb;
    font-size: .8rem;
    font-weight: 800;
    justify-content: center;
    white-space: nowrap;
    padding: 7px 9px;
}

.glance-nav-shell .public-stats-subnav a:hover,
.glance-nav-shell .public-stats-subnav a.active {
    background: rgba(238, 33, 45, .18);
    border-color: rgba(238, 33, 45, .55);
    color: #fff;
}

.glance-nav-shell .public-stats-subnav a:focus-visible,
.glance-nav-shell .public-stats-subnav a.active:focus-visible {
    outline-color: rgba(238, 33, 45, .65);
}

.server-glance-dashboard > * {
    animation: glance-rise .42s ease both;
    position: relative;
    z-index: 1;
}

.server-glance-dashboard > *:nth-child(2) { animation-delay: .04s; }
.server-glance-dashboard > *:nth-child(3) { animation-delay: .08s; }
.server-glance-dashboard > *:nth-child(4) { animation-delay: .12s; }
.server-glance-dashboard > *:nth-child(5) { animation-delay: .16s; }
.server-glance-dashboard > *:nth-child(6) { animation-delay: .2s; }

@keyframes glance-rise {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}

.server-glance-dashboard h1,
.server-glance-dashboard h2,
.server-glance-dashboard p {
    margin: 0;
}

.glance-command-panel,
.glance-panel,
.glance-stat-grid > div,
.glance-quick-links a {
    background: linear-gradient(180deg, rgba(18, 23, 33, .94), rgba(9, 13, 20, .94));
    border: 1px solid var(--glance-line);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .045), 0 14px 32px rgba(0, 0, 0, .24);
}

.glance-command-panel {
    align-items: center;
    display: grid;
    gap: 14px;
    grid-template-columns: minmax(120px, auto) minmax(280px, 1fr) minmax(280px, auto);
    padding: 12px 14px;
}

.glance-kicker,
.glance-panel-heading span,
.glance-address-card span,
.glance-activity-summary span,
.glance-map-metrics span,
.glance-flow-row span,
.glance-status-list span,
.glance-stat-grid span,
.glance-quick-links small,
.glance-map-overlay span {
    color: var(--glance-muted);
    display: block;
    font-size: .75rem;
    font-weight: 800;
    letter-spacing: .14em;
    text-transform: uppercase;
}

.glance-kicker {
    color: #ff5a62;
}

.glance-title-row {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 3px;
}

.glance-title-row h1 {
    color: #fff;
    font-size: clamp(2rem, 4.2vw, 3.55rem);
    font-weight: 900;
    letter-spacing: .045em;
    line-height: .92;
    overflow-wrap: anywhere;
    text-transform: uppercase;
    text-shadow: 0 3px 18px rgba(0, 0, 0, .55);
}

.glance-brand-stack p {
    color: #b9c0ce;
    font-size: .98rem;
    margin-top: 8px;
    max-width: 860px;
}

.server-glance-dashboard .status-badge {
    border: 1px solid currentColor;
    border-radius: 2px;
    font-size: .76rem;
    font-weight: 900;
    letter-spacing: .14em;
    padding: 5px 8px;
    text-transform: uppercase;
}

.server-glance-dashboard .status-ok { background: rgba(73, 228, 99, .11); color: var(--glance-green); }
.server-glance-dashboard .status-error { background: rgba(238, 33, 45, .14); color: #ff6068; }
.server-glance-dashboard .status-info { background: rgba(79, 160, 255, .13); color: #74b5ff; }
.server-glance-dashboard .status-neutral { background: rgba(255, 255, 255, .07); color: #c3cad8; }
.server-glance-dashboard .status-warn { background: rgba(255, 204, 85, .13); color: var(--glance-warn); }

.glance-connect-stack {
    display: grid;
    gap: 10px;
    justify-items: end;
}

.glance-address-card {
    background: rgba(255, 255, 255, .045);
    border: 1px solid rgba(255, 255, 255, .1);
    min-width: min(100%, 300px);
    padding: 8px 10px;
    text-align: left;
}

.glance-address-card strong {
    color: #fff;
    display: block;
    font-size: 1.08rem;
    font-weight: 800;
    overflow-wrap: anywhere;
}

.glance-command-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: flex-end;
}

.server-glance-dashboard .btn,
.glance-join-button {
    border-radius: 3px;
    font-weight: 900;
    letter-spacing: .08em;
    min-height: 38px;
    text-transform: uppercase;
}

.server-glance-dashboard .btn-primary,
.glance-join-button {
    background: linear-gradient(180deg, #ee212d, #a8141c);
    border-color: #ff333f;
    color: #fff;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .25), 0 10px 24px rgba(238, 33, 45, .22);
}

.server-glance-dashboard .btn-outline-primary {
    background: rgba(255, 255, 255, .035);
    border-color: rgba(255, 255, 255, .18);
    color: #f5f7fb;
}

.server-glance-dashboard .btn:disabled,
.glance-join-button:disabled {
    background: rgba(255, 255, 255, .08);
    border-color: rgba(255, 255, 255, .12);
    color: var(--glance-muted);
    box-shadow: none;
}

.glance-map-grid {
    display: grid;
    gap: 14px;
    grid-template-columns: minmax(420px, 1.7fr) minmax(300px, 1.05fr) minmax(280px, .95fr);
}

.glance-panel {
    min-width: 0;
    overflow: hidden;
}

.glance-panel-heading {
    align-items: center;
    border-bottom: 1px solid rgba(255, 255, 255, .085);
    display: flex;
    justify-content: space-between;
    gap: 12px;
    min-height: 48px;
    padding: 12px 16px;
}

.glance-panel-heading h2 {
    color: #fff;
    font-size: 1rem;
    font-weight: 900;
    letter-spacing: .12em;
    text-transform: uppercase;
}

.glance-current-map {
    border-top-color: var(--glance-line-hot);
}

.glance-map-art {
    background:
        linear-gradient(135deg, rgba(238, 33, 45, .26), rgba(79, 160, 255, .16)),
        radial-gradient(circle at 50% 15%, rgba(255, 255, 255, .12), transparent 22rem),
        #111722;
    height: var(--home-map-media-height);
    min-height: var(--home-map-media-height);
    overflow: hidden;
    position: relative;
}

.glance-map-art img {
    filter: saturate(.9) contrast(1.08) brightness(.8);
    height: 100%;
    inset: 0;
    object-fit: cover;
    position: absolute;
    transform: scale(1.01);
    width: 100%;
}

.glance-map-art::after {
    background: linear-gradient(180deg, rgba(0, 0, 0, .05), rgba(0, 0, 0, .78));
    content: "";
    inset: 0;
    position: absolute;
}

.glance-map-art-empty::before {
    background:
        linear-gradient(135deg, transparent 0 42%, rgba(255, 255, 255, .05) 42% 44%, transparent 44%),
        repeating-linear-gradient(90deg, rgba(255, 255, 255, .055) 0 1px, transparent 1px 38px);
    content: "";
    inset: 0;
    opacity: .65;
    position: absolute;
}

.glance-map-overlay {
    bottom: 0;
    left: 0;
    padding: 24px;
    position: absolute;
    right: 0;
    z-index: 1;
}

.glance-map-overlay strong {
    color: #fff;
    display: block;
    font-size: clamp(1.8rem, 3.1vw, 3rem);
    font-weight: 900;
    letter-spacing: .04em;
    line-height: .92;
    overflow-wrap: anywhere;
    text-transform: uppercase;
    text-shadow: 0 4px 18px rgba(0, 0, 0, .7);
}

.glance-next-map .glance-map-overlay strong {
    font-size: clamp(1.5rem, 2.3vw, 2.25rem);
}

.glance-map-overlay small,
.glance-flow-row small,
.glance-status-note,
.glance-round-card small,
.glance-quick-links small {
    color: var(--glance-muted);
    display: block;
    font-size: .82rem;
    overflow-wrap: anywhere;
}

.glance-map-metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.glance-map-metrics > div {
    border-right: 1px solid rgba(255, 255, 255, .085);
    padding: 13px 16px;
    text-align: center;
}

.glance-map-metrics > div:last-child {
    border-right: 0;
}

.glance-map-metrics strong,
.glance-flow-row strong,
.glance-status-list strong,
.glance-activity-summary strong,
.glance-stat-grid strong {
    color: #fff;
    display: block;
    font-size: 1.45rem;
    font-weight: 900;
    line-height: 1.05;
    margin-top: 4px;
    overflow-wrap: anywhere;
}

.glance-flow-row {
    padding: 14px 16px 16px;
}

.glance-status-panel {
    display: flex;
    flex-direction: column;
}

.glance-status-list {
    display: grid;
    gap: 0;
    padding: 8px 18px 0;
}

.glance-status-list > div {
    align-items: center;
    border-bottom: 1px solid rgba(255, 255, 255, .08);
    display: flex;
    justify-content: space-between;
    gap: 12px;
    padding: 11px 0;
}

.glance-status-list strong {
    font-size: 1rem;
    margin-top: 0;
    text-align: right;
}

.glance-good { color: var(--glance-green) !important; }
.glance-bad { color: #ff626b !important; }
.glance-warn { color: var(--glance-warn) !important; }

.glance-capacity-meter {
    background: rgba(255, 255, 255, .08);
    height: 8px;
    margin: 16px 18px 6px;
    overflow: hidden;
}

.glance-capacity-meter > div {
    background: linear-gradient(90deg, var(--glance-red), #ff7b32);
    height: 100%;
}

.glance-status-note {
    padding: 0 18px 16px;
}

.glance-join-button {
    border: 1px solid #ff333f;
    margin: auto 18px 18px;
    padding: 0 18px;
    width: calc(100% - 36px);
}

.glance-stat-grid {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(6, minmax(0, 1fr));
}

.glance-stat-grid > div {
    padding: 12px 14px;
}

.glance-stat-grid strong {
    color: #fff;
    font-size: 1.6rem;
}

.glance-live-grid,
.glance-intel-grid {
    display: grid;
    gap: 14px;
    grid-template-columns: minmax(0, 1.45fr) minmax(340px, .9fr);
}

.glance-intel-grid {
    grid-template-columns: minmax(0, 1fr) minmax(320px, .72fr);
}

.glance-player-table th,
.glance-player-table td {
    border-color: rgba(255, 255, 255, .075) !important;
    padding: .62rem .85rem;
}

.glance-player-table th {
    color: var(--glance-muted);
    font-size: .72rem;
    letter-spacing: .1em;
}

.glance-player-table tbody tr:nth-child(odd) td {
    background: rgba(255, 255, 255, .025);
}

.glance-team-pill {
    border: 1px solid rgba(255, 255, 255, .13);
    color: #cbd2df;
    display: inline-flex;
    font-size: .75rem;
    font-weight: 800;
    letter-spacing: .08em;
    padding: 3px 7px;
    text-transform: uppercase;
}

.glance-panel-link {
    align-items: center;
    border-top: 1px solid rgba(255, 255, 255, .085);
    color: #cfd5df;
    display: flex;
    font-size: .78rem;
    font-weight: 900;
    justify-content: center;
    letter-spacing: .12em;
    min-height: 42px;
    text-decoration: none;
    text-transform: uppercase;
}

.glance-panel-link:hover {
    color: #fff;
    background: rgba(238, 33, 45, .12);
}

.glance-events-panel .kill-feed-list {
    gap: 0;
    padding: 0;
}

.glance-events-panel .kill-feed-item {
    background: transparent;
    border: 0;
    border-bottom: 1px solid rgba(255, 255, 255, .075);
    border-radius: 0;
    grid-template-columns: auto minmax(0, 1fr) auto;
    margin: 0;
    padding: 10px 14px;
}

.glance-events-panel .kill-feed-item:last-child {
    border-bottom: 0;
}

.glance-events-panel .kill-feed-combatant > span,
.glance-events-panel .kill-feed-combatant a,
.glance-events-panel .kill-feed-line {
    color: #f6f7fb;
    font-weight: 800;
}

.glance-events-panel .help-text,
.glance-events-panel .kill-feed-meta .help-text {
    color: var(--glance-muted);
}

.glance-empty,
.server-glance-dashboard .empty-state {
    color: var(--glance-muted);
    padding: 18px;
}

.glance-round-list {
    display: grid;
}

.glance-round-card {
    align-items: center;
    border-bottom: 1px solid rgba(255, 255, 255, .075);
    color: var(--glance-text);
    display: grid;
    gap: 12px;
    grid-template-columns: 74px minmax(0, 1fr);
    padding: 10px 14px;
    text-decoration: none;
}

.glance-round-card:hover {
    background: rgba(238, 33, 45, .11);
    color: #fff;
}

.glance-round-card.glance-round-empty {
    opacity: .72;
}

.glance-round-card.glance-round-empty:hover {
    opacity: .92;
}

.glance-round-card .map-image-thumb {
    border-radius: 2px;
    height: 44px;
    width: 74px;
}

.glance-round-card strong {
    display: block;
    overflow-wrap: anywhere;
}

.glance-map-history {
    display: grid;
}

.glance-map-history > div {
    align-items: center;
    border-bottom: 1px solid rgba(255, 255, 255, .075);
    display: flex;
    gap: 12px;
    justify-content: space-between;
    padding: 13px 16px;
}

.glance-map-history > div:last-child,
.glance-round-card:last-child {
    border-bottom: 0;
}

.glance-map-history span {
    color: #fff;
    font-weight: 800;
    overflow-wrap: anywhere;
}

.glance-map-history strong {
    color: var(--glance-muted);
    font-size: .82rem;
    text-align: right;
}

.glance-activity-summary {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.glance-activity-summary > div {
    border-bottom: 1px solid rgba(255, 255, 255, .075);
    border-right: 1px solid rgba(255, 255, 255, .075);
    min-width: 0;
    padding: 13px 16px;
}

.glance-activity-summary > div:nth-child(2n),
.glance-activity-summary > div:last-child {
    border-right: 0;
}

.glance-activity-summary > div:nth-last-child(-n + 2) {
    border-bottom: 0;
}

.glance-activity-summary strong {
    font-size: 1.05rem;
    margin-top: 5px;
}

.glance-activity-summary small {
    color: var(--glance-muted);
    display: block;
    font-size: .8rem;
    margin-top: 4px;
    overflow-wrap: anywhere;
}

.glance-activity-wide {
    grid-column: 1 / -1;
}

.glance-quick-links {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(6, minmax(0, 1fr));
}

.glance-quick-links a {
    color: var(--glance-text);
    display: block;
    min-height: 72px;
    padding: 14px 16px;
    position: relative;
    text-decoration: none;
}

.glance-quick-links a::before {
    background: linear-gradient(180deg, var(--glance-red), rgba(255, 123, 50, .72));
    content: "";
    inset: 14px auto 14px 0;
    position: absolute;
    width: 3px;
}

.glance-quick-links a:hover {
    border-color: rgba(238, 33, 45, .65);
    color: #fff;
    transform: translateY(-1px);
}

.glance-quick-links strong {
    display: block;
    font-size: 1rem;
    font-weight: 900;
    letter-spacing: .1em;
    text-transform: uppercase;
}

.glance-quick-links small {
    letter-spacing: .02em;
    text-transform: none;
}

@media (max-width: 1024px) {
    .glance-command-panel,
    .glance-map-grid,
    .glance-live-grid,
    .glance-intel-grid {
        grid-template-columns: 1fr;
    }

    .glance-command-stack {
        justify-self: stretch;
    }

    .glance-connect-module {
        flex-wrap: wrap;
        justify-content: flex-start;
    }

    .glance-utility-cluster {
        justify-content: flex-start;
    }

    .glance-connect-stack {
        justify-items: stretch;
    }

    .glance-address-card {
        text-align: left;
    }

    .glance-command-actions {
        justify-content: flex-start;
    }

    .glance-stat-grid,
    .glance-quick-links {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 768px) {
    .server-glance-dashboard {
        gap: 10px;
        margin-left: -4px;
        margin-right: -4px;
        padding: 10px;
    }
    .public-landing-main {
        padding-left: 6px;
        padding-right: 6px;
        padding-top: 8px;
    }

    .glance-command-panel,
    .glance-panel-heading,
    .glance-map-overlay {
        padding: 12px;
    }

    .glance-title-row h1 {
        font-size: clamp(1.65rem, 10vw, 2.35rem);
    }
    .glance-dashboard-summary {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .glance-command-stack {
        align-items: stretch;
        gap: 12px;
    }
    .glance-command-stack-inner {
        justify-items: start;
    }
    .glance-brand-logo {
        height: auto;
        max-height: 44px;
        max-width: 190px;
    }
    .glance-landing-actions {
        justify-content: flex-start;
    }

    .server-glance-dashboard {
        --home-map-media-height: 176px;
    }

    .glance-map-metrics,
    .glance-stat-grid,
    .glance-quick-links {
        grid-template-columns: 1fr 1fr;
    }

    .glance-map-metrics > div:nth-child(2) {
        border-right: 0;
    }

    .glance-map-metrics > div:last-child {
        border-top: 1px solid rgba(255, 255, 255, .085);
        grid-column: 1 / -1;
    }

    .glance-events-panel .kill-feed-item,
    .glance-round-card {
        grid-template-columns: minmax(0, 1fr);
    }

    .glance-events-panel .game-icon,
    .glance-round-card .map-image-thumb {
        display: none;
    }
    .glance-nav-shell .public-stats-subnav {
        overflow: visible;
    }
    .glance-nav-shell .public-stats-subnav-list {
        display: none;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        overflow: visible;
        white-space: normal;
    }
    .glance-nav-shell .public-stats-subnav.is-open .public-stats-subnav-list {
        display: grid;
    }
    .glance-nav-shell .public-stats-subnav a {
        white-space: normal;
        min-height: 38px;
    }
    .glance-activity-summary {
        grid-template-columns: 1fr;
    }
    .glance-activity-summary > div {
        border-right: 0;
    }
    .glance-activity-summary > div:nth-last-child(-n + 2) {
        border-bottom: 1px solid rgba(255, 255, 255, .075);
    }
    .glance-activity-summary > div:last-child {
        border-bottom: 0;
    }
}

@media (max-width: 480px) {
    .glance-stat-grid,
    .glance-quick-links {
        grid-template-columns: 1fr;
    }
    .glance-dashboard-summary {
        grid-template-columns: 1fr;
    }
    .glance-nav-shell .public-stats-subnav-list {
        grid-template-columns: 1fr;
    }
    .glance-status-list > div,
    .glance-map-history > div {
        align-items: flex-start;
        flex-direction: column;
    }

    .glance-status-list strong,
    .glance-map-history strong {
        text-align: left;
    }
}

/* Empire CTF public home */
.public-landing-main {
    padding: 0;
}

.public-shell:has(.server-glance-dashboard) {
    background: #05080c;
}

.server-glance-dashboard {
    --glance-bg: #05080c;
    --glance-panel: rgba(11, 16, 22, .96);
    --glance-panel-soft: rgba(16, 22, 30, .9);
    --glance-line: rgba(198, 213, 235, .18);
    --glance-line-soft: rgba(198, 213, 235, .1);
    --glance-gold: #f7b922;
    --glance-red: #d71924;
    --glance-red-deep: #8e1118;
    --glance-green: #54e56b;
    --home-map-media-height: clamp(260px, 22vw, 360px);
    --glance-blue: #4c8dff;
    --glance-muted: #9aa3b2;
    --glance-text: #f7f8fb;
    background:
        radial-gradient(circle at 18% -16%, rgba(247, 185, 34, .18), transparent 24rem),
        radial-gradient(circle at 82% -10%, rgba(215, 25, 36, .16), transparent 28rem),
        linear-gradient(180deg, #080d13 0, #05080c 58%, #080c12 100%);
    border: 0;
    box-shadow: none;
    color: var(--glance-text);
    gap: 14px;
    max-width: 2040px;
    min-height: 100vh;
    padding: 26px 20px 0;
}

.server-glance-dashboard::before {
    background:
        linear-gradient(rgba(255, 255, 255, .025) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 255, 255, .018) 1px, transparent 1px);
    background-size: 56px 56px;
}

.glance-topbar {
    position: relative;
    z-index: 2;
    align-items: center;
    display: grid;
    gap: 18px;
    grid-template-columns: minmax(230px, 300px) minmax(0, 1fr) minmax(330px, auto);
}

.glance-brand-link {
    display: inline-flex;
    grid-column: 1;
    grid-row: 1;
    min-height: 96px;
}

.glance-brand-logo {
    background: transparent;
    border: 0;
    border-radius: 0;
    height: auto;
    max-width: 300px;
    max-height: 96px;
    object-fit: contain;
    object-position: center;
    padding: 0;
    width: 100%;
}

.glance-brand-logo-fallback {
    align-items: center;
    background: linear-gradient(180deg, #f7b922, #9f6f06);
    border: 1px solid rgba(247, 185, 34, .55);
    border-radius: 6px;
    color: #100d05;
    display: inline-flex;
    font-size: 1rem;
    font-weight: 900;
    justify-content: center;
    object-fit: contain;
    width: 96px;
}

.glance-nav-shell {
    background: linear-gradient(180deg, rgba(255, 255, 255, .055), rgba(255, 255, 255, .02));
    border: 1px solid var(--glance-line);
    border-radius: 8px;
    display: inline-flex;
    grid-column: 1 / -1;
    grid-row: 2;
    justify-self: center;
    max-width: 100%;
    overflow: visible;
    padding: 0;
    width: auto;
}

.glance-nav-shell .public-stats-subnav {
    background: transparent;
    border: 0;
    margin: 0;
    overflow: visible;
    padding: 0;
    width: auto;
}

.glance-nav-shell .public-stats-subnav-list {
    display: flex;
    gap: 0;
    justify-content: center;
    min-width: max-content;
    overflow: visible;
    width: max-content;
}

.glance-nav-shell .public-stats-subnav a,
.glance-nav-shell .public-stats-more-toggle {
    align-items: center;
    background: transparent;
    border: 0;
    border-left: 1px solid rgba(255, 255, 255, .075);
    border-radius: 0;
    color: #dce2ee;
    display: inline-flex;
    font-size: .88rem;
    font-weight: 800;
    justify-content: center;
    min-height: 56px;
    padding: 0 16px;
    white-space: nowrap;
}

.glance-nav-shell .public-stats-subnav a:first-child {
    border-left: 0;
}

.glance-nav-shell .public-stats-subnav a:hover,
.glance-nav-shell .public-stats-subnav a.active,
.glance-nav-shell .public-stats-more-toggle:hover,
.glance-nav-shell .public-stats-more-toggle.active {
    background: linear-gradient(180deg, rgba(247, 185, 34, .16), rgba(247, 185, 34, .04));
    box-shadow: inset 0 -2px 0 var(--glance-gold);
    color: #fff;
}

.public-stats-more {
    flex: 0 0 auto;
}

.public-stats-more-toggle::after {
    border: solid currentColor;
    border-width: 0 1px 1px 0;
    content: "";
    display: inline-block;
    height: 6px;
    margin-left: 8px;
    transform: rotate(45deg) translateY(-2px);
    width: 6px;
}

.public-stats-more-menu {
    background: #0d121a;
    border: 1px solid var(--glance-line);
    border-radius: 8px;
    box-shadow: 0 16px 30px rgba(0, 0, 0, .35);
    min-width: 13rem;
    padding: 6px;
}

.glance-nav-shell .public-stats-more-menu .dropdown-item {
    border: 0;
    border-radius: 6px;
    display: flex;
    justify-content: flex-start;
    min-height: 36px;
    padding: 7px 10px;
    width: 100%;
}

.glance-account-bar {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    grid-column: 3;
    grid-row: 1;
    justify-content: flex-end;
}

.glance-account-bar .btn,
.glance-command-panel .btn {
    border-radius: 5px;
    font-weight: 850;
    min-height: 38px;
}

.glance-account-bar .btn-outline-primary,
.glance-account-bar .btn-outline-secondary {
    background: rgba(255, 255, 255, .035);
    border-color: rgba(255, 255, 255, .22);
    color: #f4f6fb;
}

.glance-account-bar .btn-outline-secondary {
    border-color: rgba(215, 25, 36, .65);
    color: #ff5962;
}

.theme-toggle-landing .theme-toggle-label {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.theme-toggle-landing .theme-toggle-select {
    background-color: rgba(255, 255, 255, .035);
    border-color: rgba(255, 255, 255, .25);
    color: #fff;
    min-height: 38px;
    min-width: 7.4rem;
}

.glance-command-panel {
    align-items: center;
    border-radius: 8px;
    display: grid;
    gap: 16px;
    grid-template-columns: auto minmax(260px, 1fr) minmax(220px, .46fr) auto auto;
    padding: 14px 24px;
}

.glance-status-chip {
    align-items: center;
    background: rgba(84, 229, 107, .13);
    border: 1px solid rgba(84, 229, 107, .35);
    border-radius: 6px;
    display: inline-flex;
    gap: 10px;
    min-height: 40px;
    padding: 0 14px;
}

.glance-status-chip span {
    background: currentColor;
    border-radius: 999px;
    box-shadow: 0 0 12px currentColor;
    height: 10px;
    width: 10px;
}

.glance-status-chip.status-ok { color: var(--glance-green); }
.glance-status-chip.status-error { color: #ff616a; }

.glance-status-chip strong {
    color: #fff;
    font-size: .86rem;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.glance-address-card {
    align-items: center;
    background: transparent;
    border: 0;
    display: grid;
    gap: 10px;
    grid-template-columns: auto minmax(0, max-content);
    min-width: 0;
    padding: 0;
}

.glance-address-card span,
.glance-command-meta span {
    color: var(--glance-muted);
    font-size: .78rem;
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.glance-address-card strong {
    color: #fff;
    font-size: 1.35rem;
    letter-spacing: .02em;
}

.glance-join-button {
    justify-self: stretch;
    line-height: 1.1;
    margin: 0;
    min-height: 46px;
    padding: 0 22px;
    white-space: normal;
    width: auto;
}

.glance-join-button.is-copy-confirmed {
    background: linear-gradient(180deg, #22963a, #146725);
    border-color: rgba(84, 229, 107, .62);
    box-shadow: 0 0 0 .16rem rgba(84, 229, 107, .18);
}

.glance-command-meta {
    align-items: center;
    border-left: 1px solid rgba(255, 255, 255, .16);
    display: flex;
    gap: 8px;
    min-height: 34px;
    padding-left: 18px;
}

.glance-command-meta strong {
    color: #fff;
    font-size: .95rem;
    font-weight: 850;
}

.glance-primary-grid {
    display: grid;
    gap: 14px;
    grid-template-columns: minmax(0, 1fr) minmax(320px, .34fr);
}

.glance-panel,
.glance-command-panel,
.glance-quick-links a {
    background: linear-gradient(180deg, rgba(17, 23, 32, .95), rgba(7, 11, 17, .96));
    border: 1px solid var(--glance-line);
    border-radius: 8px;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .045), 0 14px 34px rgba(0, 0, 0, .32);
}

.glance-panel-heading {
    min-height: 50px;
    padding: 12px 18px;
}

.glance-panel-heading h2 {
    color: var(--glance-gold);
    font-size: .9rem;
    letter-spacing: .04em;
}

.glance-play-window-panel {
    border-top-color: var(--glance-line-hot);
    grid-column: 1 / -1;
}

.glance-play-window-heading-actions {
    align-items: center;
    display: inline-flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: flex-end;
}

.glance-play-window-body {
    display: grid;
    gap: 14px;
    padding: 14px;
}

.glance-play-window-summary {
    align-items: stretch;
    background: rgba(255, 255, 255, .035);
    border: 1px solid rgba(255, 255, 255, .085);
    border-radius: 6px;
    display: grid;
    gap: 14px;
    grid-template-columns: minmax(280px, 1.2fr) minmax(320px, .9fr) auto;
    padding: 14px;
}

.glance-play-window-copy {
    min-width: 0;
}

.glance-play-window-copy span,
.glance-play-map-heading h3 {
    color: var(--glance-muted);
    font-size: .75rem;
    font-weight: 850;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.glance-play-window-copy strong {
    color: #fff;
    display: block;
    font-size: clamp(1.35rem, 1.8vw, 2rem);
    font-weight: 900;
    line-height: 1.05;
    margin-top: 5px;
    overflow-wrap: anywhere;
}

.glance-play-window-copy small {
    color: var(--glance-muted);
    display: block;
    font-size: .85rem;
    line-height: 1.3;
    margin-top: 4px;
    overflow-wrap: anywhere;
}

.glance-play-window-actions {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: flex-end;
    min-width: 0;
}

.glance-play-now-facts {
    display: grid;
    gap: 8px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    min-width: 0;
}

.glance-play-now-facts > div,
.glance-connect-command {
    background: rgba(0, 0, 0, .18);
    border: 1px solid rgba(255, 255, 255, .075);
    border-radius: 6px;
    min-width: 0;
    padding: 9px 10px;
}

.glance-play-now-facts span,
.glance-play-roster-heading span,
.glance-play-progress span {
    align-items: center;
    color: var(--glance-muted);
    display: inline-flex;
    font-size: .72rem;
    font-weight: 850;
    gap: 6px;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.glance-play-now-facts strong {
    color: #fff;
    display: block;
    font-size: .98rem;
    font-weight: 850;
    line-height: 1.1;
    margin-top: 5px;
    overflow: hidden;
    overflow-wrap: anywhere;
    text-overflow: ellipsis;
}

.glance-connect-command {
    align-items: center;
    display: inline-flex;
    max-width: min(100%, 340px);
    min-height: 40px;
}

.glance-connect-command code {
    color: #fff;
    display: block;
    font-family: "Cascadia Mono", Consolas, monospace;
    font-size: .82rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.glance-play-progress {
    background: rgba(84, 229, 107, .055);
    border: 1px solid rgba(84, 229, 107, .18);
    border-radius: 6px;
    display: grid;
    gap: 10px;
    padding: 12px 14px;
}

.glance-play-progress > div {
    align-items: center;
    display: flex;
    gap: 12px;
    justify-content: space-between;
    min-width: 0;
}

.glance-play-progress strong {
    color: #fff;
    font-size: .98rem;
    font-weight: 850;
}

.glance-play-progress-bar {
    background: rgba(255, 255, 255, .08);
    border-radius: 999px;
    display: block;
    height: 7px;
    overflow: hidden;
}

.glance-play-progress-bar span {
    background: linear-gradient(90deg, var(--glance-green), var(--glance-gold));
    border-radius: inherit;
    display: block;
    height: 100%;
}

.glance-play-now-roster {
    background: rgba(255, 255, 255, .026);
    border: 1px solid rgba(255, 255, 255, .085);
    border-radius: 6px;
    overflow: hidden;
}

.glance-play-now-roster[hidden] {
    display: none;
}

.glance-play-roster-heading {
    align-items: center;
    border-bottom: 1px solid rgba(255, 255, 255, .085);
    display: flex;
    gap: 12px;
    justify-content: space-between;
    min-height: 42px;
    padding: 10px 14px;
}

.glance-play-roster-heading h3 {
    align-items: center;
    color: var(--glance-gold);
    display: inline-flex;
    font-size: .82rem;
    font-weight: 900;
    gap: 8px;
    letter-spacing: .08em;
    margin: 0;
    text-transform: uppercase;
}

.glance-play-window-map-grid {
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.glance-play-map {
    border: 1px solid rgba(255, 255, 255, .085);
    border-radius: 6px;
    min-width: 0;
    overflow: hidden;
    position: relative;
}

.glance-play-map-heading {
    align-items: center;
    display: flex;
    min-height: 42px;
    padding: 10px 14px;
}

.glance-play-window-panel .glance-map-metrics {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.glance-play-window-panel .glance-map-metrics > div:nth-child(2n) {
    border-right: 0;
}

.glance-play-window-panel .glance-map-metrics > div:nth-child(n+3) {
    border-top: 1px solid rgba(255, 255, 255, .085);
}

.glance-panel-heading a,
.glance-panel-link {
    color: #ff404a;
    font-size: .78rem;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.glance-map-art {
    height: var(--home-map-media-height);
    min-height: var(--home-map-media-height);
}

.glance-map-art img {
    filter: saturate(.9) contrast(1.08) brightness(.78);
    height: 100%;
    object-fit: cover;
    object-position: center;
    position: absolute;
    width: 100%;
}

.glance-map-overlay {
    padding: 24px 22px;
}

.glance-map-overlay span,
.glance-flow-row span,
.glance-status-list span,
.glance-total-list span,
.glance-snapshot-grid span {
    color: var(--glance-muted);
    font-size: .75rem;
    font-weight: 850;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.glance-map-overlay .glance-map-state-label {
    background: transparent;
    color: #ff4750;
    display: inline-flex;
    margin-bottom: 10px;
    padding: 0;
}

.glance-map-overlay strong {
    font-size: clamp(1.62rem, 1.85vw, 2.32rem);
    letter-spacing: 0;
    line-height: 1;
    text-transform: none;
}

.glance-next-map .glance-map-overlay strong {
    font-size: clamp(1.5rem, 1.75vw, 1.95rem);
    line-height: 1.05;
}

.glance-map-metrics {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.glance-map-metrics > div {
    text-align: left;
    min-width: 0;
}

.glance-map-metrics strong {
    color: var(--glance-gold);
    font-size: clamp(1rem, 1.08vw, 1.28rem);
}

.glance-map-metrics small {
    display: block;
    color: var(--glance-muted);
    font-size: .78rem;
    line-height: 1.15;
    margin-top: 4px;
}

.glance-map-metrics strong,
.glance-map-metrics small {
    max-width: 100%;
    overflow: hidden;
    overflow-wrap: anywhere;
    text-overflow: clip;
    white-space: normal;
}

.glance-flow-row strong {
    font-size: 1.05rem;
}

.glance-status-list {
    gap: 2px;
    padding: 12px 20px;
}

.glance-status-list > div {
    align-items: center;
    display: grid;
    gap: 12px;
    grid-template-columns: minmax(0, 1fr) auto;
    padding: 9px 0;
}

.glance-status-list strong {
    font-size: .98rem;
    max-width: 54%;
    min-width: max-content;
    overflow-wrap: anywhere;
    text-align: right;
}

.glance-total-list {
    border-top: 1px solid rgba(255, 255, 255, .09);
    display: grid;
    gap: 10px 12px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    padding: 14px 20px 18px;
}

.glance-total-list div {
    align-content: start;
    background: rgba(255, 255, 255, .026);
    border: 1px solid rgba(255, 255, 255, .075);
    border-radius: 6px;
    display: grid;
    gap: 5px;
    min-height: 54px;
    padding: 9px 10px;
}

.glance-total-list strong {
    color: #fff;
    font-size: 1.12rem;
    line-height: 1.05;
}

.glance-connected-panel {
    display: flex;
    flex-direction: column;
    min-height: 100%;
    overflow: hidden;
}

.glance-connected-panel .table-responsive {
    flex: 1 1 auto;
}

.glance-connected-table {
    table-layout: fixed;
}

.glance-connected-table th:first-child,
.glance-connected-table td:first-child {
    width: 42%;
}

.glance-connected-table th:nth-child(2),
.glance-connected-table td:nth-child(2),
.glance-connected-table th:nth-child(3),
.glance-connected-table td:nth-child(3) {
    width: 15%;
}

.glance-connected-table th:nth-child(4),
.glance-connected-table td:nth-child(4) {
    width: 28%;
}

.glance-connected-table td:first-child,
.glance-connected-table td:nth-child(4),
.glance-feed-table td {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.glance-empty-centered {
    align-items: center;
    display: flex;
    flex: 1 1 auto;
    flex-direction: column;
    gap: 10px;
    justify-content: center;
    min-height: 240px;
    padding: 28px 22px;
    text-align: center;
}

.glance-empty-centered strong {
    color: #c9d0dc;
    font-size: .98rem;
    font-weight: 850;
}

.glance-empty-centered span {
    color: var(--glance-muted);
}

.glance-empty-icon {
    color: #778295;
    height: 52px;
    opacity: .9;
    width: 52px;
}

.glance-team-pill {
    background: rgba(255, 255, 255, .055);
    border: 1px solid rgba(255, 255, 255, .09);
    border-radius: 999px;
    color: #cfd6e2;
    display: inline-flex;
    font-size: .72rem;
    font-weight: 850;
    max-width: 100%;
    min-width: 0;
    overflow: hidden;
    padding: 3px 8px;
    text-overflow: ellipsis;
    text-transform: uppercase;
    white-space: nowrap;
}

.glance-live-grid {
    align-items: stretch;
    grid-template-columns: minmax(520px, 1.22fr) minmax(430px, .9fr);
}

.glance-awards-panel {
    overflow: hidden;
}

.glance-award-grid {
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    padding: 18px 18px 16px;
}

.glance-award-spotlight {
    --award-accent: var(--glance-gold);
    align-items: center;
    background:
        radial-gradient(circle at 50% 14%, color-mix(in srgb, var(--award-accent) 21%, transparent), transparent 56%),
        linear-gradient(180deg, rgba(255, 255, 255, .06), rgba(255, 255, 255, .018));
    border: 1px solid color-mix(in srgb, var(--award-accent) 46%, rgba(255, 255, 255, .12));
    border-radius: 6px;
    color: #fff;
    display: grid;
    gap: 8px;
    justify-items: center;
    min-height: 184px;
    min-width: 0;
    overflow: hidden;
    padding: 18px 12px 16px;
    position: relative;
    text-align: center;
    text-decoration: none;
}

.glance-award-spotlight::before {
    background: linear-gradient(180deg, color-mix(in srgb, var(--award-accent) 18%, transparent), transparent);
    content: "";
    inset: 0;
    opacity: .55;
    pointer-events: none;
    position: absolute;
}

.glance-award-spotlight:hover {
    border-color: color-mix(in srgb, var(--award-accent) 76%, #fff);
    color: #fff;
    transform: translateY(-1px);
}

.glance-award-spotlight--red { --award-accent: #e1662c; }
.glance-award-spotlight--blue { --award-accent: #aab4c1; }
.glance-award-spotlight--green { --award-accent: var(--glance-gold); }
.glance-award-spotlight--gold { --award-accent: var(--glance-gold); }

.glance-award-rank {
    align-items: center;
    border: 1px solid color-mix(in srgb, var(--award-accent) 52%, rgba(255, 255, 255, .2));
    border-radius: 999px;
    color: var(--award-accent);
    display: inline-flex;
    font-size: .76rem;
    font-weight: 900;
    height: 26px;
    justify-content: center;
    left: 12px;
    line-height: 1;
    position: absolute;
    top: 12px;
    width: 26px;
    z-index: 1;
}

.glance-award-icon {
    background: transparent;
    border: 0;
    color: var(--award-accent);
    filter: drop-shadow(0 8px 18px color-mix(in srgb, var(--award-accent) 28%, transparent));
    height: 68px;
    margin-top: 6px;
    object-fit: contain;
    padding: 0;
    position: relative;
    width: 68px;
    z-index: 1;
}

.glance-award-name,
.glance-award-spotlight strong,
.glance-award-spotlight small {
    min-width: 0;
    overflow: hidden;
    position: relative;
    text-overflow: ellipsis;
    white-space: nowrap;
    width: 100%;
    z-index: 1;
}

.glance-award-name {
    color: var(--award-accent);
    font-size: .78rem;
    font-weight: 900;
    letter-spacing: .04em;
    text-transform: uppercase;
}

.glance-award-spotlight strong {
    color: #fff;
    font-size: 1.08rem;
    font-weight: 900;
}

.glance-award-spotlight small {
    color: var(--award-accent);
    font-size: 1.28rem;
    font-weight: 950;
    letter-spacing: .04em;
}

.glance-panel-link-cta {
    border-top: 1px solid rgba(255, 255, 255, .09);
    display: flex;
    justify-content: flex-end;
    padding: 14px 18px 16px;
}

.glance-player-table,
.glance-feed-table {
    color: #f5f7fb;
    margin-bottom: 0;
}

.glance-player-table th,
.glance-player-table td,
.glance-feed-table th,
.glance-feed-table td {
    background: transparent !important;
    border-color: rgba(255, 255, 255, .09) !important;
    color: #f5f7fb;
    padding: .48rem .7rem;
}

.glance-player-table th,
.glance-feed-table th {
    color: var(--glance-muted);
    font-size: .72rem;
    font-weight: 850;
    letter-spacing: .04em;
    text-transform: uppercase;
}

.glance-feed-table a,
.glance-player-table a {
    color: #5e94ff;
}

.glance-feed-table .game-icon {
    background: transparent;
    border: 0;
    filter: grayscale(.25) brightness(1.35);
    height: 18px;
    padding: 0;
    width: 36px;
}

.glance-events-panel-compact .glance-feed-table {
    table-layout: fixed;
}

.glance-events-panel-compact .glance-feed-table th:first-child,
.glance-events-panel-compact .glance-feed-table td:first-child {
    width: 76px;
}

.glance-events-panel-compact .glance-feed-table th:nth-child(3),
.glance-events-panel-compact .glance-feed-table td:nth-child(3) {
    width: 104px;
}

.glance-events-panel-compact .glance-feed-table th:nth-child(5),
.glance-events-panel-compact .glance-feed-table td:nth-child(5) {
    width: clamp(150px, 18vw, 260px);
}

.glance-events-panel-compact .glance-feed-table td:nth-child(5) {
    line-height: 1.15;
    overflow: visible;
    text-overflow: clip;
    white-space: normal;
}

.glance-feed-time {
    color: #d8dee8 !important;
    font-weight: 850;
}

.glance-feed-player a,
.glance-feed-player span {
    color: #ff4650;
    font-weight: 900;
}

.glance-feed-target a,
.glance-feed-target span {
    color: #6f93ff;
    font-weight: 850;
}

.glance-feed-action {
    align-items: center;
    display: flex;
    gap: 6px;
}

.glance-feed-action .status-badge {
    font-size: .64rem;
    padding: .16rem .34rem;
}

.glance-rounds-panel .glance-panel-heading {
    border-bottom: 0;
}

.glance-round-card-grid {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    padding: 0 16px 14px;
}

.glance-round-tile {
    background: rgba(255, 255, 255, .035);
    border: 1px solid rgba(255, 255, 255, .13);
    border-radius: 6px;
    color: #fff;
    display: grid;
    gap: 0;
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto auto;
    min-height: 0;
    overflow: hidden;
    padding: 0;
    position: relative;
    text-decoration: none;
}

.glance-round-tile:hover {
    border-color: rgba(215, 25, 36, .7);
    color: #fff;
}

.glance-round-tile .map-image-thumb {
    border: 0;
    border-bottom: 1px solid rgba(255, 255, 255, .1);
    border-radius: 0;
    display: block;
    aspect-ratio: 16 / 9;
    grid-column: 1;
    grid-row: 1;
    height: auto;
    inset: auto;
    min-height: 0;
    position: relative;
    width: 100%;
    z-index: 0;
}

.glance-round-tile .map-image-thumb::after {
    background:
        linear-gradient(180deg, rgba(5, 8, 12, .02) 0%, rgba(5, 8, 12, .08) 52%, rgba(5, 8, 12, .18) 100%);
}

.glance-round-tile .map-image {
    filter: saturate(1) contrast(1.03) brightness(.96);
}

.glance-round-tile strong,
.glance-round-tile small,
.glance-round-tile span:not(.map-image-shell) {
    display: block;
    grid-column: 1;
    min-width: 0;
    padding-left: 12px;
    padding-right: 12px;
    position: relative;
    text-overflow: ellipsis;
    overflow: hidden;
    white-space: nowrap;
    z-index: 1;
}

.glance-round-tile strong {
    align-self: end;
    grid-row: 2;
    padding-top: 10px;
}

.glance-round-tile small {
    color: var(--glance-muted);
    grid-row: 3;
}

.glance-round-tile span:not(.map-image-shell) {
    color: var(--glance-green);
    font-size: .82rem;
    font-weight: 850;
}

.glance-round-tile span.glance-round-meta {
    color: #c9d2df;
    padding-bottom: 0;
    padding-top: 2px;
}

.glance-round-tile span.glance-round-meta:last-child {
    padding-bottom: 12px;
}

.glance-bottom-grid {
    display: grid;
    gap: 14px;
    grid-template-columns: minmax(0, .96fr) minmax(520px, 1fr);
}

.glance-snapshot-grid {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
}

.glance-snapshot-grid > * {
    border-right: 1px solid rgba(255, 255, 255, .09);
    color: #fff;
    display: block;
    min-width: 0;
    padding: 14px 16px 18px;
    text-decoration: none;
}

.glance-snapshot-grid > *:last-child {
    border-right: 0;
}

.glance-snapshot-grid a:hover {
    background: rgba(247, 185, 34, .07);
    color: #fff;
}

.glance-snapshot-grid a:hover strong {
    color: #fff;
}

.glance-snapshot-grid strong {
    color: var(--glance-gold);
    display: block;
    font-size: 1.3rem;
    font-weight: 900;
    line-height: 1.1;
    margin-top: 8px;
    overflow-wrap: anywhere;
}

.glance-snapshot-grid small {
    color: var(--glance-muted);
    display: block;
    font-size: .78rem;
    margin-top: 4px;
    overflow-wrap: anywhere;
    word-break: normal;
}

.glance-quick-links {
    gap: 10px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.glance-quick-links a {
    border-radius: 6px;
    min-height: 112px;
    padding: 20px 14px 16px;
    text-align: center;
}

.glance-quick-links a::before {
    background: linear-gradient(90deg, var(--glance-red), var(--glance-gold));
    inset: auto 0 0 0;
    height: 2px;
    width: auto;
}

.glance-quick-links strong {
    color: #fff;
    font-size: 1rem;
    letter-spacing: 0;
    text-transform: none;
}

.glance-quick-links small {
    color: var(--glance-muted);
    letter-spacing: 0;
    hyphens: none;
    line-height: 1.2;
    overflow-wrap: normal;
    word-break: normal;
}

.glance-footer {
    align-items: center;
    border-top: 1px solid rgba(255, 255, 255, .08);
    color: var(--glance-muted);
    display: flex;
    gap: 18px;
    justify-content: center;
    margin: 0 -20px;
    min-height: 44px;
    padding: 10px 20px;
}

.glance-footer span:first-child {
    color: #c6cbd4;
    font-weight: 850;
}

@media (max-width: 1100px) {
    .glance-topbar,
    .glance-command-panel,
    .glance-primary-grid,
    .glance-live-grid,
    .glance-bottom-grid {
        grid-template-columns: 1fr;
    }

    .glance-play-window-summary,
    .glance-play-now-facts,
    .glance-play-window-map-grid {
        grid-template-columns: 1fr;
    }

    .glance-play-window-actions {
        justify-content: flex-start;
    }

    .glance-connect-command {
        max-width: 100%;
        width: 100%;
    }

    .glance-brand-link,
    .glance-nav-shell,
    .glance-account-bar,
    .glance-command-panel .glance-join-button {
        grid-column: 1;
        grid-row: auto;
        justify-self: stretch;
    }

    .glance-brand-link {
        justify-content: center;
    }

    .glance-account-bar {
        justify-content: center;
    }

    .glance-command-panel {
        align-items: stretch;
    }

    .glance-address-card {
        grid-template-columns: auto minmax(0, 1fr) auto;
    }

    .glance-command-meta {
        border-left: 0;
        border-top: 1px solid rgba(255, 255, 255, .12);
        justify-content: space-between;
        padding-left: 0;
        padding-top: 12px;
    }

    .glance-award-grid,
    .glance-snapshot-grid,
    .glance-quick-links {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .glance-award-grid {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }

    .glance-snapshot-grid > *:nth-child(3) {
        border-right: 0;
    }
}

@media (max-width: 767px) {
    .server-glance-dashboard {
        margin: 0;
        padding: 12px 10px 0;
    }

    .glance-brand-link {
        min-height: 92px;
    }

    .glance-brand-logo {
        height: 92px;
        width: min(280px, 100%);
    }

    .glance-account-bar {
        align-items: stretch;
        flex-direction: column;
    }

    .glance-nav-shell,
    .glance-nav-shell .public-stats-subnav,
    .glance-nav-shell .public-stats-subnav-list {
        width: 100%;
    }

    .theme-toggle-landing,
    .theme-toggle-landing .theme-toggle-select,
    .glance-account-bar .btn,
    .glance-auth-form,
    .glance-auth-form .btn {
        width: 100%;
    }

    .glance-nav-shell .public-stats-subnav-toggle {
        background: transparent;
        border: 0;
        color: #fff;
        display: flex;
    }

    .glance-nav-shell .public-stats-subnav-list {
        display: none;
        grid-template-columns: 1fr 1fr;
        min-width: 0;
        white-space: normal;
    }

    .glance-nav-shell .public-stats-subnav.is-open .public-stats-subnav-list {
        display: grid;
    }

    .glance-nav-shell .public-stats-subnav a,
    .glance-nav-shell .public-stats-more-toggle {
        border-left: 0;
        min-height: 42px;
        white-space: normal;
    }

    .public-stats-more,
    .public-stats-more-toggle {
        width: 100%;
    }

    .public-stats-more-menu {
        position: static !important;
        transform: none !important;
        width: 100%;
    }

    .glance-address-card {
        align-items: flex-start;
        grid-template-columns: 1fr;
    }

    .glance-address-card strong {
        font-size: 1.05rem;
    }

    .server-glance-dashboard {
        --home-map-media-height: 190px;
    }

    .glance-award-grid,
    .glance-total-list,
    .glance-round-card-grid,
    .glance-snapshot-grid,
    .glance-quick-links {
        grid-template-columns: 1fr 1fr;
    }

    .glance-snapshot-grid > * {
        border-bottom: 1px solid rgba(255, 255, 255, .09);
    }

    .glance-snapshot-grid > *:nth-child(2n) {
        border-right: 0;
    }
}

@media (max-width: 520px) {
    .glance-award-grid,
    .glance-total-list,
    .glance-round-card-grid,
    .glance-snapshot-grid,
    .glance-quick-links {
        grid-template-columns: 1fr;
    }

    .glance-snapshot-grid > * {
        border-right: 0;
    }

    .glance-footer {
        align-items: center;
        flex-direction: column;
        gap: 4px;
        text-align: center;
    }
}

/* Empire CTF icon system */
:root {
    --empire-gold: #f0c020;
    --empire-gold-deep: #d09010;
    --empire-red: #f01010;
    --empire-red-deep: #c00000;
    --empire-green: #49e66f;
    --empire-ink: #dde3ea;
    --empire-muted: #9aa6b2;
}

.empire-icon {
    color: currentColor;
    display: inline-block;
    flex: 0 0 auto;
    height: var(--empire-icon-size, 1.125rem);
    vertical-align: -.15em;
    width: var(--empire-icon-size, 1.125rem);
}

.empire-icon--nav { --empire-icon-size: 18px; color: var(--empire-gold); }
.empire-icon--panel { --empire-icon-size: 20px; color: var(--empire-gold); }
.empire-icon--stat { --empire-icon-size: 30px; color: var(--empire-gold); }
.empire-icon--button { --empire-icon-size: 18px; }
.empire-icon--danger,
.empire-icon--red { color: var(--empire-red); }
.empire-icon--success,
.empire-icon--green { color: var(--empire-green); }
.empire-icon--muted { color: var(--empire-muted); }
.empire-icon--gold { color: var(--empire-gold); }
.empire-icon--blue { color: var(--glance-blue, #4c8dff); }

.public-stats-subnav-toggle > span,
.public-stats-subnav a,
.public-stats-more-toggle,
.glance-address-card span,
.glance-command-meta span,
.glance-map-metrics span,
.glance-status-list span,
.glance-snapshot-grid span,
.glance-panel-heading h2,
.glance-panel-heading a,
.glance-panel-link {
    align-items: center;
    display: inline-flex;
    gap: 8px;
}

.public-stats-subnav a span,
.public-stats-more-toggle span,
.glance-account-bar .btn span,
.glance-command-panel .btn span {
    min-width: 0;
}

.server-glance-dashboard .btn,
.glance-join-button {
    align-items: center;
    display: inline-flex;
    gap: 8px;
    justify-content: center;
}

.glance-map-panel {
    isolation: isolate;
    position: relative;
}

.glance-map-tile-link {
    border-radius: inherit;
    inset: 0;
    position: absolute;
    z-index: 4;
}

.glance-map-tile-link:focus-visible {
    box-shadow: 0 0 0 .2rem rgba(247, 185, 34, .28);
    outline: 2px solid var(--glance-gold);
    outline-offset: -3px;
}

.glance-map-panel:hover {
    border-color: rgba(247, 185, 34, .42);
}

.glance-map-panel:hover .glance-map-art img {
    filter: saturate(1) contrast(1.12) brightness(.86);
    transform: scale(1.015);
}

.glance-map-art img {
    transition: filter .18s ease, transform .18s ease;
}

.glance-quick-links a {
    align-items: center;
    display: flex;
    flex-direction: column;
    gap: 7px;
    justify-content: center;
}

.glance-quick-links a:hover .empire-icon,
.glance-panel-heading a:hover .empire-icon,
.glance-panel-link:hover .empire-icon {
    color: #fff;
}

.glance-footer .empire-icon {
    --empire-icon-size: 20px;
}

/* Unified Empire CTF public header */
.public-server-header {
    --glance-bg: #05080c;
    --glance-panel: rgba(11, 16, 22, .96);
    --glance-panel-soft: rgba(16, 22, 30, .9);
    --glance-line: rgba(198, 213, 235, .18);
    --glance-line-soft: rgba(198, 213, 235, .1);
    --glance-gold: #f7b922;
    --glance-red: #d71924;
    --glance-red-deep: #8e1118;
    --glance-green: #54e56b;
    --glance-blue: #4c8dff;
    --glance-muted: #9aa3b2;
    --glance-text: #f7f8fb;
    color: var(--glance-text);
    display: grid;
    font-family: "Rajdhani", "Bahnschrift", "Agency FB", "Segoe UI", sans-serif;
    gap: 14px;
    letter-spacing: .02em;
    margin: 0 auto 22px;
    max-width: 1640px;
    position: relative;
    z-index: 2;
}

.server-glance-dashboard > .public-server-header {
    margin: 0;
    max-width: none;
}

.public-main > .public-server-header {
    margin-left: 0;
    margin-right: 0;
    max-width: none;
    width: 100%;
    overflow-x: hidden;
    min-width: 0;
}

.public-server-header .glance-topbar {
    --public-header-logo-width: clamp(250px, 14.5vw, 280px);
    --public-header-logo-height: clamp(76px, 4.4vw, 84px);
    height: auto;
    align-items: center;
    min-height: 0;
    background:
        linear-gradient(90deg, rgba(5, 9, 14, .96), rgba(13, 18, 26, .92)),
        radial-gradient(circle at 82% 0, rgba(215, 25, 36, .14), transparent 22rem);
    border: 1px solid var(--glance-line);
    border-radius: 8px;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .045), 0 14px 34px rgba(0, 0, 0, .24);
    display: grid;
    column-gap: 1.5rem;
    grid-template-columns: var(--public-header-logo-width) minmax(0, 1fr) auto;
    gap: 14px;
    padding-block: 1rem;
    padding-inline: 1rem;
}

.public-server-header .glance-brand-link {
    grid-column: 1;
    align-items: center;
    grid-row: 1;
    min-height: 0;
    flex: 0 0 auto;
    width: var(--public-header-logo-width);
    min-height: var(--public-header-logo-height);
    justify-content: flex-start;
}

.public-server-header .glance-brand-logo {
    display: block;
    height: auto;
    max-height: var(--public-header-logo-height);
    object-fit: contain;
    object-position: center;
    width: min(var(--public-header-logo-width), 100%);
}

.public-server-header .glance-brand-logo-fallback {
    width: 96px;
}

.public-server-header .glance-nav-shell {
    grid-column: 2;
    grid-row: 1;
    display: flex;
    justify-content: center;
    justify-self: stretch;
    max-width: 100%;
    min-width: 0;
    width: 100%;
}

.glance-header-play-status {
    align-items: center;
    align-self: center;
    background: rgba(255, 255, 255, .045);
    border: 1px solid rgba(255, 255, 255, .12);
    border-radius: 999px;
    color: #f7f8fb;
    display: inline-flex;
    font-size: .86rem;
    font-weight: 850;
    gap: 8px;
    grid-column: 3;
    grid-row: 1;
    justify-self: end;
    line-height: 1;
    max-width: min(28vw, 260px);
    min-height: 36px;
    min-width: 0;
    padding: 0 12px;
    text-decoration: none;
    white-space: nowrap;
}

.glance-header-play-status:hover,
.glance-header-play-status:focus-visible {
    background: rgba(247, 185, 34, .12);
    border-color: rgba(247, 185, 34, .42);
    color: #fff;
}

.glance-header-play-status .glance-status-light {
    background: currentColor;
    border-radius: 999px;
    box-shadow: 0 0 10px currentColor;
    flex: 0 0 auto;
    height: 8px;
    width: 8px;
}

.glance-header-play-status span:last-child {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
}

.glance-header-play-status.status-ok {
    border-color: rgba(84, 229, 107, .36);
    color: var(--glance-green);
}

.glance-header-play-status.status-warn {
    border-color: rgba(247, 185, 34, .38);
    color: var(--glance-gold);
}

.glance-header-play-status.status-info {
    border-color: rgba(76, 141, 255, .34);
    color: #9ebdff;
}

.public-server-header .glance-nav-shell .public-stats-subnav,
.public-server-header .glance-nav-shell .public-stats-subnav-list {
    min-width: 0;
    width: fit-content;
    max-width: 100%;
}

.public-server-header .glance-nav-shell .public-stats-subnav-list {
    flex-wrap: wrap;
    justify-content: center;
    min-width: 0;
    overflow-x: auto;
    overscroll-behavior-x: contain;
    scrollbar-width: thin;
}

.public-server-header .glance-nav-shell .public-stats-subnav a,
.public-server-header .glance-nav-shell .public-stats-nav-button,
.public-server-header .glance-nav-shell .public-stats-subnav-button {
    align-items: center;
    background: transparent;
    border: 0;
    border-left: 1px solid rgba(255, 255, 255, .075);
    border-radius: 0;
    color: #dce2ee;
    display: inline-flex;
    font-size: .88rem;
    font-weight: 800;
    gap: 8px;
    justify-content: center;
    min-height: 44px;
    padding: 0 15px;
    text-decoration: none;
    white-space: nowrap;
}

.public-server-header .glance-nav-shell .public-stats-subnav a:first-child {
    border-left: 0;
}

.public-server-header .glance-nav-shell .public-stats-subnav a:hover,
.public-server-header .glance-nav-shell .public-stats-subnav a.active,
.public-server-header .glance-nav-shell .public-stats-subnav-button:hover,
.public-server-header .glance-nav-shell .public-stats-subnav-button:focus-visible {
    background: linear-gradient(180deg, rgba(247, 185, 34, .16), rgba(247, 185, 34, .04));
    box-shadow: inset 0 -2px 0 var(--glance-gold);
    color: #fff;
}

.public-stats-subnav-divider {
    align-self: stretch;
    border-left: 1px solid rgba(255, 255, 255, .18);
    margin: 14px 8px;
    width: 1px;
}

.public-stats-subnav-form {
    display: inline-flex;
    margin: 0;
}

.public-stats-subnav-button {
    font-family: inherit;
}

.public-section-links {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: -4px 0 18px;
}

.public-section-links .btn {
    align-items: center;
    display: inline-flex;
    gap: 7px;
}

.utility-strip,
.public-server-utility.utility-strip {
    align-items: center;
    display: grid;
    grid-template-columns: minmax(0, max-content) minmax(0, 1fr) minmax(0, max-content);
    column-gap: 1rem;
    min-width: 0;
    padding: 12px 18px;
}

.utility-strip .glance-utility-group,
.public-server-utility.utility-strip .glance-utility-group {
    align-items: center;
    display: flex;
    flex-wrap: nowrap;
    gap: .75rem;
    min-width: 0;
}

.utility-strip .utility-left,
.public-server-utility.utility-strip .utility-left {
    grid-column: 1;
    justify-self: start;
    align-items: center;
    display: flex;
    gap: .75rem;
    flex-wrap: nowrap;
    min-width: max-content;
}

.utility-strip .utility-server,
.public-server-utility.utility-strip .utility-server {
    align-items: center;
    display: flex;
    gap: .75rem;
    flex: 0 0 auto;
    min-width: max-content;
}

.utility-strip .utility-server-icon,
.public-server-utility.utility-strip .utility-server-icon {
    flex: 0 0 auto;
}

.utility-strip .glance-status-chip,
.public-server-utility.utility-strip .glance-status-chip {
    align-items: center;
    display: inline-flex;
    gap: 8px;
    flex: 0 0 auto;
    min-width: max-content;
    white-space: nowrap;
}

.utility-strip .server-address,
.public-server-utility.utility-strip .server-address {
    flex: 0 0 auto;
}

.utility-strip .glance-status-address,
.public-server-utility.utility-strip .glance-status-address {
    color: #fff;
    font-size: 1.05rem;
    display: inline-block;
    flex: 0 0 auto;
    white-space: nowrap;
    min-width: max-content;
    overflow: visible;
}

.public-server-utility .glance-status-light {
    background: currentColor;
    border-radius: 999px;
    box-shadow: 0 0 12px currentColor;
    height: 10px;
    width: 10px;
}

.utility-strip .utility-actions,
.public-server-utility.utility-strip .utility-actions {
    grid-column: 2;
    width: fit-content;
    justify-self: center;
    display: flex;
    align-items: center;
    gap: .5rem;
    min-width: max-content;
    flex: 0 0 auto;
}

.public-server-utility .glance-command-actions {
    align-items: center;
    display: inline-flex;
    flex-wrap: nowrap;
    gap: 10px;
}

.utility-strip .glance-copy-feedback,
.public-server-utility.utility-strip .glance-copy-feedback {
    color: #dce2ee;
    display: inline-block;
    font-size: .78rem;
    line-height: 1;
    min-height: 1em;
    white-space: nowrap;
    flex: 0 0 auto;
}

.public-server-utility .glance-join-button {
    background: rgba(215, 25, 36, .08);
    border-color: rgba(215, 25, 36, .62);
    box-shadow: none;
    color: #ff454f;
    justify-self: auto;
    margin: 0;
    min-height: 40px;
    padding: 0 16px;
    width: auto;
}

.public-server-utility .glance-join-button:hover,
.public-server-utility .glance-join-button:focus-visible {
    background: rgba(215, 25, 36, .16);
    border-color: rgba(255, 69, 79, .86);
    color: #ff6870;
}

.public-server-utility .glance-join-button.is-copy-confirmed,
.public-server-utility .glance-copy-button.is-copy-confirmed {
    background: rgba(84, 229, 107, .14);
    border-color: rgba(84, 229, 107, .62);
    color: var(--glance-green);
}

.glance-discord-button {
    align-items: center;
    background: rgba(88, 101, 242, .12);
    border: 1px solid rgba(88, 101, 242, .58);
    border-radius: 5px;
    color: #7d89ff;
    display: inline-flex;
    font-size: .88rem;
    font-weight: 850;
    gap: 8px;
    justify-content: center;
    min-height: 40px;
    padding: 0 16px;
    text-transform: uppercase;
}

.glance-discord-button:hover,
.glance-discord-button:focus-visible {
    background: rgba(88, 101, 242, .2);
    border-color: rgba(125, 137, 255, .88);
    color: #9ba4ff;
}

.empire-icon--discord {
    --empire-icon-size: 20px;
}

.utility-strip .utility-meta,
.public-server-utility.utility-strip .utility-meta {
    grid-column: 3;
    justify-self: end;
    display: flex;
    align-items: center;
    gap: 1rem;
    min-width: max-content;
}

.utility-strip .glance-server-stats-group,
.public-server-utility.utility-strip .glance-server-stats-group {
    align-items: center;
    display: inline-flex;
    gap: 1rem;
    justify-content: flex-end;
    min-width: 0;
}

.public-server-utility .glance-command-meta {
    align-items: center;
    border-left: 0;
    display: inline-flex;
    justify-content: flex-start;
    flex: 0 1 auto;
    width: fit-content;
    min-width: 0;
    padding-left: 0;
}

.public-server-utility .utility-stat,
.public-server-utility .utility-map,
.public-server-utility .utility-actions,
.public-server-utility .utility-server,
.public-server-utility .utility-stats {
    min-width: max-content;
    flex: 0 0 auto;
}

.public-server-utility .glance-command-meta span {
    flex: 0 0 auto;
    display: inline-block;
    white-space: nowrap;
}

.public-server-utility .glance-command-meta strong {
    display: inline-block;
    font-size: .95rem;
    line-height: 1.1;
    flex: 0 1 auto;
    min-width: 0;
    white-space: nowrap;
}

.public-server-utility .utility-value {
    display: inline-block;
    max-width: 100%;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.public-server-utility .glance-command-meta-wide {
    flex: 0 1 auto;
    width: fit-content;
    max-width: clamp(180px, 22vw, 360px);
    min-width: 0;
}

.public-server-utility .glance-command-meta-wide strong,
.public-server-utility .glance-command-meta-wide .utility-value {
    width: fit-content;
    min-width: 0;
    max-width: 100%;
    word-break: normal;
    overflow: hidden;
    text-overflow: ellipsis;
}

@media (max-width: 1399px) {
    .public-server-header .public-server-utility.utility-strip {
        grid-template-columns: minmax(0, 1fr) auto;
        gap: .75rem;
    }

    .public-server-header .public-server-utility.utility-strip .utility-left,
    .public-server-header .public-server-utility.utility-strip .utility-actions,
    .public-server-header .public-server-utility.utility-strip .utility-meta {
        grid-row: auto;
        justify-self: stretch;
        min-width: 0;
        width: 100%;
    }

    .public-server-header .public-server-utility.utility-strip .utility-left {
        grid-column: 1;
    }

    .public-server-header .public-server-utility.utility-strip .utility-actions {
        grid-column: 2;
    }

    .public-server-header .public-server-utility.utility-strip .utility-meta {
        grid-column: 1 / -1;
    }

    .public-server-header .public-server-utility.utility-strip .utility-actions {
        justify-content: flex-end;
    }

    .public-server-header .public-server-utility.utility-strip .utility-meta {
        flex-wrap: wrap;
        justify-content: flex-start;
    }

    .utility-strip .glance-command-meta-wide,
    .public-server-utility.utility-strip .glance-command-meta-wide,
    .public-server-utility .glance-command-meta-wide {
        max-width: clamp(180px, 30vw, 320px);
    }
}

@media (max-width: 1024px) {
    .utility-strip,
    .public-server-utility.utility-strip {
        grid-template-columns: 1fr;
        gap: .75rem;
    }

    .utility-strip .utility-left,
    .utility-strip .utility-actions,
    .utility-strip .utility-meta,
    .public-server-utility.utility-strip .utility-left,
    .public-server-utility.utility-strip .utility-actions,
    .public-server-utility.utility-strip .utility-meta {
        width: 100%;
        justify-self: stretch;
    }

    .utility-strip .utility-actions,
    .public-server-utility.utility-strip .utility-actions {
        justify-content: center;
    }

    .utility-strip .utility-meta,
    .public-server-utility.utility-strip .utility-meta {
        justify-content: flex-start;
        gap: .75rem;
        flex-wrap: wrap;
    }

    .public-server-header .glance-topbar {
        grid-template-columns: minmax(0, 1fr) auto;
    }

    .public-server-header .glance-brand-link,
    .public-server-header .glance-nav-shell {
        grid-column: 1;
        grid-row: auto;
        justify-self: stretch;
        width: 100%;
    }

    .public-server-header .glance-brand-link {
        justify-content: flex-start;
    }

    .public-server-header .glance-nav-shell {
        grid-column: 1 / -1;
    }

    .glance-header-play-status {
        grid-column: 2;
        max-width: min(42vw, 240px);
    }

    .public-server-header .glance-nav-shell .public-stats-subnav-list {
        justify-content: flex-start;
        overflow-x: auto;
    }
}

@media (max-width: 768px) {
    .public-server-header .glance-topbar,
    .public-server-header .utility-strip,
    .public-server-header .public-server-utility.utility-strip {
        padding: 12px;
    }

    .public-server-header .glance-topbar {
        --public-header-logo-width: clamp(170px, 44vw, 210px);
        --public-header-logo-height: clamp(60px, 16vw, 76px);
    }

    .public-server-header .glance-brand-link {
        min-height: 0;
    }

    .public-server-header .glance-brand-logo {
        height: var(--public-header-logo-height);
        width: var(--public-header-logo-width);
    }

    .glance-header-play-status {
        font-size: .78rem;
        min-height: 34px;
        padding: 0 10px;
    }

    .public-server-header .glance-nav-shell .public-stats-subnav {
        width: 100%;
    }

    .public-server-header .glance-nav-shell .public-stats-subnav-list {
        display: none;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        min-width: 0;
        white-space: normal;
        width: 100%;
    }

    .public-server-header .glance-nav-shell .public-stats-subnav.is-open .public-stats-subnav-list {
        display: grid;
    }

    .public-server-header .glance-nav-shell .public-stats-subnav a,
    .public-server-header .glance-nav-shell .public-stats-subnav-button {
        border-left: 0;
        min-height: 42px;
        white-space: normal;
    }

    .public-server-header .public-stats-subnav-divider {
        display: none;
    }

    .public-server-header .public-stats-subnav-form,
    .public-server-header .public-stats-subnav-button,
    .public-server-header .glance-discord-button,
    .public-server-utility .glance-join-button {
        width: 100%;
    }

    .public-server-utility.utility-strip .utility-meta {
        white-space: nowrap;
    }

    .public-server-utility.utility-strip .glance-command-actions {
        display: grid;
        grid-template-columns: 1fr;
        width: 100%;
    }

    .public-server-utility.utility-strip .glance-command-meta {
        flex-wrap: nowrap;
        width: auto;
    }

    .public-server-utility.utility-strip .glance-command-meta span,
    .public-server-utility.utility-strip .glance-command-meta strong,
    .public-server-utility.utility-strip .utility-value {
        white-space: nowrap;
    }

    .public-server-utility.utility-strip .glance-server-stats-group {
        width: 100%;
        align-items: flex-start;
        display: flex;
        flex-wrap: wrap;
        gap: .75rem;
    }

    .public-server-utility.utility-strip .glance-command-meta-wide {
        max-width: min(100%, 320px);
    }
}

@media (max-width: 480px) {
    .public-server-header .glance-nav-shell .public-stats-subnav-list,
    .public-server-utility .glance-command-actions {
        grid-template-columns: 1fr;
    }

    .glance-header-play-status {
        max-width: 44vw;
    }

    .glance-header-play-status .empire-icon {
        display: none;
    }

    .public-server-utility .glance-server-stats-group {
        flex-direction: column;
        align-items: flex-start;
    }

    .glance-play-roster-heading {
        align-items: flex-start;
        flex-direction: column;
    }
}

@media (max-width: 768px) {
    html,
    body {
        max-width: 100%;
        overflow-x: hidden;
        width: 100%;
    }

    body,
    main,
    .public-main,
    .public-landing-main,
    .server-glance-dashboard,
    .glance-dashboard-shell,
    .public-server-header,
    .glance-primary-grid,
    .glance-live-grid,
    .glance-bottom-grid {
        display: block;
        max-width: 100%;
        opacity: 1;
        transform: none;
        visibility: visible;
    }

    .server-glance-dashboard,
    .glance-dashboard-shell {
        margin-left: 0;
        margin-right: 0;
        min-height: 0;
        overflow-x: hidden;
        overflow-y: visible;
        width: 100%;
    }

    .server-glance-dashboard > * {
        animation: none;
        opacity: 1;
        transform: none;
    }

    .public-server-header,
    .public-server-header .glance-topbar,
    .public-server-header .utility-strip,
    .public-server-header .public-server-utility.utility-strip,
    .glance-primary-grid,
    .glance-play-window-panel,
    .glance-current-map,
    .glance-next-map,
    .glance-connected-panel {
        inset: auto;
        height: auto;
        max-width: 100%;
        min-height: 0;
        position: relative;
        z-index: auto;
    }

    .public-server-header,
    .public-server-header .glance-topbar {
        overflow: visible;
    }

    .public-main > .public-server-header {
        overflow: visible;
    }

    .public-server-header .glance-nav-shell,
    .glance-nav-shell {
        max-width: 100%;
        overflow-x: auto;
        overflow-y: hidden;
        scrollbar-width: thin;
        width: 100%;
        -webkit-overflow-scrolling: touch;
    }

    .public-server-header .glance-nav-shell .public-stats-subnav,
    .glance-nav-shell .public-stats-subnav {
        max-width: 100%;
        overflow: visible;
        width: 100%;
    }

    .public-server-header .glance-nav-shell .public-stats-subnav-toggle,
    .glance-nav-shell .public-stats-subnav-toggle {
        display: flex;
    }

    .public-server-header .glance-nav-shell .public-stats-subnav-list,
    .glance-nav-shell .public-stats-subnav-list {
        display: none;
        min-width: 0;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        overflow: visible;
        white-space: normal;
        width: 100%;
    }

    .public-server-header .glance-nav-shell .public-stats-subnav.is-open .public-stats-subnav-list,
    .glance-nav-shell .public-stats-subnav.is-open .public-stats-subnav-list {
        display: grid;
    }

    .public-server-header .glance-nav-shell .public-stats-subnav a,
    .public-server-header .glance-nav-shell .public-stats-subnav-button,
    .glance-nav-shell .public-stats-subnav a,
    .glance-nav-shell .public-stats-more-toggle {
        flex: 1 1 auto;
        white-space: normal;
        word-break: normal;
    }

    .public-server-header .public-server-utility.utility-strip,
    .utility-strip {
        align-items: stretch;
        display: grid;
        gap: .75rem;
        grid-template-columns: 1fr;
        height: auto;
    }

    .public-server-utility.utility-strip .utility-left,
    .public-server-utility.utility-strip .utility-actions,
    .public-server-utility.utility-strip .utility-meta,
    .utility-strip .utility-left,
    .utility-strip .utility-actions,
    .utility-strip .utility-meta {
        display: flex;
        flex: 1 1 auto;
        min-width: 0;
        width: 100%;
    }

    .public-server-utility.utility-strip .utility-left,
    .utility-strip .utility-left {
        align-items: center;
        flex-wrap: nowrap;
        justify-content: flex-start;
    }

    .public-server-utility.utility-strip .utility-actions,
    .utility-strip .utility-actions {
        align-items: stretch;
        flex-wrap: wrap;
        justify-content: stretch;
    }

    .public-server-utility.utility-strip .utility-meta,
    .utility-strip .utility-meta {
        align-items: flex-start;
        flex-wrap: wrap;
        justify-content: flex-start;
    }

    .public-server-utility.utility-strip .glance-server-stats-group,
    .utility-strip .glance-server-stats-group {
        display: flex;
        flex-wrap: wrap;
        gap: .75rem;
        max-width: 100%;
        min-width: 0;
        width: 100%;
    }

    .public-server-utility .utility-server,
    .public-server-utility .utility-actions,
    .public-server-utility .utility-stats,
    .public-server-utility .utility-stat,
    .public-server-utility .utility-map,
    .public-server-utility.utility-strip .glance-command-meta,
    .public-server-utility.utility-strip .glance-command-meta-wide {
        flex: 0 1 auto;
        max-width: 100%;
        min-width: 0;
        width: auto;
    }

    .public-server-utility .glance-command-actions {
        display: grid;
        grid-template-columns: 1fr;
        width: 100%;
    }

    .public-server-utility.utility-strip > .glance-utility-group,
    .utility-strip > .glance-utility-group {
        grid-column: auto;
        justify-self: stretch;
        max-width: 100%;
        min-width: 0;
        width: 100%;
    }

    .public-server-utility.utility-strip > .utility-left,
    .public-server-utility.utility-strip > .utility-actions,
    .public-server-utility.utility-strip > .utility-meta,
    .utility-strip > .utility-left,
    .utility-strip > .utility-actions,
    .utility-strip > .utility-meta {
        flex: 1 1 auto;
        width: 100%;
    }

    .public-server-utility .glance-status-address,
    .public-server-utility .server-address,
    .public-server-utility .glance-command-meta span,
    .public-server-utility .glance-command-meta strong,
    .public-server-utility .utility-value {
        min-width: 0;
        overflow-wrap: normal;
        white-space: nowrap;
        word-break: normal;
    }

    .public-server-utility .glance-status-address,
    .public-server-utility .utility-value {
        max-width: 100%;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    .glance-primary-grid {
        display: grid;
        gap: 1rem;
        grid-template-columns: 1fr;
    }

    .glance-map-metrics {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .glance-map-metrics > div:nth-child(2n) {
        border-right: 0;
    }

    .glance-play-window-panel { order: 1; }
    .glance-current-map { order: 1; }
    .glance-next-map { order: 2; }
    .glance-connected-panel { order: 2; }

    .glance-live-grid,
    .glance-award-grid,
    .glance-bottom-grid,
    .glance-round-card-grid,
    .glance-snapshot-grid,
    .glance-quick-links {
        display: grid;
        grid-template-columns: 1fr;
    }

    .glance-connected-table th:nth-child(4),
    .glance-connected-table td:nth-child(4),
    .glance-events-panel-compact .glance-feed-table th:nth-child(5),
    .glance-events-panel-compact .glance-feed-table td:nth-child(5) {
        display: none;
    }

    .glance-feed-action .status-badge {
        display: none;
    }
}

/* Unified public content theme, scoped away from the landing dashboard and admin shell. */
.public-shell .public-main:not(.public-landing-main) {
    --public-content-max: 1480px;
    --glance-bg: #05080c;
    --glance-panel: rgba(11, 16, 22, .96);
    --glance-panel-strong: rgba(17, 23, 32, .97);
    --glance-panel-soft: rgba(255, 255, 255, .035);
    --glance-line: rgba(198, 213, 235, .18);
    --glance-line-soft: rgba(198, 213, 235, .1);
    --glance-gold: #f7b922;
    --glance-red: #d71924;
    --glance-red-bright: #ff4750;
    --glance-green: #54e56b;
    --glance-blue: #4c8dff;
    --glance-warn: #ffcc55;
    --glance-muted: #9aa3b2;
    --glance-text: #f7f8fb;
    --portal-link: var(--glance-gold);
    background:
        linear-gradient(rgba(255, 255, 255, .018) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 255, 255, .014) 1px, transparent 1px),
        linear-gradient(180deg, #05080c 0, #070b11 44%, #080d13 100%);
    background-size: 56px 56px, 56px 56px, auto;
    color: var(--glance-text);
    font-family: "Rajdhani", "Bahnschrift", "Agency FB", "Segoe UI", sans-serif;
    max-width: none;
    min-height: 100vh;
    padding: 24px 20px 56px;
}

.public-shell .public-main:not(.public-landing-main) > :not(.public-server-header):not(script) {
    margin-left: auto;
    margin-right: auto;
    max-width: var(--public-content-max);
    min-width: 0;
    position: relative;
    z-index: 1;
}

.public-shell .public-main:not(.public-landing-main) > .row {
    width: 100%;
}

.public-shell .public-main:not(.public-landing-main) > .row + .row,
.public-shell .public-main:not(.public-landing-main) > .detail-section-grid + .portal-card,
.public-shell .public-main:not(.public-landing-main) > .portal-card + .portal-card {
    margin-top: 18px;
}

.public-shell .public-main:not(.public-landing-main) a {
    color: var(--glance-gold);
}

.public-shell .public-main:not(.public-landing-main) a:hover,
.public-shell .public-main:not(.public-landing-main) a:focus {
    color: #ffe08a;
}

.public-shell .public-main:not(.public-landing-main) .public-dossier-crumb {
    align-items: center;
    background: rgba(5, 8, 12, .84);
    border: 1px solid var(--glance-line-soft);
    border-radius: 8px;
    display: flex;
    gap: 18px;
    justify-content: space-between;
    margin-bottom: 18px;
    min-height: 52px;
    padding: 12px 18px;
}

.public-shell .public-main:not(.public-landing-main) .public-dossier-crumb div {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    min-width: 0;
}

.public-shell .public-main:not(.public-landing-main) .public-dossier-crumb span:first-child,
.public-shell .public-main:not(.public-landing-main) .public-dossier-crumb a {
    color: var(--glance-gold);
    font-weight: 950;
    text-decoration: none;
}

.public-shell .public-main:not(.public-landing-main) .public-dossier-crumb span[aria-hidden="true"] {
    color: #d9dfec;
    font-weight: 900;
}

.public-shell .public-main:not(.public-landing-main) .public-dossier-crumb strong {
    color: #fff;
    font-weight: 950;
    overflow-wrap: anywhere;
}

.public-shell .public-main:not(.public-landing-main) .public-page-header.public-dossier-hero {
    background:
        radial-gradient(circle at 12% 8%, rgba(247, 185, 34, .16), transparent 34%),
        linear-gradient(90deg, rgba(11, 14, 11, .98) 0%, rgba(31, 30, 10, .94) 48%, rgba(10, 11, 8, .98) 100%);
    border: 1px solid var(--glance-line-soft);
    border-radius: 8px;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .045), 0 18px 42px rgba(0, 0, 0, .34);
    display: grid;
    gap: 26px;
    grid-template-columns: minmax(0, 1fr) minmax(320px, .36fr);
    margin-bottom: 18px;
    overflow: hidden;
    padding: 38px 44px;
}

.public-shell .public-main:not(.public-landing-main) .public-dossier-hero.is-red {
    background:
        radial-gradient(circle at 12% 8%, rgba(255, 71, 80, .16), transparent 34%),
        linear-gradient(90deg, rgba(15, 10, 11, .98) 0%, rgba(38, 14, 17, .92) 44%, rgba(12, 10, 8, .98) 100%);
}

.public-shell .public-main:not(.public-landing-main) .public-dossier-hero.is-blue {
    background:
        radial-gradient(circle at 12% 8%, rgba(76, 141, 255, .18), transparent 34%),
        linear-gradient(90deg, rgba(9, 12, 18, .98) 0%, rgba(16, 26, 43, .94) 48%, rgba(10, 11, 8, .98) 100%);
}

.public-shell .public-main:not(.public-landing-main) .public-dossier-hero.is-green {
    background:
        radial-gradient(circle at 12% 8%, rgba(84, 229, 107, .14), transparent 34%),
        linear-gradient(90deg, rgba(8, 13, 10, .98) 0%, rgba(13, 34, 19, .92) 44%, rgba(10, 11, 8, .98) 100%);
}

.public-shell .public-main:not(.public-landing-main) .public-dossier-hero.is-orange {
    background:
        radial-gradient(circle at 12% 8%, rgba(255, 159, 41, .17), transparent 34%),
        linear-gradient(90deg, rgba(15, 11, 8, .98) 0%, rgba(39, 24, 9, .94) 48%, rgba(10, 11, 8, .98) 100%);
}

.public-shell .public-main:not(.public-landing-main) .public-dossier-identity {
    align-items: center;
    display: grid;
    gap: 26px;
    grid-template-columns: 148px minmax(0, 1fr);
    min-width: 0;
}

.public-shell .public-main:not(.public-landing-main) .public-dossier-emblem {
    align-items: center;
    background:
        linear-gradient(180deg, rgba(247, 185, 34, .18), rgba(215, 25, 36, .08)),
        rgba(255, 255, 255, .035);
    border: 1px solid rgba(247, 185, 34, .28);
    border-radius: 8px;
    color: #fff;
    display: flex;
    height: 148px;
    justify-content: center;
    width: 148px;
}

.public-shell .public-main:not(.public-landing-main) .public-dossier-emblem .empire-icon {
    --empire-icon-size: 82px;
    color: var(--glance-gold);
    filter: drop-shadow(0 8px 18px rgba(247, 185, 34, .22));
}

.public-shell .public-main:not(.public-landing-main) .public-dossier-copy {
    min-width: 0;
}

.public-shell .public-main:not(.public-landing-main) .public-dossier-copy .eyebrow,
.public-shell .public-main:not(.public-landing-main) .public-dossier-callout span {
    color: var(--glance-gold) !important;
}

.public-shell .public-main:not(.public-landing-main) .public-dossier-copy h1,
.public-shell .public-main:not(.public-landing-main) .public-hero h1 {
    color: #fff;
    font-size: 4.65rem;
    font-weight: 950;
    letter-spacing: 0;
    line-height: .92;
    margin: 8px 0 16px;
    overflow-wrap: anywhere;
    text-shadow: 0 4px 18px rgba(0, 0, 0, .52);
}

.public-shell .public-main:not(.public-landing-main) .public-dossier-copy p,
.public-shell .public-main:not(.public-landing-main) .public-page-header-legacy p,
.public-shell .public-main:not(.public-landing-main) .public-hero p {
    color: #c5ccda;
    font-size: 1rem;
    line-height: 1.42;
    margin: 0;
    max-width: 760px;
}

.public-shell .public-main:not(.public-landing-main) .public-dossier-chips {
    gap: 10px;
    margin-top: 16px;
}

.public-shell .public-main:not(.public-landing-main) .public-dossier-callout {
    align-self: center;
    background:
        linear-gradient(180deg, rgba(247, 185, 34, .14), rgba(247, 185, 34, .035)),
        rgba(12, 10, 4, .72);
    border: 1px solid rgba(247, 185, 34, .28);
    border-radius: 8px;
    box-shadow: 0 18px 36px rgba(0, 0, 0, .28);
    display: grid;
    gap: 14px;
    grid-template-columns: auto minmax(0, 1fr);
    padding: 20px;
}

.public-shell .public-main:not(.public-landing-main) .public-dossier-callout-icon {
    --empire-icon-size: 54px;
    color: #fff;
    filter: drop-shadow(0 7px 16px rgba(247, 185, 34, .24));
    grid-row: span 2;
}

.public-shell .public-main:not(.public-landing-main) .public-dossier-callout strong {
    color: var(--glance-gold);
    display: block;
    font-size: 1.75rem;
    font-weight: 950;
    line-height: 1.05;
    margin-top: 3px;
    overflow-wrap: anywhere;
}

.public-shell .public-main:not(.public-landing-main) .public-dossier-callout small {
    color: #c5ccda;
    display: block;
    font-weight: 850;
    margin-top: 7px;
}

.public-shell .public-main:not(.public-landing-main) .public-dossier-callout .btn {
    grid-column: 1 / -1;
}

.public-shell .public-main:not(.public-landing-main) .public-page-header-legacy,
.public-shell .public-main:not(.public-landing-main) .public-hero {
    align-items: flex-end;
    border-bottom: 1px solid var(--glance-line);
    display: flex;
    gap: 18px;
    justify-content: space-between;
    margin-bottom: 20px;
    padding: 8px 0 20px;
}

.public-shell .public-main:not(.public-landing-main) .public-page-header-legacy h1 {
    color: #fff;
    font-size: 3.2rem;
    font-weight: 900;
    letter-spacing: 0;
    line-height: .95;
    margin: 4px 0 8px;
    overflow-wrap: anywhere;
}

.public-shell .public-main:not(.public-landing-main) .eyebrow,
.public-shell .public-main:not(.public-landing-main) .metric-label,
.public-shell .public-main:not(.public-landing-main) .help-text,
.public-shell .public-main:not(.public-landing-main) .metric-subtext,
.public-shell .public-main:not(.public-landing-main) .text-muted {
    color: var(--glance-muted) !important;
}

.public-shell .public-main:not(.public-landing-main) .eyebrow,
.public-shell .public-main:not(.public-landing-main) .metric-label {
    font-size: .76rem;
    font-weight: 850;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.public-shell .public-main:not(.public-landing-main) .metric-grid {
    gap: 14px;
    margin-bottom: 18px;
}

.public-shell .public-main:not(.public-landing-main) .metric-card {
    background:
        radial-gradient(circle at 0 0, rgba(247, 185, 34, .1), transparent 42%),
        linear-gradient(180deg, rgba(20, 22, 17, .96), rgba(8, 10, 9, .98));
    border: 1px solid var(--glance-line);
    border-radius: 8px;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .045), 0 14px 34px rgba(0, 0, 0, .3);
    min-height: 140px;
    overflow: hidden;
    padding: 24px 20px 18px;
    position: relative;
}

.public-shell .public-main:not(.public-landing-main) .metric-card::before {
    background: linear-gradient(90deg, var(--glance-red), var(--glance-gold));
    content: "";
    height: 3px;
    inset: 0 0 auto 0;
    position: absolute;
}

.public-shell .public-main:not(.public-landing-main) .metric-value {
    color: #fff;
    font-size: 2.55rem;
    font-weight: 950;
    line-height: 1;
    margin-top: 10px;
    overflow-wrap: anywhere;
}

@media (max-width: 1180px) {
    .public-shell .public-main:not(.public-landing-main) .public-page-header.public-dossier-hero {
        grid-template-columns: minmax(0, 1fr);
    }

    .public-shell .public-main:not(.public-landing-main) .public-dossier-copy h1 {
        font-size: 3.35rem;
    }
}

@media (max-width: 760px) {
    .public-shell .public-main:not(.public-landing-main) .public-dossier-crumb {
        align-items: flex-start;
        flex-direction: column;
        gap: 8px;
    }

    .public-shell .public-main:not(.public-landing-main) .public-page-header.public-dossier-hero {
        padding: 18px;
    }

    .public-shell .public-main:not(.public-landing-main) .public-dossier-identity {
        align-items: start;
        grid-template-columns: minmax(0, 1fr);
    }

    .public-shell .public-main:not(.public-landing-main) .public-dossier-emblem {
        height: 112px;
        width: 112px;
    }

    .public-shell .public-main:not(.public-landing-main) .public-dossier-emblem .empire-icon {
        --empire-icon-size: 62px;
    }

    .public-shell .public-main:not(.public-landing-main) .public-dossier-copy h1,
    .public-shell .public-main:not(.public-landing-main) .public-page-header-legacy h1 {
        font-size: 2.35rem;
    }

    .public-shell .public-main:not(.public-landing-main) .public-dossier-callout {
        grid-template-columns: minmax(0, 1fr);
    }

    .public-shell .public-main:not(.public-landing-main) .public-dossier-callout-icon {
        --empire-icon-size: 42px;
        grid-row: auto;
    }

    .public-shell .public-main:not(.public-landing-main) .metric-card {
        min-height: 118px;
    }

    .public-shell .public-main:not(.public-landing-main) .metric-value {
        font-size: 2rem;
    }
}

.public-shell .public-main:not(.public-landing-main) .portal-card {
    background: linear-gradient(180deg, rgba(17, 23, 32, .95), rgba(7, 11, 17, .96));
    border: 1px solid var(--glance-line);
    border-radius: 8px;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .045), 0 14px 34px rgba(0, 0, 0, .32);
    color: var(--glance-text);
    overflow: hidden;
}

.public-shell .public-main:not(.public-landing-main) .portal-card-header {
    align-items: center;
    background: linear-gradient(180deg, rgba(255, 255, 255, .035), rgba(255, 255, 255, .012));
    border-bottom: 1px solid var(--glance-line-soft);
    display: flex;
    gap: 12px;
    justify-content: space-between;
    min-height: 52px;
    padding: 13px 18px;
}

.public-shell .public-main:not(.public-landing-main) .portal-card-header h2,
.public-shell .public-main:not(.public-landing-main) .portal-card-header h3,
.public-shell .public-main:not(.public-landing-main) .detail-accordion-stack > h2 {
    color: var(--glance-gold);
    font-size: .92rem;
    font-weight: 900;
    letter-spacing: .04em;
    margin: 0;
    text-transform: uppercase;
}

.public-shell .public-main:not(.public-landing-main) .portal-card-body {
    padding: 18px;
}

.public-shell .public-main:not(.public-landing-main) .portal-card-body.border-top,
.public-shell .public-main:not(.public-landing-main) .border-top {
    border-top-color: var(--glance-line-soft) !important;
}

.public-shell .public-main:not(.public-landing-main) .status-badge {
    border: 1px solid currentColor;
    border-radius: 4px;
    display: inline-flex;
    font-size: .74rem;
    font-weight: 900;
    letter-spacing: .08em;
    line-height: 1.15;
    padding: 5px 8px;
    text-transform: uppercase;
    white-space: normal;
}

.public-shell .public-main:not(.public-landing-main) .status-ok {
    background: rgba(84, 229, 107, .12);
    color: var(--glance-green);
}

.public-shell .public-main:not(.public-landing-main) .status-error {
    background: rgba(215, 25, 36, .16);
    color: #ff626b;
}

.public-shell .public-main:not(.public-landing-main) .status-info {
    background: rgba(76, 141, 255, .14);
    color: #79b2ff;
}

.public-shell .public-main:not(.public-landing-main) .status-neutral {
    background: rgba(255, 255, 255, .055);
    color: #c7cfdd;
}

.public-shell .public-main:not(.public-landing-main) .status-warn {
    background: rgba(255, 204, 85, .14);
    color: var(--glance-warn);
}

.public-shell .public-main:not(.public-landing-main) .form-label {
    color: #d8deea;
    font-size: .82rem;
    font-weight: 800;
}

.public-shell .public-main:not(.public-landing-main) .form-control,
.public-shell .public-main:not(.public-landing-main) .form-select {
    background-color: rgba(255, 255, 255, .045);
    border-color: rgba(198, 213, 235, .2);
    color: #fff;
    min-height: 42px;
}

.public-shell .public-main:not(.public-landing-main) .form-control::placeholder {
    color: #737e90;
}

.public-shell .public-main:not(.public-landing-main) .form-control:focus,
.public-shell .public-main:not(.public-landing-main) .form-select:focus {
    background-color: rgba(255, 255, 255, .065);
    border-color: rgba(247, 185, 34, .72);
    box-shadow: 0 0 0 .18rem rgba(247, 185, 34, .16);
    color: #fff;
}

.public-shell .public-main:not(.public-landing-main) > :not(.public-server-header):not(script) .btn {
    align-items: center;
    border-radius: 5px;
    display: inline-flex;
    font-weight: 850;
    gap: 8px;
    justify-content: center;
    min-height: 38px;
}

.public-shell .public-main:not(.public-landing-main) > :not(.public-server-header):not(script) .btn-primary {
    background: linear-gradient(180deg, #e52a34, #991019);
    border-color: #ff3b45;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .22), 0 10px 24px rgba(215, 25, 36, .2);
    color: #fff;
}

.public-shell .public-main:not(.public-landing-main) > :not(.public-server-header):not(script) .btn-outline-primary,
.public-shell .public-main:not(.public-landing-main) > :not(.public-server-header):not(script) .btn-outline-secondary {
    background: rgba(255, 255, 255, .035);
    border-color: rgba(255, 255, 255, .2);
    color: #f4f6fb;
}

.public-shell .public-main:not(.public-landing-main) > :not(.public-server-header):not(script) .btn-outline-danger {
    background: rgba(215, 25, 36, .055);
    border-color: rgba(215, 25, 36, .55);
    color: #ff7178;
}

.public-shell .public-main:not(.public-landing-main) > :not(.public-server-header):not(script) .btn:hover,
.public-shell .public-main:not(.public-landing-main) > :not(.public-server-header):not(script) .btn:focus-visible {
    border-color: rgba(247, 185, 34, .76);
    color: #fff;
}

.public-shell .public-main:not(.public-landing-main) .public-section-links {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    margin: 0 auto 18px;
}

.public-shell .public-main:not(.public-landing-main) .public-section-links .btn {
    background: linear-gradient(180deg, rgba(255, 255, 255, .055), rgba(255, 255, 255, .018));
    justify-content: flex-start;
    min-height: 52px;
    padding: 0 14px;
}

.public-shell .public-main:not(.public-landing-main) .action-toolbar,
.public-shell .public-main:not(.public-landing-main) .filter-chips,
.public-shell .public-main:not(.public-landing-main) .badge-row {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.public-shell .public-main:not(.public-landing-main) .filter-chip {
    background: rgba(255, 255, 255, .045);
    border: 1px solid var(--glance-line);
    border-radius: 5px;
    color: #f4f6fb;
    font-weight: 800;
    padding: 6px 9px;
}

.public-shell .public-main:not(.public-landing-main) .table {
    --bs-table-bg: transparent;
    --bs-table-color: var(--glance-text);
    --bs-table-hover-bg: rgba(247, 185, 34, .06);
    --bs-table-hover-color: #fff;
    border-color: var(--glance-line-soft);
    color: var(--glance-text);
    margin-bottom: 0;
}

.public-shell .public-main:not(.public-landing-main) .table thead th {
    background: rgba(255, 255, 255, .035);
    border-bottom-color: var(--glance-line);
    color: var(--glance-muted);
    font-size: .72rem;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
    white-space: nowrap;
}

.public-shell .public-main:not(.public-landing-main) .table td,
.public-shell .public-main:not(.public-landing-main) .table th {
    border-color: var(--glance-line-soft);
    padding: .72rem .85rem;
    vertical-align: middle;
}

.public-shell .public-main:not(.public-landing-main) .player-matchups-table .player-detail-table {
    border-collapse: separate;
    border-spacing: 0;
}

.public-shell .public-main:not(.public-landing-main) .player-matchups-table .player-detail-table thead {
    background: #0c121b;
}

.public-shell .public-main:not(.public-landing-main) .player-matchups-table .player-detail-table thead th {
    background: #0c121b;
    background-color: #0c121b;
    box-shadow: 0 1px 0 rgba(255, 204, 0, .22), 0 10px 18px rgba(0, 0, 0, .3);
}

.public-shell .public-main:not(.public-landing-main) .table tbody tr:nth-child(odd) td {
    background: rgba(255, 255, 255, .018);
}

.public-shell .public-main:not(.public-landing-main) .table-responsive {
    scrollbar-color: rgba(247, 185, 34, .55) rgba(255, 255, 255, .05);
}

.public-shell .public-main:not(.public-landing-main) .list-group {
    --bs-list-group-bg: transparent;
    --bs-list-group-border-color: var(--glance-line-soft);
    --bs-list-group-color: var(--glance-text);
    --bs-list-group-action-color: var(--glance-text);
    --bs-list-group-action-hover-bg: rgba(247, 185, 34, .06);
    --bs-list-group-action-hover-color: #fff;
}

.public-shell .public-main:not(.public-landing-main) .list-group-item {
    background: transparent;
    border-color: var(--glance-line-soft);
    color: var(--glance-text);
}

.public-shell .public-main:not(.public-landing-main) .empty-state {
    background: rgba(255, 255, 255, .032);
    border: 1px solid var(--glance-line-soft);
    border-radius: 8px;
    color: var(--glance-muted);
    padding: 16px;
}

.public-shell .public-main:not(.public-landing-main) .play-window-index-section {
    margin-top: 18px;
}

.public-shell .public-main:not(.public-landing-main) .play-window-list-grid {
    display: grid;
    gap: 12px;
}

.public-shell .public-main:not(.public-landing-main) .play-window-card {
    align-items: stretch;
    background: rgba(255, 255, 255, .028);
    border: 1px solid var(--glance-line-soft);
    border-radius: 8px;
    display: grid;
    gap: 14px;
    grid-template-columns: minmax(0, 1fr) auto;
    padding: 15px;
}

.public-shell .public-main:not(.public-landing-main) .play-window-card-main {
    min-width: 0;
}

.public-shell .public-main:not(.public-landing-main) .play-window-card-title-row {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.public-shell .public-main:not(.public-landing-main) .play-window-card h3 {
    color: #fff;
    font-size: 1.05rem;
    font-weight: 900;
    letter-spacing: 0;
    line-height: 1.15;
    margin: 0;
    overflow-wrap: anywhere;
}

.public-shell .public-main:not(.public-landing-main) .play-window-card p {
    color: #c5ccda;
    line-height: 1.35;
    margin: 10px 0 0;
}

.public-shell .public-main:not(.public-landing-main) .play-window-card-facts {
    align-items: center;
    color: var(--glance-muted);
    display: flex;
    flex-wrap: wrap;
    gap: 8px 14px;
    margin-top: 12px;
}

.public-shell .public-main:not(.public-landing-main) .play-window-card-facts span {
    align-items: center;
    display: inline-flex;
    font-size: .82rem;
    font-weight: 800;
    gap: 6px;
    min-width: 0;
}

.public-shell .public-main:not(.public-landing-main) .play-window-card-actions {
    align-content: center;
    align-items: center;
    justify-content: flex-end;
    min-width: 210px;
}

.public-shell .public-main:not(.public-landing-main) .play-recruit-hero.play-server-hero {
    background:
        radial-gradient(circle at 12% 8%, rgba(247, 185, 34, .16), transparent 34%),
        linear-gradient(90deg, rgba(11, 14, 11, .98) 0%, rgba(31, 30, 10, .94) 48%, rgba(10, 11, 8, .98) 100%);
    border: 1px solid var(--glance-line-soft);
    border-radius: 8px;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .045), 0 18px 42px rgba(0, 0, 0, .34);
    color: var(--glance-text);
    display: grid;
    gap: 26px;
    margin-bottom: 18px;
    overflow: hidden;
    padding: 38px 44px 30px;
}

.public-shell .public-main:not(.public-landing-main) .play-server-top {
    align-items: center;
    display: grid;
    gap: 26px;
    grid-template-columns: 148px minmax(0, 1fr) minmax(330px, .38fr);
}

.public-shell .public-main:not(.public-landing-main) .play-server-map-tile {
    background:
        linear-gradient(180deg, rgba(247, 185, 34, .18), rgba(215, 25, 36, .08)),
        rgba(255, 255, 255, .035);
    border: 1px solid rgba(247, 185, 34, .28);
    border-radius: 8px;
    height: 148px;
    overflow: hidden;
    position: relative;
    width: 148px;
}

.public-shell .public-main:not(.public-landing-main) .play-server-map-tile img {
    height: 100%;
    object-fit: cover;
    width: 100%;
}

.public-shell .public-main:not(.public-landing-main) .play-server-map-tile::after {
    background: linear-gradient(180deg, transparent 26%, rgba(0, 0, 0, .62));
    content: "";
    inset: 0;
    position: absolute;
}

.public-shell .public-main:not(.public-landing-main) .play-server-map-tile .status-badge {
    bottom: 10px;
    left: 10px;
    position: absolute;
    right: 10px;
    z-index: 1;
}

.public-shell .public-main:not(.public-landing-main) .play-server-copy {
    min-width: 0;
}

.public-shell .public-main:not(.public-landing-main) .play-server-copy .eyebrow,
.public-shell .public-main:not(.public-landing-main) .play-connect-card span {
    color: var(--glance-gold) !important;
}

.public-shell .public-main:not(.public-landing-main) .play-server-copy h1 {
    color: #fff;
    font-size: 4.65rem;
    font-weight: 950;
    letter-spacing: 0;
    line-height: .92;
    margin: 8px 0 16px;
    overflow-wrap: anywhere;
    text-shadow: 0 4px 18px rgba(0, 0, 0, .52);
}

.public-shell .public-main:not(.public-landing-main) .play-server-lede {
    color: #c5ccda;
    font-size: 1rem;
    font-weight: 650;
    line-height: 1.45;
    margin: 0;
    max-width: 760px;
    overflow-wrap: anywhere;
}

.public-shell .public-main:not(.public-landing-main) .play-connect-card {
    align-self: center;
    background:
        linear-gradient(180deg, rgba(247, 185, 34, .14), rgba(247, 185, 34, .035)),
        rgba(12, 10, 4, .72);
    border: 1px solid rgba(247, 185, 34, .28);
    border-radius: 8px;
    box-shadow: 0 18px 36px rgba(0, 0, 0, .28);
    display: grid;
    gap: 14px;
    grid-template-columns: auto minmax(0, 1fr);
    padding: 20px;
}

.public-shell .public-main:not(.public-landing-main) .play-connect-card strong {
    color: var(--glance-gold);
    display: block;
    font-size: 1.35rem;
    font-weight: 950;
    line-height: 1.05;
    margin-top: 3px;
    overflow-wrap: anywhere;
}

.public-shell .public-main:not(.public-landing-main) .play-connect-card small {
    color: #c5ccda;
    display: block;
    font-weight: 850;
    margin-top: 7px;
}

.public-shell .public-main:not(.public-landing-main) .play-connect-actions {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    grid-column: 1 / -1;
}

.public-shell .public-main:not(.public-landing-main) .play-vote-button {
    background: linear-gradient(180deg, #ffd85a, var(--glance-gold));
    border: 1px solid rgba(255, 226, 115, .86);
    box-shadow: 0 10px 24px rgba(247, 185, 34, .22);
    color: #111722 !important;
    font-weight: 950;
}

.public-shell .public-main:not(.public-landing-main) .play-vote-button .empire-icon {
    color: #111722 !important;
}

.public-shell .public-main:not(.public-landing-main) .play-vote-button span {
    color: #111722 !important;
}

.public-shell .public-main:not(.public-landing-main) .play-vote-button:hover,
.public-shell .public-main:not(.public-landing-main) .play-vote-button:focus {
    background: #ffe07a;
    border-color: #fff0a7;
    color: #080b10;
}

.public-shell .public-main:not(.public-landing-main) .play-server-stat-strip {
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.public-shell .public-main:not(.public-landing-main) .play-server-stat {
    background:
        radial-gradient(circle at 0 0, rgba(247, 185, 34, .1), transparent 42%),
        linear-gradient(180deg, rgba(20, 22, 17, .96), rgba(8, 10, 9, .98));
    border: 1px solid var(--glance-line);
    border-radius: 8px;
    min-height: 140px;
    overflow: hidden;
    padding: 22px 18px 16px;
    position: relative;
}

.public-shell .public-main:not(.public-landing-main) .play-server-stat::before {
    background: linear-gradient(90deg, var(--glance-red), var(--glance-gold));
    content: "";
    height: 3px;
    inset: 0 0 auto 0;
    position: absolute;
}

.public-shell .public-main:not(.public-landing-main) .play-server-stat.is-blue::before { background: var(--glance-blue); }
.public-shell .public-main:not(.public-landing-main) .play-server-stat.is-gold::before { background: var(--glance-gold); }
.public-shell .public-main:not(.public-landing-main) .play-server-stat.is-orange::before { background: #b8740a; }

.public-shell .public-main:not(.public-landing-main) .play-server-stat .empire-icon {
    --empire-icon-size: 30px;
    color: var(--glance-gold);
    margin-bottom: 12px;
}

.public-shell .public-main:not(.public-landing-main) .play-server-stat span {
    color: var(--glance-gold);
    display: block;
    font-size: .78rem;
    font-weight: 950;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.public-shell .public-main:not(.public-landing-main) .play-server-stat strong {
    color: #fff;
    display: block;
    font-size: 1.35rem;
    font-weight: 950;
    line-height: 1.05;
    margin-top: 8px;
    overflow-wrap: anywhere;
}

.public-shell .public-main:not(.public-landing-main) .play-server-stat small {
    color: #aebbd0;
    display: block;
    font-weight: 750;
    margin-top: 8px;
    overflow-wrap: anywhere;
}

.public-shell .public-main:not(.public-landing-main) .play-featured-panel {
    margin-bottom: 18px;
}

.public-shell .public-main:not(.public-landing-main) .play-featured-window {
    align-items: center;
    display: grid;
    gap: 16px;
    grid-template-columns: minmax(0, 1fr) auto;
    padding: 16px;
}

.public-shell .public-main:not(.public-landing-main) .play-featured-window h3 {
    color: #fff;
    font-size: 1.25rem;
    font-weight: 950;
    margin: 0;
}

.public-shell .public-main:not(.public-landing-main) .play-featured-window p {
    color: #c5ccda;
    margin: 10px 0 0;
}

.public-shell .public-main:not(.public-landing-main) .play-empty-session {
    display: grid;
    gap: 5px;
    padding: 16px;
}

.public-shell .public-main:not(.public-landing-main) .play-empty-session strong {
    color: #fff;
    font-size: 1.08rem;
    font-weight: 950;
}

.public-shell .public-main:not(.public-landing-main) .play-empty-session span {
    color: var(--glance-muted);
}

.public-shell .public-main:not(.public-landing-main) .play-window-card {
    grid-template-columns: minmax(0, 1fr) auto auto;
}

.public-shell .public-main:not(.public-landing-main) .play-window-card-date {
    align-self: center;
    background: rgba(255, 255, 255, .04);
    border: 1px solid var(--glance-line-soft);
    border-radius: 7px;
    display: grid;
    gap: 2px;
    min-width: 96px;
    padding: 9px 11px;
    text-align: right;
}

.public-shell .public-main:not(.public-landing-main) .play-window-card-date span {
    color: var(--glance-muted);
    font-size: .72rem;
    font-weight: 900;
    text-transform: uppercase;
}

.public-shell .public-main:not(.public-landing-main) .play-window-card-date strong {
    color: #fff;
    font-weight: 950;
    white-space: nowrap;
}

.public-shell .public-main:not(.public-landing-main) .play-window-card-actions {
    min-width: 0;
}

.public-shell .public-main:not(.public-landing-main) .play-history-list {
    display: grid;
    gap: 10px;
}

.public-shell .public-main:not(.public-landing-main) .play-history-list a {
    align-items: center;
    display: flex;
    gap: 12px;
    justify-content: space-between;
    padding: 12px 14px;
    text-decoration: none;
}

.public-shell .public-main:not(.public-landing-main) .play-history-list a:hover {
    background: rgba(247, 185, 34, .075);
    border-color: rgba(247, 185, 34, .34);
    color: #fff;
}

.public-shell .public-main:not(.public-landing-main) .play-history-list span {
    color: #fff;
    font-weight: 900;
    min-width: 0;
    overflow-wrap: anywhere;
}

.public-shell .public-main:not(.public-landing-main) .play-history-list strong {
    color: var(--glance-muted);
    font-size: .86rem;
    text-align: right;
}

.public-shell .public-main:not(.public-landing-main) .play-window-emblem-tile {
    align-items: center;
    display: flex;
    justify-content: center;
}

.public-shell .public-main:not(.public-landing-main) .play-window-emblem-icon {
    --empire-icon-size: 74px;
    color: var(--glance-gold);
    filter: drop-shadow(0 12px 24px rgba(247, 185, 34, .24));
    position: relative;
    z-index: 1;
}

.public-shell .public-main:not(.public-landing-main) .play-explain-grid,
.public-shell .public-main:not(.public-landing-main) .play-conversion-grid {
    display: grid;
    gap: 14px;
    margin-bottom: 18px;
}

.public-shell .public-main:not(.public-landing-main) .play-explain-grid {
    grid-template-columns: minmax(0, 1.18fr) repeat(2, minmax(240px, .91fr));
}

.public-shell .public-main:not(.public-landing-main) .play-conversion-grid {
    align-items: start;
    grid-template-columns: minmax(0, 1.35fr) minmax(310px, .65fr);
}

.public-shell .public-main:not(.public-landing-main) .play-explain-card {
    background:
        radial-gradient(circle at 0 0, rgba(247, 185, 34, .1), transparent 44%),
        linear-gradient(180deg, rgba(17, 23, 32, .95), rgba(7, 11, 17, .98));
    border: 1px solid var(--glance-line);
    border-radius: 8px;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .04), 0 14px 34px rgba(0, 0, 0, .26);
    display: grid;
    gap: 12px;
    grid-template-columns: auto minmax(0, 1fr);
    min-width: 0;
    padding: 16px;
}

.public-shell .public-main:not(.public-landing-main) .play-explain-card.is-primary {
    background:
        linear-gradient(180deg, rgba(247, 185, 34, .13), rgba(247, 185, 34, .035)),
        linear-gradient(180deg, rgba(19, 18, 12, .96), rgba(8, 10, 9, .98));
    border-color: rgba(247, 185, 34, .28);
}

.public-shell .public-main:not(.public-landing-main) .play-explain-card > .empire-icon,
.public-shell .public-main:not(.public-landing-main) .play-reminder-copy > .empire-icon {
    --empire-icon-size: 34px;
    color: var(--glance-gold);
    filter: drop-shadow(0 8px 18px rgba(247, 185, 34, .2));
}

.public-shell .public-main:not(.public-landing-main) .play-explain-card span,
.public-shell .public-main:not(.public-landing-main) .play-reminder-copy span {
    color: var(--glance-gold);
    display: block;
    font-size: .74rem;
    font-weight: 950;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.public-shell .public-main:not(.public-landing-main) .play-explain-card strong,
.public-shell .public-main:not(.public-landing-main) .play-reminder-copy strong {
    color: #fff;
    display: block;
    font-size: 1.02rem;
    font-weight: 950;
    line-height: 1.15;
    margin-top: 4px;
    overflow-wrap: anywhere;
}

.public-shell .public-main:not(.public-landing-main) .play-explain-card p,
.public-shell .public-main:not(.public-landing-main) .play-panel-lede,
.public-shell .public-main:not(.public-landing-main) .play-reminder-copy p {
    color: #c5ccda;
    font-size: .9rem;
    font-weight: 650;
    line-height: 1.4;
    margin: 8px 0 0;
    overflow-wrap: anywhere;
}

.public-shell .public-main:not(.public-landing-main) .play-explain-actions {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 12px;
}

.public-shell .public-main:not(.public-landing-main) .play-reminder-copy {
    display: grid;
    gap: 12px;
    grid-template-columns: auto minmax(0, 1fr);
    min-width: 0;
}

.public-shell .public-main:not(.public-landing-main) .play-reminder-steps {
    display: grid;
    gap: 10px;
    margin-top: 16px;
}

.public-shell .public-main:not(.public-landing-main) .play-reminder-steps div {
    align-items: center;
    background: rgba(255, 255, 255, .032);
    border: 1px solid var(--glance-line-soft);
    border-radius: 7px;
    display: grid;
    gap: 10px;
    grid-template-columns: auto minmax(0, 1fr);
    padding: 10px;
}

.public-shell .public-main:not(.public-landing-main) .play-reminder-steps span {
    align-items: center;
    background: rgba(247, 185, 34, .12);
    border: 1px solid rgba(247, 185, 34, .28);
    border-radius: 999px;
    color: var(--glance-gold);
    display: inline-flex;
    font-size: .78rem;
    font-weight: 950;
    height: 28px;
    justify-content: center;
    width: 28px;
}

.public-shell .public-main:not(.public-landing-main) .play-reminder-steps strong {
    color: #fff;
    font-size: .9rem;
    font-weight: 850;
    line-height: 1.25;
    overflow-wrap: anywhere;
}

.public-shell .public-main:not(.public-landing-main) .play-time-form {
    min-width: 0;
}

.public-shell .public-main:not(.public-landing-main) .play-time-slot-grid {
    display: grid;
    gap: 10px;
}

.public-shell .public-main:not(.public-landing-main) .play-time-slot-card {
    align-items: center;
    background: rgba(255, 255, 255, .028);
    border: 1px solid var(--glance-line-soft);
    border-radius: 8px;
    color: var(--glance-text);
    cursor: pointer;
    display: grid;
    gap: 12px;
    grid-template-columns: auto minmax(0, 1fr) auto;
    min-width: 0;
    padding: 14px;
    transition: border-color .16s ease, background .16s ease;
}

.public-shell .public-main:not(.public-landing-main) .play-time-slot-card:hover,
.public-shell .public-main:not(.public-landing-main) .play-time-slot-card.is-selected {
    background: rgba(247, 185, 34, .07);
    border-color: rgba(247, 185, 34, .36);
}

.public-shell .public-main:not(.public-landing-main) .play-time-slot-card .form-check-input {
    height: 1.2rem;
    margin: 0;
    width: 1.2rem;
}

.public-shell .public-main:not(.public-landing-main) .play-time-slot-copy {
    display: grid;
    gap: 3px;
    min-width: 0;
}

.public-shell .public-main:not(.public-landing-main) .play-time-slot-copy strong {
    color: #fff;
    font-size: 1.02rem;
    font-weight: 950;
    overflow-wrap: anywhere;
}

.public-shell .public-main:not(.public-landing-main) .play-time-slot-copy small {
    color: var(--glance-muted);
    font-weight: 720;
    overflow-wrap: anywhere;
}

.public-shell .public-main:not(.public-landing-main) .play-window-card-actions .glance-plan-button,
.public-shell .public-main:not(.public-landing-main) .play-connect-actions .glance-plan-button,
.public-shell .public-main:not(.public-landing-main) .play-vote-panel .glance-plan-button {
    color: #111827 !important;
    min-height: 38px;
    padding: 0 14px;
}

.public-shell .public-main:not(.public-landing-main) .play-window-card-actions .glance-plan-button .empire-icon,
.public-shell .public-main:not(.public-landing-main) .play-connect-actions .glance-plan-button .empire-icon,
.public-shell .public-main:not(.public-landing-main) .play-vote-panel .glance-plan-button .empire-icon {
    color: #111827 !important;
}

@media (max-width: 1180px) {
    .public-shell .public-main:not(.public-landing-main) .play-server-copy h1 {
        font-size: 3.1rem;
    }

    .public-shell .public-main:not(.public-landing-main) .play-server-top {
        grid-template-columns: 128px minmax(0, 1fr);
    }

    .public-shell .public-main:not(.public-landing-main) .play-connect-card {
        grid-column: 1 / -1;
    }

    .public-shell .public-main:not(.public-landing-main) .play-server-map-tile {
        height: 128px;
        width: 128px;
    }

    .public-shell .public-main:not(.public-landing-main) .play-server-stat-strip {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .public-shell .public-main:not(.public-landing-main) .play-explain-grid,
    .public-shell .public-main:not(.public-landing-main) .play-conversion-grid {
        grid-template-columns: minmax(0, 1fr);
    }
}

@media (max-width: 760px) {
    .public-shell .public-main:not(.public-landing-main) .play-recruit-hero.play-server-hero,
    .public-shell .public-main:not(.public-landing-main) .play-server-top,
    .public-shell .public-main:not(.public-landing-main) .play-featured-window,
    .public-shell .public-main:not(.public-landing-main) .play-window-card {
        grid-template-columns: 1fr;
    }

    .public-shell .public-main:not(.public-landing-main) .play-recruit-hero.play-server-hero {
        padding: 18px;
    }

    .public-shell .public-main:not(.public-landing-main) .play-server-map-tile {
        height: 112px;
        width: 112px;
    }

    .public-shell .public-main:not(.public-landing-main) .play-server-copy h1 {
        font-size: 2.35rem;
    }

    .public-shell .public-main:not(.public-landing-main) .play-server-stat-strip {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .public-shell .public-main:not(.public-landing-main) .play-server-stat {
        min-height: 104px;
        padding: 13px 12px 12px;
    }

    .public-shell .public-main:not(.public-landing-main) .play-server-stat strong {
        font-size: 1rem;
    }

    .public-shell .public-main:not(.public-landing-main) .play-server-stat .empire-icon {
        --empire-icon-size: 24px;
        margin-bottom: 8px;
    }

    .public-shell .public-main:not(.public-landing-main) .play-server-stat small {
        margin-top: 5px;
    }

    .public-shell .public-main:not(.public-landing-main) .play-window-card-date {
        text-align: left;
        width: 100%;
    }

    .public-shell .public-main:not(.public-landing-main) .play-window-card-actions {
        justify-content: flex-start;
    }

    .public-shell .public-main:not(.public-landing-main) .play-explain-card,
    .public-shell .public-main:not(.public-landing-main) .play-reminder-copy,
    .public-shell .public-main:not(.public-landing-main) .play-time-slot-card {
        grid-template-columns: 1fr;
    }

    .public-shell .public-main:not(.public-landing-main) .play-time-slot-card .status-badge {
        justify-self: start;
    }
}

@media (max-width: 350px) {
    .public-shell .public-main:not(.public-landing-main) .play-server-stat-strip {
        grid-template-columns: 1fr;
    }
}

.public-shell .public-main:not(.public-landing-main) .dimension-map-list {
    display: grid;
    gap: 10px;
}

.public-shell .public-main:not(.public-landing-main) .map-activity-panel {
    margin-bottom: 18px;
}

.public-shell .public-main:not(.public-landing-main) .map-activity-grid {
    display: grid;
    gap: 16px;
    grid-template-columns: minmax(260px, .52fr) minmax(0, 1.48fr);
}

.public-shell .public-main:not(.public-landing-main) .map-mode-summary,
.public-shell .public-main:not(.public-landing-main) .map-recent-summary {
    display: grid;
    gap: 10px;
    min-width: 0;
}

.public-shell .public-main:not(.public-landing-main) .map-section-label {
    color: var(--glance-gold);
    font-size: .82rem;
    font-weight: 950;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.public-shell .public-main:not(.public-landing-main) .map-mode-feature,
.public-shell .public-main:not(.public-landing-main) .map-mode-stack a {
    background: rgba(255, 255, 255, .035);
    border: 1px solid var(--glance-line-soft);
    border-radius: 8px;
    color: var(--glance-text);
    min-width: 0;
    padding: 12px;
}

.public-shell .public-main:not(.public-landing-main) .map-mode-feature {
    display: grid;
    gap: 4px;
}

.public-shell .public-main:not(.public-landing-main) .map-mode-feature span,
.public-shell .public-main:not(.public-landing-main) .map-mode-stack small {
    color: var(--glance-muted);
    font-size: .72rem;
    font-weight: 900;
    text-transform: uppercase;
}

.public-shell .public-main:not(.public-landing-main) .map-mode-feature strong,
.public-shell .public-main:not(.public-landing-main) .map-mode-stack strong {
    color: #fff;
    font-weight: 950;
    overflow-wrap: anywhere;
}

.public-shell .public-main:not(.public-landing-main) .map-mode-feature a,
.public-shell .public-main:not(.public-landing-main) .map-mode-stack a {
    color: inherit;
    text-decoration: none;
}

.public-shell .public-main:not(.public-landing-main) .map-mode-feature a:hover,
.public-shell .public-main:not(.public-landing-main) .map-mode-stack a:hover {
    color: var(--glance-gold);
}

.public-shell .public-main:not(.public-landing-main) .map-mode-feature small {
    color: var(--glance-muted);
}

.public-shell .public-main:not(.public-landing-main) .map-mode-stack {
    display: grid;
    gap: 8px;
}

.public-shell .public-main:not(.public-landing-main) .map-mode-stack a {
    align-items: center;
    display: grid;
    gap: 6px 10px;
    grid-template-columns: minmax(0, 1fr) auto;
}

.public-shell .public-main:not(.public-landing-main) .map-mode-stack span {
    color: #fff;
    font-weight: 950;
    overflow-wrap: anywhere;
}

.public-shell .public-main:not(.public-landing-main) .map-mode-stack small {
    grid-column: 1 / -1;
    text-transform: none;
}

@media (max-width: 980px) {
    .public-shell .public-main:not(.public-landing-main) .map-activity-grid {
        grid-template-columns: 1fr;
    }
}

.public-shell .public-main:not(.public-landing-main) .dimension-map-row {
    align-items: center;
    background: rgba(255, 255, 255, .03);
    border: 1px solid var(--glance-line-soft);
    border-radius: 8px;
    display: grid;
    gap: 12px;
    grid-template-columns: auto auto minmax(220px, 1fr) minmax(360px, .9fr);
    min-width: 0;
    padding: 12px;
}

.public-shell .public-main:not(.public-landing-main) .dimension-map-rank {
    color: var(--glance-muted);
    font-size: .76rem;
    font-weight: 950;
    min-width: 38px;
}

.public-shell .public-main:not(.public-landing-main) .dimension-map-row .map-image-thumb {
    height: 54px;
    width: 86px;
}

.public-shell .public-main:not(.public-landing-main) .dimension-map-main {
    display: grid;
    gap: 7px;
    justify-items: start;
    min-width: 0;
}

.public-shell .public-main:not(.public-landing-main) .dimension-map-title-row {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    min-width: 0;
}

.public-shell .public-main:not(.public-landing-main) .dimension-map-title-row .stat-primary {
    color: #fff;
    font-size: 1.02rem;
    font-weight: 950;
    overflow-wrap: anywhere;
    text-decoration: none;
}

.public-shell .public-main:not(.public-landing-main) .dimension-map-title-row .stat-primary:hover {
    color: var(--glance-gold);
}

.public-shell .public-main:not(.public-landing-main) .dimension-map-metrics {
    display: grid;
    gap: 8px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.public-shell .public-main:not(.public-landing-main) .dimension-map-metrics span {
    background: rgba(255, 255, 255, .035);
    border: 1px solid var(--glance-line-soft);
    border-radius: 7px;
    display: grid;
    gap: 2px;
    min-width: 0;
    padding: 8px 9px;
}

.public-shell .public-main:not(.public-landing-main) .dimension-map-metrics small {
    color: var(--glance-muted);
    font-size: .68rem;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.public-shell .public-main:not(.public-landing-main) .dimension-map-metrics strong {
    color: #fff;
    font-size: 1rem;
    font-weight: 950;
    overflow-wrap: anywhere;
}

@media (max-width: 1100px) {
    .public-shell .public-main:not(.public-landing-main) .dimension-map-row {
        grid-template-columns: auto auto minmax(0, 1fr);
    }

    .public-shell .public-main:not(.public-landing-main) .dimension-map-metrics {
        grid-column: 1 / -1;
    }
}

@media (max-width: 640px) {
    .public-shell .public-main:not(.public-landing-main) .dimension-map-row {
        grid-template-columns: auto minmax(0, 1fr);
    }

    .public-shell .public-main:not(.public-landing-main) .dimension-map-row .map-image-thumb {
        grid-column: 1 / -1;
        height: auto;
        width: 100%;
    }

    .public-shell .public-main:not(.public-landing-main) .dimension-map-rank {
        align-self: start;
    }

    .public-shell .public-main:not(.public-landing-main) .dimension-map-metrics {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

.public-shell .public-main:not(.public-landing-main) .detail-hero,
.public-shell .public-main:not(.public-landing-main) .map-hero-panel {
    background:
        linear-gradient(180deg, rgba(247, 185, 34, .055), rgba(247, 185, 34, 0) 46%),
        linear-gradient(180deg, rgba(17, 23, 32, .96), rgba(7, 11, 17, .97));
    border: 1px solid var(--glance-line);
    border-radius: 8px;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .045), 0 14px 34px rgba(0, 0, 0, .3);
    color: var(--glance-text);
}

.public-shell .public-main:not(.public-landing-main) .detail-hero h2,
.public-shell .public-main:not(.public-landing-main) .map-hero-panel h2 {
    color: #fff;
    font-weight: 900;
    letter-spacing: 0;
}

.public-shell .public-main:not(.public-landing-main) .detail-hero p,
.public-shell .public-main:not(.public-landing-main) .map-hero-panel p {
    color: #c5ccda;
}

.public-shell .public-main:not(.public-landing-main) .detail-hero-side > div,
.public-shell .public-main:not(.public-landing-main) .health-summary-grid > div,
.public-shell .public-main:not(.public-landing-main) .insight-card,
.public-shell .public-main:not(.public-landing-main) .top-player-card,
.public-shell .public-main:not(.public-landing-main) .award-card,
.public-shell .public-main:not(.public-landing-main) .mobile-stat-card {
    background: rgba(255, 255, 255, .04);
    border: 1px solid var(--glance-line-soft);
    border-radius: 8px;
    color: var(--glance-text);
}

.public-shell .public-main:not(.public-landing-main) .detail-hero-side span,
.public-shell .public-main:not(.public-landing-main) .health-summary-grid span,
.public-shell .public-main:not(.public-landing-main) .insight-card > span,
.public-shell .public-main:not(.public-landing-main) .top-player-card > span,
.public-shell .public-main:not(.public-landing-main) .mobile-stat-grid span {
    color: var(--glance-muted);
}

.public-shell .public-main:not(.public-landing-main) .detail-hero-side strong,
.public-shell .public-main:not(.public-landing-main) .health-summary-grid strong,
.public-shell .public-main:not(.public-landing-main) .insight-card strong,
.public-shell .public-main:not(.public-landing-main) .top-player-card strong,
.public-shell .public-main:not(.public-landing-main) .mobile-stat-grid strong {
    color: #fff;
}

.public-shell .public-main:not(.public-landing-main) .compact-list-item,
.public-shell .public-main:not(.public-landing-main) .insight-list a {
    background: rgba(255, 255, 255, .028);
    border: 1px solid var(--glance-line-soft);
    border-radius: 7px;
    color: var(--glance-text);
}

.public-shell .public-main:not(.public-landing-main) .compact-list-item:hover,
.public-shell .public-main:not(.public-landing-main) .insight-list a:hover,
.public-shell .public-main:not(.public-landing-main) .top-player-card:hover {
    background: rgba(247, 185, 34, .075);
    border-color: rgba(247, 185, 34, .34);
    color: #fff;
}

.public-shell .public-main:not(.public-landing-main) .detail-accordion {
    background: linear-gradient(180deg, rgba(17, 23, 32, .95), rgba(7, 11, 17, .96));
    border: 1px solid var(--glance-line);
    border-radius: 8px;
    box-shadow: 0 12px 28px rgba(0, 0, 0, .24);
    color: var(--glance-text);
    overflow: hidden;
}

.public-shell .public-main:not(.public-landing-main) .detail-accordion summary {
    background: rgba(255, 255, 255, .035);
    border-bottom: 1px solid var(--glance-line-soft);
    color: var(--glance-text);
}

.public-shell .public-main:not(.public-landing-main) .detail-accordion-body {
    background: transparent;
}

.public-shell .public-main:not(.public-landing-main) .player-insights-heading {
    border-bottom-color: var(--glance-line);
}

.public-shell .public-main:not(.public-landing-main) .award-v2-heading,
.public-shell .public-main:not(.public-landing-main) .award-v2-group-title,
.public-shell .public-main:not(.public-landing-main) .player-award-badge-heading {
    border-bottom-color: var(--glance-line);
}

.public-shell .public-main:not(.public-landing-main) .player-insights-heading h2,
.public-shell .public-main:not(.public-landing-main) .award-v2-heading h2,
.public-shell .public-main:not(.public-landing-main) .award-v2-group-title h3,
.public-shell .public-main:not(.public-landing-main) .player-insights-block-header h3,
.public-shell .public-main:not(.public-landing-main) .relationship-list-heading h4 {
    color: var(--glance-gold);
    font-weight: 900;
}

.public-shell .public-main:not(.public-landing-main) .award-v2-heading p,
.public-shell .public-main:not(.public-landing-main) .award-v2-group-title p,
.public-shell .public-main:not(.public-landing-main) .award-v2-evidence,
.public-shell .public-main:not(.public-landing-main) .player-award-badge-heading > span,
.public-shell .public-main:not(.public-landing-main) .player-award-badge-partner {
    color: var(--glance-muted);
}

.public-shell .public-main:not(.public-landing-main) .award-v2-card,
.public-shell .public-main:not(.public-landing-main) .player-award-badge {
    background: linear-gradient(180deg, rgba(255, 255, 255, .045), rgba(255, 255, 255, .018));
    border-color: var(--glance-line);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .04), 0 12px 28px rgba(0, 0, 0, .22);
    color: var(--glance-text);
}

.public-shell .public-main:not(.public-landing-main) .award-v2-card {
    border-top-color: rgba(247, 185, 34, .82);
}

.public-shell .public-main:not(.public-landing-main) .award-v2-rank,
.public-shell .public-main:not(.public-landing-main) .player-award-badge-top span {
    color: var(--glance-gold);
}

.public-shell .public-main:not(.public-landing-main) .award-v2-medal span,
.public-shell .public-main:not(.public-landing-main) .award-v2-subject,
.public-shell .public-main:not(.public-landing-main) .player-award-badge-top strong {
    color: #fff;
}

.public-shell .public-main:not(.public-landing-main) .award-v2-metrics > div,
.public-shell .public-main:not(.public-landing-main) .player-award-badge-metric {
    background: rgba(255, 255, 255, .045);
    border-color: var(--glance-line-soft);
}

.public-shell .public-main:not(.public-landing-main) .relationship-card,
.public-shell .public-main:not(.public-landing-main) .relationship-list-panel {
    background: linear-gradient(180deg, rgba(255, 255, 255, .04), rgba(255, 255, 255, .018));
    border-color: var(--glance-line);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .04), 0 12px 28px rgba(0, 0, 0, .22);
}

.public-shell .public-main:not(.public-landing-main) .relationship-card-metrics > div,
.public-shell .public-main:not(.public-landing-main) .relationship-list-item {
    background: rgba(255, 255, 255, .045);
    border-color: var(--glance-line-soft);
}

.public-shell .public-main:not(.public-landing-main) .relationship-list-item:hover,
.public-shell .public-main:not(.public-landing-main) .relationship-list-item:focus {
    background: rgba(247, 185, 34, .08);
}

.public-shell .public-main:not(.public-landing-main) .timeline-summary-card,
.public-shell .public-main:not(.public-landing-main) .timeline-highlight-card,
.public-shell .public-main:not(.public-landing-main) .timeline-note-row,
.public-shell .public-main:not(.public-landing-main) .timeline-event-meta > span,
.public-shell .public-main:not(.public-landing-main) .timeline-group-preview span {
    background: rgba(255, 255, 255, .04);
    border-color: var(--glance-line-soft);
}

.public-shell .public-main:not(.public-landing-main) .timeline-summary-card strong,
.public-shell .public-main:not(.public-landing-main) .timeline-highlight-card h4,
.public-shell .public-main:not(.public-landing-main) .timeline-section-heading h3,
.public-shell .public-main:not(.public-landing-main) .timeline-event-title-row strong,
.public-shell .public-main:not(.public-landing-main) .timeline-group-title {
    color: #fff;
}

.public-shell .public-main:not(.public-landing-main) .timeline-summary-card span,
.public-shell .public-main:not(.public-landing-main) .timeline-summary-card small,
.public-shell .public-main:not(.public-landing-main) .timeline-highlight-card p,
.public-shell .public-main:not(.public-landing-main) .timeline-section-heading p,
.public-shell .public-main:not(.public-landing-main) .timeline-note-row,
.public-shell .public-main:not(.public-landing-main) .timeline-clock,
.public-shell .public-main:not(.public-landing-main) .timeline-time-note,
.public-shell .public-main:not(.public-landing-main) .timeline-group-clock,
.public-shell .public-main:not(.public-landing-main) .timeline-group-preview span,
.public-shell .public-main:not(.public-landing-main) .timeline-event-main p,
.public-shell .public-main:not(.public-landing-main) .timeline-event-meta,
.public-shell .public-main:not(.public-landing-main) .timeline-event-meta > span > span,
.public-shell .public-main:not(.public-landing-main) .timeline-player-row {
    color: var(--glance-muted);
}

.public-shell .public-main:not(.public-landing-main) .timeline-highlight-card {
    background: linear-gradient(180deg, rgba(255, 255, 255, .045), rgba(255, 255, 255, .02));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .04), 0 10px 24px rgba(0, 0, 0, .22);
}

.public-shell .public-main:not(.public-landing-main) .timeline-event-row + .timeline-event-row,
.public-shell .public-main:not(.public-landing-main) .timeline-event-spine::before {
    border-color: var(--glance-line-soft);
}

.public-shell .public-main:not(.public-landing-main) .timeline-event-spine::before {
    background: var(--glance-line-soft);
}

.public-shell .public-main:not(.public-landing-main) .timeline-event-spine span {
    background: #070b11;
    border-color: var(--glance-muted);
}

.public-shell .public-main:not(.public-landing-main) .timeline-category-objective {
    border-left-color: var(--glance-gold);
}

.public-shell .public-main:not(.public-landing-main) .timeline-category-combat {
    border-left-color: #79b2ff;
}

.public-shell .public-main:not(.public-landing-main) .timeline-category-presence,
.public-shell .public-main:not(.public-landing-main) .timeline-category-session {
    border-left-color: var(--glance-line);
}

.public-shell .public-main:not(.public-landing-main) .timeline-category-result {
    border-left-color: var(--glance-green);
}

.public-shell .public-main:not(.public-landing-main) .timeline-event-row.timeline-category-objective .timeline-event-spine span,
.public-shell .public-main:not(.public-landing-main) .timeline-highlight-card.timeline-category-objective {
    border-color: var(--glance-gold);
}

.public-shell .public-main:not(.public-landing-main) .timeline-event-row.timeline-category-combat .timeline-event-spine span,
.public-shell .public-main:not(.public-landing-main) .timeline-highlight-card.timeline-category-combat {
    border-color: #79b2ff;
}

.public-shell .public-main:not(.public-landing-main) .timeline-event-row.timeline-category-result .timeline-event-spine span,
.public-shell .public-main:not(.public-landing-main) .timeline-highlight-card.timeline-category-result {
    border-color: var(--glance-green);
}

.public-shell .public-main:not(.public-landing-main) .timeline-event-row.is-highlight {
    background: linear-gradient(90deg, rgba(247, 185, 34, .08), rgba(247, 185, 34, 0));
}

.public-shell .public-main:not(.public-landing-main) .timeline-importance-critical {
    box-shadow: inset 0 0 0 1px rgba(215, 25, 36, .32), 0 10px 24px rgba(215, 25, 36, .08);
}

.public-shell .public-main:not(.public-landing-main) .timeline-importance-high {
    box-shadow: inset 0 0 0 1px rgba(247, 185, 34, .18), 0 10px 24px rgba(0, 0, 0, .18);
}

.public-shell .public-main:not(.public-landing-main) .auth-brand-panel {
    background:
        linear-gradient(90deg, rgba(247, 185, 34, .08), transparent 60%),
        rgba(255, 255, 255, .026);
    border-bottom-color: var(--glance-line-soft);
}

.public-shell .public-main:not(.public-landing-main) .account-auth-brand-banner {
    background: linear-gradient(130deg, rgba(88, 101, 242, .24), rgba(73, 95, 215, .8));
    border-bottom-color: var(--glance-line-soft);
}

.public-shell .public-main:not(.public-landing-main) .account-auth-brand-banner .brand-preview-logo,
.public-shell .public-main:not(.public-landing-main) .account-auth-brand-banner .brand-logo-fallback-lg {
    background: rgba(255, 255, 255, .12);
    border-color: rgba(255, 255, 255, .2);
}

.public-shell .public-main:not(.public-landing-main) .account-auth-brand-banner .brand-logo-fallback-lg {
    color: #fff;
}

.public-shell .public-main:not(.public-landing-main) .brand-preview-logo,
.public-shell .public-main:not(.public-landing-main) .brand-logo-fallback-lg {
    background: rgba(255, 255, 255, .08);
    border-color: var(--glance-line);
}

.public-shell .public-main:not(.public-landing-main) .auth-brand-panel strong,
.public-shell .public-main:not(.public-landing-main) .award-card-title,
.public-shell .public-main:not(.public-landing-main) .stat-primary {
    color: #fff;
}

.public-shell .public-main:not(.public-landing-main) .external-login-btn {
    background: rgba(255, 255, 255, .04);
    border-color: var(--glance-line);
    color: #fff;
}

.public-shell .public-main:not(.public-landing-main) .external-login-btn.external-login-discord,
.public-shell .public-main:not(.public-landing-main) .external-login-btn.external-login-discord:hover,
.public-shell .public-main:not(.public-landing-main) .external-login-btn.external-login-discord:focus {
    background: rgba(88, 101, 242, .23);
    border-color: rgba(88, 101, 242, .82);
    color: #fff;
}

.public-shell .public-main:not(.public-landing-main) .alert {
    background: rgba(76, 141, 255, .12);
    border-color: rgba(76, 141, 255, .32);
    color: #dce9ff;
}

.public-shell .public-main:not(.public-landing-main) .alert-danger {
    background: rgba(215, 25, 36, .14);
    border-color: rgba(215, 25, 36, .36);
    color: #ffd5d8;
}

.public-shell .public-main:not(.public-landing-main) code {
    background: rgba(247, 185, 34, .1);
    border: 1px solid rgba(247, 185, 34, .2);
    border-radius: 4px;
    color: #ffe08a;
    padding: 2px 5px;
}

@media (max-width: 1100px) {
    .public-shell .public-main:not(.public-landing-main) .metric-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .public-shell .public-main:not(.public-landing-main) .public-page-header,
    .public-shell .public-main:not(.public-landing-main) .public-hero {
        align-items: flex-start;
        flex-direction: column;
    }
}

@media (max-width: 680px) {
    .public-shell .public-main:not(.public-landing-main) {
        padding: 16px 12px 42px;
    }

    .public-shell .public-main:not(.public-landing-main) .metric-grid,
    .public-shell .public-main:not(.public-landing-main) .public-section-links {
        grid-template-columns: 1fr;
    }

    .public-shell .public-main:not(.public-landing-main) .play-window-card {
        grid-template-columns: 1fr;
    }

    .public-shell .public-main:not(.public-landing-main) .play-window-card-actions {
        justify-content: flex-start;
        min-width: 0;
    }

    .public-shell .public-main:not(.public-landing-main) .portal-card-header,
    .public-shell .public-main:not(.public-landing-main) .portal-card-body.border-top.d-flex,
    .public-shell .public-main:not(.public-landing-main) .portal-card-body.border-top.d-flex.justify-content-between {
        align-items: flex-start !important;
        flex-direction: column;
    }

    .public-shell .public-main:not(.public-landing-main) .btn-group {
        display: grid;
        grid-template-columns: 1fr 1fr;
        width: 100%;
    }

    .public-shell .public-main:not(.public-landing-main) .btn-group .btn {
        width: 100%;
    }
}

@media (max-width: 768px) {
    .public-server-header .public-server-utility.utility-strip {
        grid-template-columns: 1fr;
    }

    .public-server-header .public-server-utility.utility-strip .utility-left,
    .public-server-header .public-server-utility.utility-strip .utility-actions,
    .public-server-header .public-server-utility.utility-strip .utility-meta {
        grid-column: 1 / -1;
        justify-self: stretch;
        max-width: 100%;
        min-width: 0;
        width: 100%;
    }

    .public-server-header .public-server-utility.utility-strip .utility-left {
        flex-wrap: wrap;
    }

    .public-server-header .public-server-utility.utility-strip .utility-actions {
        justify-content: stretch;
    }

    .public-server-header .public-server-utility.utility-strip .glance-command-actions,
    .public-server-header .public-server-utility.utility-strip .glance-join-button,
    .public-server-header .public-server-utility.utility-strip .glance-discord-button {
        width: 100%;
    }

    .public-server-header .public-server-utility.utility-strip .utility-meta,
    .public-server-header .public-server-utility.utility-strip .glance-server-stats-group {
        display: grid;
        gap: .65rem;
        grid-template-columns: 1fr;
    }

.public-server-header .public-server-utility.utility-strip .glance-command-meta,
.public-server-header .public-server-utility.utility-strip .glance-command-meta-wide {
    justify-content: space-between;
    max-width: 100%;
    width: 100%;
}

/* Public server header overlap guardrails.
   The header contains live values with unpredictable lengths, so avoid
   max-content tracks/items that can force controls and status text to collide. */
.public-server-header .public-server-utility.utility-strip {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: .75rem 1rem;
    min-width: 0;
}

.public-server-header .public-server-utility.utility-strip > .glance-utility-group {
    max-width: 100%;
    min-width: 0;
}

.public-server-header .public-server-utility.utility-strip .utility-left {
    flex: 1 1 18rem;
    flex-wrap: nowrap;
}

.public-server-header .public-server-utility.utility-strip .utility-actions {
    flex: 0 1 auto;
    justify-content: center;
    width: auto;
}

.public-server-header .public-server-utility.utility-strip .utility-meta {
    flex: 999 1 34rem;
    flex-wrap: wrap;
    justify-content: flex-end;
    white-space: normal;
}

.public-server-header .public-server-utility.utility-strip .glance-server-stats-group {
    flex: 1 1 auto;
    flex-wrap: wrap;
    justify-content: flex-end;
    max-width: 100%;
    min-width: 0;
    white-space: normal;
}

.public-server-header .public-server-utility .utility-server,
.public-server-header .public-server-utility .utility-actions,
.public-server-header .public-server-utility .utility-stats,
.public-server-header .public-server-utility .utility-stat,
.public-server-header .public-server-utility .utility-map,
.public-server-header .public-server-utility.utility-strip .glance-command-meta,
.public-server-header .public-server-utility.utility-strip .glance-command-meta-wide {
    max-width: 100%;
    min-width: 0;
}

.public-server-header .public-server-utility.utility-strip .glance-status-chip {
    flex: 0 0 auto;
    min-width: 0;
}

.public-server-header .public-server-utility .glance-status-address,
.public-server-header .public-server-utility .server-address {
    flex: 1 1 10rem;
    max-width: 100%;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.public-server-header .public-server-utility .glance-command-meta span {
    flex: 0 0 auto;
    min-width: 0;
}

.public-server-header .public-server-utility .glance-command-meta strong,
.public-server-header .public-server-utility .utility-value {
    flex: 1 1 auto;
    max-width: 100%;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.public-server-header .public-server-utility .glance-command-meta-wide {
    flex: 1 1 16rem;
    max-width: min(100%, 24rem);
    width: auto;
}

.public-server-header .public-server-utility .glance-join-button,
.public-server-header .public-server-utility .glance-discord-button {
    max-width: 100%;
    min-width: 0;
}

@media (max-width: 768px) {
    .public-server-header .public-server-utility.utility-strip {
        align-items: stretch;
    }

    .public-server-header .public-server-utility.utility-strip .utility-left,
    .public-server-header .public-server-utility.utility-strip .utility-actions,
    .public-server-header .public-server-utility.utility-strip .utility-meta {
        flex: 1 1 100%;
        width: 100%;
    }

    .public-server-header .public-server-utility.utility-strip .utility-left {
        flex-wrap: wrap;
    }

    .public-server-header .public-server-utility.utility-strip .glance-command-actions,
    .public-server-header .public-server-utility.utility-strip .glance-join-button,
    .public-server-header .public-server-utility.utility-strip .glance-discord-button {
        width: 100%;
    }

    .public-server-header .public-server-utility.utility-strip .glance-server-stats-group {
        display: grid;
        gap: .65rem;
        grid-template-columns: 1fr;
        justify-content: stretch;
        width: 100%;
    }

    .public-server-header .public-server-utility.utility-strip .glance-command-meta,
    .public-server-header .public-server-utility.utility-strip .glance-command-meta-wide {
        justify-content: space-between;
        width: 100%;
    }
}
}

/* Public server header desktop/tablet overlap guardrails. */
@media (min-width: 769px) {
    .public-server-header .public-server-utility.utility-strip {
        align-items: center;
        display: flex;
        flex-wrap: wrap;
        gap: .75rem 1rem;
        min-width: 0;
    }

    .public-server-header .public-server-utility.utility-strip > .glance-utility-group {
        max-width: 100%;
        min-width: 0;
    }

    .public-server-header .public-server-utility.utility-strip .utility-left {
        flex: 1 1 18rem;
        flex-wrap: nowrap;
    }

    .public-server-header .public-server-utility.utility-strip .utility-actions {
        flex: 0 1 auto;
        justify-content: center;
        width: auto;
    }

    .public-server-header .public-server-utility.utility-strip .utility-meta {
        flex: 999 1 34rem;
        flex-wrap: wrap;
        justify-content: flex-end;
        white-space: normal;
    }

    .public-server-header .public-server-utility.utility-strip .glance-server-stats-group {
        flex: 1 1 auto;
        flex-wrap: wrap;
        justify-content: flex-end;
        max-width: 100%;
        min-width: 0;
        white-space: normal;
    }

    .public-server-header .public-server-utility .utility-server,
    .public-server-header .public-server-utility .utility-actions,
    .public-server-header .public-server-utility .utility-stats,
    .public-server-header .public-server-utility .utility-stat,
    .public-server-header .public-server-utility .utility-map,
    .public-server-header .public-server-utility.utility-strip .glance-command-meta,
    .public-server-header .public-server-utility.utility-strip .glance-command-meta-wide {
        max-width: 100%;
        min-width: 0;
    }

    .public-server-header .public-server-utility.utility-strip .glance-status-chip {
        flex: 0 0 auto;
        min-width: 0;
    }

    .public-server-header .public-server-utility .glance-status-address,
    .public-server-header .public-server-utility .server-address {
        flex: 1 1 10rem;
        max-width: 100%;
        min-width: 0;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    .public-server-header .public-server-utility .glance-command-meta span {
        flex: 0 0 auto;
        min-width: 0;
    }

    .public-server-header .public-server-utility .glance-command-meta strong,
    .public-server-header .public-server-utility .utility-value {
        flex: 1 1 auto;
        max-width: 100%;
        min-width: 0;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    .public-server-header .public-server-utility .glance-command-meta-wide {
        flex: 1 1 16rem;
        max-width: min(100%, 24rem);
        width: auto;
    }

    .public-server-header .public-server-utility .glance-join-button,
    .public-server-header .public-server-utility .glance-discord-button {
        max-width: 100%;
        min-width: 0;
    }
}

/* Public header navigation v2 */
.public-server-header .glance-topbar {
    grid-template-columns: var(--public-header-logo-width) minmax(0, 1fr);
}

.public-server-header .glance-nav-shell {
    grid-column: 2;
    grid-row: 1;
    justify-self: stretch;
    width: 100%;
}

.public-server-header .glance-nav-shell .public-stats-subnav {
    max-width: 100%;
    width: 100%;
}

.public-server-header .glance-nav-shell .public-stats-subnav-list {
    align-items: center;
    display: flex;
    gap: 16px;
    justify-content: space-between;
    max-width: 100%;
    min-width: 0;
    overflow: visible;
    width: 100%;
}

.public-stats-nav-primary,
.public-stats-nav-utility {
    align-items: center;
    display: flex;
    flex: 0 1 auto;
    min-width: 0;
}

.public-stats-nav-primary {
    flex-wrap: nowrap;
}

.public-stats-nav-utility {
    border-left: 1px solid rgba(255, 255, 255, .18);
    flex: 0 0 auto;
    gap: 10px;
    margin-left: auto;
    padding-left: 18px;
}

.public-server-header .glance-nav-shell .public-stats-nav-link,
.public-server-header .glance-nav-shell .public-stats-menu-toggle,
.public-server-header .glance-nav-shell .public-stats-subnav-button {
    align-items: center;
    background: transparent;
    border: 0;
    border-left: 1px solid rgba(255, 255, 255, .075);
    border-radius: 0;
    color: #dce2ee;
    display: inline-flex;
    font: inherit;
    font-size: .9rem;
    font-weight: 850;
    gap: 8px;
    justify-content: center;
    line-height: 1;
    min-height: 54px;
    padding: 0 18px;
    text-decoration: none;
    white-space: nowrap;
}

.public-server-header .glance-nav-shell .public-stats-nav-primary > .public-stats-nav-link:first-child {
    border-left: 0;
}

.public-server-header .glance-nav-shell .public-stats-nav-utility .public-stats-nav-link,
.public-server-header .glance-nav-shell .public-stats-nav-utility .public-stats-menu-toggle {
    border-left: 0;
}

.public-server-header .glance-nav-shell .public-stats-nav-link:hover,
.public-server-header .glance-nav-shell .public-stats-nav-link.active,
.public-server-header .glance-nav-shell .public-stats-menu-toggle:hover,
.public-server-header .glance-nav-shell .public-stats-menu-toggle.active,
.public-server-header .glance-nav-shell .public-stats-menu-toggle[aria-expanded="true"],
.public-server-header .glance-nav-shell .public-stats-subnav-button:hover,
.public-server-header .glance-nav-shell .public-stats-subnav-button:focus-visible {
    background: linear-gradient(180deg, rgba(247, 185, 34, .16), rgba(247, 185, 34, .04));
    box-shadow: inset 0 -2px 0 var(--glance-gold);
    color: #fff;
}

.public-server-header .glance-nav-shell .public-stats-nav-link:focus-visible,
.public-server-header .glance-nav-shell .public-stats-menu-toggle:focus-visible,
.public-server-header .glance-nav-shell .public-stats-subnav-button:focus-visible,
.public-server-header .glance-nav-shell .public-stats-menu-panel a:focus-visible {
    box-shadow: 0 0 0 .18rem rgba(247, 185, 34, .28);
    outline: 2px solid var(--glance-gold);
    outline-offset: 2px;
}

.public-stats-nav-mobile-home {
    display: none !important;
}

.public-stats-menu {
    display: inline-flex;
    position: relative;
}

.public-stats-menu-caret {
    border: solid currentColor;
    border-width: 0 2px 2px 0;
    display: inline-block;
    height: 7px;
    margin-left: 2px;
    transform: rotate(45deg) translateY(-2px);
    transition: transform .16s ease;
    width: 7px;
}

.public-stats-menu-toggle[aria-expanded="true"] .public-stats-menu-caret {
    transform: rotate(225deg) translateY(-1px);
}

.public-stats-menu-panel {
    background: #0d121a;
    border: 1px solid var(--glance-line);
    border-radius: 8px;
    box-shadow: 0 16px 30px rgba(0, 0, 0, .38);
    display: grid;
    gap: 4px;
    left: 0;
    min-width: 13rem;
    padding: 6px;
    position: absolute;
    top: calc(100% + 8px);
    z-index: 30;
}

.public-stats-account-panel {
    left: auto;
    right: 0;
}

.public-stats-menu-panel[hidden] {
    display: none;
}

.public-server-header .glance-nav-shell .public-stats-menu-panel a,
.public-server-header .glance-nav-shell .public-stats-menu-panel .public-stats-subnav-button {
    align-items: center;
    background: transparent;
    border: 0;
    border-radius: 6px;
    box-shadow: none;
    color: #dce2ee;
    display: flex;
    font: inherit;
    font-size: .86rem;
    font-weight: 800;
    justify-content: flex-start;
    min-height: 38px;
    padding: 8px 10px;
    text-align: left;
    text-decoration: none;
    width: 100%;
}

.public-server-header .glance-nav-shell .public-stats-menu-panel a:hover,
.public-server-header .glance-nav-shell .public-stats-menu-panel a:focus-visible,
.public-server-header .glance-nav-shell .public-stats-menu-panel .public-stats-subnav-button:hover,
.public-server-header .glance-nav-shell .public-stats-menu-panel .public-stats-subnav-button:focus-visible {
    background: rgba(247, 185, 34, .12);
    color: #fff;
}

.public-stats-subnav-form {
    margin: 0;
}

.public-server-header .glance-nav-shell .public-stats-auth-link,
.public-server-header .glance-nav-shell .public-stats-account-toggle {
    background: rgba(255, 255, 255, .055);
    border: 1px solid rgba(255, 255, 255, .09);
    border-radius: 999px;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .04);
    min-height: 44px;
    padding: 0 18px;
}

.public-server-header .glance-nav-shell .public-stats-auth-link:hover,
.public-server-header .glance-nav-shell .public-stats-auth-link.active,
.public-server-header .glance-nav-shell .public-stats-account-toggle:hover,
.public-server-header .glance-nav-shell .public-stats-account-toggle.active,
.public-server-header .glance-nav-shell .public-stats-account-toggle[aria-expanded="true"] {
    border-color: rgba(247, 185, 34, .28);
}

@media (max-width: 991px) {
    .public-server-header .glance-topbar {
        grid-template-columns: minmax(0, 1fr);
    }

    .public-server-header .glance-brand-link,
    .public-server-header .glance-nav-shell {
        grid-column: 1;
        justify-self: stretch;
        width: 100%;
    }
}

@media (max-width: 768px) {
    .public-server-header .glance-nav-shell .public-stats-subnav-toggle {
        background: transparent;
        border: 0;
        color: #fff;
        display: flex;
    }

    .public-server-header .glance-nav-shell .public-stats-subnav-list {
        display: none;
        gap: 8px;
        grid-template-columns: 1fr;
        margin-top: 8px;
        white-space: normal;
        width: 100%;
    }

    .public-server-header .glance-nav-shell .public-stats-subnav.is-open .public-stats-subnav-list {
        display: grid;
    }

    .public-stats-nav-primary,
    .public-stats-nav-utility {
        align-items: stretch;
        display: grid;
        gap: 6px;
        width: 100%;
    }

    .public-stats-nav-utility {
        border-left: 0;
        border-top: 1px solid rgba(255, 255, 255, .16);
        margin-left: 0;
        padding-left: 0;
        padding-top: 8px;
    }

    .public-stats-nav-mobile-home {
        display: inline-flex !important;
        order: -1;
    }

    .public-stats-menu {
        display: grid;
        width: 100%;
    }

    .public-server-header .glance-nav-shell .public-stats-nav-link,
    .public-server-header .glance-nav-shell .public-stats-menu-toggle,
    .public-server-header .glance-nav-shell .public-stats-subnav-button,
    .public-server-header .glance-nav-shell .public-stats-auth-link,
    .public-server-header .glance-nav-shell .public-stats-account-toggle {
        border: 0;
        border-radius: 6px;
        justify-content: flex-start;
        min-height: 42px;
        padding: 0 12px;
        white-space: normal;
        width: 100%;
    }

    .public-stats-menu-panel,
    .public-stats-account-panel {
        box-shadow: none;
        left: auto;
        min-width: 0;
        position: static;
        right: auto;
        top: auto;
        width: 100%;
    }

    .public-server-header .glance-nav-shell .public-stats-menu-panel a,
    .public-server-header .glance-nav-shell .public-stats-menu-panel .public-stats-subnav-button {
        min-height: 38px;
        padding-left: 34px;
    }
}

/* Refined public homepage cascade overrides */
.glance-primary-grid {
    grid-template-columns: minmax(0, 1fr);
}

.glance-play-now-layout {
    display: grid;
    gap: 18px;
    padding: 14px 18px 18px;
}

.glance-play-now-layout.is-live {
    grid-template-columns: minmax(300px, .72fr) minmax(420px, 1fr) minmax(300px, .46fr);
}

.glance-play-now-layout.is-empty {
    grid-template-columns: minmax(0, 1fr) minmax(320px, .35fr);
}

.public-server-utility.utility-strip .glance-copy-address-button {
    align-items: center;
    background: rgba(255, 255, 255, .035);
    border: 1px solid rgba(255, 255, 255, .14);
    border-radius: 5px;
    color: #d7dde8;
    display: inline-flex;
    flex: 0 0 auto;
    height: 30px;
    justify-content: center;
    padding: 0;
    width: 30px;
}

.public-server-utility.utility-strip .glance-copy-address-button:hover,
.public-server-utility.utility-strip .glance-copy-address-button:focus-visible {
    border-color: rgba(255, 204, 0, .72);
    color: var(--glance-gold);
}

.public-server-header .public-server-utility .glance-status-address-group {
    align-items: center;
    display: inline-flex;
    flex: 0 1 auto;
    gap: .35rem;
    max-width: min(100%, 22rem);
    min-width: 0;
    white-space: nowrap;
}

.public-server-header .public-server-utility .glance-status-address-group .glance-status-address,
.public-server-header .public-server-utility .glance-status-address-group .server-address {
    flex: 0 1 auto;
    max-width: 16rem;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.public-server-header .public-server-utility .glance-status-address-group .glance-copy-address-button {
    flex: 0 0 30px;
    min-width: 30px;
}

.public-server-header .public-server-utility .glance-status-address-group .glance-copy-feedback {
    min-width: 3.25rem;
}

.glance-live-summary-panel,
.glance-window-summary-panel,
.glance-play-actions-panel {
    min-width: 0;
}

.glance-live-summary-panel,
.glance-window-summary-panel {
    background: rgba(255, 255, 255, .026);
    border: 1px solid rgba(255, 255, 255, .085);
    border-radius: 6px;
    padding: 24px;
}

.glance-live-now-label,
.glance-window-copy > span,
.glance-live-facts dt,
.glance-window-meta-grid span,
.glance-window-footer span {
    color: var(--glance-muted);
    font-size: .75rem;
    font-weight: 850;
    letter-spacing: 0;
    text-transform: uppercase;
}

.glance-live-now-label {
    align-items: center;
    color: #ff404a;
    display: inline-flex;
    gap: 8px;
}

.glance-live-now-label span {
    background: #ff1f2d;
    border-radius: 999px;
    box-shadow: 0 0 18px rgba(255, 31, 45, .5);
    height: 10px;
    width: 10px;
}

.glance-live-summary-panel h3,
.glance-window-copy h3 {
    color: #fff;
    font-size: clamp(1.45rem, 1.85vw, 2rem);
    font-weight: 900;
    letter-spacing: 0;
    line-height: 1.08;
    margin: 8px 0 0;
    overflow-wrap: anywhere;
}

.glance-window-copy p,
.glance-live-summary-panel p,
.glance-seed-note,
.glance-how-to-join-panel,
.glance-action-tile small {
    color: var(--glance-muted);
    font-size: .9rem;
    line-height: 1.35;
    margin: 10px 0 0;
    overflow-wrap: anywhere;
}

.glance-team-count-row {
    align-items: center;
    display: grid;
    gap: 18px;
    grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
    margin: 28px 0 22px;
}

.glance-team-count {
    align-items: center;
    display: grid;
    gap: 6px;
    justify-items: center;
    min-width: 0;
}

.glance-team-count span {
    font-size: .78rem;
    font-weight: 900;
    letter-spacing: 0;
    text-transform: uppercase;
}

.glance-team-count strong {
    color: #fff;
    font-size: clamp(2.4rem, 3vw, 3.6rem);
    font-weight: 950;
    line-height: .9;
}

.glance-team-axis span,
.glance-team-axis strong {
    color: #ff404a;
}

.glance-team-allies span,
.glance-team-allies strong {
    color: #6784ff;
}

.glance-team-count-separator {
    color: #fff;
    font-size: 1rem;
    font-weight: 900;
    text-transform: uppercase;
}

.glance-live-player-total {
    align-items: center;
    display: grid;
    justify-items: center;
    margin: 28px 0 22px;
}

.glance-live-player-total strong {
    color: var(--glance-green);
    font-size: clamp(3rem, 4vw, 4.5rem);
    font-weight: 950;
    line-height: .9;
}

.glance-live-player-total span {
    color: var(--glance-muted);
    font-size: .8rem;
    font-weight: 900;
    letter-spacing: 0;
    text-transform: uppercase;
}

.glance-live-facts,
.glance-window-meta-grid {
    display: grid;
    gap: 10px;
    margin: 0;
}

.glance-live-facts {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.glance-window-meta-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    margin-top: 24px;
}

.glance-live-facts > div,
.glance-window-meta-grid > div {
    background: rgba(0, 0, 0, .18);
    border: 1px solid rgba(255, 255, 255, .075);
    border-radius: 6px;
    min-width: 0;
    padding: 9px 10px;
}

.glance-live-facts dt,
.glance-window-meta-grid span,
.glance-window-footer span {
    align-items: center;
    display: inline-flex;
    gap: 6px;
}

.glance-live-facts dd,
.glance-window-meta-grid strong {
    color: #fff;
    display: block;
    font-size: .98rem;
    font-weight: 850;
    line-height: 1.1;
    margin: 5px 0 0;
    overflow: hidden;
    overflow-wrap: anywhere;
    text-overflow: ellipsis;
}

.glance-window-footer {
    align-items: center;
    border-top: 1px solid rgba(255, 255, 255, .085);
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    justify-content: space-between;
    margin-top: 20px;
    padding-top: 18px;
}

.glance-seed-note {
    align-items: center;
    display: inline-flex;
    gap: 8px;
}

.glance-plan-button {
    background: linear-gradient(180deg, #ffcf1a, #d79b00);
    border-color: rgba(255, 225, 84, .65);
    color: #111827;
    font-weight: 950;
    min-height: 44px;
    padding: 0 24px;
    text-transform: uppercase;
}

.glance-play-actions-panel {
    align-content: start;
    border-left: 1px solid rgba(255, 255, 255, .085);
    display: grid;
    gap: 10px;
    padding-left: 18px;
}

.glance-copy-connect-button,
.glance-action-tile,
.glance-live-stats-link {
    align-items: center;
    border-radius: 6px;
    display: grid;
    gap: 5px 12px;
    grid-template-columns: auto minmax(0, 1fr);
    min-height: 60px;
    padding: 12px 16px;
    text-align: left;
    text-decoration: none;
}

.glance-copy-connect-button {
    background: linear-gradient(180deg, #d80e1a, #a80610);
    border: 1px solid rgba(255, 79, 89, .72);
    color: #fff;
}

.glance-copy-connect-button.is-disabled {
    opacity: .62;
}

.glance-copy-connect-button span,
.glance-action-tile span,
.glance-live-stats-link span {
    color: #fff;
    font-size: .94rem;
    font-weight: 950;
    letter-spacing: 0;
    text-transform: uppercase;
}

.glance-copy-connect-button code,
.glance-action-tile small {
    grid-column: 2;
}

.glance-copy-connect-button code {
    color: #fff;
    font-family: "Cascadia Mono", Consolas, monospace;
    font-size: .8rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.glance-copy-connect-button.is-copy-confirmed {
    background: linear-gradient(180deg, #22963a, #146725);
    border-color: rgba(84, 229, 107, .62);
}

.glance-play-actions-panel .glance-copy-feedback {
    color: var(--glance-muted);
    font-size: .85rem;
    min-height: 1.1rem;
}

.glance-action-tile {
    background: rgba(255, 255, 255, .028);
    border: 1px solid rgba(255, 255, 255, .14);
    color: #fff;
    width: 100%;
}

.glance-discord-action {
    background: linear-gradient(180deg, rgba(88, 101, 242, .42), rgba(38, 45, 116, .5));
    border-color: rgba(120, 133, 255, .72);
}

.glance-how-to-join-panel {
    background: rgba(0, 0, 0, .2);
    border: 1px solid rgba(255, 255, 255, .09);
    border-radius: 6px;
    padding: 12px 16px;
}

.glance-how-to-join-panel ol {
    margin: 0;
    padding-left: 18px;
}

.glance-how-to-join-panel li + li {
    margin-top: 6px;
}

.glance-live-stats-link {
    background: rgba(255, 255, 255, .035);
    border: 1px solid rgba(255, 255, 255, .16);
    color: #fff;
}

.glance-map-grid .glance-play-map {
    background: linear-gradient(180deg, rgba(17, 23, 32, .95), rgba(7, 11, 17, .96));
}

.glance-roster-scroll {
    max-height: clamp(280px, 36vh, 430px);
    overflow-x: auto;
    overflow-y: auto;
    scrollbar-gutter: stable;
}

.glance-roster-scroll .glance-connected-table {
    margin-bottom: 0;
}

.glance-roster-scroll thead th {
    background: rgba(8, 12, 18, .98);
    position: sticky;
    top: 0;
    z-index: 1;
}

.glance-team-pill {
    align-items: center;
    gap: 6px;
}

.glance-team-pill img {
    flex: 0 0 auto;
    height: 18px;
    width: 18px;
}

.glance-team-pill.glance-team-axis {
    border-color: rgba(255, 64, 74, .5);
    color: #ff7078;
}

.glance-team-pill.glance-team-allies {
    border-color: rgba(103, 132, 255, .55);
    color: #8fa2ff;
}

.glance-play-map-heading h3,
.glance-play-roster-heading span,
.glance-live-now-label,
.glance-window-copy > span,
.glance-live-facts dt,
.glance-window-meta-grid span,
.glance-window-footer span {
    letter-spacing: 0;
}

.glance-map-grid {
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.glance-current-map .glance-map-metrics {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.glance-next-map .glance-map-metrics {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.glance-awards-panel .glance-award-grid {
    grid-template-columns: repeat(6, minmax(0, 1fr));
}

@media (max-width: 1320px) {
    .glance-play-now-layout.is-live {
        grid-template-columns: minmax(0, 1fr) minmax(300px, .48fr);
    }

    .glance-play-now-layout.is-live .glance-play-now-roster {
        grid-column: 1;
        grid-row: 2;
    }

    .glance-play-now-layout.is-live .glance-play-actions-panel {
        grid-column: 2;
        grid-row: 1 / span 2;
    }

    .glance-awards-panel .glance-award-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 920px) {
    .glance-play-now-layout.is-live,
    .glance-play-now-layout.is-empty,
    .glance-map-grid,
    .glance-live-facts,
    .glance-window-meta-grid {
        grid-template-columns: 1fr;
    }

    .glance-play-now-layout.is-live .glance-live-summary-panel,
    .glance-play-now-layout.is-live .glance-play-now-roster,
    .glance-play-now-layout.is-live .glance-play-actions-panel {
        grid-column: auto;
        grid-row: auto;
    }

    .glance-play-actions-panel {
        border-left: 0;
        border-top: 1px solid rgba(255, 255, 255, .085);
        padding-left: 0;
        padding-top: 16px;
    }

    .glance-current-map .glance-map-metrics,
    .glance-next-map .glance-map-metrics {
        grid-template-columns: 1fr;
    }

    .glance-awards-panel .glance-award-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 560px) {
    .glance-awards-panel .glance-award-grid {
        grid-template-columns: 1fr;
    }
}
