:root {
    --page: #f2eee5;
    --page-deep: #e7ded1;
    --ink: #16211a;
    --ink-strong: #0d1711;
    --muted: #6c766f;
    --muted-strong: #4f5a53;
    --surface: #fffdf8;
    --surface-soft: #f8f4ec;
    --surface-tint: #f0eadf;
    --line: #ded5c8;
    --line-strong: #c8bbaa;
    --field: #1f7048;
    --field-deep: #0d3e29;
    --teal: #158b8d;
    --blue: #286aa2;
    --amber: #d39b28;
    --coral: #d9634c;
    --green: #237b4d;
    --danger: #bb493d;
    --success: #1d7a46;
    --header: #101914;
    --header-soft: #17241d;
    --header-line: rgba(255, 255, 255, 0.1);
    --white: #ffffff;
    --shadow-sm: 0 8px 20px rgba(31, 37, 32, 0.08);
    --shadow-md: 0 18px 44px rgba(31, 37, 32, 0.13);
    --shadow-strong: 0 28px 70px rgba(11, 17, 13, 0.26);
    --radius-card: 8px;
    --radius-control: 6px;
    --radius-tight: 4px;
    --display-font: "Sora", "SUIT Variable", sans-serif;
    --body-font: "SUIT Variable", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

* {
    box-sizing: border-box;
}

html {
    min-height: 100%;
    background: var(--page);
    font-size: 16px;
}

body {
    min-height: 100vh;
    margin: 0;
    color: var(--ink);
    background:
            linear-gradient(90deg, rgba(22, 33, 26, 0.035) 1px, transparent 1px),
            linear-gradient(180deg, rgba(22, 33, 26, 0.026) 1px, transparent 1px),
            linear-gradient(180deg, #fbf8f0 0%, var(--page) 42%, var(--page-deep) 100%);
    background-size: 64px 64px, 64px 64px, auto;
    font-family: var(--body-font);
    line-height: 1.45;
}

body::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: -1;
    pointer-events: none;
    background:
            linear-gradient(120deg, rgba(31, 112, 72, 0.08), transparent 32%),
            linear-gradient(240deg, rgba(211, 155, 40, 0.08), transparent 30%);
}

a {
    color: inherit;
    text-decoration: none;
}

button,
input {
    font: inherit;
}

button {
    cursor: pointer;
}

img {
    display: block;
    max-width: 100%;
}

strong {
    font-weight: 800;
}

:focus-visible {
    outline: 3px solid rgba(21, 139, 141, 0.35);
    outline-offset: 2px;
}

.shell,
.page-shell {
    width: min(1520px, calc(100vw - 32px));
    margin: 0 auto;
}

.page-shell {
    display: grid;
    gap: 16px;
    padding: 18px 0 32px;
}

.site-header {
    color: #f6f1e7;
    background:
            linear-gradient(180deg, rgba(16, 25, 20, 0.98), rgba(16, 25, 20, 0.96)),
            var(--header);
    border-bottom: 1px solid rgba(22, 33, 26, 0.18);
    box-shadow: 0 18px 40px rgba(16, 25, 20, 0.18);
}

.utility-bar {
    background: rgba(6, 10, 8, 0.82);
    border-bottom: 1px solid var(--header-line);
}

.utility-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    min-height: 36px;
    padding: 6px 0;
}

.utility-links,
.utility-user {
    display: flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
}

.utility-links {
    overflow-x: auto;
    white-space: nowrap;
    scrollbar-width: thin;
}

.utility-label {
    flex: 0 0 auto;
    color: #f0c76c;
    font-size: 0.72rem;
    font-weight: 900;
}

.utility-links a,
.utility-user a {
    color: rgba(246, 241, 231, 0.78);
    font-size: 0.78rem;
}

.utility-links a:hover,
.utility-user a:hover {
    color: #ffffff;
}

.topbar {
    display: grid;
    grid-template-columns: 285px minmax(0, 1fr);
    align-items: center;
    gap: 22px;
    padding: 18px 0 16px;
}

.brand-lockup {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
}

.brand-lockup__mark {
    display: grid;
    flex: 0 0 auto;
    place-items: center;
    width: 52px;
    height: 52px;
    border-radius: var(--radius-control);
    color: #fff8ec;
    background:
            linear-gradient(135deg, rgba(35, 123, 77, 0.96), rgba(21, 139, 141, 0.96)),
            var(--green);
    box-shadow: 0 14px 28px rgba(0, 0, 0, 0.18);
    font-family: var(--display-font);
    font-size: 1.1rem;
    font-weight: 900;
}

.brand-lockup__copy {
    min-width: 0;
}

.brand-lockup__name {
    color: #fffaf0;
    font-family: var(--display-font);
    font-size: 1.5rem;
    font-weight: 900;
    line-height: 1;
}

.brand-lockup__tag {
    margin-top: 5px;
    color: rgba(246, 241, 231, 0.66);
    font-size: 0.82rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.board-search {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 8px;
    align-items: center;
}

.board-search input,
.header-search input,
.chat-form input {
    width: 100%;
    border: 1px solid var(--line);
    border-radius: var(--radius-control);
    background: #ffffff;
    color: var(--ink);
    outline: none;
}

.board-search input {
    height: 44px;
    padding: 0 14px;
    border-color: rgba(255, 255, 255, 0.14);
    background: rgba(255, 255, 255, 0.09);
    color: #fffdf8;
}

.board-search input::placeholder {
    color: rgba(246, 241, 231, 0.56);
}

.header-search-button,
.button-primary,
.button-secondary,
.chat-form button,
.primary-link,
.ghost-link,
.dev-login-form button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-control);
    font-weight: 850;
    border: 1px solid transparent;
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease, background 0.18s ease;
}

.header-search-button {
    height: 44px;
    padding: 0 18px;
    color: #101914;
    background: linear-gradient(180deg, #f2c766, #d49a28);
    border-color: rgba(242, 199, 102, 0.4);
}

.main-nav {
    background: var(--header-soft);
    border-top: 1px solid var(--header-line);
    border-bottom: 1px solid rgba(0, 0, 0, 0.32);
}

.nav-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    min-height: 48px;
}

.site-nav,
.nav-actions {
    display: flex;
    align-items: center;
    gap: 6px;
}

.site-nav {
    flex-wrap: wrap;
}

