.roa-aim-page {
  --roa-container: var(--roa-container-width, var(--roa-site-container, 1180px));
  --roa-font-heading: var(--roa-typography-heading-font, var(--font-heading, "Montserrat", Arial, Helvetica, sans-serif));
  --roa-font-body: var(--roa-typography-body-font, var(--font-body, Arial, Helvetica, sans-serif));
  --roa-aim-bg: #08090b;
  --roa-aim-surface: rgba(255,255,255,.055);
  --roa-aim-surface-strong: rgba(255,255,255,.09);
  --roa-aim-border: rgba(255,255,255,.14);
  --roa-aim-muted: #9aa0ad;
  --roa-aim-soft: #d8dbe4;
  --roa-aim-red: #ff0000;
  --roa-aim-blue: #38bdf8;
  --roa-aim-green: #35d07f;
  --roa-aim-gold: #fbbf24;
  color: var(--roa-aim-soft);
  background:
    linear-gradient(145deg, #08090b 0%, #131313 50%, #0c1018 100%);
}

.roa-aim-route-host {
  background:
    radial-gradient(circle at 16% 8%, rgba(255,255,255,.035), transparent 30%),
    radial-gradient(circle at 82% 26%, rgba(255,255,255,.026), transparent 35%),
    linear-gradient(145deg, #090811 0%, #131313 34%, #100811 68%, #090811 100%);
}

.roa-aim-route-host > .roa-aim-page {
  width: 100%;
  max-width: 100%;
  margin: 0;
}

body.roa-aim-run-active .roa-aim-play > .roa-aim-hero,
body.roa-aim-run-active .roa-aim-play > .roa-aim-subnav {
  display: none !important;
}

body.roa-aim-run-active .roa-aim-play .roa-front-section {
  padding-top: clamp(22px, 3vw, 42px);
}

.roa-aim-page .roa-container {
  width: min(var(--roa-container), calc(100% - 40px));
  margin-inline: auto;
}

.roa-aim-page .roa-section,
.roa-aim-page .roa-front-section {
  position: relative;
  padding-block: clamp(64px, 7vw, 112px);
}

.roa-aim-page :where(h1, h2, h3, strong, b) {
  letter-spacing: 0;
}

.roa-aim-hero .roa-hero-copy h1 {
  letter-spacing: 0;
}

.roa-aim-subtitle {
  color: #fff;
  font-family: var(--roa-font-heading, var(--font-heading));
  font-size: 1.1rem;
  font-weight: 900;
  text-transform: uppercase;
}

.roa-aim-hero-visual {
  min-height: 320px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  align-items: end;
}

.roa-aim-hero-visual img {
  width: 100%;
  max-height: 210px;
  object-fit: contain;
  filter: drop-shadow(0 24px 36px rgba(0,0,0,.38));
}

.roa-aim-hero-visual img:first-child {
  grid-column: 1 / -1;
  max-height: 260px;
}

.roa-aim-subnav {
  position: sticky;
  top: 64px;
  z-index: 30;
  border-block: 1px solid rgba(255,255,255,.10);
  background: rgba(8,9,11,.88);
  backdrop-filter: blur(14px);
}

.roa-aim-subnav .roa-container {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding-block: 12px;
  scrollbar-width: thin;
}

.roa-aim-subnav a,
.roa-aim-filter-row a,
.roa-aim-button,
.roa-aim-inline-form button,
.roa-aim-form-actions a,
.roa-aim-icon-button {
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 0 16px;
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 8px;
  background: rgba(255,255,255,.045);
  color: #fff;
  font-family: var(--roa-font-heading, var(--font-heading));
  font-size: .78rem;
  font-weight: 900;
  letter-spacing: 0;
  line-height: 1;
  text-decoration: none;
  text-transform: uppercase;
  cursor: pointer;
}

.roa-aim-subnav a.is-active,
.roa-aim-filter-row a.is-active,
.roa-aim-button,
.roa-aim-form-actions a:hover,
.roa-aim-inline-form button:hover {
  border-color: rgba(255,0,0,.52);
  background: linear-gradient(180deg, rgba(255,0,0,.28), rgba(255,0,0,.10));
}

.roa-aim-button.is-secondary,
.roa-aim-icon-button {
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.18);
}

.roa-aim-status-grid,
.roa-aim-character-grid,
.roa-aim-rules-grid,
.roa-aim-season-grid,
.roa-aim-prize-grid,
.roa-aim-ranking-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

.roa-aim-ranking-stats {
  grid-template-columns: repeat(5, minmax(0, 1fr));
  margin-bottom: 18px;
}

.roa-aim-character-grid,
.roa-aim-rules-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.roa-aim-stat,
.roa-aim-ranking-stats article,
.roa-aim-character-card,
.roa-aim-prize-card,
.roa-aim-rule-card,
.roa-aim-season-card,
.roa-aim-copy,
.roa-aim-admin-card,
.roa-aim-start-panel,
.roa-aim-end-panel,
.roa-aim-prize-preview article {
  border: 1px solid var(--roa-aim-border);
  border-radius: 8px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.072), rgba(255,255,255,.026));
  box-shadow: 0 22px 58px rgba(0,0,0,.25), inset 0 1px 0 rgba(255,255,255,.08);
}

.roa-aim-stat,
.roa-aim-ranking-stats article,
.roa-aim-character-card,
.roa-aim-prize-card,
.roa-aim-rule-card,
.roa-aim-season-card,
.roa-aim-copy,
.roa-aim-admin-card,
.roa-aim-start-panel,
.roa-aim-end-panel {
  padding: 24px;
}

.roa-aim-stat span,
.roa-aim-ranking-stats span,
.roa-aim-character-card span,
.roa-aim-prize-card span,
.roa-aim-season-card span,
.roa-aim-status,
.roa-aim-start-panel label span,
.roa-aim-admin-card label span {
  display: block;
  color: var(--roa-aim-muted);
  font-size: .78rem;
  font-weight: 800;
  line-height: 1.2;
  text-transform: uppercase;
}

.roa-aim-stat strong {
  display: block;
  margin-top: 10px;
  color: #fff;
  font-family: var(--roa-font-heading, var(--font-heading));
  font-size: 1.55rem;
  line-height: 1.08;
}

.roa-aim-ranking-stats strong {
  display: block;
  margin-top: 10px;
  color: #fff;
  font-family: "Comic Sans MS", var(--roa-font-heading, var(--font-heading));
  font-size: clamp(1.45rem, 2.7vw, 2.15rem);
  line-height: 1;
  text-shadow: 0 3px 0 rgba(0,0,0,.65);
}

.roa-aim-stat p,
.roa-aim-character-card p,
.roa-aim-prize-card p,
.roa-aim-season-card p,
.roa-aim-copy p,
.roa-aim-rule-card li {
  color: rgba(216,219,228,.78);
}

.roa-aim-prize-image {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  border-radius: 8px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
}

.roa-aim-split {
  display: grid;
  grid-template-columns: minmax(0, .9fr) minmax(280px, 1.1fr);
  gap: 24px;
  align-items: start;
}

.roa-aim-highlight {
  border-block: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.025);
}

.roa-aim-prize-preview {
  display: grid;
  gap: 12px;
}

.roa-aim-prize-preview article {
  padding: 18px;
}

.roa-aim-prize-preview span {
  color: var(--roa-aim-gold);
  font-weight: 900;
}

.roa-aim-prize-preview strong {
  display: block;
  color: #fff;
  font-size: 1.1rem;
}

.roa-aim-character-card {
  min-height: 260px;
  display: flex;
  flex-direction: column;
}

.roa-aim-character-card img {
  width: 96px;
  height: 96px;
  object-fit: contain;
  margin-bottom: 18px;
}

.roa-aim-character-card h3,
.roa-aim-prize-card h2,
.roa-aim-rule-card h2,
.roa-aim-season-card h2,
.roa-aim-copy h2,
.roa-aim-admin-card h2 {
  margin: 10px 0 12px;
  color: #fff;
  font-family: var(--roa-font-heading, var(--font-heading));
  font-size: 1.35rem;
  line-height: 1.1;
}

.roa-aim-footer-cta {
  text-align: center;
  border-top: 1px solid rgba(255,255,255,.08);
}

.roa-aim-footer-cta .roa-hero-actions {
  justify-content: center;
}

.roa-aim-filter-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 18px;
}

.roa-aim-table-wrap {
  width: 100%;
  overflow-x: auto;
  border: 1px solid var(--roa-aim-border);
  border-radius: 8px;
  background: rgba(255,255,255,.035);
}

.roa-aim-table {
  width: 100%;
  min-width: 720px;
  border-collapse: collapse;
}

.roa-aim-table th,
.roa-aim-table td {
  padding: 14px 16px;
  border-bottom: 1px solid rgba(255,255,255,.08);
  color: rgba(216,219,228,.86);
  text-align: left;
  vertical-align: middle;
}

.roa-aim-table th {
  color: #fff;
  font-family: var(--roa-font-heading, var(--font-heading));
  font-size: .78rem;
  font-weight: 900;
  text-transform: uppercase;
}

.roa-aim-status {
  width: max-content;
  padding: 6px 10px;
  border: 1px solid rgba(53,208,127,.34);
  border-radius: 999px;
  color: #fff;
  background: rgba(53,208,127,.10);
}

.roa-aim-game-shell {
  position: relative;
  display: block;
}

.roa-aim-game-shell.is-playing,
.roa-aim-game-shell.has-started {
  grid-template-columns: 1fr;
}

.roa-aim-game-shell [hidden] {
  display: none !important;
}

.roa-aim-start-form,
.roa-aim-admin-card,
.roa-aim-start-panel,
.roa-aim-device-lock {
  display: grid;
  gap: 14px;
}

