:root {
  color-scheme: dark;
  --black: #030100;
  --black-2: #090403;
  --deep-red: #350604;
  --red: #ff2a1f;
  --orange: #ff8700;
  --amber: #ffb02e;
  --green: #9cff35;
  --text: #fff7ef;
  --muted: #b8a39b;
  --dim: #77625c;
  --line: #ffffff24;
  --line-red: #ff2a1f6b;
  --panel: #0d0706e6;
  --shadow: 0 32px 90px #00000094;
  --font-heading: "Arial Narrow", "Roboto Condensed", Impact, Haettenschweiler, sans-serif;
  --font-ui: Inter, "Segoe UI", Arial, sans-serif;
  --font-telemetry: "Cascadia Mono", "Roboto Mono", Consolas, "Courier New", monospace;
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  min-width: 320px;
  color: var(--text);
  font-family: var(--font-ui);
  letter-spacing: 0;
  background:
    radial-gradient(circle at 12% 10%, #ff2a1f2e, #0000 28rem),
    radial-gradient(circle at 86% 36%, #ff87001f, #0000 25rem),
    linear-gradient(#060201 0%, #180504 48%, #060201 100%);
  margin: 0;
  font-weight: 400;
  overflow-x: hidden;
}

body::before {
  content: "";
  z-index: -2;
  pointer-events: none;
  opacity: 0.42;
  background:
    linear-gradient(90deg, #0000 0 7%, #ffffff0d 7.1% 7.18%, #0000 7.3% 92%, #ff2a1f14 92.1% 92.2%, #0000 92.32%),
    repeating-linear-gradient(90deg, #ffffff06 0 1px, #0000 1px 80px),
    repeating-linear-gradient(0deg, #ffffff05 0 1px, #0000 1px 80px);
  position: fixed;
  inset: 0;
  mask-image: linear-gradient(#000 0 76%, #0000 100%);
}

body::after {
  content: "";
  z-index: -1;
  pointer-events: none;
  opacity: 0.5;
  mix-blend-mode: screen;
  background:
    radial-gradient(at 0 78%, #ff2a1f38, #0000 38%),
    radial-gradient(at 100% 72%, #00c5ff17, #0000 34%),
    linear-gradient(110deg, #ff2a1f21, #0000 38% 64%, #ff870014);
  position: fixed;
  inset: 0;
}

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

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

.app-shell {
  background: #0000001f;
  min-height: 100vh;
}

.site-header {
  z-index: 30;
  isolation: isolate;
  background: #040101f7;
  border-bottom: 1px solid #ff2a1f33;
  position: sticky;
  top: 0;
  box-shadow: 0 18px 45px #0000008c;
}

.live-ticker {
  background: linear-gradient(90deg, #ff2a1f1f, #0000 24% 76%, #ff2a1f1f), #120403;
  border-bottom: 1px solid #ff2a1f61;
  height: 32px;
  overflow: hidden;
}

.ticker-track {
  align-items: center;
  width: max-content;
  min-width: 100%;
  height: 100%;
  animation: ticker-scroll 34s linear infinite;
  display: flex;
}

.ticker-track span {
  color: #bca7a0;
  min-height: 100%;
  font-family: var(--font-telemetry);
  letter-spacing: 0.32rem;
  text-transform: uppercase;
  white-space: nowrap;
  align-items: center;
  gap: 16px;
  padding: 0 clamp(18px, 2.8vw, 34px);
  font-size: 0.7rem;
  font-weight: 900;
  line-height: 1;
  display: inline-flex;
}

.ticker-track span::before {
  content: "";
  background: var(--red);
  border-radius: 999px;
  width: 7px;
  height: 7px;
  box-shadow: 0 0 18px #ff2a1fe6;
}

.nav-shell {
  grid-template-columns: minmax(340px, 1fr) auto minmax(340px, 1fr);
  align-items: center;
  column-gap: clamp(22px, 3vw, 42px);
  width: min(1680px, calc(100% - 48px));
  min-height: 96px;
  margin: 0 auto;
  padding: 6px 0;
  display: grid;
  position: relative;
}

.main-nav {
  align-items: center;
  gap: clamp(20px, 2.2vw, 36px);
  min-width: 0;
  display: flex;
}

.main-nav-left {
  justify-content: flex-end;
}

.main-nav-right {
  justify-content: flex-start;
  padding-inline-end: clamp(220px, 15vw, 290px);
}

.main-nav a {
  color: #c1aea8;
  font-family: var(--font-heading);
  letter-spacing: 0.2rem;
  text-transform: uppercase;
  white-space: nowrap;
  text-shadow: 0 2px #000;
  font-size: 0.84rem;
  font-weight: 950;
  transition: color 0.18s, transform 0.18s;
}

.main-nav a:hover,
.main-nav a.active {
  color: #fff;
  transform: translateY(-1px);
}

.brand-lockup {
  filter: drop-shadow(0 18px 24px #000000c7);
  justify-self: center;
  place-items: center;
  width: clamp(74px, 6.8vw, 92px);
  height: clamp(74px, 6.8vw, 92px);
  display: grid;
  overflow: hidden;
}

.brand-lockup img {
  object-fit: contain;
  object-position: center;
  width: 100%;
  max-width: none;
  height: 100%;
}

.play-now-button,
.solid-action {
  color: #120302;
  background: linear-gradient(135deg, var(--red), var(--orange) 72%, var(--amber));
  min-height: 46px;
  font-family: var(--font-heading);
  letter-spacing: 0.22rem;
  text-transform: uppercase;
  white-space: nowrap;
  border: 1px solid #ffa6008f;
  justify-content: center;
  align-items: center;
  gap: 9px;
  padding: 0 24px;
  font-size: 0.96rem;
  font-weight: 950;
  transition: transform 0.18s, filter 0.18s;
  display: inline-flex;
  box-shadow: 0 18px 42px #ff2a1f38, inset 0 1px #ffffff47;
}

.play-now-button {
  --button-y: -50%;
  clip-path: polygon(0 0, calc(100% - 26px) 0, 100% 24%, 100% 100%, 0 100%);
  min-width: 184px;
  min-height: 44px;
  transform: translateY(var(--button-y));
  padding-inline: 28px 25px;
  position: absolute;
  top: 50%;
  right: 0;
}

.play-now-button:hover {
  filter: brightness(1.08);
  transform: translateY(calc(var(--button-y) - 2px));
}

.forum-hero {
  isolation: isolate;
  background:
    linear-gradient(90deg, #120000f0 0%, #680503ad 27%, #0a030359 52%, #020203ad 100%),
    radial-gradient(circle at 24% 85%, #ff2a1f52, #0000 42rem),
    #050201;
  border-bottom: 1px solid #ff2a1f4d;
  min-height: 430px;
  display: grid;
  place-items: center;
  position: relative;
  overflow: hidden;
}

.forum-hero::after {
  content: "";
  z-index: -1;
  pointer-events: none;
  opacity: 0.42;
  background:
    repeating-linear-gradient(90deg, #ffffff07 0 1px, #0000 1px 80px),
    repeating-linear-gradient(0deg, #ffffff06 0 1px, #0000 1px 80px),
    linear-gradient(#0000 0 73%, #ff2a1f3d);
  position: absolute;
  inset: 0;
}

.hero-red-wash {
  z-index: -2;
  filter: blur(2px);
  background: radial-gradient(at 28% 100%, #ff2a1f80, #0000 62%), linear-gradient(90deg, #ff2a1f6b, #0000);
  width: 70vw;
  height: 48vh;
  position: absolute;
  bottom: 0;
  left: -8vw;
}

.side-rail {
  z-index: 2;
  color: #fff4ee8f;
  font-family: var(--font-telemetry);
  letter-spacing: 0.42rem;
  text-transform: uppercase;
  writing-mode: vertical-rl;
  text-orientation: mixed;
  font-size: 0.74rem;
  font-weight: 900;
  position: absolute;
  top: 50%;
}

.side-rail-left {
  left: max(22px, calc(50vw - 592px));
  transform: translateY(-50%) rotate(180deg);
}

.side-rail-right {
  right: max(22px, calc(50vw - 592px));
  transform: translateY(-50%);
}

.forum-hero-inner {
  text-align: center;
  justify-items: center;
  width: min(1220px, calc(100% - 48px));
  margin: 0 auto;
  padding: clamp(54px, 8vw, 88px) 0;
  display: grid;
}

.status-strip {
  border-top: 1px solid var(--line-red);
  border-bottom: 1px solid var(--line-red);
  background: linear-gradient(90deg, #5f060570, #0a0202b3 42%, #5f060552);
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: clamp(22px, 4vw, 46px);
  width: min(798px, 100%);
  min-height: 52px;
  margin-bottom: clamp(16px, 3svh, 26px);
  display: flex;
}

.status-strip span {
  color: #ded0ca;
  font-family: var(--font-heading);
  letter-spacing: 0.34rem;
  text-transform: uppercase;
  white-space: nowrap;
  align-items: center;
  gap: 11px;
  font-size: 0.9rem;
  font-weight: 950;
  display: inline-flex;
}

.status-strip .server-live {
  color: var(--red);
}

.status-strip i {
  background: var(--amber);
  border-radius: 999px;
  width: 9px;
  height: 9px;
  box-shadow: 0 0 16px #ffb02ed1;
}

.forum-kicker {
  color: var(--red);
  font-family: var(--font-telemetry);
  letter-spacing: 0.42rem;
  text-transform: uppercase;
  margin: 0 0 14px;
  font-size: 0.72rem;
  font-weight: 900;
}

.forum-hero h1 {
  color: #fff7ef;
  max-width: 790px;
  font-family: var(--font-heading);
  letter-spacing: 0;
  text-transform: uppercase;
  text-shadow: 0 5px #000000db, 0 0 30px #ff2a1f47;
  margin: 0;
  font-size: clamp(3.4rem, 7vw, 6.6rem);
  font-weight: 950;
  line-height: 0.88;
}

.forum-hero h1 span {
  color: var(--orange);
  display: block;
}

.forum-copy {
  color: var(--muted);
  max-width: 640px;
  margin: 18px 0 0;
  font-size: 0.98rem;
  font-weight: 750;
  line-height: 1.55;
}

.forum-stats {
  background: #0603039e;
  border: 1px solid #ffffff1a;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  width: min(860px, 100%);
  margin-top: 28px;
  display: grid;
  box-shadow: 0 18px 40px #0000005c;
}

.forum-stats span {
  min-height: 64px;
  color: var(--muted);
  text-transform: uppercase;
  border-right: 1px solid #ffffff14;
  gap: 4px;
  padding: 12px 10px;
  font-size: 0.7rem;
  font-weight: 900;
  display: grid;
}

.forum-stats span:last-child {
  border-right: 0;
}

.forum-stats b {
  color: #fff;
  font-family: var(--font-telemetry);
  font-size: 0.96rem;
}

.content-section {
  width: min(1320px, calc(100% - 44px));
  margin: 0 auto;
  padding: clamp(62px, 9vw, 102px) 0 0;
  position: relative;
}

.section-intro {
  gap: 9px;
  max-width: 780px;
  margin-bottom: 24px;
  display: grid;
}

.section-intro span {
  color: var(--red);
  font-family: var(--font-telemetry);
  letter-spacing: 0.42rem;
  text-transform: uppercase;
  font-size: 0.72rem;
  font-weight: 900;
}

.section-intro h2 {
  color: #fff7ef;
  font-family: var(--font-heading);
  letter-spacing: 0;
  text-transform: uppercase;
  text-shadow: 0 4px #000c;
  margin: 0;
  font-size: clamp(2.3rem, 5vw, 4.6rem);
  font-weight: 950;
  line-height: 0.9;
  overflow-wrap: anywhere;
}

.section-intro p {
  color: var(--muted);
  margin: 0;
  font-size: 0.94rem;
  font-weight: 650;
  line-height: 1.55;
}

.forum-panel,
.forum-foot {
  border: 1px solid var(--line);
  box-shadow: var(--shadow), inset 0 1px 0 #ffffff14;
  background: linear-gradient(#ffffff0f, #0000 36px), radial-gradient(circle at 18% 0, #ff2a1f1f, #0000 45%), #0d0706db;
  position: relative;
  overflow: hidden;
}

.forum-panel::before,
.forum-foot::before {
  content: "";
  pointer-events: none;
  opacity: 0.36;
  background:
    repeating-linear-gradient(0deg, #ffffff08 0 1px, #0000 1px 5px),
    linear-gradient(112deg, #0000 0 35%, #ffffff14 48%, #0000 61%);
  position: absolute;
  inset: 0;
}

.forum-panel > *,
.forum-foot > * {
  z-index: 1;
  position: relative;
}

.forum-panel-header {
  background: linear-gradient(#ffffff14, #ff2a1f1a 48%, #00000029);
  border-bottom: 1px solid #ffffff14;
  grid-template-columns: minmax(0, 1fr) 320px 80px 90px;
  align-items: center;
  min-height: 46px;
  gap: 18px;
  padding: 0 18px;
  display: grid;
}

.forum-panel-header h3 {
  color: #fff7ef;
  font-family: var(--font-heading);
  letter-spacing: 0.22rem;
  text-transform: uppercase;
  margin: 0;
  font-size: 0.92rem;
  font-weight: 950;
}

.forum-column-labels {
  grid-column: 2 / -1;
  grid-template-columns: 320px 80px 90px;
  gap: 18px;
  display: grid;
}

.forum-column-labels span {
  color: var(--dim);
  font-family: var(--font-telemetry);
  letter-spacing: 0.18rem;
  text-transform: uppercase;
  font-size: 0.62rem;
  font-weight: 900;
  text-align: right;
}

.forum-column-labels span:first-child {
  text-align: left;
}

.forum-list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.forum-index-panel {
  margin-bottom: 18px;
}

.forum-row {
  border-bottom: 1px solid #ffffff10;
  grid-template-columns: 44px minmax(0, 1fr) 320px 80px 90px;
  align-items: center;
  gap: 18px;
  min-height: 94px;
  padding: 18px;
  display: grid;
  transition: background 0.18s;
}

.forum-row:last-child {
  border-bottom: 0;
}

.forum-row:nth-child(odd) {
  background: #ffffff06;
}

.forum-row:hover {
  background: #ff2a1f12;
}

.forum-icon,
.legend-icon {
  border: 1px solid var(--line);
  background: radial-gradient(circle at 30% 30%, #4b1b16, #140706);
  display: grid;
  place-items: center;
  box-shadow: inset 0 1px #ffffff14;
}

.forum-icon {
  width: 42px;
  height: 42px;
}

.is-hot .forum-icon,
.legend-icon.hot {
  border-color: #ff2a1f80;
  background: radial-gradient(circle at 30% 30%, #ff2a1f70, #180403);
  box-shadow: 0 0 18px #ff2a1f59, inset 0 1px #ffffff20;
}

.forum-icon svg {
  width: 19px;
  height: 19px;
  stroke: #fff2e9;
  stroke-width: 2;
}

.forum-name a {
  color: #fff7ef;
  font-family: var(--font-heading);
  letter-spacing: 0.08rem;
  text-transform: uppercase;
  font-size: 1.34rem;
  font-weight: 950;
  line-height: 0.96;
}

.forum-name span {
  color: #dbc9c1;
  font-family: var(--font-heading);
  letter-spacing: 0.08rem;
  text-transform: uppercase;
  font-size: 1.16rem;
  font-weight: 950;
  line-height: 0.96;
}

.forum-name p {
  color: var(--muted);
  margin: 6px 0 0;
  font-size: 0.8rem;
  font-weight: 750;
  line-height: 1.4;
}

.forum-last-post {
  min-width: 0;
}

.forum-last-post a {
  color: #fff4ed;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 0.78rem;
  font-weight: 850;
  display: block;
  overflow: hidden;
}

.forum-last-post a:hover,
.forum-name a:hover {
  color: var(--orange);
}

.forum-last-post span {
  color: var(--dim);
  font-family: var(--font-telemetry);
  letter-spacing: 0.05rem;
  text-transform: uppercase;
  margin-top: 5px;
  font-size: 0.64rem;
  font-weight: 850;
  display: block;
}

.forum-count {
  color: #fff4ed;
  font-family: var(--font-telemetry);
  text-align: right;
  white-space: nowrap;
  font-size: 0.86rem;
  font-weight: 950;
}

.forum-count.posts {
  color: var(--orange);
}

.forum-row.is-disabled {
  opacity: 0.62;
  filter: saturate(0.72);
}

.forum-row.is-disabled:hover {
  background: #ffffff06;
}

.forum-row.is-disabled .forum-icon {
  border-color: #ffffff18;
  background: radial-gradient(circle at 30% 30%, #2a1714, #090403);
  box-shadow: inset 0 1px #ffffff0f;
}

.forum-foot {
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 20px;
  margin-top: 18px;
  padding: 18px;
  display: grid;
}

.forum-foot h4 {
  color: var(--muted);
  font-family: var(--font-heading);
  letter-spacing: 0.22rem;
  text-transform: uppercase;
  margin: 0 0 12px;
  font-size: 0.82rem;
  font-weight: 950;
}

.legend-row {
  color: var(--muted);
  flex-wrap: wrap;
  gap: 18px;
  font-size: 0.78rem;
  font-weight: 800;
  display: flex;
}

.legend-row span {
  align-items: center;
  gap: 8px;
  display: inline-flex;
}

.legend-icon {
  width: 18px;
  height: 18px;
}

.community-stats {
  text-align: right;
}

.community-stats p {
  color: var(--muted);
  font-family: var(--font-telemetry);
  letter-spacing: 0.06rem;
  text-transform: uppercase;
  margin: 0;
  font-size: 0.74rem;
  font-weight: 850;
}

.community-stats b {
  color: var(--orange);
}

.forum-display-shell {
  display: grid;
  gap: 10px;
  border: 1px solid #ffffff16;
  background: linear-gradient(180deg, #070302f2, #0c0504e6);
  padding: 10px;
  box-shadow: var(--shadow), inset 0 1px 0 #ffffff12;
}

.forum-display-topline,
.forum-subnav,
.forum-action-row {
  border: 1px solid #ffffff18;
  background: linear-gradient(#ffffff0c, #0000 30px), #0a0504d9;
  box-shadow: inset 0 1px 0 #ffffff14;
}

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

.forum-breadcrumb {
  color: var(--dim);
  flex-wrap: wrap;
  align-items: center;
  gap: 7px;
  font-size: 0.72rem;
  font-weight: 850;
  display: flex;
}

.forum-breadcrumb a,
.forum-breadcrumb strong,
.forum-display-header a,
.forum-subnav a,
.forum-pager strong,
.new-thread-button {
  color: #fff7ef;
  text-decoration: none;
}

.forum-breadcrumb a:hover,
.forum-display-header a:hover,
.forum-subnav a:hover {
  color: var(--orange);
}

.forum-login-strip {
  align-items: end;
  gap: 8px;
  display: flex;
}

.forum-login-strip label {
  color: var(--dim);
  gap: 5px;
  font-size: 0.62rem;
  font-weight: 900;
  text-transform: uppercase;
  display: grid;
}

.forum-login-strip input {
  border: 1px solid #ffffff1d;
  background: #070403;
  color: #fff7ef;
  width: 116px;
  min-height: 30px;
  padding: 0 10px;
  font: inherit;
  font-size: 0.68rem;
  font-weight: 800;
}

.forum-login-strip button,
.new-thread-button {
  border: 1px solid #ff7a183f;
  background: linear-gradient(135deg, var(--red), var(--orange));
  color: #140501;
  min-height: 32px;
  padding: 0 14px;
  font-family: var(--font-telemetry);
  font-size: 0.64rem;
  font-weight: 950;
  letter-spacing: 0.18rem;
  text-transform: uppercase;
  box-shadow: 0 12px 26px #ff2a1f22;
}

.forum-subnav {
  grid-template-columns: repeat(6, minmax(0, 1fr));
  display: grid;
}

.forum-subnav a {
  border-right: 1px solid #ffffff12;
  padding: 9px 10px;
  text-align: center;
  font-family: var(--font-heading);
  font-size: 0.68rem;
  font-weight: 950;
  letter-spacing: 0.12rem;
  text-transform: uppercase;
}

.forum-subnav a:last-child {
  border-right: 0;
}

.forum-action-row {
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 9px 10px;
  display: flex;
}

.forum-action-row-bottom {
  margin-top: 2px;
}

.forum-pager {
  color: var(--dim);
  align-items: center;
  gap: 7px;
  font-family: var(--font-telemetry);
  font-size: 0.64rem;
  font-weight: 900;
  letter-spacing: 0.12rem;
  text-transform: uppercase;
  display: flex;
}

.forum-pager strong {
  border: 1px solid #ffffff1f;
  background: #ffffff10;
  min-width: 26px;
  min-height: 26px;
  place-items: center;
  display: grid;
}

.forum-display-header {
  grid-template-columns: none;
  justify-content: space-between;
  min-height: 38px;
  padding: 0 14px;
  background: linear-gradient(#ffffff10, #5a100d40 48%, #070302);
  display: flex;
}

.forum-display-header h3 {
  letter-spacing: 0.14rem;
  font-size: 0.78rem;
  line-height: 1.15;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.forum-display-header a {
  font-family: var(--font-telemetry);
  font-size: 0.62rem;
  font-weight: 950;
  letter-spacing: 0.16rem;
  text-transform: uppercase;
}

.announcement-list {
  border-bottom: 1px solid #ffffff12;
  background: #0603038f;
}

.announcement-row {
  grid-template-columns: 34px minmax(0, 1fr) 86px;
  align-items: center;
  gap: 14px;
  min-height: 62px;
  padding: 12px 14px;
  display: grid;
}

.announcement-row b,
.empty-thread-state h4 {
  color: #fff7ef;
  font-family: var(--font-heading);
  letter-spacing: 0.1rem;
  text-transform: uppercase;
}

.announcement-row span,
.empty-thread-state p {
  color: var(--muted);
  margin-top: 3px;
  font-size: 0.76rem;
  font-weight: 700;
  display: block;
}

.announcement-row strong {
  color: var(--orange);
  font-family: var(--font-telemetry);
  font-size: 0.66rem;
  letter-spacing: 0.12rem;
  text-transform: uppercase;
  text-align: right;
}

.announcement-row .forum-icon,
.empty-thread-state .forum-icon {
  width: 34px;
  height: 34px;
}

.announcement-row .forum-icon svg,
.empty-thread-state .forum-icon svg {
  width: 16px;
  height: 16px;
}

.thread-table-head {
  border-bottom: 1px solid #ffffff12;
  background: linear-gradient(#ffffff10, #3d0b093d);
  grid-template-columns: 68px minmax(0, 1fr) 220px 74px 74px;
  gap: 12px;
  padding: 9px 14px;
  display: grid;
}

.thread-table-head span {
  color: var(--dim);
  font-family: var(--font-heading);
  font-size: 0.62rem;
  font-weight: 950;
  letter-spacing: 0.1rem;
  text-transform: uppercase;
}

.empty-thread-state {
  grid-template-columns: 34px minmax(0, 1fr);
  align-items: center;
  gap: 14px;
  min-height: 82px;
  padding: 14px;
  display: grid;
  background: #090403a8;
}

.empty-thread-state h4 {
  margin: 0;
  font-size: 0.82rem;
}

.empty-thread-state p {
  margin-bottom: 0;
}

.site-footer {
  color: #8e7973;
  border-top: 1px solid #ffffff14;
  grid-template-columns: minmax(0, 1fr) auto auto;
  align-items: center;
  gap: 18px;
  width: min(1180px, calc(100% - 44px));
  margin: 36px auto 0;
  padding: 18px 0 42px;
  display: grid;
}

.language-row,
.site-footer nav {
  text-transform: uppercase;
  flex-wrap: wrap;
  align-items: center;
  gap: 14px;
  font-size: 0.7rem;
  font-weight: 850;
  display: flex;
}

.language-row a:last-child,
.site-footer nav a:hover {
  color: #fff;
}

.site-footer nav a {
  color: #a99790;
}

.site-footer b {
  color: #fff;
  text-transform: uppercase;
  white-space: nowrap;
  background: linear-gradient(#777d81, #191b1d);
  min-height: 25px;
  padding: 7px 15px;
  font-size: 0.64rem;
  font-weight: 900;
  box-shadow: 0 2px 10px #0000008c, inset 0 1px #ffffff38;
}

.site-footer p {
  color: #685651;
  text-align: center;
  grid-column: 1 / -1;
  margin: 4px 0 0;
  font-size: 0.64rem;
  line-height: 1.45;
}

@keyframes ticker-scroll {
  0% {
    transform: translate(0);
  }
  100% {
    transform: translate(-50%);
  }
}

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

@media (max-width: 1100px) {
  .nav-shell {
    grid-template-columns: 1fr auto 1fr;
    gap: 18px;
    min-height: 0;
    padding: 13px 0;
  }

  .main-nav-right {
    padding-inline-end: 0;
  }

  .play-now-button {
    --button-y: 0px;
    grid-column: 1 / -1;
    justify-self: center;
    position: static;
  }

  .main-nav {
    gap: 18px;
  }

  .main-nav a {
    letter-spacing: 0.22rem;
    font-size: 0.78rem;
  }

  .forum-row,
  .forum-panel-header {
    grid-template-columns: 44px minmax(0, 1fr) 220px 74px 74px;
  }

  .forum-display-header {
    grid-template-columns: none;
    display: flex;
  }

  .forum-column-labels {
    grid-template-columns: 220px 74px 74px;
  }

  .forum-display-topline {
    grid-template-columns: 1fr;
  }

  .forum-login-strip {
    flex-wrap: wrap;
  }

  .thread-table-head {
    grid-template-columns: 70px minmax(0, 1fr) 200px 70px 70px;
  }
}

@media (max-width: 820px) {
  .site-header {
    position: relative;
  }

  .nav-shell {
    grid-template-columns: 1fr;
    justify-items: center;
    width: min(calc(100% - 26px), 680px);
  }

  .main-nav,
  .main-nav-left,
  .main-nav-right {
    flex-wrap: wrap;
    justify-content: center;
  }

  .brand-lockup {
    order: -1;
    width: min(108px, 34vw);
    height: min(108px, 34vw);
  }

  .side-rail {
    display: none;
  }

  .forum-stats,
  .forum-foot,
  .site-footer {
    grid-template-columns: 1fr;
  }

  .forum-stats span {
    border-right: 0;
    border-bottom: 1px solid #ffffff14;
  }

  .forum-stats span:last-child {
    border-bottom: 0;
  }

  .forum-panel-header {
    display: block;
    padding: 14px 18px;
  }

  .forum-display-header {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
  }

  .forum-display-header h3 {
    white-space: normal;
  }

  .forum-display-header a {
    display: inline-block;
    margin-top: 8px;
  }

  .forum-subnav {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .forum-login-strip,
  .forum-login-strip label,
  .forum-login-strip input {
    width: 100%;
  }

  .announcement-row,
  .empty-thread-state {
    grid-template-columns: 42px minmax(0, 1fr);
  }

  .announcement-row strong {
    grid-column: 2;
  }

  .thread-table-head {
    grid-template-columns: minmax(0, 1fr);
  }

  .thread-table-head span:not(:nth-child(2)) {
    display: none;
  }

  .forum-column-labels {
    display: none;
  }

  .forum-row {
    grid-template-columns: 42px minmax(0, 1fr);
    align-items: start;
  }

  .forum-last-post,
  .forum-count {
    grid-column: 2;
    text-align: left;
  }

  .community-stats {
    text-align: left;
  }
}

@media (max-width: 540px) {
  .ticker-track span {
    letter-spacing: 0.22rem;
    padding: 0 16px;
    font-size: 0.62rem;
  }

  .main-nav {
    gap: 14px;
  }

  .main-nav a {
    letter-spacing: 0.16rem;
    font-size: 0.72rem;
  }

  .brand-lockup {
    width: min(96px, 34vw);
    height: min(96px, 34vw);
  }

  .play-now-button,
  .solid-action {
    width: 100%;
  }

  .forum-hero-inner,
  .content-section {
    width: min(calc(100% - 24px), 520px);
  }

  .status-strip {
    gap: 14px;
    padding: 12px;
  }

  .status-strip span,
  .forum-kicker,
  .section-intro span {
    letter-spacing: 0.12rem;
    font-size: 0.64rem;
  }

  .forum-hero h1 {
    font-size: clamp(2.65rem, 12.5vw, 3.05rem);
  }

  .forum-copy {
    max-width: 330px;
    margin-left: auto;
    margin-right: auto;
    font-size: 0.9rem;
  }

  .section-intro h2 {
    font-size: clamp(2.35rem, 11vw, 2.85rem);
    line-height: 0.92;
  }

  .forum-subnav,
  .forum-action-row {
    grid-template-columns: 1fr;
  }

  .forum-action-row {
    align-items: stretch;
    display: grid;
  }

  .new-thread-button,
  .forum-pager {
    justify-content: center;
  }
}

.forum-runtime-status {
  border: 1px solid #ffffff18;
  background: linear-gradient(90deg, #ffffff0f, #0000 40%), #080403e0;
  color: var(--muted);
  padding: 10px 12px;
  font-family: var(--font-telemetry);
  font-size: 0.68rem;
  font-weight: 900;
  letter-spacing: 0.08rem;
  text-transform: uppercase;
}

.forum-runtime-status[data-tone="success"] {
  color: var(--green);
  border-color: #9cff3552;
}

.forum-runtime-status[data-tone="error"] {
  color: var(--red);
  border-color: #ff2a1f61;
}

.thread-composer,
.reply-composer {
  border: 1px solid #ffffff18;
  background: linear-gradient(#ffffff0c, #0000 30px), #0a0504d9;
  display: grid;
  gap: 10px;
  padding: 12px;
  box-shadow: inset 0 1px 0 #ffffff14;
}

.thread-composer label,
.reply-composer label {
  color: var(--dim);
  display: grid;
  gap: 6px;
  font-size: 0.62rem;
  font-weight: 900;
  text-transform: uppercase;
}

.thread-composer input,
.thread-composer textarea,
.reply-composer textarea {
  border: 1px solid #ffffff1d;
  background: #070403;
  color: #fff7ef;
  width: 100%;
  min-height: 34px;
  padding: 9px 10px;
  font: inherit;
  font-size: 0.78rem;
  font-weight: 750;
}

.thread-composer textarea,
.reply-composer textarea {
  min-height: 112px;
  resize: vertical;
}

.thread-composer div {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.thread-composer button,
.reply-composer button {
  border: 1px solid #ff7a183f;
  background: linear-gradient(135deg, var(--red), var(--orange));
  color: #140501;
  min-height: 34px;
  padding: 0 14px;
  font-family: var(--font-telemetry);
  font-size: 0.64rem;
  font-weight: 950;
  letter-spacing: 0.18rem;
  text-transform: uppercase;
  cursor: pointer;
}

.thread-composer button[type="button"] {
  color: #e8d8d1;
  background: linear-gradient(#ffffff14, #0a0505e0);
  border-color: #ffffff24;
}

.thread-list {
  display: grid;
}

.thread-row {
  border: 0;
  border-bottom: 1px solid #ffffff12;
  background: #090403a8;
  color: inherit;
  grid-template-columns: 68px minmax(0, 1fr) 220px 74px 74px;
  align-items: center;
  gap: 12px;
  min-height: 64px;
  padding: 11px 14px;
  display: grid;
  text-align: left;
  cursor: pointer;
}

.thread-row:hover {
  background: #ff2a1f12;
}

.thread-rating,
.thread-row > span:last-child,
.thread-row > span:nth-last-child(2) {
  color: var(--orange);
  font-family: var(--font-telemetry);
  font-size: 0.66rem;
  font-weight: 950;
  letter-spacing: 0.1rem;
  text-transform: uppercase;
}

.thread-main,
.thread-last {
  min-width: 0;
  display: grid;
  gap: 3px;
}

.thread-main b {
  color: #fff7ef;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-family: var(--font-heading);
  font-size: 0.92rem;
  letter-spacing: 0.08rem;
  text-transform: uppercase;
}

.thread-main small,
.thread-last,
.thread-last small {
  color: var(--muted);
  font-size: 0.68rem;
  font-weight: 800;
}

.thread-detail {
  display: grid;
  gap: 10px;
  padding: 12px;
  background: #0603038f;
}

.thread-post {
  border: 1px solid #ffffff14;
  background: linear-gradient(#ffffff0a, #0000 38px), #090403;
  padding: 13px;
}

.thread-post header {
  border-bottom: 1px solid #ffffff12;
  display: flex;
  flex-wrap: wrap;
  gap: 8px 14px;
  justify-content: space-between;
  padding-bottom: 8px;
}

.thread-post b {
  color: #fff7ef;
  font-family: var(--font-heading);
  letter-spacing: 0.12rem;
  text-transform: uppercase;
}

.thread-post span {
  color: var(--dim);
  font-family: var(--font-telemetry);
  font-size: 0.64rem;
  font-weight: 900;
  letter-spacing: 0.08rem;
  text-transform: uppercase;
}

.thread-post p {
  color: var(--muted);
  margin: 11px 0 0;
  font-size: 0.86rem;
  font-weight: 700;
  line-height: 1.55;
}

@media (max-width: 820px) {
  .thread-row {
    grid-template-columns: minmax(0, 1fr);
  }

  .thread-rating,
  .thread-row > span:last-child,
  .thread-row > span:nth-last-child(2) {
    text-align: left;
  }
}

.account-page .account-hero {
  min-height: 560px;
}

.account-hero-inner {
  padding-top: clamp(70px, 9vw, 118px);
  padding-bottom: clamp(70px, 9vw, 118px);
}

.account-section {
  padding-top: clamp(54px, 7vw, 84px);
}

.account-panel {
  border: 1px solid var(--line);
  box-shadow: var(--shadow), inset 0 1px 0 #ffffff14;
  background: linear-gradient(#ffffff0f, #0000 36px), radial-gradient(circle at 18% 0, #ff2a1f1f, #0000 45%), #0d0706db;
  padding: clamp(16px, 3vw, 28px);
  position: relative;
  overflow: hidden;
}

.account-panel::before {
  content: "";
  pointer-events: none;
  opacity: 0.36;
  background: repeating-linear-gradient(0deg, #ffffff08 0 1px, #0000 1px 5px), linear-gradient(112deg, #0000 0 35%, #ffffff14 48%, #0000 61%);
  position: absolute;
  inset: 0;
}

.account-panel > * {
  position: relative;
  z-index: 1;
}

.account-form {
  display: grid;
  gap: 18px;
}

.account-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.account-form label {
  color: var(--dim);
  display: grid;
  gap: 7px;
  font-size: 0.64rem;
  font-weight: 900;
  letter-spacing: 0.14rem;
  text-transform: uppercase;
}

.account-form input,
.account-form select {
  border: 1px solid #ffffff1d;
  background: #070403;
  color: #fff7ef;
  min-height: 42px;
  padding: 0 12px;
  font: inherit;
  font-size: 0.8rem;
  font-weight: 800;
  outline: none;
}

.account-form input:focus,
.account-form select:focus {
  border-color: #ff87008f;
  box-shadow: 0 0 0 3px #ff2a1f24;
}

.field-hint {
  color: var(--dim);
  font-family: var(--font-telemetry);
  font-size: 0.62rem;
  font-weight: 800;
  letter-spacing: 0.06rem;
  text-transform: uppercase;
  cursor: pointer;
  padding: 4px 0 0;
}

.field-hint strong {
  color: #ff8700cc;
  font-weight: 900;
}

.field-hint:hover strong {
  color: #ff8700;
}

.account-rules {
  border: 1px solid #ffffff14;
  background: #0603038f;
  display: grid;
  gap: 7px;
  padding: 12px;
}

.account-rules span {
  color: var(--muted);
  font-family: var(--font-telemetry);
  font-size: 0.68rem;
  font-weight: 850;
  letter-spacing: 0.06rem;
  text-transform: uppercase;
}

.account-status {
  border: 1px solid #ffffff18;
  background: linear-gradient(90deg, #ffffff0f, #0000 40%), #080403e0;
  color: var(--muted);
  padding: 12px;
  font-family: var(--font-telemetry);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.08rem;
  text-transform: uppercase;
}

.account-status[data-tone="success"] {
  color: var(--green);
  border-color: #9cff3552;
}

.account-status[data-tone="error"] {
  color: var(--red);
  border-color: #ff2a1f61;
}

.account-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.account-actions button,
.account-actions a {
  border: 1px solid #ff7a183f;
  background: linear-gradient(135deg, var(--red), var(--orange));
  color: #140501;
  min-height: 42px;
  padding: 0 16px;
  font-family: var(--font-telemetry);
  font-size: 0.68rem;
  font-weight: 950;
  letter-spacing: 0.18rem;
  text-transform: uppercase;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.account-actions a {
  color: #e8d8d1;
  background: linear-gradient(#ffffff14, #0a0505e0);
  border-color: #ffffff24;
}

.account-actions button:disabled {
  cursor: wait;
  filter: grayscale(0.4);
  opacity: 0.7;
}

.starter-car-section {
  display: grid;
  gap: 14px;
}

.starter-car-heading,
.starter-color-section > span {
  color: var(--dim);
  display: grid;
  gap: 6px;
  font-size: 0.64rem;
  font-weight: 900;
  letter-spacing: 0.14rem;
  text-transform: uppercase;
}

.starter-car-heading p,
.starter-color-section p {
  color: #fff7efbf;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.04rem;
  line-height: 1.45;
  text-transform: none;
}

.starter-car-grid {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.starter-car-option {
  border: 1px solid #ffffff1d;
  background: linear-gradient(180deg, #120907, #070403);
  color: #fff7ef;
  cursor: pointer;
  display: grid;
  gap: 6px;
  min-height: 92px;
  padding: 14px 12px;
  text-align: left;
  transition: border-color 0.15s ease, box-shadow 0.15s ease, transform 0.15s ease;
}

.starter-car-option strong {
  font-size: 0.82rem;
  letter-spacing: 0.04rem;
}

.starter-car-option span {
  color: #ff8700cc;
  font-family: var(--font-telemetry);
  font-size: 0.62rem;
  font-weight: 800;
  letter-spacing: 0.08rem;
  text-transform: uppercase;
}

.starter-car-option.is-selected,
.starter-car-option:hover {
  border-color: #ff87008f;
  box-shadow: 0 0 0 3px #ff2a1f24;
  transform: translateY(-1px);
}

.starter-color-section {
  display: grid;
  gap: 10px;
}

.starter-color-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.starter-color-option {
  border: 2px solid #ffffff2b;
  background: var(--swatch-color, #c0c0c0);
  border-radius: 999px;
  cursor: pointer;
  height: 34px;
  width: 34px;
}

.starter-color-option.is-selected {
  border-color: #fff7ef;
  box-shadow: 0 0 0 3px #ff2a1f55;
}

@media (max-width: 820px) {
  .account-form-grid {
    grid-template-columns: 1fr;
  }

  .starter-car-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 540px) {
  .account-actions button,
  .account-actions a {
    width: 100%;
  }
}