.site-nav a {
    display: inline-flex;
    align-items: center;
    min-height: 48px;
    padding: 0 14px;
    color: rgba(246, 241, 231, 0.76);
    font-size: 0.88rem;
    font-weight: 850;
    border-bottom: 3px solid transparent;
}

.site-nav a.is-active {
    color: #fffaf0;
    border-bottom-color: var(--amber);
    background: rgba(255, 255, 255, 0.05);
}

.ghost-link,
.primary-link {
    min-height: 34px;
    padding: 0 12px;
    font-size: 0.78rem;
}

.ghost-link {
    color: rgba(246, 241, 231, 0.82);
    background: rgba(255, 255, 255, 0.04);
    border-color: rgba(255, 255, 255, 0.12);
}

.primary-link {
    color: #101914;
    background: #f2c766;
    border-color: rgba(242, 199, 102, 0.48);
}

.spot-major-nav {
    color: var(--ink);
    background: rgba(248, 244, 236, 0.96);
    border-bottom: 1px solid var(--line);
}

.spot-major-shell {
    display: flex;
    align-items: stretch;
    gap: 8px;
    padding: 10px 0;
    overflow-x: auto;
}

.spot-major-label {
    display: inline-flex;
    flex: 0 0 auto;
    align-items: center;
    padding: 0 8px;
    color: var(--muted-strong);
    font-size: 0.72rem;
    font-weight: 900;
}

.spot-major-shell a {
    display: grid;
    gap: 2px;
    min-width: 132px;
    padding: 9px 11px;
    border: 1px solid var(--line);
    border-radius: var(--radius-control);
    background: #fffdf8;
    box-shadow: var(--shadow-sm);
}

.spot-major-shell a.is-active {
    border-color: rgba(31, 112, 72, 0.34);
    background: #eff7ef;
}

.spot-major-shell strong {
    font-size: 0.84rem;
}

.spot-major-shell span {
    color: var(--muted);
    font-size: 0.7rem;
}

.dev-login-form {
    margin: 0;
}

.dev-login-form button,
.dev-login-state {
    min-height: 28px;
    padding: 0 9px;
    font-size: 0.72rem;
    white-space: nowrap;
}

.dev-login-form button {
    color: #101914;
    background: #f2c766;
    border-color: rgba(242, 199, 102, 0.35);
}

.dev-login-state {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    border-radius: var(--radius-control);
    color: #dff7e7;
    background: rgba(46, 132, 80, 0.28);
    border: 1px solid rgba(190, 238, 207, 0.2);
    font-size: 0.74rem;
    font-weight: 850;
}

.dev-login-state .dev-login-form button {
    min-height: 22px;
    padding: 0 8px;
    color: #fff8ec;
    background: rgba(255, 255, 255, 0.12);
    border-color: rgba(255, 255, 255, 0.16);
}

.portal-shell,
.admin-shell {
    gap: 14px;
}

.page-shell--sub {
    grid-template-columns: minmax(0, 1fr) 320px;
    align-items: start;
}

.content-column,
.side-column,
.portal-sidebar,
.portal-main,
.portal-side-stack,
.admin-main {
    display: grid;
    gap: 14px;
    align-content: start;
    min-width: 0;
}

.portal-sidebar,
.side-column {
    position: sticky;
    top: 14px;
}

.portal-layout {
    display: grid;
    gap: 14px;
    align-items: start;
}

.portal-layout--home {
    grid-template-columns: 286px minmax(0, 1fr);
}

.portal-layout--match {
    grid-template-columns: 1fr;
}

.portal-breaking-strip {
    display: flex;
    align-items: center;
    gap: 12px;
    min-height: 44px;
    padding: 9px 12px;
    overflow-x: auto;
    white-space: nowrap;
    border: 1px solid var(--line);
    border-radius: var(--radius-card);
    background: rgba(255, 253, 248, 0.94);
    box-shadow: var(--shadow-sm);
}

.portal-breaking-strip strong {
    flex: 0 0 auto;
    color: var(--green);
    font-size: 0.76rem;
    font-weight: 950;
}

.portal-breaking-strip a {
    color: var(--muted-strong);
    font-size: 0.84rem;
}

.portal-card,
.module-card,
.admin-card,
.page-hero,
.article-card,
.comment-card {
    border: 1px solid var(--line);
    border-radius: var(--radius-card);
    background: var(--surface);
    box-shadow: var(--shadow-sm);
}

.portal-card,
.module-card,
.admin-card,
.article-card,
.comment-card {
    padding: 16px;
}

.portal-card-head,
.module-head,
.admin-card__head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 12px;
}

.portal-card-head strong,
.module-head h2,
.admin-card__head strong {
    display: block;
    margin: 0;
    color: var(--ink-strong);
    font-family: var(--display-font);
    font-size: 1rem;
    font-weight: 900;
    line-height: 1.2;
}

.portal-card-head span,
.admin-card__head span,
.module-head__eyebrow {
    display: block;
    margin-top: 4px;
    color: var(--muted);
    font-size: 0.76rem;
}

.portal-card-head a,
.admin-card__head a,
.module-head a {
    color: var(--teal);
    font-size: 0.78rem;
    font-weight: 850;
}

.module-head__eyebrow,
.page-hero__eyebrow {
    margin: 0 0 6px;
    color: var(--green);
    font-size: 0.76rem;
    font-weight: 900;
}

.data-notice {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 10px 12px;
    border: 1px solid #ead095;
    border-radius: var(--radius-control);
    color: #67480f;
    background: #fff6df;
}

.data-notice strong {
    flex: 0 0 auto;
    color: #865c0c;
    font-size: 0.74rem;
    font-weight: 950;
}

.data-notice span {
    color: #6f571e;
    font-size: 0.78rem;
    line-height: 1.5;
}

.data-notice--hero,
.data-notice--overlay {
    margin-bottom: 14px;
}

.portal-match-card {
    position: relative;
    overflow: hidden;
    padding: 18px;
    color: #f8f4ea;
    border-color: rgba(255, 255, 255, 0.12);
    background:
            linear-gradient(135deg, rgba(16, 25, 20, 0.96), rgba(23, 36, 29, 0.98)),
            var(--header);
    box-shadow: var(--shadow-strong);
}

