: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-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;
}

.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;
}

.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;
}

.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);
}

.auth-brand-panel {
    border-bottom: 1px solid var(--portal-line);
    padding: 16px;
}

.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-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;
}

.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;
}

.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;
}

.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;
}

.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;
}

.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 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .quick-stat-strip { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .rotation-toggle-grid { grid-template-columns: 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 { padding: 10px 14px 40px; }
    .public-hero { display: grid; }
    .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,
    .top-player-strip { grid-template-columns: 1fr; }
    .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);
    }
    .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); }

.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-page-header,
.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 h1,
.public-shell .public-main:not(.public-landing-main) .public-hero h1 {
    color: #fff;
    font-size: clamp(2rem, 3.6vw, 3.45rem);
    font-weight: 900;
    letter-spacing: 0;
    line-height: .95;
    margin: 4px 0 8px;
    overflow-wrap: anywhere;
    text-shadow: 0 4px 18px rgba(0, 0, 0, .52);
}

.public-shell .public-main:not(.public-landing-main) .public-page-header p,
.public-shell .public-main:not(.public-landing-main) .public-hero p {
    color: #c5ccda;
    font-size: 1rem;
    margin: 0;
    max-width: 760px;
}

.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:
        linear-gradient(180deg, rgba(247, 185, 34, .08), 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);
    min-height: 116px;
    overflow: hidden;
    padding: 15px 16px;
    position: relative;
}

.public-shell .public-main:not(.public-landing-main) .metric-card::before {
    background: linear-gradient(180deg, var(--glance-red), var(--glance-gold));
    content: "";
    inset: 0 auto 0 0;
    position: absolute;
    width: 3px;
}

.public-shell .public-main:not(.public-landing-main) .metric-value {
    color: #fff;
    font-size: clamp(1.45rem, 2.4vw, 2.05rem);
    font-weight: 900;
    line-height: 1.05;
    margin-top: 7px;
}

.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) .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) .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) .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) .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) .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;
    }
}

/* 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;
    }
}