.roa-aim-start-panel,
.roa-aim-end-panel,
.roa-aim-device-lock {
  position: absolute;
  left: 50%;
  top: 50%;
  z-index: 8;
  width: min(520px, calc(100% - 44px));
  max-height: min(78vh, calc(100% - 54px));
  overflow: auto;
  transform: translate(-50%, -50%);
  border: 4px solid #171717;
  border-radius: 18px;
  background:
    radial-gradient(circle at 18% 8%, rgba(255,255,255,.85), transparent 17%),
    linear-gradient(180deg, #fff4ad 0%, #ffd166 48%, #ff8a3d 100%);
  box-shadow:
    0 9px 0 #171717,
    0 26px 72px rgba(0,0,0,.50),
    inset 0 2px 0 rgba(255,255,255,.72);
  color: #1e140c;
}

.roa-aim-start-panel h2,
.roa-aim-end-panel h2,
.roa-aim-device-lock h2 {
  font-family: "Comic Sans MS", var(--roa-font-heading, var(--font-heading));
  color: #ff1744;
  font-size: clamp(1.85rem, 4vw, 3.2rem);
  line-height: .92;
  text-shadow: 0 3px 0 #fff, 0 6px 0 #171717, 0 14px 18px rgba(0,0,0,.28);
  text-transform: uppercase;
}

.roa-aim-start-panel .roa-kicker,
.roa-aim-end-panel .roa-kicker,
.roa-aim-device-lock .roa-kicker,
.roa-aim-start-panel p,
.roa-aim-end-panel p,
.roa-aim-device-lock p,
.roa-aim-start-panel label span {
  color: #1e140c;
  text-shadow: 0 1px 0 rgba(255,255,255,.7);
}

.roa-aim-end-panel {
  width: min(760px, calc(100% - 44px));
}

.roa-aim-start-form label,
.roa-aim-admin-card label {
  display: grid;
  gap: 8px;
}

.roa-aim-handle-choice {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.roa-aim-handle-choice label {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  cursor: pointer;
}

.roa-aim-handle-choice input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.roa-aim-handle-choice span {
  width: 100%;
  padding: 9px 12px;
  border: 3px solid #171717;
  border-radius: 10px;
  background: #fff7c7;
  color: #171717;
  font-family: "Comic Sans MS", "Trebuchet MS", Arial, sans-serif;
  font-weight: 900;
  text-align: center;
  box-shadow: 0 4px 0 #171717;
}

.roa-aim-handle-choice input:checked + span {
  background: #ff1744;
  color: #fff;
  text-shadow: 0 2px 0 rgba(0,0,0,.65);
}

.roa-aim-start-form :where(input[type="text"], input[type="email"], textarea),
.roa-aim-admin-card :where(input, textarea, select) {
  width: 100%;
  min-height: 46px;
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 8px;
  background: rgba(0,0,0,.24);
  color: #fff;
  padding: 10px 12px;
}

.roa-aim-admin-card textarea {
  min-height: 92px;
  resize: vertical;
}

.roa-aim-admin-card .roa-aim-media-button {
  justify-self: start;
  min-height: 34px;
}

.roa-aim-check {
  grid-template-columns: 20px 1fr;
  align-items: start;
}

.roa-aim-check input {
  margin-top: 3px;
}

.roa-aim-form-actions,
.roa-aim-stage-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}

.roa-aim-form-message {
  min-height: 1.5em;
  margin: 0;
  color: var(--roa-aim-soft);
}

.roa-aim-form-message.is-error {
  color: #ff8a8a;
}

.roa-aim-share-preview {
  display: grid;
  gap: 10px;
  margin-top: 12px;
}

.roa-aim-share-preview img {
  width: 100%;
  max-height: 260px;
  object-fit: contain;
  border: 4px solid #171717;
  border-radius: 10px;
  background: #fff4ad;
  box-shadow: 0 7px 0 #171717, 0 18px 34px rgba(0,0,0,.28);
}

.roa-aim-stage {
  min-width: 0;
  padding: clamp(10px, 1.4vw, 18px);
  border: 1px solid rgba(236, 190, 112, .38);
  border-radius: 8px;
  background:
    linear-gradient(180deg, rgba(255, 214, 148, .16), rgba(255,255,255,.045) 28%, rgba(36,24,12,.20)),
    #16100b;
  box-shadow: 0 28px 80px rgba(0,0,0,.42), inset 0 1px 0 rgba(255,255,255,.08);
}

.roa-aim-hud {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 12px;
}

.roa-aim-hud span,
.roa-aim-end-grid article,
.roa-aim-breakdown article {
  min-height: 70px;
  padding: 12px;
  border: 1px solid rgba(255,255,255,.13);
  border-radius: 8px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.075), rgba(255,255,255,.025));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08);
}

.roa-aim-hud b,
.roa-aim-end-grid strong,
.roa-aim-breakdown strong {
  display: block;
  color: #fff;
  font-family: var(--roa-font-heading, var(--font-heading));
  font-size: 1.25rem;
  line-height: 1;
}

.roa-aim-hud em,
.roa-aim-end-grid span,
.roa-aim-breakdown span {
  display: block;
  margin-top: 8px;
  color: var(--roa-aim-muted);
  font-style: normal;
  font-size: .72rem;
  font-weight: 800;
  text-transform: uppercase;
}

.roa-aim-canvas-wrap {
  position: relative;
  isolation: isolate;
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  border: 1px solid rgba(236, 190, 112, .46);
  border-radius: 8px;
  background:
    radial-gradient(circle at 50% 24%, rgba(255,255,255,.30), transparent 42%),
    linear-gradient(180deg, rgba(118,190,224,.20), rgba(211,174,111,.08)),
    #d5bd8b;
  box-shadow: 0 32px 90px rgba(0,0,0,.50), 0 0 0 1px rgba(255,255,255,.04) inset;
  touch-action: none;
}

.roa-aim-canvas-wrap::before,
.roa-aim-canvas-wrap::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 3;
}

.roa-aim-canvas-wrap::before {
  background:
    linear-gradient(90deg, rgba(255,255,255,.10), transparent 8%, transparent 92%, rgba(255,255,255,.10)),
    radial-gradient(circle at 50% 36%, transparent 44%, rgba(0,0,0,.28) 100%);
  box-shadow:
    inset 0 0 0 2px rgba(255,255,255,.055),
    inset 0 18px 34px rgba(255,255,255,.08),
    inset 0 -34px 58px rgba(0,0,0,.48);
}

.roa-aim-canvas-wrap::after {
  opacity: .28;
  background:
    repeating-linear-gradient(0deg, rgba(255,255,255,.10) 0 1px, transparent 1px 5px),
    linear-gradient(135deg, transparent 0 46%, rgba(255,255,255,.08) 50%, transparent 54%);
  mix-blend-mode: screen;
}

.roa-aim-canvas-wrap canvas {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
  display: block;
  cursor: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='48' height='48' viewBox='0 0 48 48'%3E%3Ccircle cx='24' cy='24' r='13' fill='none' stroke='%23000000' stroke-width='5'/%3E%3Ccircle cx='24' cy='24' r='13' fill='none' stroke='%23ffffff' stroke-width='3'/%3E%3Cpath d='M24 2v14M24 32v14M2 24h14M32 24h14' stroke='%23000000' stroke-width='6' stroke-linecap='round'/%3E%3Cpath d='M24 2v14M24 32v14M2 24h14M32 24h14' stroke='%23ff1744' stroke-width='3' stroke-linecap='round'/%3E%3Ccircle cx='24' cy='24' r='3.5' fill='%23ff1744' stroke='%23ffffff' stroke-width='1.5'/%3E%3C/svg%3E") 24 24, crosshair;
  background: #d5bd8b url("../../public/aim-challenge/assets/v3/environment/background/map-full.png") center / cover no-repeat;
  image-rendering: auto;
}

.roa-aim-stage-backdrop {
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  pointer-events: none;
  user-select: none;
}

.roa-aim-game-ui {
  position: absolute;
  inset: 12px 14px auto;
  z-index: 4;
  display: grid;
  grid-template-columns: minmax(120px, 180px) minmax(110px, 170px) minmax(150px, 230px);
  justify-content: space-between;
  align-items: start;
  gap: 10px;
  pointer-events: none;
  font-family: "Comic Sans MS", "Trebuchet MS", Arial, sans-serif;
  font-weight: 900;
  text-shadow: 0 3px 0 rgba(0,0,0,.70), 0 8px 18px rgba(0,0,0,.45);
}

.roa-aim-game-score,
.roa-aim-game-time,
.roa-aim-game-leaderboard {
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  filter: drop-shadow(0 4px 0 rgba(0,0,0,.58)) drop-shadow(0 9px 16px rgba(0,0,0,.48));
}

.roa-aim-game-score,
.roa-aim-game-time {
  padding: 2px 0;
}

.roa-aim-game-score span,
.roa-aim-game-time span,
.roa-aim-game-leaderboard > span {
  display: block;
  color: #fff;
  font-size: clamp(.58rem, 1.2vw, .76rem);
  line-height: 1;
  text-transform: uppercase;
}

.roa-aim-game-score b,
.roa-aim-game-time b {
  display: block;
  margin-top: 2px;
  color: #ffe66b;
  font-size: clamp(1.35rem, 3.4vw, 2.5rem);
  line-height: .95;
}

.roa-aim-game-time {
  justify-self: center;
  text-align: center;
}

.roa-aim-game-time b {
  color: #ffffff;
}

.roa-aim-game-leaderboard {
  justify-self: end;
  min-width: min(230px, 32vw);
  padding: 2px 0 0;
}

.roa-aim-game-leaderboard ol {
  display: grid;
  gap: 3px;
  margin: 6px 0 0;
  padding: 0;
  list-style: none;
}

.roa-aim-game-leaderboard li {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr) auto;
  gap: 6px;
  align-items: center;
  min-width: 0;
  color: #fff;
  font-size: clamp(.62rem, 1.2vw, .82rem);
  line-height: 1;
}