.portal-match-card::before {
    content: "";
    position: absolute;
    inset: 0 0 auto;
    height: 4px;
    background: linear-gradient(90deg, var(--coral), var(--amber), var(--teal));
}

.portal-match-card > * {
    position: relative;
    z-index: 1;
}

.portal-match-card .portal-card-head strong,
.portal-match-card .portal-match-hero-head h1 {
    color: #fffaf0;
}

.portal-match-card .portal-card-head span,
.portal-match-card .portal-match-hero-head p,
.portal-match-card .portal-team-card__top span,
.portal-match-card .portal-team-card__coach span,
.portal-match-card .portal-team-card__tagline,
.portal-match-card .portal-team-card__players span,
.portal-match-card .showdown-row label {
    color: rgba(248, 244, 234, 0.72);
}

.portal-card-head--match {
    align-items: center;
}

.hero-indicators {
    display: inline-flex;
    align-items: center;
    gap: 7px;
}

.hero-indicator {
    width: 9px;
    height: 9px;
    padding: 0;
    border: 0;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.24);
}

.hero-indicator.is-active {
    width: 28px;
    background: linear-gradient(90deg, var(--amber), #f4d77d);
}

.portal-match-deck {
    display: none;
    border-radius: var(--radius-card);
}

.portal-match-deck.is-active {
    display: block;
}

.portal-match-grid {
    display: grid;
    gap: 16px;
    align-items: stretch;
}

.portal-shell--home .portal-match-grid {
    grid-template-columns: minmax(560px, 1.16fr) minmax(360px, 0.84fr);
}

.portal-shell--match .portal-match-grid {
    grid-template-columns: minmax(360px, 0.78fr) minmax(560px, 1.22fr);
}

.portal-match-summary,
.portal-match-board,
.arena-board {
    min-width: 0;
}

.portal-match-summary {
    display: grid;
    gap: 12px;
    align-content: start;
}

.match-deck__hud {
    display: flex;
    flex-wrap: wrap;
    gap: 7px;
    align-items: center;
}

.match-deck__hud span,
.portal-match-tag,
.portal-match-state,
.chat-topic,
.status-chip,
.tag-chip,
.topic-card__category,
.post-row__badge,
.compact-link__badge,
.article-meta__board {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 24px;
    padding: 0 8px;
    border: 1px solid rgba(22, 33, 26, 0.1);
    border-radius: 999px;
    font-size: 0.7rem;
    font-weight: 900;
    line-height: 1;
    white-space: nowrap;
}

.match-deck__hud span {
    color: rgba(248, 244, 234, 0.82);
    background: rgba(255, 255, 255, 0.08);
    border-color: rgba(255, 255, 255, 0.12);
}

.match-deck__mode {
    color: #101914 !important;
    background: linear-gradient(180deg, #f5d070, #d49a28) !important;
    border-color: rgba(245, 208, 112, 0.4) !important;
}

.portal-match-hero-head {
    display: grid;
    gap: 9px;
}

.portal-match-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 7px;
}

.portal-match-tag {
    color: #fee5a0;
    background: rgba(211, 155, 40, 0.16);
    border-color: rgba(211, 155, 40, 0.28);
}

.portal-match-state,
.chat-topic {
    color: #bdeced;
    background: rgba(21, 139, 141, 0.16);
    border-color: rgba(21, 139, 141, 0.28);
}

.portal-match-hero-head h1 {
    margin: 0;
    font-family: var(--display-font);
    font-size: 1.82rem;
    line-height: 1.18;
}

.portal-match-hero-head p {
    margin: 0;
    font-size: 0.9rem;
}

.portal-headtohead {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 12px;
    padding: 12px;
    border: 1px solid rgba(255, 255, 255, 0.11);
    border-radius: var(--radius-control);
    background: rgba(255, 255, 255, 0.07);
}

.portal-headtohead__record strong {
    display: block;
    color: rgba(248, 244, 234, 0.66);
    font-size: 0.74rem;
}

.portal-headtohead__record span {
    display: block;
    margin-top: 4px;
    color: #fffaf0;
    font-weight: 800;
}

.portal-headtohead__sides {
    display: flex;
    align-items: stretch;
    gap: 8px;
}

.portal-headtohead__sides div {
    display: grid;
    justify-items: center;
    min-width: 42px;
    padding: 8px 7px;
    border-radius: var(--radius-tight);
    background: rgba(255, 255, 255, 0.08);
}

.portal-headtohead__sides small {
    color: rgba(248, 244, 234, 0.62);
    font-size: 0.68rem;
}

.portal-headtohead__sides strong {
    color: #fffaf0;
    font-family: var(--display-font);
    font-size: 1.12rem;
}

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

.portal-team-card {
    display: grid;
    gap: 10px;
    min-width: 0;
    padding: 12px;
    border: 1px solid rgba(255, 255, 255, 0.11);
    border-radius: var(--radius-control);
    background: rgba(255, 255, 255, 0.07);
}

.portal-team-card--home {
    border-color: rgba(217, 99, 76, 0.28);
}

.portal-team-card--away {
    border-color: rgba(40, 106, 162, 0.28);
}

.portal-team-card__top {
    display: grid;
    grid-template-columns: 44px minmax(0, 1fr);
    gap: 10px;
    align-items: center;
}

.portal-team-card__code {
    display: grid;
    place-items: center;
    width: 44px;
    height: 44px;
    border-radius: var(--radius-control);
    color: #101914;
    background: #f3cf71;
    font-family: var(--display-font);
    font-size: 0.86rem;
    font-weight: 950;
}

.portal-team-card__top strong {
    display: block;
    overflow: hidden;
    color: #fffaf0;
    font-size: 0.98rem;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.portal-team-card__top span {
    display: block;
    margin-top: 3px;
    font-size: 0.76rem;
}

.portal-team-card__coach,
.portal-team-card__tagline {
    margin: 0;
    font-size: 0.78rem;
}

.portal-team-card__coach strong {
    margin-left: 6px;
    color: #fffaf0;
}

.portal-team-card__players {
    display: grid;
    gap: 6px;
}

.portal-team-card__players div {
    display: grid;
    grid-template-columns: 34px minmax(0, 1fr);
    gap: 8px;
    padding-top: 6px;
    border-top: 1px dashed rgba(255, 255, 255, 0.15);
}

.portal-team-card__players strong {
    color: #f3cf71;
    font-size: 0.68rem;
}

.portal-team-card__players span {
    overflow: hidden;
    font-size: 0.74rem;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.portal-metric-stack {
    display: grid;
    gap: 8px;
}

.showdown-row {
    display: grid;
    grid-template-columns: 34px minmax(0, 1fr) 76px minmax(0, 1fr) 34px;
    gap: 8px;
    align-items: center;
}

.showdown-row__value {
    color: #fffaf0;
    font-family: var(--display-font);
    font-size: 0.9rem;
    font-weight: 900;
    text-align: center;
}

.showdown-row label {
    font-size: 0.64rem;
    font-weight: 900;
    text-align: center;
}

.showdown-row__track {
    position: relative;
    height: 7px;
    overflow: hidden;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.12);
}

.showdown-row__fill {
    position: absolute;
    inset: 0 auto 0 0;
}

.showdown-row__fill--home {
    background: linear-gradient(90deg, var(--coral), #f0a08f);
}

.showdown-row__fill--away {
    right: 0;
    left: auto;
    background: linear-gradient(270deg, var(--blue), #7fb7de);
}

.arena-board {
    display: grid;
    gap: 12px;
}

.arena-board__stadium {
    position: relative;
    display: grid;
    justify-items: center;
    gap: 5px;
    min-height: 128px;
    padding: 24px 18px 18px;
    overflow: hidden;
    color: #fffaf0;
    text-align: center;
    border: 1px solid rgba(255, 255, 255, 0.13);
    border-radius: var(--radius-card);
    background:
            linear-gradient(180deg, rgba(10, 16, 13, 0.24), rgba(10, 16, 13, 0.82)),
            var(--stadium-image) center / cover no-repeat,
            #17241d;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.arena-board__stadium > * {
    position: relative;
    z-index: 1;
}

.arena-board__stadium-badge {
    min-height: 24px;
    padding: 0 9px;
    border-radius: 999px;
    color: rgba(255, 250, 240, 0.78);
    background: rgba(0, 0, 0, 0.36);
    font-size: 0.7rem;
    font-weight: 850;
}

.arena-board__stadium strong {
    font-family: var(--display-font);
    font-size: 1.36rem;
    line-height: 1.12;
}

.arena-board__stadium-subtitle {
    color: rgba(255, 250, 240, 0.78);
    font-size: 0.8rem;
}

.arena-board__meta {
    justify-content: center;
}

.arena-board__field {
    position: relative;
    height: 520px;
    min-height: 520px;
    overflow: hidden;
    border: 1px solid rgba(222, 255, 231, 0.22);
    border-radius: var(--radius-card);
    background:
            linear-gradient(180deg, rgba(42, 132, 81, 0.92), rgba(15, 76, 47, 0.98)),
            repeating-linear-gradient(
                    180deg,
                    rgba(255, 255, 255, 0.04) 0,
                    rgba(255, 255, 255, 0.04) 42px,
                    rgba(0, 0, 0, 0.04) 42px,
                    rgba(0, 0, 0, 0.04) 84px
            );
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.06), 0 18px 36px rgba(0, 0, 0, 0.18);
}

.arena-board__field::before,
.arena-board__field::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
}

.arena-board__field::before {
    background:
            linear-gradient(90deg, transparent 0 32.8%, rgba(255, 255, 255, 0.11) 32.8% 33%, transparent 33% 67%, rgba(255, 255, 255, 0.11) 67% 67.2%, transparent 67.2%),
            linear-gradient(180deg, transparent 0 24.8%, rgba(255, 255, 255, 0.08) 24.8% 25%, transparent 25% 49.9%, rgba(255, 255, 255, 0.1) 49.9% 50.1%, transparent 50.1% 75%, rgba(255, 255, 255, 0.08) 75% 75.2%, transparent 75.2%);
}

.arena-board__field::after {
    background:
            linear-gradient(90deg, rgba(217, 99, 76, 0.13), transparent 34%, transparent 66%, rgba(40, 106, 162, 0.14)),
            linear-gradient(180deg, rgba(0, 0, 0, 0.02), rgba(0, 0, 0, 0.12));
}

.arena-board__zone {
    position: absolute;
    top: 0;
    bottom: 0;
    z-index: 1;
    width: 50%;
    pointer-events: none;
}

.arena-board__zone--home {
    left: 0;
}

.arena-board__zone--away {
    right: 0;
}

.arena-board__centerline,
.arena-board__ring,
.arena-board__box,
.arena-board__six-yard {
    position: absolute;
    z-index: 1;
    border: 1px solid rgba(255, 255, 255, 0.42);
    pointer-events: none;
}

.arena-board__centerline {
    top: 8%;
    bottom: 8%;
    left: 50%;
    width: 0;
}

.arena-board__ring {
    left: calc(50% - 64px);
    top: calc(50% - 64px);
    width: 128px;
    height: 128px;
    border-radius: 50%;
}

.arena-board__box {
    top: 30%;
    width: 13.5%;
    height: 40%;
}

.arena-board__box--home,
.arena-board__six-yard--home {
    left: 3.4%;
}

.arena-board__box--away,
.arena-board__six-yard--away {
    right: 3.4%;
}

.arena-board__six-yard {
    top: 39%;
    width: 6.6%;
    height: 22%;
}

.arena-board__spot {
    position: absolute;
    z-index: 2;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.8);
    box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.16);
}