.roa-aim-game-leaderboard li span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.roa-aim-game-leaderboard li.rank-1 { color: #ffe66b; }
.roa-aim-game-leaderboard li.rank-2 { color: #c7f9ff; }
.roa-aim-game-leaderboard li.rank-3 { color: #ffb86b; }
.roa-aim-game-leaderboard li.rank-4 { color: #a7f3d0; }
.roa-aim-game-leaderboard li.rank-5 { color: #f0abfc; }

.roa-aim-point-legend {
  position: absolute;
  left: 14px;
  bottom: 14px;
  z-index: 4;
  display: flex;
  flex-wrap: wrap;
  gap: 5px 9px;
  max-width: min(560px, 58vw);
  padding: 0;
  border: 0;
  background: transparent;
  color: #fff;
  font-family: "Comic Sans MS", "Trebuchet MS", Arial, sans-serif;
  font-size: clamp(.66rem, 1.15vw, .88rem);
  font-weight: 900;
  line-height: 1.1;
  text-shadow: 0 2px 0 rgba(0,0,0,.88), 0 7px 15px rgba(0,0,0,.72);
  pointer-events: none;
}

.roa-aim-point-legend span {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  min-height: 27px;
  color: #ffe66b;
  filter: drop-shadow(0 3px 2px rgba(0,0,0,.65));
}

.roa-aim-point-legend img {
  width: 27px;
  height: 27px;
  object-fit: contain;
  transform-origin: center bottom;
}

.roa-aim-reticle {
  position: absolute;
  left: 50%;
  top: 50%;
  width: clamp(34px, 4vw, 54px);
  height: clamp(34px, 4vw, 54px);
  z-index: 5;
  border: 2px solid rgba(255,255,255,.82);
  border-radius: 50%;
  transform: translate(-50%, -50%);
  pointer-events: none;
  box-shadow:
    0 0 0 1px rgba(0,0,0,.72),
    0 0 18px rgba(255,0,0,.48),
    inset 0 0 10px rgba(255,255,255,.12);
}

.roa-aim-reticle::before,
.roa-aim-reticle::after {
  content: "";
  position: absolute;
  inset: -10px;
  background:
    linear-gradient(90deg, transparent calc(50% - 1px), rgba(255,255,255,.84) calc(50% - 1px), rgba(255,255,255,.84) calc(50% + 1px), transparent calc(50% + 1px)),
    linear-gradient(0deg, transparent calc(50% - 1px), rgba(255,255,255,.84) calc(50% - 1px), rgba(255,255,255,.84) calc(50% + 1px), transparent calc(50% + 1px));
  filter: drop-shadow(0 0 5px rgba(255,0,0,.42));
}

.roa-aim-reticle::after {
  inset: 50%;
  width: 7px;
  height: 7px;
  margin: -3.5px 0 0 -3.5px;
  border-radius: 50%;
  background: #ff0000;
  box-shadow: 0 0 13px rgba(255,0,0,.9);
}

.roa-aim-reticle.is-hit,
.roa-aim-reticle.is-golden {
  border-color: #ffffff;
  box-shadow:
    0 0 0 1px rgba(0,0,0,.78),
    0 0 28px rgba(53,208,127,.82),
    inset 0 0 14px rgba(53,208,127,.24);
}

.roa-aim-reticle.is-golden {
  box-shadow:
    0 0 0 1px rgba(0,0,0,.78),
    0 0 32px rgba(251,191,36,.92),
    inset 0 0 16px rgba(251,191,36,.26);
}

.roa-aim-reticle.is-miss,
.roa-aim-reticle.is-warning {
  border-color: #ff6b6b;
  box-shadow:
    0 0 0 1px rgba(0,0,0,.78),
    0 0 30px rgba(255,0,0,.86),
    inset 0 0 16px rgba(255,0,0,.28);
}

.roa-aim-reticle.is-firing {
  animation: roaAimReticleFire 180ms ease-out both;
}

.roa-aim-canvas-wrap.is-shot-hit,
.roa-aim-canvas-wrap.is-shot-golden {
  animation: roaAimShotGood 180ms ease-out both;
}

.roa-aim-canvas-wrap.is-shot-miss,
.roa-aim-canvas-wrap.is-shot-warning {
  animation: roaAimShotBad 180ms ease-out both;
}

.roa-aim-feedback {
  position: absolute;
  inset: 0;
  z-index: 4;
  pointer-events: none;
  overflow: hidden;
}

.roa-aim-round-overlay,
.roa-aim-combo-banner {
  position: absolute;
  pointer-events: none;
  font-family: var(--roa-font-heading, var(--font-heading));
  text-align: center;
  text-transform: uppercase;
  z-index: 4;
}

.roa-aim-round-overlay {
  inset: 0;
  display: grid;
  place-content: center;
  gap: 10px;
  background: radial-gradient(circle at center, rgba(0,0,0,.52), rgba(0,0,0,.10) 46%, transparent 70%);
  animation: roaAimRoundPulse 900ms ease forwards;
}

.roa-aim-round-overlay strong {
  color: #fff;
  font-size: clamp(3.4rem, 12vw, 9rem);
  line-height: .86;
  text-shadow: 0 0 28px rgba(255,0,0,.55), 0 8px 22px rgba(0,0,0,.64);
}

.roa-aim-round-overlay span {
  color: rgba(216,219,228,.86);
  font-size: clamp(.82rem, 1.9vw, 1.15rem);
  font-weight: 900;
  letter-spacing: 0;
}

.roa-aim-round-overlay.is-go strong,
.roa-aim-round-overlay.is-rush strong {
  color: #ff0000;
}

.roa-aim-round-overlay.is-complete strong {
  color: #fbbf24;
}

.roa-aim-combo-banner {
  top: 88px;
  left: 50%;
  min-width: min(360px, calc(100% - 32px));
  transform: translateX(-50%);
  padding: 12px 18px;
  border: 1px solid rgba(255,0,0,.48);
  border-radius: 8px;
  background: linear-gradient(180deg, rgba(255,0,0,.38), rgba(0,0,0,.68));
  box-shadow: 0 18px 48px rgba(0,0,0,.42), 0 0 34px rgba(255,0,0,.24);
}

.roa-aim-combo-banner strong,
.roa-aim-combo-banner span {
  display: block;
}

.roa-aim-combo-banner strong {
  color: #fff;
  font-size: clamp(1.1rem, 2.7vw, 2rem);
  line-height: 1;
}

.roa-aim-combo-banner span {
  margin-top: 5px;
  color: rgba(255,255,255,.78);
  font-size: .72rem;
  font-weight: 900;
}

.roa-aim-combo-banner.is-hot {
  animation: roaAimComboHit 720ms cubic-bezier(.17,.67,.24,1.28) both;
}

.roa-aim-popup {
  position: absolute;
  transform: translate(-50%, -50%);
  color: #fff;
  font-family: var(--roa-font-heading, var(--font-heading));
  font-size: clamp(.95rem, 1.8vw, 1.45rem);
  font-weight: 900;
  text-shadow: 0 3px 16px rgba(0,0,0,.5);
  animation: roaAimPopup 780ms ease forwards;
}

.roa-aim-popup.is-warning {
  color: #ff6b6b;
}

.roa-aim-popup.is-headshot {
  padding: .35em .58em .38em;
  border: 0;
  border-radius: 0;
  background: #fff4a8;
  color: #ff1744;
  font-family: "Comic Sans MS", "Trebuchet MS", Arial, sans-serif;
  font-size: clamp(.48rem, 1vw, .82rem);
  line-height: .95;
  text-transform: uppercase;
  clip-path: polygon(50% 0, 58% 17%, 75% 8%, 73% 27%, 94% 28%, 79% 43%, 100% 56%, 78% 61%, 87% 82%, 66% 74%, 58% 100%, 47% 78%, 30% 92%, 30% 69%, 5% 75%, 20% 55%, 0 43%, 24% 36%, 15% 16%, 36% 23%);
  text-shadow:
    0 2px 0 #fff,
    0 3px 0 rgba(0,0,0,.18),
    0 7px 14px rgba(0,0,0,.32);
  box-shadow: 0 5px 0 rgba(0,0,0,.30), 0 0 18px rgba(255,229,0,.58);
  animation: roaAimHeadshotBubble 900ms cubic-bezier(.16,.84,.32,1.25) forwards;
}

.roa-aim-popup.is-headshot::after {
  content: none;
}

@keyframes roaAimPopup {
  from { opacity: 0; transform: translate(-50%, -30%) scale(.9); }
  18% { opacity: 1; }
  to { opacity: 0; transform: translate(-50%, -95%) scale(1.05); }
}

@keyframes roaAimHeadshotBubble {
  from { opacity: 0; transform: translate(-50%, -30%) scale(.62) rotate(-5deg); }
  16% { opacity: 1; transform: translate(-50%, -62%) scale(1.15) rotate(2deg); }
  70% { opacity: 1; transform: translate(-50%, -82%) scale(1) rotate(-1deg); }
  to { opacity: 0; transform: translate(-50%, -120%) scale(.86) rotate(4deg); }
}

.roa-aim-end-panel h2 small {
  display: block;
  margin-top: 8px;
  color: #1e140c;
  font-size: .86rem;
  font-weight: 900;
  text-transform: uppercase;
  text-shadow: 0 1px 0 rgba(255,255,255,.75);
}

.roa-aim-end-summary {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin: 20px 0 14px;
}

.roa-aim-end-summary article,
.roa-aim-end-leaderboard {
  color: #171717;
  font-family: "Comic Sans MS", "Trebuchet MS", Arial, sans-serif;
  font-weight: 900;
  text-shadow: 0 2px 0 rgba(255,255,255,.86), 0 5px 10px rgba(0,0,0,.18);
}

.roa-aim-end-summary span,
.roa-aim-end-leaderboard > span {
  display: block;
  color: #171717;
  font-size: .78rem;
  line-height: 1;
  text-transform: uppercase;
}

.roa-aim-end-summary strong {
  display: block;
  color: #ff1744;
  font-size: clamp(2.5rem, 7vw, 5rem);
  line-height: .86;
  text-shadow: 0 3px 0 #fff, 0 7px 0 #171717, 0 14px 18px rgba(0,0,0,.25);
}

.roa-aim-end-leaderboard {
  margin: 14px 0 18px;
}

.roa-aim-end-leaderboard ol {
  display: grid;
  gap: 7px;
  margin: 10px 0 0;
  padding: 0;
  list-style: none;
}

.roa-aim-end-leaderboard li {
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  font-size: clamp(.92rem, 2vw, 1.25rem);
  line-height: 1;
}

.roa-aim-end-leaderboard li span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.roa-aim-end-leaderboard li.rank-1 { color: #ff1744; }
.roa-aim-end-leaderboard li.rank-2 { color: #005cff; }
.roa-aim-end-leaderboard li.rank-3 { color: #008f4e; }
.roa-aim-end-leaderboard li.rank-4 { color: #7c2dff; }
.roa-aim-end-leaderboard li.rank-5 { color: #c05600; }

.roa-aim-full-stats {
  margin: 14px 0 18px;
}

.roa-aim-full-stats summary {
  width: max-content;
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 16px;
  border: 2px solid #171717;
  border-radius: 8px;
  background: #fff;
  color: #171717;
  font-family: "Comic Sans MS", var(--roa-font-heading, var(--font-heading));
  font-size: .78rem;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
  box-shadow: 0 5px 0 #171717;
  cursor: pointer;
}

.roa-aim-full-stats summary::marker {
  content: "";
}

.roa-aim-full-stats summary::-webkit-details-marker {
  display: none;
}

@keyframes roaAimRoundPulse {
  from { opacity: 0; transform: scale(.92); }
  15% { opacity: 1; transform: scale(1); }
  78% { opacity: 1; }
  to { opacity: 0; transform: scale(1.05); }
}

@keyframes roaAimComboHit {
  from { opacity: 0; transform: translate(-50%, -14px) scale(.92); }
  18% { opacity: 1; transform: translate(-50%, 0) scale(1.04); }
  76% { opacity: 1; transform: translate(-50%, 0) scale(1); }
  to { opacity: 0; transform: translate(-50%, -10px) scale(.98); }
}

@keyframes roaAimReticleFire {
  from { transform: translate(-50%, -50%) scale(.82); }
  42% { transform: translate(-50%, -50%) scale(1.22); }
  to { transform: translate(-50%, -50%) scale(1); }
}

@keyframes roaAimShotGood {
  from { filter: saturate(1.25) brightness(1.12); transform: translate3d(0, 0, 0); }
  38% { filter: saturate(1.35) brightness(1.18); transform: translate3d(2px, -2px, 0); }
  to { filter: none; transform: translate3d(0, 0, 0); }
}

@keyframes roaAimShotBad {
  from { filter: saturate(1.35) brightness(1.10); transform: translate3d(0, 0, 0); }
  30% { filter: saturate(1.45) brightness(1.16); transform: translate3d(-3px, 2px, 0); }
  62% { transform: translate3d(2px, -1px, 0); }
  to { filter: none; transform: translate3d(0, 0, 0); }
}

.roa-aim-end-panel {
  grid-column: 1 / -1;
}

.roa-aim-end-panel [data-submit-score] {
  display: none !important;
}

.roa-aim-end-grid,
.roa-aim-breakdown {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin: 18px 0;
}

.roa-aim-rules-grid ul {
  margin: 0;
  padding-left: 18px;
}

.roa-aim-legal-list {
  display: grid;
  gap: 14px;
}

.roa-aim-legal-list article {
  padding: 20px 0;
  border-bottom: 1px solid rgba(255,255,255,.10);
}

.roa-aim-legal-list h2 {
  margin: 0 0 8px;
  color: #fff;
  font-size: 1.2rem;
}

.roa-aim-admin-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 20px;
  margin-bottom: 20px;
}

.roa-aim-admin-grid.is-wp-admin,
.roa-aim-wp-admin .roa-aim-admin-grid {
  color: #1d2327;
}

.roa-aim-wp-admin .roa-aim-admin-card {
  background: #fff;
  border-color: #dcdcde;
  box-shadow: none;
}

.roa-aim-wp-admin .roa-aim-admin-card :where(h2, label span) {
  color: #1d2327;
}

.roa-aim-wp-admin .roa-aim-admin-card :where(input, textarea, select) {
  color: #1d2327;
  background: #fff;
  border-color: #8c8f94;
}

.roa-aim-admin-card fieldset {
  display: grid;
  gap: 10px;
  margin: 0;
  padding: 14px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 8px;
}

.roa-aim-admin-card legend {
  color: #fff;
  font-weight: 900;
}

.roa-aim-admin-runs {
  margin-top: 20px;
}

.roa-aim-inline-form {
  display: inline-flex;
  margin: 2px;
}

.roa-aim-inline-form button {
  min-height: 34px;
  padding: 0 10px;
  font-size: .7rem;
}

.roa-aim-admin-notice {
  padding: 12px 14px;
  border: 1px solid rgba(53,208,127,.34);
  border-radius: 8px;
  color: #fff;
  background: rgba(53,208,127,.12);
}

.roa-aim-intro-cinematic {
  padding-block: clamp(24px, 4vw, 54px);
}

.roa-aim-intro-stage {
  position: relative;
  overflow: hidden;
  min-height: 260px;
  padding: clamp(18px, 3vw, 30px);
  border: 2px solid rgba(255,255,255,.16);
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(255,0,0,.18), rgba(56,189,248,.10) 42%, rgba(251,191,36,.14)),
    rgba(8,9,11,.90);
  box-shadow: 0 30px 80px rgba(0,0,0,.36), inset 0 1px 0 rgba(255,255,255,.12);
}

.roa-aim-intro-stage::before {
  content: "";
  position: absolute;
  inset: 0;
  opacity: .23;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px) 0 0 / 40px 40px,
    linear-gradient(0deg, rgba(255,255,255,.04) 1px, transparent 1px) 0 0 / 40px 40px;
}

.roa-aim-intro-scenes {
  position: relative;
  min-height: 210px;
  z-index: 1;
}

.roa-aim-intro-scene {
  position: absolute;
  inset: 0;
  display: grid;
  grid-template-columns: minmax(120px, 210px) minmax(0, 1fr);
  gap: clamp(16px, 3vw, 34px);
  align-items: center;
  opacity: 0;
  pointer-events: none;
  transform: translateX(20px) scale(.985);
  transition: opacity .28s ease, transform .28s ease;
}

.roa-aim-intro-scene.is-active {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(0) scale(1);
}

.roa-aim-intro-scene img {
  width: min(100%, 210px);
  max-height: 210px;
  object-fit: contain;
  filter: drop-shadow(0 18px 20px rgba(0,0,0,.46));
}

.roa-aim-intro-scene span,
.roa-aim-case-card span,
.roa-aim-speech span,
.roa-aim-target-summary span {
  color: var(--roa-aim-gold);
  font-size: .78rem;
  font-weight: 950;
  text-transform: uppercase;
}

.roa-aim-intro-scene h2 {
  margin: 8px 0;
  color: #fff;
  font-family: "Comic Sans MS", var(--roa-font-heading, var(--font-heading));
  font-size: clamp(1.7rem, 4.6vw, 3.4rem);
  line-height: .98;
  text-shadow: 0 4px 0 rgba(0,0,0,.70), 0 0 22px rgba(255,0,0,.28);
}

.roa-aim-intro-scene p {
  max-width: 680px;
  margin: 0;
  color: rgba(255,255,255,.82);
  font-size: clamp(1rem, 1.7vw, 1.18rem);
}

.roa-aim-intro-controls {
  position: relative;
  z-index: 2;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-end;
  margin-top: 18px;
}

.roa-aim-intro-cinematic.is-collapsed {
  padding-block: 12px;
}

.roa-aim-intro-cinematic.is-collapsed .roa-aim-intro-stage {
  min-height: 0;
  padding: 14px;
}

.roa-aim-intro-cinematic.is-collapsed .roa-aim-intro-scenes,
.roa-aim-intro-cinematic.is-collapsed [data-intro-skip] {
  display: none;
}

.roa-aim-intro-cinematic.is-collapsed .roa-aim-intro-controls {
  margin-top: 0;
  justify-content: center;
}

.roa-aim-speech {
  position: relative;
  display: grid;
  grid-template-columns: 72px minmax(0, 1fr);
  gap: 14px;
  align-items: end;
  margin: 18px 0;
  padding: 14px 16px;
  color: #171717;
  background: #fff8df;
  border: 3px solid #111;
  box-shadow: 7px 8px 0 rgba(0,0,0,.45);
  clip-path: polygon(0 0, 96% 0, 100% 10%, 98% 34%, 100% 62%, 96% 100%, 15% 100%, 11% 90%, 0 100%, 4% 70%, 0 48%, 3% 24%);
}

.roa-aim-speech::after {
  content: "";
  position: absolute;
  left: 78px;
  bottom: -18px;
  width: 34px;
  height: 24px;
  background: #fff8df;
  border: 3px solid #111;
  border-top: 0;
  transform: skewX(-26deg);
}

.roa-aim-speech img {
  width: 72px;
  height: 72px;
  object-fit: contain;
  align-self: center;
  filter: drop-shadow(0 8px 8px rgba(0,0,0,.25));
}

.roa-aim-speech p {
  margin: 4px 0 8px;
  color: #171717;
  font-family: "Comic Sans MS", var(--roa-font-heading, var(--font-heading));
  font-size: 1.02rem;
  font-weight: 900;
  line-height: 1.18;
}

.roa-aim-speech a {
  color: #b00020;
  font-weight: 950;
  text-decoration: underline;
  text-decoration-thickness: 3px;
}

.roa-aim-speech.is-warning {
  background: #ffe3e3;
}

.roa-aim-speech.is-warning::after {
  background: #ffe3e3;
}

.roa-aim-case-mini,
.roa-aim-target-summary,
.roa-aim-steps {
  display: grid;
  gap: 14px;
}

.roa-aim-case-mini {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.roa-aim-case-mini article,
.roa-aim-target-summary article,
.roa-aim-steps article {
  padding: 18px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 8px;
  background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.03));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08);
}

.roa-aim-case-mini strong,
.roa-aim-steps strong,
.roa-aim-target-summary strong {
  display: block;
  margin: 8px 0;
  color: #fff;
  font-family: var(--roa-font-heading, var(--font-heading));
  font-size: 1.12rem;
  line-height: 1.1;
}

.roa-aim-case-mini p,
.roa-aim-target-summary p {
  margin: 0;
  color: rgba(216,219,228,.78);
}

.roa-aim-case-file {
  display: grid;
  gap: 18px;
}

.roa-aim-case-card {
  display: grid;
  grid-template-columns: minmax(110px, 170px) minmax(0, 1fr);
  gap: clamp(16px, 3vw, 28px);
  align-items: center;
  padding: clamp(18px, 3vw, 30px);
  border: 2px solid rgba(255,255,255,.16);
  border: 2px solid color-mix(in srgb, var(--case-accent, #ff1744) 48%, rgba(255,255,255,.16));
  background:
    linear-gradient(90deg, rgba(255,0,0,.10), rgba(255,255,255,.04)),
    rgba(255,255,255,.045);
  border-radius: 8px;
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--case-accent, #ff1744) 18%, transparent), rgba(255,255,255,.04)),
    rgba(255,255,255,.045);
  box-shadow: 0 20px 58px rgba(0,0,0,.28);
}

.roa-aim-case-media {
  min-height: 140px;
  display: grid;
  place-items: center;
}

.roa-aim-case-media img {
  width: min(100%, 170px);
  max-height: 170px;
  object-fit: contain;
  filter: drop-shadow(0 16px 20px rgba(0,0,0,.42));
}

.roa-aim-case-card h2 {
  margin: 8px 0;
  color: #fff;
  font-family: "Comic Sans MS", var(--roa-font-heading, var(--font-heading));
  font-size: clamp(1.35rem, 2.6vw, 2.15rem);
  line-height: 1.02;
  text-shadow: 0 3px 0 rgba(0,0,0,.66);
}

.roa-aim-case-summary {
  color: #fff;
  font-weight: 900;
}

.roa-aim-case-card blockquote,
.roa-aim-character-card blockquote {
  margin: 14px 0 0;
  padding-left: 14px;
  border-left: 4px solid var(--case-accent, var(--character-accent, #ff1744));
  color: rgba(255,255,255,.82);
  font-weight: 800;
}

.roa-aim-briefing {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, .8fr);
  gap: 24px;
  align-items: start;
}

.roa-aim-target-summary {
  grid-template-columns: 1fr;
}

.roa-aim-target-summary strong {
  font-size: clamp(2rem, 5vw, 3.2rem);
  text-shadow: 0 4px 0 rgba(0,0,0,.62);
}

.roa-aim-character-card.is-profile {
  border-color: rgba(255,255,255,.18);
  border-color: color-mix(in srgb, var(--character-accent, #ff1744) 45%, rgba(255,255,255,.16));
}

.roa-aim-character-card.is-profile img {
  width: 118px;
  height: 118px;
}

.roa-aim-character-card.is-profile dl {
  display: grid;
  gap: 8px;
  margin: 16px 0 0;
}

.roa-aim-character-card.is-profile dt {
  color: var(--character-accent, #ff1744);
  font-size: .72rem;
  font-weight: 950;
  text-transform: uppercase;
}

.roa-aim-character-card.is-profile dd {
  margin: -6px 0 0;
  color: rgba(255,255,255,.84);
}

.roa-aim-steps {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin: 0 0 22px;
}

.roa-aim-steps article {
  display: grid;
  grid-template-columns: 46px minmax(0, 1fr);
  align-items: center;
  gap: 12px;
}

.roa-aim-steps span {
  width: 46px;
  height: 46px;
  display: grid;
  place-items: center;
  border: 3px solid #111;
  border-radius: 50%;
  color: #111;
  background: var(--roa-aim-gold);
  font-family: "Comic Sans MS", var(--roa-font-heading, var(--font-heading));
  font-size: 1.3rem;
  font-weight: 950;
  box-shadow: 3px 4px 0 rgba(0,0,0,.55);
}

.roa-aim-faq-section {
  padding-top: 0;
}

.roa-aim-faq-list {
  display: grid;
  gap: 12px;
}

.roa-aim-faq-list details {
  padding: 16px 18px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 8px;
  background: rgba(255,255,255,.045);
}

.roa-aim-faq-list summary {
  color: #fff;
  font-family: var(--roa-font-heading, var(--font-heading));
  font-weight: 900;
  cursor: pointer;
}

.roa-aim-faq-list p {
  color: rgba(216,219,228,.82);
}

.roa-aim-faq-list em {
  color: var(--roa-aim-gold);
  font-style: normal;
  font-weight: 900;
}

.roa-aim-fiction-notice {
  padding-block: 28px;
  border-block: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.025);
}

.roa-aim-fiction-notice p {
  max-width: 980px;
  margin: 0 auto;
  color: rgba(216,219,228,.76);
  text-align: center;
}

.roa-aim-content-admin {
  grid-column: 1 / -1;
}

.roa-aim-content-admin > details,
.roa-aim-content-admin details fieldset {
  margin: 14px 0;
}

.roa-aim-content-admin > details {
  padding: 14px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 8px;
  background: rgba(255,255,255,.025);
}

.roa-aim-content-admin summary {
  color: #fff;
  font-family: var(--roa-font-heading, var(--font-heading));
  font-weight: 950;
  cursor: pointer;
}

.roa-aim-content-admin textarea {
  min-height: 92px;
}

@media (prefers-reduced-motion: reduce) {
  .roa-aim-intro-scene {
    transition: none;
    transform: none;
  }
}

/* Pedro Clash comic art direction */
.roa-aim-page {
  --roa-comic-ink: #15100f;
  --roa-comic-ink-soft: #33261f;
  --roa-comic-paper: #fff4b8;
  --roa-comic-paper-soft: #fff9e4;
  --roa-comic-panel: #211614;
  --roa-comic-red: #ff1744;
  --roa-comic-red-deep: #b00020;
  --roa-comic-blue: #0094ff;
  --roa-comic-cyan: #38d9ff;
  --roa-comic-green: #35d07f;
  --roa-comic-gold: #fbbf24;
  --roa-comic-orange: #ff6a00;
  --roa-comic-pink: #ff2f8d;
  --roa-comic-bg: #ffcf3d;
  --roa-comic-bg-hot: #ff6a00;
  --roa-comic-bg-cool: #0094ff;
  --roa-comic-bg-deep: #211614;
  --roa-comic-shadow: rgba(21,16,15,.48);
  position: relative;
  overflow: hidden;
  color: var(--roa-comic-paper-soft);
  background-color: var(--roa-comic-bg-deep);
  background-image:
    radial-gradient(circle at 12% 4%, rgba(255,23,68,.52), transparent 24rem),
    radial-gradient(circle at 84% 10%, rgba(56,217,255,.40), transparent 25rem),
    radial-gradient(circle at 52% 88%, rgba(251,191,36,.50), transparent 30rem),
    repeating-radial-gradient(circle at 18% 22%, rgba(255,249,228,.18) 0 1px, transparent 1.5px 9px),
    linear-gradient(135deg, #31100e 0%, #6b210f 34%, #0b3a55 68%, #21100f 100%);
}

.roa-aim-page::before,
.roa-aim-page::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}

.roa-aim-page::before {
  opacity: .26;
  background:
    radial-gradient(circle, rgba(255,255,255,.30) 0 1px, transparent 1.5px) 0 0 / 14px 14px,
    repeating-linear-gradient(135deg, rgba(255,255,255,.08) 0 1px, transparent 1px 10px);
  mix-blend-mode: screen;
}

.roa-aim-page::after {
  opacity: .55;
  background:
    radial-gradient(circle at 10% 12%, rgba(255,23,68,.55) 0, rgba(255,23,68,.55) 7px, transparent 8px, transparent 18px, rgba(255,23,68,.22) 19px, rgba(255,23,68,.22) 23px, transparent 24px),
    radial-gradient(circle at 91% 70%, rgba(56,217,255,.42) 0, rgba(56,217,255,.42) 6px, transparent 7px, transparent 16px, rgba(56,217,255,.18) 17px, rgba(56,217,255,.18) 22px, transparent 23px),
    radial-gradient(circle at 78% 18%, rgba(251,191,36,.42) 0, rgba(251,191,36,.42) 9px, transparent 10px, transparent 20px);
}

.roa-aim-page > * {
  position: relative;
  z-index: 1;
}

body.roa-aim-challenge-route,
.roa-aim-route-host {
  background-color: var(--roa-comic-bg-deep, #211614);
  background-image:
    radial-gradient(circle at 10% 2%, rgba(255,23,68,.34), transparent 24rem),
    radial-gradient(circle at 88% 18%, rgba(0,148,255,.30), transparent 26rem),
    linear-gradient(135deg, #2a100f 0%, #4a180f 42%, #0f2f42 72%, #211614 100%);
}

.roa-aim-page .roa-container {
  width: min(var(--roa-container), calc(100% - 44px));
}

.roa-aim-page .roa-section,
.roa-aim-page .roa-front-section {
  padding-block: 72px;
}

.roa-aim-page :where(h1, h2, h3, strong, b) {
  letter-spacing: 0;
}

.roa-aim-hero {
  min-height: 620px;
  display: grid;
  align-items: center;
  overflow: hidden;
  border-bottom: 5px solid var(--roa-comic-ink);
  background:
    linear-gradient(180deg, rgba(21,16,15,.28), rgba(21,16,15,.64)),
    linear-gradient(90deg, rgba(255,244,184,.98) 0 1px, transparent 1px) 0 0 / 38px 38px,
    linear-gradient(0deg, rgba(255,244,184,.70) 0 1px, transparent 1px) 0 0 / 38px 38px,
    var(--page-hero-bg) center bottom / cover no-repeat,
    linear-gradient(135deg, #29130f, #0d1720);
  box-shadow: inset 0 -12px 0 rgba(21,16,15,.28);
}

.roa-aim-hero::after {
  content: "";
  position: absolute;
  inset: auto 0 0;
  height: 34%;
  background:
    linear-gradient(180deg, transparent, rgba(21,16,15,.78)),
    repeating-linear-gradient(-10deg, rgba(255,255,255,.10) 0 2px, transparent 2px 12px);
  pointer-events: none;
}

.roa-aim-hero .roa-front-hero-inner,
.roa-aim-hero .roa-hero-inner {
  min-height: 520px;
  grid-template-columns: minmax(0, .95fr) minmax(360px, 1.05fr);
  gap: 34px;
  align-items: end;
  padding-block: 58px 40px;
}

.roa-aim-hero .roa-front-hero-copy,
.roa-aim-hero .roa-hero-copy {
  align-self: center;
  max-width: 720px;
  padding: 26px;
  border: 4px solid var(--roa-comic-ink);
  border-radius: 8px;
  background:
    linear-gradient(180deg, rgba(255,249,228,.96), rgba(255,244,184,.93)),
    radial-gradient(circle at 14% 16%, rgba(255,255,255,.88), transparent 8rem);
  box-shadow: 10px 12px 0 var(--roa-comic-shadow), inset 0 2px 0 rgba(255,255,255,.88);
  color: var(--roa-comic-ink);
  transform: rotate(-1deg);
}

.roa-aim-hero .roa-kicker,
.roa-aim-page .roa-section-head > span,
.roa-aim-page .roa-kicker {
  width: max-content;
  max-width: 100%;
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 5px 10px;
  border: 3px solid var(--roa-comic-ink);
  border-radius: 8px;
  background: var(--roa-comic-gold);
  color: var(--roa-comic-ink);
  font-family: "Comic Sans MS", var(--roa-font-heading, var(--font-heading));
  font-size: .78rem;
  font-weight: 950;
  line-height: 1;
  text-transform: uppercase;
  box-shadow: 4px 5px 0 rgba(21,16,15,.42);
}

.roa-aim-hero .roa-hero-copy h1 {
  margin-block: 16px 10px;
  color: var(--roa-comic-red);
  font-family: "Comic Sans MS", var(--roa-font-heading, var(--font-heading));
  font-size: 4.8rem;
  line-height: .88;
  text-transform: uppercase;
  -webkit-text-stroke: 2px var(--roa-comic-ink);
  text-shadow:
    0 3px 0 #fff,
    0 7px 0 var(--roa-comic-ink),
    0 16px 26px rgba(21,16,15,.38);
}

.roa-aim-hero .roa-hero-copy p {
  color: var(--roa-comic-ink-soft);
  font-size: 1.05rem;
  font-weight: 800;
  line-height: 1.5;
}

.roa-aim-subtitle {
  width: max-content;
  max-width: 100%;
  margin: 0 0 12px;
  padding: 7px 12px;
  border: 3px solid var(--roa-comic-ink);
  border-radius: 8px;
  background: var(--roa-comic-red);
  color: #fff;
  box-shadow: 4px 5px 0 rgba(21,16,15,.42);
  text-shadow: 0 2px 0 rgba(21,16,15,.70);
}

.roa-aim-hero-visual {
  position: relative;
  min-height: 430px;
  display: block;
  isolation: isolate;
}

.roa-aim-hero-visual::before {
  content: "";
  position: absolute;
  inset: 16% 4% 4% 3%;
  z-index: 0;
  border: 5px solid var(--roa-comic-ink);
  border-radius: 8px;
  background:
    radial-gradient(circle at 50% 50%, rgba(255,255,255,.38) 0 2px, transparent 2.5px) 0 0 / 16px 16px,
    linear-gradient(135deg, rgba(255,23,68,.82), rgba(251,191,36,.80) 46%, rgba(0,148,255,.74));
  clip-path: polygon(50% 0, 58% 16%, 78% 6%, 76% 26%, 99% 29%, 82% 45%, 100% 62%, 76% 62%, 84% 87%, 62% 76%, 50% 100%, 39% 77%, 16% 90%, 23% 65%, 0 64%, 18% 47%, 2% 28%, 25% 27%, 22% 7%, 42% 17%);
  box-shadow: 10px 14px 0 rgba(21,16,15,.45);
}

.roa-aim-hero-visual img {
  position: absolute;
  z-index: 2;
  width: auto;
  object-fit: contain;
  filter:
    drop-shadow(0 5px 0 #15100f)
    drop-shadow(0 18px 18px rgba(21,16,15,.48));
}

.roa-aim-hero-visual .is-pedro {
  left: 28%;
  bottom: 0;
  max-height: 310px;
  transform: rotate(-3deg);
}

.roa-aim-hero-visual .is-rick {
  left: 4%;
  bottom: 36px;
  max-height: 170px;
  transform: rotate(4deg);
}

.roa-aim-hero-visual .is-flick {
  right: 6%;
  bottom: 34px;
  max-height: 176px;
  transform: rotate(-5deg);
}

.roa-aim-hero-visual .is-bolt {
  right: 26%;
  bottom: 174px;
  max-height: 150px;
  transform: rotate(7deg);
}

.roa-aim-hero-burst {
  position: absolute;
  right: 8%;
  top: 24px;
  z-index: 3;
  max-width: 190px;
  padding: 16px 20px;
  border: 4px solid var(--roa-comic-ink);
  border-radius: 8px;
  background: var(--roa-comic-paper);
  color: var(--roa-comic-red);
  font-family: "Comic Sans MS", var(--roa-font-heading, var(--font-heading));
  font-size: 1.55rem;
  font-weight: 950;
  line-height: .92;
  text-align: center;
  text-transform: uppercase;
  transform: rotate(8deg);
  box-shadow: 7px 8px 0 rgba(21,16,15,.48);
  -webkit-text-stroke: 1px var(--roa-comic-ink);
}

.roa-aim-page :is(.roa-hero-actions a, .roa-aim-subnav a, .roa-aim-filter-row a, .roa-aim-button, .roa-aim-inline-form button, .roa-aim-form-actions a, .roa-aim-icon-button) {
  min-height: 44px;
  border: 3px solid var(--roa-comic-ink);
  border-radius: 8px;
  background: var(--roa-comic-paper-soft);
  color: var(--roa-comic-ink);
  font-family: "Comic Sans MS", var(--roa-font-heading, var(--font-heading));
  font-weight: 950;
  box-shadow: 4px 5px 0 rgba(21,16,15,.52);
  text-shadow: none;
  transition: transform .14s ease, box-shadow .14s ease, background-color .14s ease;
}

.roa-aim-page :is(.roa-hero-actions a.is-primary, .roa-aim-subnav a.is-active, .roa-aim-filter-row a.is-active, .roa-aim-button) {
  background: var(--roa-comic-red);
  color: #fff;
  text-shadow: 0 2px 0 rgba(21,16,15,.70);
}

.roa-aim-page :is(.roa-aim-button.is-secondary, .roa-aim-icon-button) {
  background: var(--roa-comic-paper-soft);
  color: var(--roa-comic-ink);
  text-shadow: none;
}

.roa-aim-page :is(.roa-hero-actions a, .roa-aim-subnav a, .roa-aim-filter-row a, .roa-aim-button, .roa-aim-inline-form button, .roa-aim-form-actions a, .roa-aim-icon-button):hover {
  transform: translateY(-2px) rotate(-1deg);
  box-shadow: 5px 7px 0 rgba(21,16,15,.58);
}

.roa-aim-subnav {
  position: sticky;
  top: 64px;
  z-index: 30;
  border-block: 4px solid var(--roa-comic-ink);
  background:
    linear-gradient(180deg, rgba(255,244,184,.97), rgba(255,249,228,.94));
  box-shadow: 0 8px 0 rgba(21,16,15,.28);
}

.roa-aim-subnav .roa-container {
  gap: 10px;
  padding-block: 14px;
}

.roa-aim-game-center-nav .roa-container {
  justify-content: center;
  overflow-x: auto;
}

.roa-aim-game-center-panel,
.roa-aim-next-season-inner {
  display: grid;
  grid-template-columns: minmax(0, .92fr) minmax(360px, 1.08fr);
  gap: clamp(24px, 4vw, 54px);
  align-items: center;
}

.roa-aim-game-center-panel h2,
.roa-aim-next-season-copy h2 {
  margin: 12px 0 14px;
  color: var(--roa-comic-paper-soft);
  font-family: "Comic Sans MS", var(--roa-font-heading, var(--font-heading));
  font-size: clamp(2.2rem, 5vw, 4.2rem);
  line-height: .92;
  text-transform: uppercase;
  -webkit-text-stroke: 1px var(--roa-comic-ink);
  text-shadow: 0 4px 0 rgba(21,16,15,.74), 0 14px 24px rgba(21,16,15,.34);
}

.roa-aim-game-center-panel p,
.roa-aim-next-season-copy p {
  color: rgba(255,249,228,.88);
  font-weight: 800;
  line-height: 1.55;
}

.roa-aim-current-season-card,
.roa-aim-next-season-preview {
  border: 5px solid var(--roa-comic-ink);
  border-radius: 8px;
  background:
    radial-gradient(circle at 18% 9%, rgba(255,255,255,.84), transparent 9rem),
    linear-gradient(135deg, #fff9e4 0%, #fff4b8 44%, #ffcf3d 100%);
  color: var(--roa-comic-ink);
  box-shadow: 10px 12px 0 var(--roa-comic-shadow), inset 0 2px 0 rgba(255,255,255,.86);
}

.roa-aim-current-season-card {
  padding: clamp(20px, 3vw, 30px);
  transform: rotate(1deg);
}

.roa-aim-current-season-card > span,
.roa-aim-next-season-tags span,
.roa-aim-next-season-preview figcaption {
  color: var(--roa-comic-red-deep);
  font-family: "Comic Sans MS", var(--roa-font-heading, var(--font-heading));
  font-weight: 950;
  text-transform: uppercase;
}

.roa-aim-current-season-card > strong {
  display: block;
  margin: 8px 0 8px;
  color: var(--roa-comic-red);
  font-family: "Comic Sans MS", var(--roa-font-heading, var(--font-heading));
  font-size: clamp(2rem, 4vw, 3.5rem);
  line-height: .95;
  text-transform: uppercase;
  -webkit-text-stroke: 1px var(--roa-comic-ink);
  text-shadow: 0 3px 0 #fff, 0 7px 0 var(--roa-comic-ink);
}

.roa-aim-current-season-card > p {
  color: var(--roa-comic-ink-soft);
}

.roa-aim-current-season-card .roa-aim-target-summary {
  grid-template-columns: 1fr;
  margin-top: 18px;
}

.roa-aim-current-season-card .roa-aim-target-summary article {
  box-shadow: 4px 5px 0 rgba(21,16,15,.28);
}

.roa-aim-game-center-play {
  border-block: 4px solid var(--roa-comic-ink);
  background:
    linear-gradient(90deg, rgba(255,255,255,.06) 0 1px, transparent 1px) 0 0 / 34px 34px,
    linear-gradient(0deg, rgba(255,255,255,.05) 0 1px, transparent 1px) 0 0 / 34px 34px,
    rgba(0,148,255,.08);
}

.roa-aim-game-center-play .roa-aim-game-shell {
  margin-top: 24px;
}

.roa-aim-game-center-stats {
  padding-top: 36px;
}

.roa-aim-next-season {
  border-block: 4px solid var(--roa-comic-ink);
  background:
    radial-gradient(circle at 82% 20%, rgba(0,148,255,.34), transparent 18rem),
    radial-gradient(circle at 18% 80%, rgba(255,106,0,.32), transparent 20rem),
    linear-gradient(135deg, rgba(21,16,15,.42), rgba(9,40,60,.48));
}

.roa-aim-next-season-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
  margin-top: 18px;
}

.roa-aim-next-season-tags span {
  min-height: 34px;
  display: inline-flex;
  align-items: center;
  padding: 6px 10px;
  border: 3px solid var(--roa-comic-ink);
  border-radius: 8px;
  background: var(--roa-comic-gold);
  box-shadow: 3px 4px 0 rgba(21,16,15,.40);
}

.roa-aim-next-season-preview {
  position: relative;
  overflow: hidden;
  margin: 0;
  transform: rotate(-1deg);
}

.roa-aim-next-season-preview img {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
}

.roa-aim-next-season-preview figcaption {
  position: absolute;
  left: 16px;
  bottom: 16px;
  max-width: calc(100% - 32px);
  padding: 8px 12px;
  border: 3px solid var(--roa-comic-ink);
  border-radius: 8px;
  background: var(--roa-comic-paper-soft);
  box-shadow: 4px 5px 0 rgba(21,16,15,.38);
}

.roa-aim-game-center-rules .roa-aim-faq-list {
  margin-bottom: 22px;
}

.roa-aim-highlight,
.roa-aim-fiction-notice,
.roa-aim-footer-cta {
  border-block: 4px solid var(--roa-comic-ink);
  background:
    linear-gradient(90deg, rgba(255,255,255,.06) 0 1px, transparent 1px) 0 0 / 34px 34px,
    linear-gradient(0deg, rgba(255,255,255,.05) 0 1px, transparent 1px) 0 0 / 34px 34px,
    rgba(255,244,184,.06);
}

.roa-aim-page .roa-section-head {
  max-width: 820px;
  margin-bottom: 24px;
}

.roa-aim-page .roa-section-head h2,
.roa-aim-footer-cta h2,
.roa-aim-copy h2 {
  color: var(--roa-comic-paper-soft);
  font-family: "Comic Sans MS", var(--roa-font-heading, var(--font-heading));
  font-size: 2.35rem;
  line-height: 1;
  text-transform: uppercase;
  -webkit-text-stroke: 1px var(--roa-comic-ink);
  text-shadow: 0 4px 0 rgba(21,16,15,.74), 0 12px 22px rgba(21,16,15,.34);
}

.roa-aim-page .roa-section-head p {
  color: rgba(255,249,228,.84);
  font-weight: 750;
}

.roa-aim-stat,
.roa-aim-ranking-stats article,
.roa-aim-character-card,
.roa-aim-prize-card,
.roa-aim-rule-card,
.roa-aim-season-card,
.roa-aim-copy,
.roa-aim-admin-card,
.roa-aim-start-panel,
.roa-aim-end-panel,
.roa-aim-device-lock,
.roa-aim-prize-preview article,
.roa-aim-case-mini article,
.roa-aim-target-summary article,
.roa-aim-steps article,
.roa-aim-faq-list details,
.roa-aim-legal-list article {
  border: 4px solid var(--roa-comic-ink);
  border-radius: 8px;
  background:
    radial-gradient(circle at 16% 8%, rgba(255,255,255,.82), transparent 8rem),
    linear-gradient(180deg, var(--roa-comic-paper-soft), var(--roa-comic-paper));
  color: var(--roa-comic-ink);
  box-shadow: 7px 8px 0 var(--roa-comic-shadow), inset 0 2px 0 rgba(255,255,255,.82);
}

.roa-aim-stat:nth-child(2),
.roa-aim-prize-card:nth-child(2),
.roa-aim-season-card:nth-child(2n),
.roa-aim-rule-card:nth-child(2n),
.roa-aim-character-card:nth-child(2n) {
  transform: rotate(.45deg);
}

.roa-aim-stat:nth-child(3),
.roa-aim-prize-card:nth-child(3),
.roa-aim-case-mini article:nth-child(2n),
.roa-aim-character-card:nth-child(odd) {
  transform: rotate(-.35deg);
}

.roa-aim-stat span,
.roa-aim-ranking-stats span,
.roa-aim-character-card span,
.roa-aim-prize-card span,
.roa-aim-season-card span,
.roa-aim-status,
.roa-aim-start-panel label span,
.roa-aim-admin-card label span,
.roa-aim-intro-scene span,
.roa-aim-case-card span,
.roa-aim-speech span,
.roa-aim-target-summary span {
  color: var(--roa-comic-red-deep);
  font-family: "Comic Sans MS", var(--roa-font-heading, var(--font-heading));
  font-weight: 950;
}

.roa-aim-stat strong,
.roa-aim-ranking-stats strong,
.roa-aim-character-card h3,
.roa-aim-prize-card h2,
.roa-aim-rule-card h2,
.roa-aim-season-card h2,
.roa-aim-copy h2,
.roa-aim-admin-card h2,
.roa-aim-case-mini strong,
.roa-aim-steps strong,
.roa-aim-target-summary strong,
.roa-aim-faq-list summary,
.roa-aim-legal-list h2 {
  color: var(--roa-comic-ink);
  font-family: "Comic Sans MS", var(--roa-font-heading, var(--font-heading));
  text-shadow: 0 2px 0 rgba(255,255,255,.85);
}

.roa-aim-stat p,
.roa-aim-character-card p,
.roa-aim-prize-card p,
.roa-aim-season-card p,
.roa-aim-copy p,
.roa-aim-rule-card li,
.roa-aim-case-mini p,
.roa-aim-target-summary p,
.roa-aim-faq-list p,
.roa-aim-legal-list p {
  color: var(--roa-comic-ink-soft);
  font-weight: 750;
}

.roa-aim-character-card img,
.roa-aim-case-media img,
.roa-aim-intro-scene img {
  filter:
    drop-shadow(0 3px 0 var(--roa-comic-ink))
    drop-shadow(0 12px 12px rgba(21,16,15,.34));
}

.roa-aim-character-card.is-profile {
  position: relative;
  overflow: hidden;
}

.roa-aim-character-card.is-profile::after {
  content: "";
  position: absolute;
  inset: auto 0 0;
  height: 9px;
  background: var(--character-accent, var(--roa-comic-red));
}

.roa-aim-character-card.is-profile dd {
  color: var(--roa-comic-ink);
}

.roa-aim-character-card blockquote,
.roa-aim-case-card blockquote {
  border-left: 0;
  margin-top: 16px;
  padding: 14px 16px;
  border: 3px solid var(--roa-comic-ink);
  border-radius: 8px;
  background: #fff;
  color: var(--roa-comic-ink);
  box-shadow: 4px 5px 0 rgba(21,16,15,.28);
}

.roa-aim-table-wrap {
  border: 4px solid var(--roa-comic-ink);
  border-radius: 8px;
  background: var(--roa-comic-paper-soft);
  box-shadow: 8px 9px 0 var(--roa-comic-shadow);
}

.roa-aim-table th,
.roa-aim-table td {
  border-bottom: 2px solid rgba(21,16,15,.16);
  color: var(--roa-comic-ink);
}

.roa-aim-table th {
  background: var(--roa-comic-panel);
  color: #fff;
  font-family: "Comic Sans MS", var(--roa-font-heading, var(--font-heading));
}

.roa-aim-table tbody tr:nth-child(odd) td {
  background: rgba(251,191,36,.13);
}

.roa-aim-table td strong {
  color: var(--roa-comic-red);
  font-family: "Comic Sans MS", var(--roa-font-heading, var(--font-heading));
  font-size: 1.15rem;
}

.roa-aim-status {
  width: max-content;
  padding: 6px 10px;
  border: 3px solid var(--roa-comic-ink);
  border-radius: 8px;
  background: var(--roa-comic-green);
  color: var(--roa-comic-ink);
  box-shadow: 3px 4px 0 rgba(21,16,15,.28);
}

.roa-aim-intro-stage {
  border: 5px solid var(--roa-comic-ink);
  border-radius: 8px;
  background:
    radial-gradient(circle at 14% 18%, rgba(255,23,68,.44), transparent 10rem),
    radial-gradient(circle at 84% 20%, rgba(0,148,255,.40), transparent 12rem),
    linear-gradient(135deg, #fff9e4 0%, #fff4b8 50%, #ffc44d 100%);
  box-shadow: 10px 12px 0 var(--roa-comic-shadow);
}

.roa-aim-intro-stage::before {
  opacity: .38;
  background:
    radial-gradient(circle, rgba(21,16,15,.18) 0 1px, transparent 1.5px) 0 0 / 13px 13px,
    repeating-linear-gradient(-12deg, rgba(21,16,15,.08) 0 1px, transparent 1px 12px);
}

.roa-aim-intro-scene h2 {
  color: var(--roa-comic-red);
  -webkit-text-stroke: 1px var(--roa-comic-ink);
  text-shadow: 0 3px 0 #fff, 0 7px 0 var(--roa-comic-ink);
}

.roa-aim-intro-scene p {
  color: var(--roa-comic-ink-soft);
  font-weight: 800;
}

.roa-aim-speech {
  border: 4px solid var(--roa-comic-ink);
  border-radius: 8px;
  background: var(--roa-comic-paper-soft);
  box-shadow: 7px 8px 0 var(--roa-comic-shadow);
}

.roa-aim-speech::after {
  border-width: 4px;
  border-color: var(--roa-comic-ink);
  background: var(--roa-comic-paper-soft);
}

.roa-aim-speech p {
  color: var(--roa-comic-ink);
}

.roa-aim-speech.is-hype {
  background: #e6f8ff;
}

.roa-aim-speech.is-hype::after {
  background: #e6f8ff;
}

.roa-aim-speech.is-sarcastic {
  background: #fff3b0;
}

.roa-aim-speech.is-sarcastic::after {
  background: #fff3b0;
}

.roa-aim-speech.is-suspicious,
.roa-aim-speech.is-thought {
  background: #f5e8ff;
}

.roa-aim-speech.is-suspicious::after,
.roa-aim-speech.is-thought::after {
  background: #f5e8ff;
}

.roa-aim-case-card {
  position: relative;
  overflow: hidden;
  border: 4px solid var(--roa-comic-ink);
  border-radius: 8px;
  background:
    radial-gradient(circle at 20% 18%, rgba(255,255,255,.82), transparent 10rem),
    linear-gradient(90deg, rgba(255,255,255,.92), rgba(255,244,184,.96));
  color: var(--roa-comic-ink);
  box-shadow: 8px 9px 0 var(--roa-comic-shadow);
}

.roa-aim-case-card::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 11px;
  background: var(--case-accent, var(--roa-comic-red));
}

.roa-aim-case-card:nth-child(2n) {
  transform: rotate(.35deg);
}

.roa-aim-case-card:nth-child(2n + 1) {
  transform: rotate(-.25deg);
}

.roa-aim-case-card h2 {
  color: var(--roa-comic-red);
  -webkit-text-stroke: 1px var(--roa-comic-ink);
  text-shadow: 0 2px 0 #fff, 0 5px 0 var(--roa-comic-ink);
}

.roa-aim-case-summary {
  color: var(--roa-comic-ink);
}

.roa-aim-stage {
  border: 5px solid var(--roa-comic-ink);
  border-radius: 8px;
  background:
    radial-gradient(circle at 18% 10%, rgba(251,191,36,.24), transparent 13rem),
    linear-gradient(180deg, #2a180f, #12100f);
  box-shadow: 10px 12px 0 var(--roa-comic-shadow), 0 28px 80px rgba(0,0,0,.46);
}

.roa-aim-canvas-wrap {
  border: 5px solid var(--roa-comic-ink);
  border-radius: 8px;
  background:
    radial-gradient(circle at 50% 24%, rgba(255,255,255,.24), transparent 42%),
    #d5bd8b url("../../public/aim-challenge/assets/v3/environment/background/map-full.png") center / cover no-repeat;
  box-shadow: inset 0 0 0 3px rgba(255,255,255,.14), 0 8px 0 rgba(21,16,15,.48);
}

.roa-aim-canvas-wrap::before {
  background:
    linear-gradient(90deg, rgba(255,255,255,.16), transparent 8%, transparent 92%, rgba(255,255,255,.12)),
    radial-gradient(circle at 50% 36%, transparent 44%, rgba(21,16,15,.25) 100%);
}

.roa-aim-canvas-wrap::after {
  opacity: .24;
  background:
    radial-gradient(circle, rgba(21,16,15,.25) 0 1px, transparent 1.5px) 0 0 / 12px 12px,
    linear-gradient(135deg, transparent 0 46%, rgba(255,255,255,.13) 50%, transparent 54%);
}

.roa-aim-canvas-wrap canvas {
  background: #d5bd8b url("../../public/aim-challenge/assets/v3/environment/background/map-full.png") center / cover no-repeat;
}

.roa-aim-game-score b,
.roa-aim-game-time b,
.roa-aim-game-leaderboard li {
  -webkit-text-stroke: 1px rgba(21,16,15,.72);
  text-shadow:
    0 2px 0 var(--roa-comic-ink),
    0 7px 12px rgba(21,16,15,.56);
}

/* Restore the lighter pre-Game-Center play surface inside the comic onepager. */
.roa-aim-game-shell .roa-aim-stage {
  min-width: 0;
  padding: clamp(10px, 1.4vw, 18px);
  border: 1px solid rgba(236, 190, 112, .38);
  border-radius: 8px;
  background:
    linear-gradient(180deg, rgba(255, 214, 148, .16), rgba(255,255,255,.045) 28%, rgba(36,24,12,.20)),
    #16100b;
  box-shadow: 0 20px 54px rgba(0,0,0,.36), inset 0 1px 0 rgba(255,255,255,.08);
}

.roa-aim-game-shell .roa-aim-canvas-wrap {
  border: 1px solid rgba(236, 190, 112, .46);
  border-radius: 8px;
  background:
    radial-gradient(circle at 50% 24%, rgba(255,255,255,.18), transparent 42%),
    #d5bd8b url("../../public/aim-challenge/assets/v3/environment/background/map-full.png") center / cover no-repeat;
  box-shadow: 0 18px 48px rgba(0,0,0,.36), 0 0 0 1px rgba(255,255,255,.04) inset;
}

.roa-aim-game-shell .roa-aim-canvas-wrap::before,
.roa-aim-game-shell .roa-aim-canvas-wrap::after {
  display: none;
}

.roa-aim-game-shell .roa-aim-game-score b,
.roa-aim-game-shell .roa-aim-game-time b,
.roa-aim-game-shell .roa-aim-game-leaderboard li {
  -webkit-text-stroke: 0;
  text-shadow: none;
}

/* Keep the repainting canvas away from expensive comic chrome during active play. */
body.roa-aim-run-animating .roa-aim-page::before,
body.roa-aim-run-animating .roa-aim-page::after,
body.roa-aim-run-animating .roa-aim-canvas-wrap::before,
body.roa-aim-run-animating .roa-aim-canvas-wrap::after {
  display: none;
}

body.roa-aim-run-animating .roa-aim-stage,
body.roa-aim-run-animating .roa-aim-canvas-wrap {
  contain: layout paint;
  box-shadow: none;
}

body.roa-aim-run-animating .roa-aim-stage {
  background: #211614;
}

body.roa-aim-run-animating .roa-aim-canvas-wrap {
  background: #d5bd8b url("../../public/aim-challenge/assets/v3/environment/background/map-full.png") center / cover no-repeat;
}

body.roa-aim-run-animating .roa-aim-canvas-wrap.is-shot-hit,
body.roa-aim-run-animating .roa-aim-canvas-wrap.is-shot-golden,
body.roa-aim-run-animating .roa-aim-canvas-wrap.is-shot-miss,
body.roa-aim-run-animating .roa-aim-canvas-wrap.is-shot-warning {
  animation: none;
}

body.roa-aim-run-animating .roa-aim-canvas-wrap canvas {
  transform: translateZ(0);
  will-change: transform;
}

body.roa-aim-run-animating .roa-aim-game-score b,
body.roa-aim-run-animating .roa-aim-game-time b,
body.roa-aim-run-animating .roa-aim-game-leaderboard li,
body.roa-aim-run-animating .roa-aim-point-legend span {
  -webkit-text-stroke: 0;
  text-shadow: none;
}

.roa-aim-combo-banner {
  border: 4px solid var(--roa-comic-ink);
  border-radius: 8px;
  background: var(--roa-comic-red);
  box-shadow: 6px 7px 0 rgba(21,16,15,.48);
}

.roa-aim-round-overlay strong,
.roa-aim-combo-banner strong {
  font-family: "Comic Sans MS", var(--roa-font-heading, var(--font-heading));
  -webkit-text-stroke: 2px var(--roa-comic-ink);
  text-shadow: 0 4px 0 #fff, 0 8px 0 var(--roa-comic-ink);
}

.roa-aim-popup {
  font-family: "Comic Sans MS", var(--roa-font-heading, var(--font-heading));
  -webkit-text-stroke: 1px var(--roa-comic-ink);
}

.roa-aim-point-legend span {
  color: #fff;
  -webkit-text-stroke: 1px rgba(21,16,15,.80);
}

.roa-aim-start-panel,
.roa-aim-end-panel,
.roa-aim-device-lock {
  background:
    radial-gradient(circle at 18% 8%, rgba(255,255,255,.85), transparent 8rem),
    linear-gradient(180deg, #fff4b8 0%, #ffd166 48%, #ff8a3d 100%);
}

.roa-aim-start-form :where(input[type="text"], input[type="email"], textarea),
.roa-aim-admin-card :where(input, textarea, select) {
  border: 3px solid var(--roa-comic-ink);
  border-radius: 8px;
  background: #fffdf0;
  color: var(--roa-comic-ink);
  font-weight: 800;
  box-shadow: inset 0 2px 0 rgba(21,16,15,.12);
}

.roa-aim-form-message {
  color: var(--roa-comic-ink);
  font-weight: 800;
}

.roa-aim-share-preview img,
.roa-aim-prize-image {
  border: 4px solid var(--roa-comic-ink);
  border-radius: 8px;
  box-shadow: 5px 6px 0 rgba(21,16,15,.38);
}

.roa-aim-steps span {
  background: var(--roa-comic-red);
  color: #fff;
  text-shadow: 0 2px 0 rgba(21,16,15,.70);
}

.roa-aim-fiction-notice p {
  color: rgba(255,249,228,.86);
  font-weight: 750;
}

@media (prefers-reduced-motion: reduce) {
  .roa-aim-page :is(.roa-hero-actions a, .roa-aim-subnav a, .roa-aim-filter-row a, .roa-aim-button, .roa-aim-inline-form button, .roa-aim-form-actions a, .roa-aim-icon-button) {
    transition: none;
  }

  .roa-aim-page :is(.roa-hero-actions a, .roa-aim-subnav a, .roa-aim-filter-row a, .roa-aim-button, .roa-aim-inline-form button, .roa-aim-form-actions a, .roa-aim-icon-button):hover,
  .roa-aim-stat:nth-child(2),
  .roa-aim-stat:nth-child(3),
  .roa-aim-character-card,
  .roa-aim-prize-card,
  .roa-aim-season-card,
  .roa-aim-rule-card,
  .roa-aim-case-card {
    transform: none;
  }
}

@media (max-width: 1020px) {
  .roa-aim-game-center-panel,
  .roa-aim-next-season-inner {
    grid-template-columns: 1fr;
  }

  .roa-aim-current-season-card,
  .roa-aim-next-season-preview {
    transform: none;
  }

  .roa-aim-hero {
    min-height: auto;
  }

  .roa-aim-hero .roa-front-hero-inner,
  .roa-aim-hero .roa-hero-inner {
    min-height: 0;
    grid-template-columns: 1fr;
    align-items: center;
    padding-block: 44px 28px;
  }

  .roa-aim-hero .roa-front-hero-copy,
  .roa-aim-hero .roa-hero-copy {
    transform: none;
  }

  .roa-aim-hero .roa-hero-copy h1 {
    font-size: 3.5rem;
  }

  .roa-aim-hero-visual {
    min-height: 330px;
  }

  .roa-aim-hero-visual .is-pedro {
    left: 34%;
    max-height: 250px;
  }

  .roa-aim-hero-visual .is-rick,
  .roa-aim-hero-visual .is-flick {
    max-height: 130px;
  }

  .roa-aim-hero-visual .is-bolt {
    max-height: 118px;
  }
}

@media (max-width: 700px) {
  .roa-aim-game-center-nav .roa-container {
    justify-content: flex-start;
  }

  .roa-aim-game-center-panel h2,
  .roa-aim-next-season-copy h2 {
    font-size: 2.25rem;
    -webkit-text-stroke-width: 1px;
  }

  .roa-aim-current-season-card {
    padding: 18px;
  }

  .roa-aim-next-season-preview figcaption {
    left: 10px;
    bottom: 10px;
    max-width: calc(100% - 20px);
    font-size: .75rem;
  }

  .roa-aim-page .roa-container {
    width: min(var(--roa-container), calc(100% - 28px));
  }

  .roa-aim-page .roa-section,
  .roa-aim-page .roa-front-section {
    padding-block: 46px;
  }

  .roa-aim-subnav {
    top: 62px;
  }

  .roa-aim-hero .roa-front-hero-copy,
  .roa-aim-hero .roa-hero-copy {
    padding: 18px;
    box-shadow: 6px 7px 0 var(--roa-comic-shadow);
  }

  .roa-aim-hero .roa-hero-copy h1 {
    font-size: 2.65rem;
    -webkit-text-stroke-width: 1px;
    text-shadow: 0 2px 0 #fff, 0 5px 0 var(--roa-comic-ink);
  }

  .roa-aim-hero .roa-hero-copy p {
    font-size: .96rem;
  }

  .roa-aim-hero-visual {
    min-height: 240px;
  }

  .roa-aim-hero-visual::before {
    inset: 18% 0 4%;
  }

  .roa-aim-hero-visual .is-pedro {
    left: 32%;
    max-height: 178px;
  }

  .roa-aim-hero-visual .is-rick {
    left: 0;
    bottom: 26px;
    max-height: 90px;
  }

  .roa-aim-hero-visual .is-flick {
    right: 0;
    bottom: 24px;
    max-height: 94px;
  }

  .roa-aim-hero-visual .is-bolt {
    right: 22%;
    bottom: 112px;
    max-height: 82px;
  }

  .roa-aim-hero-burst {
    right: 2%;
    top: 10px;
    max-width: 128px;
    padding: 10px 12px;
    font-size: 1rem;
  }

  .roa-aim-page .roa-section-head h2,
  .roa-aim-footer-cta h2,
  .roa-aim-copy h2 {
    font-size: 1.8rem;
  }

  .roa-aim-stat:nth-child(2),
  .roa-aim-stat:nth-child(3),
  .roa-aim-character-card,
  .roa-aim-prize-card,
  .roa-aim-season-card,
  .roa-aim-rule-card,
  .roa-aim-case-card {
    transform: none;
  }

  .roa-aim-table {
    min-width: 680px;
  }
}

@media (max-width: 1020px) {
  .roa-aim-game-center-panel,
  .roa-aim-next-season-inner {
    grid-template-columns: 1fr;
  }

  .roa-aim-status-grid,
  .roa-aim-ranking-stats,
  .roa-aim-character-grid,
  .roa-aim-rules-grid,
  .roa-aim-season-grid,
  .roa-aim-prize-grid,
  .roa-aim-case-mini,
  .roa-aim-steps,
  .roa-aim-admin-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .roa-aim-split,
  .roa-aim-briefing,
  .roa-aim-game-shell {
    grid-template-columns: 1fr;
  }

  .roa-aim-end-grid,
  .roa-aim-breakdown {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .roa-aim-hud {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .roa-aim-game-ui {
    grid-template-columns: minmax(90px, 1fr) minmax(84px, 1fr) minmax(130px, 1.3fr);
    inset: 8px 8px auto;
  }

  .roa-aim-game-leaderboard {
    min-width: 0;
  }
}

@media (max-width: 700px) {
  .roa-aim-game-center-panel h2,
  .roa-aim-next-season-copy h2 {
    font-size: 2.25rem;
  }

  .roa-aim-page .roa-container {
    width: min(var(--roa-container), calc(100% - 28px));
  }

  .roa-aim-subnav {
    top: 62px;
  }

  .roa-aim-status-grid,
  .roa-aim-ranking-stats,
  .roa-aim-character-grid,
  .roa-aim-rules-grid,
  .roa-aim-season-grid,
  .roa-aim-prize-grid,
  .roa-aim-case-mini,
  .roa-aim-case-card,
  .roa-aim-steps,
  .roa-aim-admin-grid {
    grid-template-columns: 1fr;
  }

  .roa-aim-intro-scene {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .roa-aim-intro-scene img {
    justify-self: center;
    max-height: 150px;
  }

  .roa-aim-speech {
    grid-template-columns: 52px minmax(0, 1fr);
    padding: 12px;
  }

  .roa-aim-speech img {
    width: 52px;
    height: 52px;
  }

  .roa-aim-case-media {
    min-height: 100px;
  }

  .roa-aim-case-media img {
    max-height: 125px;
  }

  .roa-aim-hud {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .roa-aim-game-ui {
    grid-template-columns: 1fr auto;
    align-items: start;
  }

  .roa-aim-game-score,
  .roa-aim-game-time {
    padding: 6px 8px;
  }

  .roa-aim-game-leaderboard {
    grid-column: 1 / -1;
    justify-self: stretch;
    padding: 6px 8px;
  }

  .roa-aim-game-leaderboard ol {
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 4px;
  }

  .roa-aim-game-leaderboard li {
    grid-template-columns: 1fr;
    gap: 2px;
    text-align: center;
  }

  .roa-aim-game-leaderboard li strong {
    display: none;
  }

  .roa-aim-point-legend {
    left: 8px;
    bottom: 8px;
    max-width: 64vw;
    gap: 3px 6px;
    font-size: .58rem;
  }

  .roa-aim-point-legend img {
    width: 21px;
    height: 21px;
  }

  .roa-aim-end-grid,
  .roa-aim-breakdown {
    grid-template-columns: 1fr 1fr;
  }

  .roa-aim-end-summary {
    grid-template-columns: 1fr;
  }

  .roa-aim-hero-visual {
    min-height: 220px;
  }

  .roa-aim-hero-visual img:first-child {
    max-height: 180px;
  }

  .roa-aim-start-panel,
  .roa-aim-end-panel,
  .roa-aim-stat,
  .roa-aim-character-card,
  .roa-aim-prize-card,
  .roa-aim-rule-card,
  .roa-aim-season-card,
  .roa-aim-copy,
  .roa-aim-admin-card {
    padding: 18px;
  }
}