.arena-board__spot--center {
    top: calc(50% - 3px);
    left: calc(50% - 3px);
}

.arena-board__spot--home {
    top: calc(50% - 3px);
    left: calc(13% - 3px);
}

.arena-board__spot--away {
    top: calc(50% - 3px);
    right: calc(13% - 3px);
}

.arena-board__team-label {
    position: absolute;
    top: 12px;
    z-index: 4;
    display: grid;
    gap: 2px;
    min-width: 70px;
    padding: 7px 10px;
    color: #fffaf0;
    border: 1px solid rgba(255, 255, 255, 0.16);
    border-radius: var(--radius-control);
    background: rgba(10, 16, 13, 0.72);
    backdrop-filter: blur(10px);
}

.arena-board__team-label--home {
    left: 12px;
}

.arena-board__team-label--away {
    right: 12px;
    justify-items: end;
}

.arena-board__team-label strong {
    font-family: var(--display-font);
    font-size: 0.82rem;
}

.arena-board__team-label span {
    color: rgba(255, 250, 240, 0.72);
    font-size: 0.64rem;
}

.tactical-node {
    position: absolute;
    left: var(--node-x);
    top: var(--node-y);
    z-index: 5;
    display: grid;
    gap: 3px;
    width: 86px;
    min-height: 46px;
    padding: 6px 7px 6px 8px;
    color: var(--ink);
    text-align: left;
    border: 1px solid rgba(255, 255, 255, 0.82);
    border-radius: var(--radius-control);
    background: rgba(255, 253, 248, 0.95);
    box-shadow: 0 10px 18px rgba(9, 22, 14, 0.22);
    transform: translate(-50%, -50%);
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
    backdrop-filter: blur(8px);
}

.tactical-node::before {
    content: "";
    position: absolute;
    inset: 0 auto 0 0;
    width: 3px;
    border-radius: var(--radius-control) 0 0 var(--radius-control);
    background: var(--node-accent, var(--teal));
}

.tactical-node--home {
    --node-accent: var(--home-accent, var(--coral));
}

.tactical-node--away {
    --node-accent: var(--away-accent, var(--blue));
}

.tactical-node:hover,
.tactical-node:focus-visible {
    transform: translate(-50%, -50%) translateY(-2px);
    border-color: #ffffff;
    box-shadow: 0 16px 28px rgba(9, 22, 14, 0.3);
}

.tactical-node__topline {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 4px;
}

.tactical-node__rating {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 26px;
    min-height: 18px;
    padding: 0 5px;
    border-radius: 999px;
    color: #101914;
    background: #eef1e8;
    font-family: var(--display-font);
    font-size: 0.58rem;
    font-weight: 950;
}

.tactical-node--elite .tactical-node__rating {
    background: #f0c85e;
}

.tactical-node--strong .tactical-node__rating {
    color: #fffaf0;
    background: var(--teal);
}

.tactical-node__number {
    color: #6b756e;
    font-size: 0.52rem;
    font-weight: 850;
}

.tactical-node__name {
    overflow: hidden;
    color: var(--ink-strong);
    font-size: 0.7rem;
    font-weight: 950;
    line-height: 1.08;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.tactical-node__meta {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    color: var(--muted);
    font-size: 0.54rem;
    font-weight: 900;
}

.tactical-node__dot {
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background: var(--node-accent, var(--teal));
}

.arena-board__footer {
    display: flex;
    justify-content: center;
    gap: 8px;
    flex-wrap: wrap;
}

.button-primary,
.button-secondary,
.chat-form button {
    min-height: 38px;
    padding: 0 14px;
}

.button-primary,
.chat-form button {
    color: #fffdf8;
    background: linear-gradient(180deg, #237b4d, #185c39);
    border-color: rgba(35, 123, 77, 0.28);
}

.button-secondary {
    color: var(--ink);
    background: #ffffff;
    border-color: var(--line-strong);
}

.compact-stack,
.portal-compact-stack,
.schedule-list,
.rank-table,
.post-list,
.comment-list,
.timeline-list,
.portal-section-stack,
.portal-side-stack,
.analytics-list,
.setting-list,
.audit-log,
.admin-queue-list {
    display: grid;
    gap: 9px;
}

.compact-link,
.schedule-card,
.fixture-card,
.topic-card,
.club-card,
.post-row,
.rank-row,
.timeline-item,
.stat-chip,
.squad-card,
.chat-message,
.admin-queue-item,
.policy-card,
.setting-list__item,
.analytics-list__item,
.audit-log__item,
.admin-table__row {
    border: 1px solid var(--line);
    border-radius: var(--radius-control);
    background: #ffffff;
    box-shadow: 0 6px 15px rgba(31, 37, 32, 0.055);
}

.compact-link {
    display: grid;
    grid-template-columns: 52px minmax(0, 1fr) auto;
    gap: 9px;
    align-items: start;
    padding: 10px;
}

.compact-link__badge,
.post-row__badge,
.topic-card__category,
.article-meta__board,
.tag-chip {
    color: #126b6d;
    background: #e8f4f0;
    border-color: #c7e0d7;
}

.compact-link__body {
    min-width: 0;
}

.compact-link__body strong,
.topic-card strong,
.post-row__body strong,
.timeline-item__body strong,
.squad-card strong,
.rank-row__body strong,
.club-card__name,
.schedule-card strong,
.fixture-card strong {
    display: block;
    color: var(--ink-strong);
    font-size: 0.9rem;
    line-height: 1.28;
}

.compact-link__body span,
.topic-card p,
.post-row__body p,
.post-row__body span,
.timeline-item__body p,
.squad-card p,
.squad-card span,
.rank-row__body span,
.rank-row__score,
.compact-link__meta,
.schedule-card span,
.schedule-card em,
.fixture-card span,
.fixture-card em,
.club-card p,
.club-card__meta,
.comment-card__meta span,
.comment-card__likes,
.article-meta,
.article-summary,
.team-summary-bar {
    color: var(--muted);
    font-size: 0.78rem;
}

.compact-link__body span,
.compact-link__meta {
    display: block;
    margin-top: 3px;
}

.compact-link__meta {
    color: var(--muted-strong);
    white-space: nowrap;
}

.rank-row {
    display: grid;
    grid-template-columns: 30px minmax(0, 1fr) auto;
    gap: 10px;
    align-items: center;
    padding: 10px;
}

.rank-row__index {
    display: grid;
    place-items: center;
    width: 30px;
    height: 30px;
    border-radius: var(--radius-tight);
    color: #101914;
    background: #f0c85e;
    font-family: var(--display-font);
    font-size: 0.78rem;
    font-weight: 950;
}

.rank-row__score {
    white-space: nowrap;
}

.portal-priority-grid,
.portal-content-grid {
    display: grid;
    gap: 14px;
}

.portal-priority-grid--home {
    grid-template-columns: minmax(0, 1fr) minmax(330px, 0.8fr);
}

.portal-priority-grid--match {
    grid-template-columns: minmax(0, 1fr) 330px;
}

.portal-content-grid {
    grid-template-columns: minmax(0, 1fr) 330px;
}

.portal-section-block {
    display: grid;
    gap: 9px;
}

.portal-section-block__head {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 10px;
}

.portal-section-block__head strong {
    font-size: 0.9rem;
}

.portal-section-block__head span {
    color: var(--muted);
    font-size: 0.74rem;
}

.schedule-card,
.fixture-card,
.topic-card,
.club-card,
.stat-chip,
.timeline-item,
.squad-card,
.policy-card,
.setting-list__item,
.analytics-list__item,
.audit-log__item {
    padding: 12px;
}

.schedule-card,
.fixture-card,
.topic-card {
    display: grid;
    gap: 7px;
}

.schedule-card__time,
.fixture-card__time,
.timeline-item__minute,
.audit-log__time,
.analytics-list__value em {
    color: var(--green);
    font-size: 0.72rem;
    font-weight: 950;
}

.topic-wall,
.topic-wall--portal,
.schedule-grid,
.topics-grid,
.club-grid,
.squad-grid,
.fixture-list,
.stats-chip-grid,
.policy-grid {
    display: grid;
    gap: 12px;
}

.topic-wall--portal {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.stats-chip-grid {
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
}

.club-grid,
.squad-grid {
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.fixture-list {
    grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
}

.stat-chip {
    display: grid;
    gap: 6px;
}

.stat-chip span {
    color: var(--muted);
    font-size: 0.76rem;
}

.stat-chip strong {
    color: var(--ink-strong);
    font-family: var(--display-font);
    font-size: 1.08rem;
}

.chat-messages {
    display: grid;
    gap: 9px;
    min-height: 230px;
    max-height: 330px;
    padding: 10px;
    overflow-y: auto;
    border: 1px solid var(--line);
    border-radius: var(--radius-control);
    background: var(--surface-soft);
}

.chat-message {
    padding: 9px 10px;
}

.chat-message--home {
    border-color: rgba(217, 99, 76, 0.28);
}

.chat-message--away {
    border-color: rgba(40, 106, 162, 0.26);
}

.chat-message__meta {
    display: flex;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 5px;
}

.chat-message__meta strong {
    color: var(--ink-strong);
    font-size: 0.8rem;
}

.chat-message__meta span,
.chat-message p {
    color: var(--muted);
    font-size: 0.78rem;
}

.chat-message p {
    margin: 0;
}

.chat-form {
    display: grid;
    grid-template-columns: 112px minmax(0, 1fr) auto;
    gap: 8px;
    align-items: center;
    margin-top: 10px;
}

.chat-form input {
    height: 38px;
    padding: 0 11px;
}

.page-hero {
    position: relative;
    overflow: hidden;
    padding: 24px;
    background:
            linear-gradient(135deg, rgba(35, 123, 77, 0.11), transparent 38%),
            var(--surface);
}

.page-hero::before {
    content: "";
    position: absolute;
    inset: 0 auto 0 0;
    width: 5px;
    background: var(--hero-accent, var(--green));
}

.page-hero h1,
.article-card h1 {
    margin: 0;
    color: var(--ink-strong);
    font-family: var(--display-font);
    font-size: 2.05rem;
    line-height: 1.12;
}

.page-hero p {
    max-width: 760px;
    margin: 10px 0 0;
    color: var(--muted);
}

.team-summary-bar,
.article-meta,
.article-stats,
.tag-row,
.hero-pill-row,
.hero-metadata,
.hero-headtohead {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
}

.team-summary-bar {
    margin-top: 14px;
}

.team-summary-bar span,
.article-stats span {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 0 9px;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: #ffffff;
}

.league-hero,
.board-hero,
.team-hero {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 220px;
    gap: 18px;
    align-items: end;
}

.league-hero__crest,
.board-hero__status,
.team-hero__coach {
    display: grid;
    justify-items: end;
    gap: 6px;
    padding: 14px;
    border: 1px solid var(--line);
    border-radius: var(--radius-control);
    background: #ffffff;
}

.league-hero__crest strong,
.board-hero__status strong {
    color: var(--green);
    font-family: var(--display-font);
    font-size: 1.22rem;
}

.league-hero__crest span,
.board-hero__status span,
.team-hero__coach span {
    color: var(--muted);
    font-size: 0.78rem;
}

.team-hero {
    grid-template-columns: minmax(0, 1fr) 210px;
}

.team-hero__coach {
    justify-items: center;
    text-align: center;
}

.team-hero__coach img {
    width: 168px;
    height: 204px;
    object-fit: cover;
    border-radius: var(--radius-control);
    background: var(--surface-tint);
}

.team-hero__coach strong {
    display: block;
    color: var(--ink-strong);
}

.dense-table {
    display: grid;
    gap: 8px;
}

.dense-table__head,
.dense-table__row {
    display: grid;
    grid-template-columns: 62px minmax(0, 1.4fr) 82px 82px 82px minmax(0, 1fr);
    gap: 10px;
    align-items: center;
    padding: 11px 12px;
}

.dense-table__head {
    color: var(--muted);
    border-radius: var(--radius-control);
    background: var(--surface-soft);
    font-size: 0.76rem;
    font-weight: 900;
}

.dense-table__row {
    color: var(--ink-strong);
    border: 1px solid var(--line);
    border-radius: var(--radius-control);
    background: #ffffff;
    box-shadow: 0 6px 15px rgba(31, 37, 32, 0.05);
    font-size: 0.84rem;
}

.post-row {
    display: grid;
    grid-template-columns: 76px minmax(0, 1fr) auto;
    gap: 12px;
    align-items: start;
    padding: 13px;
}

.post-row--pinned {
    border-color: #e2c677;
    background: #fff9e8;
}

.post-row__body {
    min-width: 0;
}

.post-row__body p {
    margin: 7px 0 6px;
    line-height: 1.5;
}

.post-row__stats {
    color: var(--muted);
    font-size: 0.78rem;
    white-space: nowrap;
}

.article-card {
    padding: 24px;
}

.article-meta {
    margin-bottom: 14px;
}

.article-summary {
    margin: 12px 0 16px;
    font-size: 0.98rem;
}

.article-body {
    margin-top: 18px;
    color: #243027;
    white-space: pre-line;
    line-height: 1.78;
}

.article-stats {
    margin-top: 20px;
}

.tag-chip--gold {
    color: #7b540b;
    background: #fff2c7;
    border-color: #e9cb75;
}

.tag-chip--red {
    color: #a94135;
    background: #fff0ec;
    border-color: #efb8ae;
}

.tag-chip--blue {
    color: #1e5f95;
    background: #e9f3fb;
    border-color: #bfdaef;
}

.tag-chip--teal {
    color: #126b6d;
    background: #e8f4f0;
    border-color: #c7e0d7;
}

.comment-list {
    display: grid;
    gap: 10px;
}

.comment-card__meta {
    display: flex;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 8px;
}

.comment-card p {
    margin: 0 0 10px;
    color: #27342c;
}

.club-card {
    position: relative;
    overflow: hidden;
}

.club-card::before {
    content: "";
    position: absolute;
    inset: 0 0 auto;
    height: 4px;
    background: var(--club-tone, var(--green));
}

.club-card p {
    margin: 8px 0 0;
}

.club-card__meta {
    display: flex;
    justify-content: space-between;
    gap: 8px;
    margin-top: 12px;
}

.squad-card--face {
    display: grid;
    grid-template-columns: 84px minmax(0, 1fr);
    gap: 12px;
    align-items: center;
}

.squad-card__portrait {
    width: 84px;
    height: 98px;
    object-fit: cover;
    border-radius: var(--radius-control);
    background: var(--surface-tint);
}

.timeline-item {
    display: grid;
    grid-template-columns: 88px minmax(0, 1fr);
    gap: 12px;
}

.timeline-item--home {
    border-color: rgba(217, 99, 76, 0.26);
}

.timeline-item--away {
    border-color: rgba(40, 106, 162, 0.24);
}

.timeline-item__body p {
    margin: 5px 0 0;
}

.admin-layout {
    display: grid;
    grid-template-columns: 250px minmax(0, 1fr);
    gap: 16px;
    align-items: start;
}

.admin-sidebar {
    position: sticky;
    top: 14px;
    display: grid;
    gap: 12px;
    align-content: start;
}

.admin-sidebar__panel,
.admin-hero {
    border: 1px solid var(--line);
    border-radius: var(--radius-card);
    background: var(--surface);
    box-shadow: var(--shadow-sm);
}

.admin-sidebar__panel {
    padding: 16px;
}

.admin-sidebar__eyebrow,
.admin-hero__eyebrow {
    color: var(--green);
    font-size: 0.76rem;
    font-weight: 950;
}

.admin-sidebar__panel h1,
.admin-hero h2 {
    margin: 7px 0;
    color: var(--ink-strong);
    font-family: var(--display-font);
}

.admin-sidebar__panel h1 {
    font-size: 1.28rem;
    line-height: 1.18;
}

.admin-sidebar__panel p,
.admin-hero p,
.admin-nav__item span,
.admin-metric-card span,
.admin-queue-item p,
.policy-card p,
.policy-card span,
.setting-list__item p,
.analytics-list__item p,
.audit-log__body p {
    color: var(--muted);
    font-size: 0.78rem;
    line-height: 1.5;
}

.admin-nav {
    display: grid;
    gap: 8px;
}

.admin-nav__item {
    display: grid;
    gap: 4px;
    padding: 11px 12px;
    border: 1px solid var(--line);
    border-radius: var(--radius-control);
    background: #ffffff;
}

.admin-nav__item.is-active {
    border-color: rgba(35, 123, 77, 0.32);
    background: #eef7ef;
}

.admin-nav__item strong {
    color: var(--ink-strong);
    font-size: 0.9rem;
}

.admin-hero {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 18px;
    padding: 18px;
}

.admin-hero h2 {
    font-size: 1.45rem;
    line-height: 1.15;
}

.admin-hero p {
    margin: 0;
}

.admin-hero__chips {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 8px;
}

.admin-hero__chips span {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 0 9px;
    color: #126b6d;
    border: 1px solid #c7e0d7;
    border-radius: 999px;
    background: #e8f4f0;
    font-size: 0.74rem;
    font-weight: 850;
}

.admin-metric-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
}

.admin-metric-card {
    display: grid;
    gap: 5px;
    padding: 14px;
    border: 1px solid var(--line);
    border-radius: var(--radius-card);
    background: #ffffff;
    box-shadow: var(--shadow-sm);
}

.admin-metric-card strong {
    color: var(--ink-strong);
    font-family: var(--display-font);
    font-size: 1.34rem;
}

.admin-metric-card em {
    font-style: normal;
    font-size: 0.78rem;
    font-weight: 850;
}

.admin-metric-card--good {
    border-color: rgba(29, 122, 70, 0.28);
}

.admin-metric-card--warn {
    border-color: rgba(211, 155, 40, 0.34);
}

.admin-metric-card--danger {
    border-color: rgba(187, 73, 61, 0.3);
}

.admin-metric-card--accent {
    border-color: rgba(21, 139, 141, 0.3);
}

.admin-grid {
    display: grid;
    gap: 14px;
}

.admin-grid--dashboard,
.admin-grid--split {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

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

.admin-card {
    display: grid;
    gap: 12px;
    min-width: 0;
}

.admin-queue-item {
    display: grid;
    gap: 8px;
    padding: 12px;
}

.admin-queue-item__top {
    display: flex;
    justify-content: space-between;
    gap: 8px;
    flex-wrap: wrap;
}

.admin-queue-item strong,
.policy-card strong,
.setting-list__item strong,
.analytics-list__item strong,
.audit-log__body strong {
    color: var(--ink-strong);
    font-size: 0.9rem;
}

.admin-queue-item p,
.policy-card p,
.setting-list__item p,
.analytics-list__item p,
.audit-log__body p {
    margin: 0;
}

.admin-queue-item__meta {
    color: var(--green);
    font-size: 0.74rem;
    font-weight: 850;
}

.status-chip {
    color: var(--muted-strong);
    background: var(--surface-soft);
    border-color: var(--line);
}

.status-chip--good {
    color: #14643b;
    background: #e8f6ed;
    border-color: #bfe0ca;
}

.status-chip--warn {
    color: #7c570e;
    background: #fff4d2;
    border-color: #e7cc7b;
}

.status-chip--danger {
    color: #a63e33;
    background: #fff0ec;
    border-color: #edb7ae;
}

.status-chip--accent {
    color: #126b6d;
    background: #e8f4f0;
    border-color: #c7e0d7;
}

.admin-table {
    display: grid;
    gap: 8px;
    min-width: 0;
}

.admin-table__head,
.admin-table__row {
    display: grid;
    gap: 10px;
    align-items: start;
    padding: 10px 12px;
    border-radius: var(--radius-control);
}

.admin-table__head {
    color: var(--muted);
    background: var(--surface-soft);
    font-size: 0.72rem;
    font-weight: 950;
}

.admin-table__row {
    color: var(--ink);
    font-size: 0.82rem;
    line-height: 1.45;
}

.admin-table__head--four,
.admin-table__row--four {
    grid-template-columns: 1.1fr 1.2fr 1.3fr 0.9fr;
}

.admin-table__head--five,
.admin-table__row--five {
    grid-template-columns: 1fr 0.8fr 1.2fr 0.8fr 1.2fr;
}

.admin-table__head--six,
.admin-table__row--six {
    grid-template-columns: 0.82fr 1.1fr 1.35fr 0.72fr 0.92fr 1.35fr;
}

.policy-grid {
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
}

.policy-card {
    display: grid;
    gap: 7px;
}

.setting-list__item,
.analytics-list__item {
    display: grid;
    gap: 6px;
}

.setting-list__item span,
.analytics-list__value span {
    display: block;
    color: var(--ink-strong);
    font-weight: 850;
}

.analytics-list__value {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.audit-log__item {
    display: grid;
    grid-template-columns: 76px minmax(0, 1fr);
    gap: 10px;
}

.site-footer {
    color: var(--ink);
    background: rgba(255, 253, 248, 0.96);
    border-top: 1px solid var(--line);
}

.site-footer__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    padding: 20px 0 24px;
}

.site-footer__inner strong {
    margin-right: 10px;
    color: var(--ink-strong);
}

.site-footer__inner span,
.site-footer__links a {
    color: var(--muted);
    font-size: 0.82rem;
}

.site-footer__links {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
}

.compact-link:hover,
.schedule-card:hover,
.fixture-card:hover,
.topic-card:hover,
.club-card:hover,
.post-row:hover,
.rank-row:hover,
.admin-nav__item:hover,
.admin-queue-item:hover {
    border-color: rgba(35, 123, 77, 0.34);
    box-shadow: var(--shadow-md);
    transform: translateY(-1px);
}

.header-search-button:hover,
.button-primary:hover,
.button-secondary:hover,
.chat-form button:hover,
.primary-link:hover,
.ghost-link:hover,
.dev-login-form button:hover {
    transform: translateY(-1px);
}

@media (max-width: 1320px) {
    .portal-layout--home,
    .portal-priority-grid--home,
    .portal-content-grid,
    .portal-priority-grid--match,
    .admin-layout {
        grid-template-columns: 1fr;
    }

    .portal-sidebar,
    .side-column,
    .admin-sidebar {
        position: static;
    }

    .portal-shell--home .portal-match-grid,
    .portal-shell--match .portal-match-grid {
        grid-template-columns: 1fr;
    }

    .portal-shell--home .portal-match-summary {
        order: -1;
    }
}

@media (max-width: 1080px) {
    .page-shell--sub,
    .admin-grid--dashboard,
    .admin-grid--split,
    .admin-grid--triple,
    .admin-metric-grid,
    .portal-team-grid,
    .topic-wall--portal,
    .league-hero,
    .board-hero,
    .team-hero {
        grid-template-columns: 1fr;
    }

    .league-hero__crest,
    .board-hero__status,
    .team-hero__coach {
        justify-items: start;
        text-align: left;
    }

    .team-hero__coach img {
        width: 144px;
        height: 176px;
    }

    .admin-table__head--four,
    .admin-table__row--four,
    .admin-table__head--five,
    .admin-table__row--five,
    .admin-table__head--six,
    .admin-table__row--six,
    .dense-table__head,
    .dense-table__row {
        grid-template-columns: 1fr;
    }

    .admin-table__head,
    .dense-table__head {
        display: none;
    }
}

@media (max-width: 820px) {
    .shell,
    .page-shell {
        width: min(100vw - 20px, 100%);
    }

    .utility-inner,
    .nav-row,
    .site-footer__inner,
    .admin-hero {
        display: grid;
        justify-content: stretch;
    }

    .topbar,
    .board-search,
    .chat-form,
    .post-row,
    .timeline-item,
    .audit-log__item,
    .squad-card--face {
        grid-template-columns: 1fr;
    }

    .nav-actions,
    .admin-hero__chips {
        justify-content: flex-start;
    }

    .site-nav a {
        min-height: 40px;
    }

    .portal-match-card,
    .portal-card,
    .module-card,
    .admin-card,
    .article-card,
    .comment-card,
    .page-hero {
        padding: 14px;
    }

    .portal-match-hero-head h1,
    .page-hero h1,
    .article-card h1 {
        font-size: 1.48rem;
    }

    .arena-board__field {
        height: 460px;
        min-height: 460px;
    }

    .tactical-node {
        width: 72px;
        min-height: 42px;
        padding: 5px 6px;
    }

    .tactical-node__name {
        font-size: 0.62rem;
    }

    .tactical-node__meta,
    .tactical-node__number {
        font-size: 0.48rem;
    }

    .portal-headtohead,
    .portal-headtohead__sides {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 560px) {
    .shell,
    .page-shell {
        width: min(100vw - 14px, 100%);
    }

    .utility-user,
    .site-nav,
    .nav-actions {
        flex-wrap: wrap;
    }

    .brand-lockup__tag {
        white-space: normal;
    }

    .compact-link,
    .rank-row {
        grid-template-columns: 1fr;
    }

    .compact-link__badge,
    .compact-link__meta,
    .rank-row__score {
        justify-self: start;
    }

    .arena-board__field {
        height: 430px;
        min-height: 430px;
    }

    .arena-board__team-label {
        min-width: 58px;
        padding: 6px 7px;
    }

    .tactical-node {
        width: 64px;
        min-height: 38px;
        padding: 4px 5px;
    }

    .tactical-node__rating {
        min-width: 22px;
        min-height: 16px;
        font-size: 0.52rem;
    }

    .tactical-node__name {
        font-size: 0.58rem;
    }
}

@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        scroll-behavior: auto !important;
        transition-duration: 0.01ms !important;
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
    }
}
