:root {
  --bg: #8a6338;
  --bg-soft: rgba(138, 99, 56, 0.12);
  --cream: #ecd9aa;
  --cream-soft: #f3e3bc;
  --cream-strong: #e1be67;
  --gold: #c89c44;
  --navy: #6b4e16;
  --sky: #b98953;
  --ink: #412a17;
  --ink-soft: rgba(65, 42, 23, 0.76);
  --white: #f7eacc;
  --shadow: 0 20px 45px rgba(65, 42, 23, 0.12);
  --shadow-strong: 0 24px 60px rgba(65, 42, 23, 0.2);
  --radius-xl: 32px;
  --radius-lg: 24px;
  --radius-md: 18px;
  --radius-sm: 14px;
  --wallpaper-image: url("./assets/mascot/library/final-pack/wallpaper.png");
  --frame-card-wide-a: url("./assets/mascot/library/final-pack/generated-frames/frame-card-wide-a.png");
  --frame-card-wide-b: url("./assets/mascot/library/final-pack/generated-frames/frame-card-wide-b.png");
  --frame-card-wide-c: url("./assets/mascot/library/final-pack/generated-frames/frame-card-wide-c.png");
  --frame-card-wide-d: url("./assets/mascot/library/final-pack/generated-frames/frame-card-wide-d.png");
  --frame-card-wide-e: url("./assets/mascot/library/final-pack/generated-frames/frame-card-wide-e.png");
  --frame-card-square-a: url("./assets/mascot/library/final-pack/generated-frames/frame-card-square-a.png");
  --frame-card-square-b: url("./assets/mascot/library/final-pack/generated-frames/frame-card-square-b.png");
  --frame-card-square-c: url("./assets/mascot/library/final-pack/generated-frames/frame-card-square-c.png");
  --frame-card-tall-a: url("./assets/mascot/library/final-pack/generated-frames/frame-card-tall-a.png");
  --frame-card-tall-b: url("./assets/mascot/library/final-pack/generated-frames/frame-card-tall-b.png");
  --frame-header-wide-a: url("./assets/mascot/library/final-pack/generated-frames/frame-header-wide-a.png");
  --frame-header-wide-b: url("./assets/mascot/library/final-pack/generated-frames/frame-header-wide-b.png");
  --frame-header-wide-c: url("./assets/mascot/library/final-pack/generated-frames/frame-header-wide-c.png");
  --frame-header-wide-d: url("./assets/mascot/library/final-pack/generated-frames/frame-header-wide-d.png");
  --frame-header-wide-e: url("./assets/mascot/library/final-pack/generated-frames/frame-header-wide-e.png");
}

/* Final local header mosaic: keep this after earlier local header experiments. */
@media (min-width: 1121px) {
  body.is-local-mode .hero {
    position: relative !important;
    min-height: clamp(410px, 31vw, 520px) !important;
    padding: 0 clamp(18px, 1.7vw, 30px) clamp(8px, 0.8vw, 14px) !important;
    overflow: hidden !important;
  }

  body.is-local-mode .hero-layout {
    display: block !important;
    position: relative !important;
    width: 100% !important;
    min-height: clamp(398px, 30vw, 504px) !important;
  }

  body.is-local-mode .hero-links {
    display: contents !important;
    width: auto !important;
    padding: 0 !important;
  }

  body.is-local-mode .hero-discord-link,
  body.is-local-mode .hero-link-icon,
  body.is-local-mode .session-controls {
    position: absolute !important;
    z-index: 4 !important;
  }

  body.is-local-mode .hero-discord-link {
    left: calc(50% - 110px) !important;
    top: clamp(36px, 3.4vw, 58px) !important;
    width: clamp(58px, 4.2vw, 76px) !important;
  }

  body.is-local-mode .hero-link-icon {
    width: clamp(62px, 4.4vw, 84px) !important;
  }

  body.is-local-mode .hero-link-icon:nth-of-type(1) {
    left: clamp(82px, 9vw, 155px) !important;
    top: clamp(56px, 5.5vw, 94px) !important;
  }

  body.is-local-mode .hero-link-icon:nth-of-type(2) {
    left: clamp(88px, 9.4vw, 166px) !important;
    top: clamp(160px, 12vw, 220px) !important;
  }

  body.is-local-mode .session-controls {
    left: calc(50% + 34px) !important;
    top: clamp(32px, 3.2vw, 55px) !important;
    width: auto !important;
  }

  body.is-local-mode .session-control-stack {
    display: flex !important;
    align-items: center !important;
    gap: clamp(16px, 2vw, 34px) !important;
  }

  body.is-local-mode .session-signout-button {
    width: clamp(58px, 4.3vw, 78px) !important;
  }

  body.is-local-mode .session-mode-icon-button {
    width: clamp(82px, 5.8vw, 112px) !important;
  }

  body.is-local-mode .session-mode-icon-button.switch-online img {
    width: clamp(82px, 5.8vw, 112px) !important;
    height: clamp(82px, 5.8vw, 112px) !important;
  }

  body.is-local-mode .session-mode-icon-button.switch-local img {
    width: clamp(68px, 4.8vw, 90px) !important;
    height: clamp(68px, 4.8vw, 90px) !important;
  }

  body.is-local-mode .session-controls .session-mode-icon-button {
    display: none !important;
  }

  body.is-local-mode .hero-copy {
    position: absolute !important;
    left: 50% !important;
    top: clamp(150px, 13.3vw, 220px) !important;
    width: min(56vw, 760px) !important;
    min-height: 0 !important;
    padding: 0 !important;
    text-align: center !important;
    transform: translateX(-50%) !important;
    z-index: 2 !important;
    pointer-events: none;
  }

  body.is-local-mode .hero h1 {
    font-size: clamp(3.05rem, 5.05vw, 6.15rem) !important;
    line-height: 0.86 !important;
  }

  body.is-local-mode .hero-stats,
  body.is-local-mode .stats-strip {
    display: contents !important;
    margin: 0 !important;
    width: auto !important;
    max-width: none !important;
  }

  body.is-local-mode .hero-progress-circles {
    position: absolute !important;
    right: clamp(98px, 9.6vw, 180px) !important;
    top: clamp(64px, 5.2vw, 92px) !important;
    width: clamp(196px, 14vw, 264px) !important;
    min-height: clamp(196px, 14vw, 264px) !important;
    padding: clamp(24px, 2vw, 36px) clamp(22px, 1.9vw, 34px) !important;
    z-index: 3 !important;
  }

  body.is-local-mode .hero-best-strip {
    position: absolute !important;
    left: 50% !important;
    right: auto !important;
    bottom: clamp(10px, 1vw, 18px) !important;
    width: min(88vw, 1420px) !important;
    max-width: min(88vw, 1420px) !important;
    margin: 0 !important;
    padding: clamp(28px, 2.3vw, 38px) clamp(42px, 5vw, 76px) !important;
    transform: translateX(-50%) !important;
    z-index: 2 !important;
  }
}

/* Final local header alignment fix: session icons stay in their own row, not absolute-stacked. */
@media (min-width: 1121px) {
  body.is-local-mode .hero {
    min-height: clamp(420px, 30vw, 505px) !important;
  }

  body.is-local-mode .hero-layout {
    min-height: clamp(405px, 29vw, 488px) !important;
  }

  body.is-local-mode .hero-link-icon:nth-of-type(1),
  body.is-local-mode .hero-link-icon:nth-of-type(2) {
    left: clamp(96px, 10.5vw, 176px) !important;
    width: clamp(62px, 4.4vw, 82px) !important;
    transform: translateX(-50%) !important;
  }

  body.is-local-mode .hero-link-icon:nth-of-type(1) {
    top: clamp(76px, 6.8vw, 112px) !important;
  }

  body.is-local-mode .hero-link-icon:nth-of-type(2) {
    top: clamp(172px, 13.4vw, 226px) !important;
  }

  body.is-local-mode .hero-discord-link {
    left: calc(50% - clamp(180px, 13vw, 230px)) !important;
    top: clamp(66px, 5.5vw, 88px) !important;
    width: clamp(58px, 4.2vw, 74px) !important;
  }

  body.is-local-mode .session-controls {
    left: calc(50% - clamp(28px, 2vw, 36px)) !important;
    top: clamp(56px, 4.8vw, 78px) !important;
    transform: translateX(-50%) !important;
  }

  body.is-local-mode .session-control-stack {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: center !important;
    gap: clamp(70px, 6vw, 112px) !important;
  }

  body.is-local-mode .session-controls .hero-link-icon,
  body.is-local-mode .session-controls .session-signout-button,
  body.is-local-mode .session-controls .session-mode-icon-button {
    position: static !important;
    inset: auto !important;
    left: auto !important;
    top: auto !important;
    transform: none !important;
    display: grid !important;
    place-items: center !important;
    flex: 0 0 auto !important;
  }

  body.is-local-mode .session-controls .session-signout-button {
    width: clamp(58px, 4.2vw, 74px) !important;
  }

  body.is-local-mode .session-controls .session-mode-icon-button {
    width: clamp(84px, 5.9vw, 110px) !important;
  }

  body.is-local-mode .session-controls .session-mode-icon-button.switch-online img {
    width: clamp(84px, 5.9vw, 110px) !important;
    height: clamp(84px, 5.9vw, 110px) !important;
  }

  body.is-local-mode .session-controls .session-mode-icon-button.switch-local img {
    width: clamp(66px, 4.7vw, 86px) !important;
    height: clamp(66px, 4.7vw, 86px) !important;
  }

  body.is-local-mode .hero-copy {
    top: clamp(150px, 12.3vw, 204px) !important;
  }

  body.is-local-mode .hero-progress-circles {
    right: clamp(120px, 10.8vw, 205px) !important;
    top: clamp(70px, 5.5vw, 96px) !important;
  }
}

/* Local header mosaic: spread the clickable icons around the title instead of one centered row. */
@media (min-width: 1121px) {
  body.is-local-mode .hero {
    position: relative !important;
    min-height: clamp(410px, 31vw, 520px) !important;
    padding: 0 clamp(18px, 1.7vw, 30px) clamp(8px, 0.8vw, 14px) !important;
    overflow: hidden !important;
  }

  body.is-local-mode .hero-layout {
    display: block !important;
    position: relative !important;
    width: 100% !important;
    min-height: clamp(398px, 30vw, 504px) !important;
  }

  body.is-local-mode .hero-links {
    display: contents !important;
    width: auto !important;
    padding: 0 !important;
  }

  body.is-local-mode .hero-discord-link,
  body.is-local-mode .hero-link-icon,
  body.is-local-mode .session-controls {
    position: absolute !important;
    z-index: 4 !important;
  }

  body.is-local-mode .hero-discord-link {
    left: calc(50% - 110px) !important;
    top: clamp(36px, 3.4vw, 58px) !important;
    width: clamp(58px, 4.2vw, 76px) !important;
  }

  body.is-local-mode .hero-link-icon {
    width: clamp(62px, 4.4vw, 84px) !important;
  }

  body.is-local-mode .hero-link-icon:nth-of-type(1) {
    left: clamp(82px, 9vw, 155px) !important;
    top: clamp(56px, 5.5vw, 94px) !important;
  }

  body.is-local-mode .hero-link-icon:nth-of-type(2) {
    left: clamp(88px, 9.4vw, 166px) !important;
    top: clamp(160px, 12vw, 220px) !important;
  }

  body.is-local-mode .session-controls {
    left: calc(50% + 34px) !important;
    top: clamp(32px, 3.2vw, 55px) !important;
    width: auto !important;
  }

  body.is-local-mode .session-control-stack {
    display: flex !important;
    align-items: center !important;
    gap: clamp(16px, 2vw, 34px) !important;
  }

  body.is-local-mode .session-signout-button {
    width: clamp(58px, 4.3vw, 78px) !important;
  }

  body.is-local-mode .session-mode-icon-button {
    width: clamp(82px, 5.8vw, 112px) !important;
  }

  body.is-local-mode .session-mode-icon-button.switch-online img {
    width: clamp(82px, 5.8vw, 112px) !important;
    height: clamp(82px, 5.8vw, 112px) !important;
  }

  body.is-local-mode .session-mode-icon-button.switch-local img {
    width: clamp(68px, 4.8vw, 90px) !important;
    height: clamp(68px, 4.8vw, 90px) !important;
  }

  body.is-local-mode .hero-copy {
    position: absolute !important;
    left: 50% !important;
    top: clamp(150px, 13.3vw, 220px) !important;
    width: min(56vw, 760px) !important;
    min-height: 0 !important;
    padding: 0 !important;
    text-align: center !important;
    transform: translateX(-50%) !important;
    z-index: 2 !important;
    pointer-events: none;
  }

  body.is-local-mode .hero h1 {
    font-size: clamp(3.05rem, 5.05vw, 6.15rem) !important;
    line-height: 0.86 !important;
  }

  body.is-local-mode .hero-stats,
  body.is-local-mode .stats-strip {
    display: contents !important;
    margin: 0 !important;
    width: auto !important;
    max-width: none !important;
  }

  body.is-local-mode .hero-progress-circles {
    position: absolute !important;
    right: clamp(98px, 9.6vw, 180px) !important;
    top: clamp(64px, 5.2vw, 92px) !important;
    width: clamp(196px, 14vw, 264px) !important;
    min-height: clamp(196px, 14vw, 264px) !important;
    padding: clamp(24px, 2vw, 36px) clamp(22px, 1.9vw, 34px) !important;
    z-index: 3 !important;
  }

  body.is-local-mode .hero-best-strip {
    position: absolute !important;
    left: 50% !important;
    right: auto !important;
    bottom: clamp(10px, 1vw, 18px) !important;
    width: min(88vw, 1420px) !important;
    max-width: min(88vw, 1420px) !important;
    margin: 0 !important;
    padding: clamp(28px, 2.3vw, 38px) clamp(42px, 5vw, 76px) !important;
    transform: translateX(-50%) !important;
    z-index: 2 !important;
  }
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  font-family: "Inter Tight", system-ui, sans-serif;
  color: var(--ink);
  background-color: #f8ecce;
  background-image: var(--wallpaper-image);
  background-position: top center;
  background-repeat: repeat;
  background-size: 1086px 1448px;
}

body.with-popup {
  overflow: hidden;
}

a {
  color: var(--navy);
}

button {
  font: inherit;
}

.hidden {
  display: none !important;
}

.page-shell {
  width: calc(100% - clamp(10px, 1.4vw, 28px));
  max-width: none;
  margin: 12px auto 42px;
}

body.is-online-mode .page-shell {
  width: calc(100% - clamp(8px, 1vw, 18px));
  max-width: none;
}

.hero {
  padding: 28px;
  border-radius: 34px;
  background:
    radial-gradient(circle at top center, rgba(255, 241, 208, 0.32), transparent 30%),
    linear-gradient(180deg, rgba(247, 236, 205, 0.98) 0%, rgba(229, 205, 153, 0.97) 54%, rgba(171, 126, 78, 0.97) 100%);
  color: var(--ink);
  box-shadow: var(--shadow-strong);
  overflow: hidden;
  position: relative;
}

.hero-layout {
  display: grid;
  grid-template-columns: 108px minmax(0, 1fr) minmax(190px, 240px);
  grid-template-rows: minmax(0, 1fr) auto;
  gap: 18px;
  align-items: center;
  min-height: 226px;
  position: relative;
  z-index: 1;
}

.hero-discord-link {
  display: inline-flex;
  width: 88px;
  aspect-ratio: 1;
  align-items: center;
  justify-content: center;
  border-radius: 22px;
  background: transparent;
  transition: filter 180ms ease, transform 180ms ease;
}

.hero-discord-link:hover,
.hero-discord-link:focus-visible {
  filter: drop-shadow(0 12px 18px rgba(65, 42, 23, 0.18));
  transform: translateY(-2px);
}

.hero-discord-link:focus-visible {
  outline: 3px solid rgba(200, 156, 68, 0.55);
  outline-offset: 5px;
}

.hero-discord-link img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: contain;
  background: transparent;
}

.hero-links {
  display: grid;
  gap: 10px;
  justify-items: start;
  align-content: start;
  padding-top: 2px;
}

.session-controls {
  width: 100%;
  display: grid;
}

.session-control-stack {
  display: grid;
  gap: 6px;
  justify-items: center;
}

.session-signout-button {
  width: 88px;
  padding: 0;
  border: none;
  background: transparent;
  box-shadow: none;
}

.session-signout-button img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: contain;
}

.session-mode-button {
  display: grid;
  justify-items: center;
  gap: 4px;
  width: 88px;
  padding: 7px 6px 8px;
  border: 1px solid rgba(107, 78, 22, 0.18);
  border-radius: 16px;
  background: rgba(255, 252, 242, 0.68);
  color: var(--bg);
  cursor: pointer;
  font: inherit;
  box-shadow: 0 10px 20px rgba(75, 47, 33, 0.08);
}

.session-mode-button img {
  width: 46px;
  aspect-ratio: 1;
  object-fit: contain;
  filter: drop-shadow(0 8px 12px rgba(54, 35, 22, 0.15));
}

.session-mode-button strong {
  font-size: 0.72rem;
  line-height: 1;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.session-mode-button span {
  max-height: 0;
  overflow: hidden;
  color: var(--ink-soft);
  font-size: 0.66rem;
  font-weight: 800;
  opacity: 0;
  transition: max-height 180ms ease, opacity 180ms ease;
}

.session-mode-button:hover span,
.session-mode-button:focus-visible span {
  max-height: 20px;
  opacity: 1;
}

.session-mode-icon-button {
  width: 88px;
  padding: 0;
  border: none;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.session-mode-icon-button img {
  width: 74px;
  height: 74px;
  object-fit: contain;
}

.session-mode-icon-button.switch-online img {
  width: 98px;
  height: 98px;
}

.session-mode-icon-button.switch-local img {
  width: 74px;
  height: 74px;
}

.hero-link-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 88px;
  padding: 0;
  border: none;
  background: transparent;
  cursor: pointer;
  transition: transform 180ms ease;
}

.hero-link-icon:hover {
  transform: translateY(-2px);
}

.hero-link-icon img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: contain;
}

body.is-online-mode .hero {
  padding: 12px 18px 18px;
  overflow: visible;
}

body.is-online-mode .hero-layout {
  grid-template-columns: 1fr;
  grid-template-rows: auto auto auto;
  min-height: 0;
  gap: 8px;
}

body.is-online-mode .hero-links {
  display: flex;
  grid-column: 1;
  grid-row: 1;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
  padding: 0;
}

body.is-online-mode .hero-discord-link,
body.is-online-mode .hero-link-icon,
body.is-online-mode .session-signout-button {
  width: 58px;
}

body.is-online-mode .session-controls {
  width: auto;
}

body.is-online-mode .session-control-stack {
  display: flex;
  align-items: center;
  gap: 10px;
}

body.is-online-mode .session-mode-icon-button {
  width: 70px;
}

body.is-online-mode .session-mode-icon-button.switch-local img {
  width: 66px;
  height: 66px;
}

body.is-online-mode .session-mode-icon-button.switch-online img {
  width: 90px;
  height: 90px;
}

body.is-online-mode .hero-copy {
  grid-column: 1;
  grid-row: 2;
  text-align: left;
}

body.is-online-mode .hero h1 {
  margin: 0;
  font-size: clamp(2.2rem, 5vw, 4.4rem);
  line-height: 0.9;
}

body.is-online-mode .hero-stats {
  grid-column: 1;
  grid-row: 3;
  justify-self: stretch;
  width: 100%;
}

body.is-online-mode .hero-best-strip {
  width: 100%;
  min-height: 92px;
  padding: 30px clamp(42px, 5vw, 76px);
}

.auth-modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 70;
  display: grid;
  place-items: center;
  padding: 24px;
  background: rgba(75, 47, 33, 0.22);
  backdrop-filter: blur(6px);
}

.auth-modal-overlay.signin-gate {
  z-index: 90;
  background:
    radial-gradient(circle at top center, rgba(247, 234, 204, 0.22), transparent 32%),
    rgba(75, 47, 33, 0.34);
}

.app-entry-gate-overlay {
  position: fixed;
  inset: 0;
  z-index: 66;
  display: grid;
  place-items: center;
  padding: 24px;
  background:
    radial-gradient(circle at top center, rgba(255, 248, 232, 0.36), transparent 34%),
    linear-gradient(135deg, rgba(66, 43, 26, 0.34), rgba(25, 39, 53, 0.36));
  backdrop-filter: blur(9px);
}

.app-entry-gate-window {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
  width: min(900px, calc(100vw - 30px));
  max-height: calc(100vh - 32px);
  overflow: auto;
  padding: clamp(20px, 3vw, 34px);
  border-radius: 34px;
  border: 1px solid rgba(107, 78, 22, 0.18);
  background:
    radial-gradient(circle at top left, rgba(255, 250, 242, 0.84), transparent 35%),
    linear-gradient(180deg, rgba(247, 234, 204, 0.99), rgba(236, 214, 165, 0.98));
  box-shadow: 0 34px 70px rgba(54, 35, 22, 0.28);
}

.app-entry-auth-panel {
  display: grid;
  gap: 12px;
  padding: clamp(14px, 2vw, 20px);
  border-radius: 24px;
  border: 1px solid rgba(107, 78, 22, 0.14);
  background: rgba(255, 252, 242, 0.72);
}

.app-entry-auth-panel.signed-in {
  grid-template-columns: minmax(0, 1fr);
}

.app-entry-auth-heading h3,
.app-entry-auth-panel h3 {
  margin: 0;
  color: var(--bg);
  font-size: clamp(1.45rem, 3vw, 2.2rem);
  line-height: 0.95;
}

.app-entry-auth-panel p {
  margin: 4px 0 0;
  color: var(--ink-soft);
  font-weight: 750;
}

.app-entry-auth-panel .alpaccount-form {
  gap: 10px;
}

.app-entry-auth-panel .auth-form-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

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

.app-entry-choice-card {
  display: grid;
  gap: 8px;
  min-height: 168px;
  padding: 18px;
  border-radius: 24px;
  border: 1px solid rgba(107, 78, 22, 0.16);
  background: rgba(255, 252, 242, 0.78);
  color: var(--ink);
  text-align: left;
  cursor: pointer;
  font: inherit;
}

.app-entry-choice-card span {
  text-transform: uppercase;
  letter-spacing: 0.13em;
  color: var(--gold);
  font-size: 0.76rem;
  font-weight: 900;
}

.app-entry-choice-card strong {
  color: var(--bg);
  font-size: clamp(1.3rem, 2vw, 1.7rem);
  line-height: 1;
}

.app-entry-choice-card small {
  color: var(--ink-soft);
  font-weight: 750;
  line-height: 1.25;
}

.app-entry-choice-card.primary-choice {
  justify-items: center;
  text-align: center;
  background:
    radial-gradient(circle at top right, rgba(200, 156, 68, 0.22), transparent 44%),
    rgba(255, 252, 242, 0.92);
  border-color: rgba(200, 156, 68, 0.36);
}

.app-entry-choice-card.primary-choice span {
  justify-self: start;
}

.app-entry-choice-card.online-choice {
  justify-items: center;
  text-align: center;
  background:
    radial-gradient(circle at top, rgba(95, 126, 191, 0.18), transparent 44%),
    rgba(255, 252, 242, 0.86);
}

.app-entry-choice-card.online-choice span {
  justify-self: start;
}

.app-entry-choice-logo {
  display: block;
  width: min(132px, 52%);
  aspect-ratio: 1;
  object-fit: contain;
  filter: drop-shadow(0 16px 22px rgba(54, 35, 22, 0.18));
}

.app-entry-choice-card:disabled {
  cursor: not-allowed;
  opacity: 0.62;
  filter: grayscale(0.25);
}

.app-entry-note-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.auth-modal-window {
  position: relative;
  width: min(460px, calc(100vw - 28px));
  border-radius: 28px;
  background: rgba(247, 234, 204, 0.98);
  border: 1px solid rgba(107, 78, 22, 0.16);
  box-shadow: 0 28px 56px rgba(75, 47, 33, 0.22);
}

.signup-window {
  width: min(760px, calc(100vw - 32px));
  max-height: calc(100vh - 32px);
  overflow: auto;
  background:
    radial-gradient(circle at top right, rgba(200, 156, 68, 0.16), transparent 30%),
    linear-gradient(180deg, rgba(247, 234, 204, 0.98), rgba(236, 214, 165, 0.97));
}

.alpaccount-window {
  width: min(860px, calc(100vw - 32px));
}

.resources-modal-window {
  width: min(760px, calc(100vw - 28px));
}

.cooperation-modal-window {
  width: min(900px, calc(100vw - 28px));
  max-height: calc(100vh - 28px);
  overflow: auto;
  background:
    radial-gradient(circle at top right, rgba(200, 156, 68, 0.16), transparent 32%),
    linear-gradient(180deg, rgba(247, 234, 204, 0.99), rgba(236, 214, 165, 0.98));
}

.auth-modal-stack {
  display: grid;
  gap: 14px;
  padding: 28px;
}

.resources-modal-stack {
  gap: 16px;
}

.cooperation-modal-stack {
  gap: 16px;
  padding: clamp(22px, 4vw, 36px);
}

.cooperation-modal-stack h3 {
  color: var(--bg);
  font-size: clamp(2.2rem, 5vw, 4.4rem);
  line-height: 0.9;
}

.cooperation-copy {
  display: grid;
  gap: 12px;
  color: var(--ink);
  font-weight: 750;
}

.cooperation-copy p {
  margin: 0;
  font-size: clamp(1rem, 1.45vw, 1.22rem);
  line-height: 1.32;
}

.cooperation-copy strong {
  color: var(--bg);
  font-weight: 900;
}

.cooperation-copy .big-question,
.cooperation-copy .final-call {
  color: var(--bg);
  font-size: clamp(1.35rem, 2.2vw, 2rem);
  text-align: center;
}

.cooperation-copy .promise,
.community-call {
  padding: 14px;
  border-radius: 18px;
  border: 1px solid rgba(107, 78, 22, 0.14);
  background: rgba(255, 252, 242, 0.66);
}

.community-call {
  display: grid;
  gap: 8px;
}

.cooperation-actions {
  justify-content: center;
}

.cooperation-action-card {
  display: grid;
  justify-items: center;
  gap: 8px;
  min-width: 138px;
  padding: 12px 14px;
  border-radius: 18px;
  color: var(--bg);
  font-weight: 900;
  text-align: center;
  text-decoration: none;
  transition: transform 180ms ease, filter 180ms ease;
}

.cooperation-action-card:hover,
.cooperation-action-card:focus-visible {
  outline: none;
  filter: drop-shadow(0 14px 24px rgba(75, 47, 33, 0.2));
  transform: translateY(-3px) scale(1.03);
}

.cooperation-action-card img {
  width: 76px;
  height: 76px;
  object-fit: contain;
}

.cooperation-action-card strong {
  line-height: 1;
}

.signup-stack {
  padding: 20px;
}

.alpaccount-stack {
  gap: 18px;
}

.alpaccount-brand {
  display: grid;
  grid-template-columns: 118px minmax(0, 1fr);
  gap: 18px;
  align-items: center;
}

.alpaccount-brand img {
  width: 100%;
  aspect-ratio: 1;
  object-fit: contain;
  filter: drop-shadow(0 14px 22px rgba(75, 47, 33, 0.16));
}

.alpaccount-form {
  display: grid;
  gap: 14px;
}

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

.auth-helper {
  color: var(--ink-soft);
  font-size: 0.92rem;
  line-height: 1.45;
}

.auth-notice {
  margin: 0;
  padding: 12px 14px;
  border-radius: 16px;
  border: 1px solid rgba(107, 78, 22, 0.14);
  font-weight: 700;
  line-height: 1.4;
}

.auth-notice.error {
  color: #6d2a1a;
  background: rgba(255, 226, 207, 0.72);
}

.auth-notice.success {
  color: #4d5b1d;
  background: rgba(232, 236, 184, 0.74);
}

.auth-actions {
  align-items: center;
  margin-top: 2px;
}

.auth-text-button {
  justify-self: start;
  border: none;
  padding: 0;
  background: transparent;
  color: var(--bg);
  font-weight: 800;
  text-decoration: underline;
  text-underline-offset: 4px;
  cursor: pointer;
}

.alpaccount-profile-card {
  display: grid;
  gap: 8px;
  padding: 16px;
  border-radius: 20px;
  border: 1px solid rgba(107, 78, 22, 0.14);
  background: rgba(255, 250, 238, 0.64);
}

.alpaccount-profile-card span {
  color: var(--ink-soft);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.alpaccount-profile-card strong {
  color: var(--bg);
  font-family: "Cardo", Georgia, serif;
  font-size: clamp(1.35rem, 2.4vw, 2rem);
}

.resource-link-list {
  display: grid;
  gap: 12px;
}

.resource-link-item {
  display: grid;
  gap: 6px;
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid rgba(107, 78, 22, 0.14);
  background: rgba(236, 205, 171, 0.48);
  color: var(--bg);
  text-decoration: none;
}

.resource-link-item:hover {
  border-color: rgba(138, 99, 56, 0.34);
  background: rgba(236, 205, 171, 0.74);
}

.resource-link-label {
  font-weight: 800;
}

.resource-link-url {
  color: var(--ink-soft);
  font-size: 0.86rem;
  line-height: 1.45;
  overflow-wrap: anywhere;
}

.auth-modal-stack h3,
.setup-card h3 {
  margin: 0;
  color: var(--bg);
  font-size: clamp(1.24rem, 2vw, 1.7rem);
}

.auth-modal-stack p {
  margin: 0;
}

.auth-field {
  display: grid;
  gap: 8px;
}

.auth-field span {
  color: var(--bg);
  font-weight: 800;
}

.auth-field input,
.auth-field select {
  width: 100%;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid rgba(107, 78, 22, 0.16);
  background: rgba(255, 250, 238, 0.94);
  color: var(--ink);
  font: inherit;
}

.auth-field select {
  appearance: none;
  cursor: pointer;
}

.hero::after {
  content: "";
  position: absolute;
  left: -8%;
  right: -8%;
  bottom: -12px;
  height: 92px;
  opacity: 0.28;
  background:
    linear-gradient(90deg, transparent 0%, rgba(107, 78, 22, 0.32) 10%, rgba(107, 78, 22, 0.08) 50%, transparent 90%),
    linear-gradient(rgba(107, 78, 22, 0.24), rgba(107, 78, 22, 0.24));
  background-size: 100% 100%, 100% 2px;
  background-repeat: no-repeat;
}

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin: 0 0 14px;
  font-size: 0.86rem;
  font-weight: 800;
  letter-spacing: 0.13em;
  text-transform: uppercase;
}

.eyebrow::before {
  content: "";
  width: 34px;
  height: 2px;
  border-radius: 999px;
  background: var(--gold);
}

.eyebrow.local {
  color: var(--ink-soft);
}

.hero h1,
.hero h2,
.section-heading h2,
.panel-title h2,
.result-banner h2 {
  font-family: "Cardo", Georgia, serif;
  letter-spacing: -0.02em;
}

.hero h1 {
  margin: 0;
  max-width: 100%;
  font-size: clamp(2.3rem, 4vw, 4.35rem);
  line-height: 0.95;
  white-space: nowrap;
  color: #4b2f21;
  font-weight: 800;
}

.hero-route-title {
  margin: 16px 0 0;
  font-family: "Cardo", Georgia, serif;
  max-width: 100%;
  font-size: clamp(1.02rem, 1.95vw, 1.75rem);
  line-height: 1.02;
  letter-spacing: -0.02em;
  color: var(--ink);
  white-space: nowrap;
}

.lead,
.side-intro,
.section-heading p,
.footer p {
  line-height: 1.6;
}

.lead {
  max-width: 100%;
  margin: 14px 0 10px;
  color: var(--ink-soft);
  font-size: clamp(0.96rem, 1.2vw, 1.05rem);
  white-space: nowrap;
  font-style: italic;
}

.hero-note-row {
  display: grid;
  gap: 12px;
}

.hero-actions {
  display: grid;
  gap: 12px;
  width: min(100%, 340px);
  margin: 0 auto;
}

.install-status {
  margin: 0;
  color: var(--ink-soft);
  font-size: 0.95rem;
}

.hero-copy {
  width: min(100%, 1160px);
  min-height: 100%;
  padding: 0;
  display: grid;
  align-content: center;
  justify-items: center;
  text-align: left;
}

.hero-note,
.stat-card,
.insight-card,
.summary-chip,
.step-panel,
.choice-card,
.target-card,
.mode-card,
.experience-panel,
.slide-card,
.map-node,
.question-card,
.feedback-card,
.result-shell,
.jeopardy-category,
.run-status-card {
  box-shadow: var(--shadow);
}

.hero-note {
  min-width: 180px;
  padding: 14px 16px;
  border-radius: 18px;
  background: rgba(247, 234, 204, 0.5);
  border: 1px solid rgba(107, 78, 22, 0.16);
}

.hero-note strong,
.stat-card strong,
.choice-card h3,
.target-card h3,
.mode-card h3,
.slide-card h2,
.map-node h3,
.question-card h2,
.feedback-card h3,
.result-banner h2,
.jeopardy-category h3,
.run-card h2 {
  display: block;
}

.hero-note strong {
  margin-bottom: 6px;
  font-size: 0.88rem;
  color: var(--gold);
}

.stats-strip {
  display: contents;
}

.hero-stats {
  display: contents;
}

.stat-card {
  padding: 16px;
  border-radius: 18px;
  background: rgba(247, 234, 204, 0.5);
  border: 1px solid rgba(107, 78, 22, 0.16);
}

.stat-card span {
  display: block;
  margin-bottom: 8px;
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  opacity: 0.72;
}

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

.progress-stat-card {
  display: grid;
  gap: 8px;
}

.hero-progress-circles {
  grid-column: 3;
  grid-row: 1;
  width: min(100%, 240px);
  justify-self: end;
  align-self: center;
  display: grid;
  justify-content: stretch;
  gap: 12px;
}

.progress-circle-card {
  width: min(100%, 300px);
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 12px;
}

.stat-progress-ring {
  --percent: 0;
  width: 84px;
  height: 84px;
  position: relative;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background:
    conic-gradient(rgba(252, 209, 39, 0.92) calc(var(--percent) * 1%), rgba(138, 99, 56, 0.16) 0),
    rgba(247, 234, 204, 0.72);
  box-shadow: inset 0 0 0 1px rgba(107, 78, 22, 0.08), 0 12px 22px rgba(75, 47, 33, 0.1);
}

.stat-progress-ring-inner {
  width: 62px;
  height: 62px;
  display: grid;
  place-items: center;
  margin: 0;
  border-radius: 50%;
  background: rgba(255, 250, 238, 0.95);
  color: #4b2f21;
}

.stat-progress-ring-inner strong {
  font-size: 1.05rem;
}

.stat-progress-circle-copy {
  display: grid;
  gap: 3px;
}

.stat-progress-circle-copy span,
.hero-best-card span {
  display: block;
  margin: 0;
  color: rgba(75, 47, 33, 0.72);
  font-size: 0.68rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.stat-progress-circle-copy strong {
  font-size: 1rem;
}

.stat-progress-circle-copy em,
.hero-best-card em {
  color: var(--ink-soft);
  font-size: 0.76rem;
  font-style: normal;
  font-weight: 800;
}

.hero-best-strip {
  grid-column: 1 / -1;
  grid-row: 2;
  width: min(100%, 980px);
  justify-self: center;
  align-self: end;
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
  margin-top: 4px;
}

.hero-best-strip-online {
  grid-row: 1 / span 2;
  align-self: center;
}

.hero-best-card {
  display: grid;
  align-content: center;
  gap: 4px;
  min-height: 68px;
  padding: 10px 12px;
  border-radius: 16px;
  background:
    radial-gradient(circle at top left, rgba(255, 250, 238, 0.72), transparent 48%),
    rgba(247, 234, 204, 0.5);
  border: 1px solid rgba(107, 78, 22, 0.16);
  box-shadow: 0 12px 22px rgba(75, 47, 33, 0.08);
}

.hero-best-card strong {
  color: #4b2f21;
  font-size: clamp(0.95rem, 1.5vw, 1.18rem);
  line-height: 1.02;
}

.breakdown-columns.single {
  grid-template-columns: 1fr;
}

.stat-progress-track {
  position: relative;
  min-height: 42px;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(138, 99, 56, 0.14);
  border: 1px solid rgba(107, 78, 22, 0.12);
}

.stat-progress-fill {
  position: absolute;
  inset: 0 auto 0 0;
  display: block;
  margin: 0;
  border-radius: inherit;
  background: linear-gradient(90deg, rgba(252, 209, 39, 0.84), rgba(185, 137, 83, 0.72));
}

.stat-progress-copy {
  position: relative;
  z-index: 1;
  min-height: 42px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 8px 12px;
  color: #4b2f21;
}

.stat-progress-copy strong,
.stat-progress-copy em {
  display: block;
  margin: 0;
  font-style: normal;
  line-height: 1.05;
}

.stat-progress-copy strong {
  font-size: 0.95rem;
}

.stat-progress-copy em {
  font-size: 0.78rem;
  font-weight: 800;
}

.hero-stats .stat-card {
  padding: 10px 12px;
  border-radius: 16px;
  background: rgba(247, 234, 204, 0.42);
  box-shadow: 0 14px 26px rgba(75, 47, 33, 0.08);
}

.hero-stats .stat-card span {
  margin-bottom: 4px;
  font-size: 0.68rem;
  letter-spacing: 0.08em;
}

.hero-stats .stat-card strong {
  font-size: 1.08rem;
  line-height: 1;
  color: #4b2f21;
}

.card-panel,
.experience-panel {
  border-radius: var(--radius-xl);
  background:
    radial-gradient(circle at top right, rgba(200, 156, 68, 0.12), transparent 26%),
    linear-gradient(180deg, rgba(247, 234, 204, 0.96), rgba(243, 227, 188, 0.96));
  border: 1px solid rgba(107, 78, 22, 0.12);
}

.asset-slot {
  position: relative;
  display: grid;
  place-items: center;
}

.asset-image {
  display: block;
  max-width: 100%;
  height: auto;
}

.alpaca-review-shell {
  position: relative;
  display: inline-block;
}

.alpaca-review-badge {
  position: absolute;
  top: -10px;
  right: -10px;
  z-index: 8;
  min-width: 30px;
  height: 30px;
  padding: 0 8px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  background: #22f36a;
  color: #10331a;
  border: 2px solid #0d7d2d;
  box-shadow: 0 8px 18px rgba(17, 120, 45, 0.26);
  font-size: 0.82rem;
  font-weight: 900;
  line-height: 1;
  letter-spacing: 0.02em;
}

.layout {
  display: grid;
  gap: 20px;
  margin-top: 20px;
}

.section-heading {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 18px;
}

.wizard,
.experience-panel {
  padding: 24px;
}

.wizard {
  display: grid;
  align-content: start;
}

.section-heading h2 {
  margin: 0;
  color: var(--bg);
  font-size: clamp(2rem, 5vw, 3rem);
}

.section-heading p {
  max-width: 70ch;
  margin: 0;
}

.summary-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 20px;
  min-height: 20px;
}

.summary-chip {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid rgba(107, 78, 22, 0.14);
  background: rgba(247, 234, 204, 0.82);
}

.summary-chip strong {
  color: var(--bg);
}

.summary-chip button {
  border: none;
  background: transparent;
  color: var(--ink-soft);
  cursor: pointer;
  padding: 0;
}

.wizard-steps {
  display: grid;
  gap: 16px;
  margin-top: 8px;
  perspective: 1600px;
  overflow: visible;
  align-items: start;
}

.wizard-rail-mount {
  min-width: 0;
  width: auto;
  overflow-x: auto;
}

.step-page-shell {
  display: grid;
  gap: 14px;
  min-height: 0;
  align-content: start;
}

.step-page-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.route-back-button {
  flex: 0 0 auto;
  width: min(100%, 340px);
  padding: 0;
  border: none;
  background: transparent;
  cursor: pointer;
  transition: transform 180ms ease, filter 180ms ease, opacity 180ms ease;
}

.route-back-button:hover {
  transform: translateY(-1px);
  filter: drop-shadow(0 12px 18px rgba(75, 47, 33, 0.12));
}

.route-back-button:focus-visible {
  outline: 3px solid rgba(200, 156, 68, 0.42);
  outline-offset: 6px;
  border-radius: 20px;
}

.route-back-button .asset-slot {
  width: 100%;
}

.route-back-asset-image {
  width: 100%;
  height: auto;
  display: block;
}

.route-back-fallback {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 54px;
  padding: 0 18px;
  border-radius: 999px;
  background: rgba(247, 234, 204, 0.94);
  border: 1px solid rgba(107, 78, 22, 0.14);
  color: var(--bg);
  font-weight: 800;
}

.step-page-kicker {
  margin: 0 0 8px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 0.78rem;
  font-weight: 800;
  color: var(--gold);
}

.step-page-progress {
  display: flex;
  align-items: center;
  gap: 8px;
}

.step-page-progress span {
  width: 28px;
  height: 6px;
  border-radius: 999px;
  background: rgba(107, 78, 22, 0.16);
}

.step-page-progress span.done {
  background: rgba(138, 99, 56, 0.5);
}

.step-page-progress span.active {
  background: linear-gradient(90deg, var(--gold), #b98932);
}

.step-panel {
  padding: 18px;
  border-radius: 22px;
  background: rgba(247, 234, 204, 0.8);
  border: 1px solid rgba(107, 78, 22, 0.12);
  position: relative;
  overflow: hidden;
  backface-visibility: hidden;
  transform-style: preserve-3d;
  min-height: 0;
  will-change: transform, opacity;
  box-shadow:
    0 24px 48px rgba(75, 47, 33, 0.08),
    inset 0 1px 0 rgba(255, 248, 232, 0.42);
  display: grid;
  align-content: start;
}

.step-panel::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 22px;
  height: 100%;
  background: linear-gradient(180deg, rgba(107, 78, 22, 0.18), rgba(107, 78, 22, 0.03) 26%, rgba(107, 78, 22, 0.14));
  opacity: 0.35;
  pointer-events: none;
}

.step-panel.page-forward {
  transform-origin: left center;
  animation: wizard-page-forward 360ms cubic-bezier(0.2, 0.9, 0.2, 1);
  animation-fill-mode: both;
}

.step-panel.page-backward {
  transform-origin: right center;
  animation: wizard-page-backward 360ms cubic-bezier(0.2, 0.9, 0.2, 1);
  animation-fill-mode: both;
}

.step-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
}

.step-index {
  display: inline-grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: var(--gold);
  color: var(--ink);
  font-weight: 800;
}

.step-title-wrap h3 {
  margin: 0 0 4px;
  color: var(--bg);
  font-size: 1.05rem;
}

.step-title-wrap p {
  margin: 0;
  color: var(--ink-soft);
}

.step-grid {
  display: grid;
  gap: 12px;
  align-items: stretch;
  grid-auto-rows: 1fr;
}

.step-grid.one {
  grid-template-columns: minmax(240px, 520px);
  justify-content: center;
}

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

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

.step-grid.four {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.step-grid.five {
  grid-template-columns: repeat(6, minmax(0, 1fr));
}

.step-grid.five > .mode-card {
  grid-column: span 2;
}

.step-grid.five > .mode-card:nth-last-child(-n + 2) {
  grid-column: span 3;
}

.wizard-rail {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
  padding: 0;
  min-width: 0;
}

.wizard-rail-progress {
  display: none;
}

.wizard-rail-progress span {
  display: none;
}

.wizard-rail-items {
  display: flex;
  flex-wrap: nowrap;
  gap: 12px;
  justify-content: flex-start;
  width: max-content;
}

.wizard-rail-item {
  width: auto;
  min-width: 176px;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 15px;
  border-radius: 20px;
  border: 1px solid rgba(107, 78, 22, 0.12);
  background: rgba(247, 234, 204, 0.7);
  color: var(--ink);
  text-align: left;
  box-shadow: var(--shadow);
}

.wizard-rail-item.done,
.wizard-rail-item.active:not(:disabled) {
  cursor: pointer;
  transition:
    transform 180ms ease,
    border-color 180ms ease,
    box-shadow 180ms ease;
}

.wizard-rail-item.done:hover,
.wizard-rail-item.active:not(:disabled):hover {
  transform: translateY(-1px);
  border-color: rgba(107, 78, 22, 0.24);
}

.wizard-rail-item:disabled {
  cursor: default;
}

.wizard-rail-item.active {
  background:
    radial-gradient(circle at top right, rgba(200, 156, 68, 0.2), transparent 40%),
    linear-gradient(180deg, rgba(247, 234, 204, 0.98), rgba(236, 217, 170, 0.96));
  border-color: rgba(107, 78, 22, 0.2);
}

.wizard-rail-item.upcoming {
  opacity: 0.74;
  box-shadow: none;
}

.wizard-rail-dot {
  flex: 0 0 auto;
  width: 14px;
  height: 14px;
  margin-top: 4px;
  border-radius: 50%;
  background: rgba(107, 78, 22, 0.18);
  border: 2px solid rgba(107, 78, 22, 0.22);
}

.wizard-rail-item.done .wizard-rail-dot {
  background: rgba(138, 99, 56, 0.82);
  border-color: rgba(138, 99, 56, 0.3);
}

.wizard-rail-item.active .wizard-rail-dot {
  background: var(--gold);
  border-color: rgba(107, 78, 22, 0.26);
}

.wizard-rail-copy {
  min-width: 0;
  display: grid;
  gap: 3px;
  align-items: center;
}

.wizard-rail-title {
  color: var(--bg);
  font-weight: 800;
  line-height: 1.3;
  white-space: nowrap;
}

.wizard-rail-value {
  display: block;
  color: var(--ink-soft);
  font-size: 0.88rem;
  line-height: 1.25;
  white-space: nowrap;
}

@keyframes wizard-page-forward {
  from {
    opacity: 0;
    transform: rotateY(-18deg) translateX(28px) scale(0.985);
    filter: saturate(0.94);
  }

  to {
    opacity: 1;
    transform: rotateY(0deg) translateX(0) scale(1);
    filter: saturate(1);
  }
}

@keyframes wizard-page-backward {
  from {
    opacity: 0;
    transform: rotateY(16deg) translateX(-28px) scale(0.985);
    filter: saturate(0.94);
  }

  to {
    opacity: 1;
    transform: rotateY(0deg) translateX(0) scale(1);
    filter: saturate(1);
  }
}

.choice-card,
.target-card,
.mode-card {
  width: 100%;
  height: 100%;
  text-align: center;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 16px;
  border: 1px solid rgba(107, 78, 22, 0.14);
  border-radius: 22px;
  background:
    radial-gradient(circle at top right, rgba(200, 156, 68, 0.18), transparent 30%),
    linear-gradient(180deg, rgba(247, 234, 204, 0.96), rgba(243, 227, 188, 0.95));
  cursor: pointer;
  transition:
    transform 180ms ease,
    border-color 180ms ease,
    box-shadow 180ms ease;
  min-height: 160px;
}

.choice-card:hover,
.target-card:hover,
.mode-card:hover,
.button:hover,
.mini-button:hover,
.tile-button:hover,
.option-button:hover {
  transform: translateY(-1px);
}

.choice-card.active,
.target-card.active,
.mode-card.active {
  border-color: rgba(107, 78, 22, 0.28);
  box-shadow: 0 18px 34px rgba(107, 78, 22, 0.12);
}

.card-top {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  margin-bottom: 0;
  width: 100%;
  text-align: center;
}

.card-top h3 {
  margin: 0;
  color: var(--bg);
  font-size: 1.06rem;
  text-wrap: balance;
}

.wizard-choice-card {
  padding: 12px;
}

.wizard-choice-card .card-top {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0;
  height: 100%;
  min-height: 100%;
  text-align: right;
  padding: 4px 10px 4px 6px;
  overflow: visible;
}

.wizard-choice-slot {
  position: absolute;
  left: 2px;
  top: 4px;
  bottom: 4px;
  width: 156px;
  height: auto;
  min-height: auto;
  align-self: auto;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: visible;
  z-index: 1;
}

.wizard-choice-slot .asset-image,
.wizard-choice-slot .mascot-asset {
  width: 100%;
  height: 100%;
  max-width: none;
  max-height: none;
  object-fit: contain;
  object-position: left center;
}

.wizard-choice-copy {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0;
  min-width: 0;
  width: min(100%, calc(100% - 72px));
  max-width: calc(100% - 4px);
  min-height: 100%;
  margin-left: auto;
  text-align: right;
  padding: 0 8px 0 0;
}

.wizard-choice-copy h3 {
  width: auto;
  max-width: 100%;
  margin-left: auto;
  font-size: clamp(1.24rem, 1.9vw, 1.72rem);
  line-height: 1.05;
  text-align: right;
}

.card-top p,
.card-body,
.target-meta,
.mode-meta,
.slide-card p,
.map-node p,
.question-card p,
.feedback-card p,
.result-banner p {
  margin: 0;
  line-height: 1.55;
}

.card-kicker,
.mode-kicker {
  display: block;
  margin-bottom: 4px;
  color: var(--navy);
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-weight: 800;
}

.card-body {
  color: var(--ink-soft);
}

.target-meta,
.mode-meta {
  margin-top: 12px;
  color: var(--navy);
  font-weight: 700;
}

.target-card {
  justify-content: center;
  min-height: 132px;
  padding: 10px;
}

.target-card .card-top {
  margin-bottom: 0;
}

.target-card .wizard-choice-copy h3 {
  font-size: clamp(0.96rem, 1.1vw, 1.22rem);
  line-height: 1.02;
}

.choice-card .card-top,
.mode-card .card-top,
.target-card .card-top {
  align-items: center;
  justify-content: flex-end;
}

.mode-card {
  min-height: 170px;
  text-align: center;
}

.mode-card .card-top {
  width: 100%;
  justify-content: flex-end;
  align-items: center;
  text-align: right;
}

.mode-card .wizard-choice-copy h3 {
  font-size: clamp(0.94rem, 1.05vw, 1.2rem);
  line-height: 1.02;
}

.mode-card .wizard-choice-copy {
  flex-direction: column;
  align-items: flex-end;
  justify-content: center;
}

.mode-card-thanks {
  margin: 6px 0 0;
  color: rgba(75, 47, 33, 0.72);
  font-size: 0.84rem;
  font-style: italic;
  font-weight: 700;
}

.mode-card[data-pick-mode="run"] .wizard-choice-slot,
.mode-card[data-pick-mode="jump"] .wizard-choice-slot,
.mode-card[data-pick-mode="buildcase"] .wizard-choice-slot,
.mode-card[data-pick-mode="relay"] .wizard-choice-slot,
.mode-card[data-pick-mode="race"] .wizard-choice-slot {
  transform: scale(1.36);
  transform-origin: center;
}

.mode-card.unavailable,
.learn-footer-card-button.unavailable {
  cursor: not-allowed;
  opacity: 0.58;
  filter: grayscale(0.18);
}

.mode-card-unavailable {
  margin: 3px 0 0;
  color: rgba(75, 47, 33, 0.7);
  font-size: 0.74rem;
  font-weight: 800;
  line-height: 1.08;
}

.launch-row {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.button,
.mini-button,
.tile-button,
.option-button {
  transition:
    transform 180ms ease,
    background-color 180ms ease,
    border-color 180ms ease,
    color 180ms ease,
    opacity 180ms ease;
}

.button {
  border: 1px solid transparent;
  border-radius: 999px;
  padding: 14px 20px;
  cursor: pointer;
  font-weight: 800;
}

.button:disabled {
  cursor: wait;
  opacity: 0.62;
}

.button.primary {
  background: linear-gradient(180deg, var(--gold), #b98932);
  color: var(--ink);
  box-shadow: 0 12px 24px rgba(107, 78, 22, 0.18);
}

.button.secondary {
  background: rgba(138, 99, 56, 0.1);
  color: var(--bg);
  border-color: rgba(107, 78, 22, 0.16);
}

.button.ghost,
.mini-button {
  background: var(--white);
  color: var(--ink);
  border: 1px solid rgba(107, 78, 22, 0.14);
}

.experience-panel {
  min-height: 280px;
}

.panel-title {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 18px;
}

.panel-title h2 {
  margin: 0 0 8px;
  color: var(--bg);
  font-size: clamp(2rem, 4vw, 2.8rem);
}

.panel-title:has(.channel-panel-title-brand) {
  position: relative;
  align-items: center;
  min-height: 64px;
}

.panel-title:has(.channel-panel-title-brand) .panel-actions {
  position: relative;
  z-index: 2;
}

.channel-panel-title-brand {
  display: inline-flex;
  align-items: center;
  flex-wrap: nowrap;
  gap: 12px;
  color: #cc1010;
  font-size: clamp(1.2rem, 2.4vw, 1.65rem);
  font-weight: 900;
  line-height: 1;
}

.channel-panel-section-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  z-index: 1;
  top: 50%;
  left: 50%;
  max-width: min(38vw, 440px);
  min-height: 30px;
  padding: 5px 12px;
  border-radius: 999px;
  background: rgba(247, 234, 204, 0.82);
  border: 1px solid rgba(107, 78, 22, 0.2);
  color: var(--bg);
  font-size: clamp(0.78rem, 1.1vw, 0.98rem);
  font-weight: 900;
  line-height: 1.05;
  text-align: center;
  transform: translate(-50%, -50%);
  box-shadow: 0 8px 20px rgba(107, 78, 22, 0.1);
}

.channel-panel-title-icon-slot {
  flex: 0 0 auto;
  width: 58px;
}

.channel-panel-title-icon {
  display: block;
  width: 100%;
  max-height: 58px;
  object-fit: contain;
}

.panel-title p {
  margin: 0;
  color: var(--ink-soft);
}

.panel-section-spans {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 2px;
}

.panel-section-spans span {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 5px 10px;
  border-radius: 999px;
  background: rgba(200, 156, 68, 0.18);
  border: 1px solid rgba(107, 78, 22, 0.12);
  color: var(--bg);
  font-size: 0.82rem;
  font-weight: 800;
  line-height: 1.15;
}

.panel-title .meta-line {
  margin-top: 12px;
  color: var(--navy);
  font-weight: 700;
}

.panel-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.panel-hub-link {
  border: 0;
  background: transparent;
  color: var(--bg);
  cursor: pointer;
  font: inherit;
  font-size: clamp(0.92rem, 1.1vw, 1rem);
  font-weight: 900;
  line-height: 1;
  padding: 8px 2px;
  text-decoration: underline;
  text-decoration-color: rgba(107, 78, 22, 0.35);
  text-decoration-thickness: 2px;
  text-underline-offset: 5px;
}

.panel-hub-link:hover,
.panel-hub-link:focus-visible {
  color: #3f8760;
  outline: none;
  text-decoration-color: rgba(63, 135, 96, 0.7);
}

.button.small {
  min-height: 36px;
  padding: 8px 12px;
  font-size: 0.86rem;
}

.slide-shell {
  display: grid;
  grid-template-columns: 260px minmax(0, 1fr);
  gap: 18px;
  align-items: stretch;
}

.slide-rail,
.slide-card,
.mindmap-shell,
.challenge-card,
.feedback-card,
.result-shell,
.jeopardy-focus,
.run-card {
  border-radius: 24px;
  background: rgba(247, 234, 204, 0.88);
  border: 1px solid rgba(107, 78, 22, 0.12);
}

.slide-rail {
  padding: 18px;
  display: grid;
  align-content: start;
  justify-items: center;
  gap: 16px;
}

.lesson-visual-shell {
  display: grid;
  place-items: center;
}

.lesson-visual-slot {
  width: min(140px, 100%);
}

.lesson-visual-image {
  width: 100%;
  max-height: 150px;
  object-fit: contain;
}

.slide-progress {
  color: var(--navy);
  font-weight: 800;
  width: 100%;
  text-align: center;
}

.slide-card {
  padding: 24px;
}

.channel-shell {
  display: grid;
  gap: 18px;
}

.channel-browser,
.channel-empty {
  border-radius: 28px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(249, 242, 226, 0.96)),
    var(--cream);
  border: 1px solid rgba(107, 78, 22, 0.14);
  box-shadow: var(--shadow);
}

.channel-empty {
  display: grid;
  grid-template-columns: minmax(90px, 150px) minmax(0, 1fr);
  align-items: center;
  gap: 18px;
  padding: 24px;
}

.channel-empty h3 {
  margin: 0 0 6px;
  color: var(--navy);
  font-size: clamp(1.25rem, 3vw, 1.8rem);
}

.channel-empty p {
  margin: 0;
  color: var(--muted);
}

.channel-empty-icon-slot,
.channel-brand-icon-slot {
  width: 100%;
}

.channel-empty-icon,
.channel-brand-icon {
  width: 100%;
  object-fit: contain;
}

.channel-browser {
  overflow: hidden;
}

.channel-browser-bar {
  display: grid;
  grid-template-columns: auto minmax(0, 0.74fr);
  align-items: center;
  gap: 10px;
  padding: 9px 13px;
  background: linear-gradient(180deg, #edf1f7, #dfe6ef);
  border-bottom: 1px solid rgba(15, 23, 42, 0.12);
}

.channel-window-dots {
  display: flex;
  gap: 6px;
}

.channel-window-dots span {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: #f35f56;
  box-shadow: inset 0 -1px 1px rgba(0, 0, 0, 0.18);
}

.channel-window-dots span:nth-child(2) {
  background: #f6c146;
}

.channel-window-dots span:nth-child(3) {
  background: #54c96f;
}

.channel-address-pill {
  min-width: 0;
  display: block;
  max-width: 520px;
  padding: 7px 12px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.86);
  color: #5b6472;
  font-size: 0.82rem;
  box-shadow: inset 0 0 0 1px rgba(15, 23, 42, 0.08);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.channel-youtube-copy {
  padding: 18px 20px 14px;
  background: #fff;
}

.channel-brand-row {
  display: flex;
  align-items: center;
  gap: 10px;
  color: #cc1010;
  font-weight: 900;
  letter-spacing: -0.02em;
}

.channel-brand-icon-slot {
  width: 42px;
}

.channel-youtube-copy h2 {
  margin: 0;
  color: #111827;
  font-size: clamp(1.35rem, 3vw, 2.35rem);
  line-height: 1.05;
}

.channel-brand-row + h2 {
  margin-top: 14px;
}

.channel-video-frame {
  position: relative;
  aspect-ratio: 16 / 9;
  margin: 0 20px 18px;
  overflow: hidden;
  border-radius: 20px;
  background:
    radial-gradient(circle at 18% 22%, rgba(255, 255, 255, 0.16), transparent 34%),
    linear-gradient(135deg, #151515, #050505);
  box-shadow: 0 18px 40px rgba(15, 23, 42, 0.26);
}

.channel-open-link {
  position: absolute;
  right: 14px;
  bottom: 14px;
  z-index: 2;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.9);
  color: #111827;
  font-size: 0.78rem;
  font-weight: 900;
  text-decoration: none;
  box-shadow: 0 8px 22px rgba(0, 0, 0, 0.24);
}

.channel-video-iframe,
.channel-video-fallback,
.channel-video-fallback img {
  width: 100%;
  height: 100%;
}

.channel-video-iframe {
  display: block;
  border: 0;
}

.channel-video-fallback {
  display: grid;
  place-items: center;
  color: #fff;
  text-decoration: none;
}

.channel-video-fallback img {
  object-fit: cover;
  filter: saturate(0.95) contrast(1.02);
}

.channel-video-fallback span {
  position: absolute;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 106px;
  min-height: 52px;
  padding: 0 18px;
  border-radius: 999px;
  background: #e62117;
  color: #fff;
  font-weight: 900;
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.28);
}

.channel-video-count {
  padding: 0 22px 20px;
  color: var(--muted);
  font-weight: 800;
  text-align: right;
}

.channel-browser-footer {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
  align-items: center;
  gap: 10px;
  padding: 0 20px 20px;
}

.channel-browser-footer .channel-video-count {
  padding: 0;
  color: var(--bg);
  font-size: clamp(0.92rem, 1.2vw, 1.08rem);
  font-weight: 950;
  text-align: center;
  white-space: nowrap;
}

.channel-nav-button {
  min-height: 42px;
  padding: 7px 11px;
  border-radius: 14px;
  display: grid;
  align-content: center;
  gap: 1px;
  min-width: 0;
}

.channel-nav-label,
.channel-nav-title {
  display: block;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.channel-nav-label {
  font-size: 0.72rem;
  font-weight: 950;
  line-height: 1;
}

.channel-nav-title {
  max-width: 100%;
  font-size: 0.62rem;
  font-weight: 800;
  line-height: 1.05;
  opacity: 0.82;
}

.channel-description {
  margin: 0 20px 14px;
  padding: 15px 16px;
  border-radius: 18px;
  background: rgba(248, 250, 252, 0.92);
  border: 1px solid rgba(15, 23, 42, 0.08);
}

.channel-description h3 {
  margin: 0 0 6px;
  color: #111827;
  font-size: 0.95rem;
}

.channel-description p {
  margin: 0;
  color: #4b5563;
  line-height: 1.45;
}

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

.slide-context-card {
  display: grid;
  justify-items: center;
  gap: 8px;
  width: 100%;
  padding: 0;
  background: transparent;
  border: none;
}

.slide-context-card span {
  display: block;
  width: 100%;
  text-align: center;
  padding: 0;
  border-radius: 0;
  background: transparent;
  color: var(--bg);
  font-weight: 800;
  line-height: 1.25;
}

.slide-rail-mascot-slot {
  width: min(138px, 100%);
  min-height: 138px;
  display: grid;
  place-items: center;
}

.slide-rail-mascot-image {
  width: 100%;
  max-height: 138px;
  object-fit: contain;
}

.slide-overline {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 12px;
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.13em;
  font-weight: 800;
  color: var(--navy);
}

.slide-overline::before {
  content: "";
  width: 26px;
  height: 2px;
  border-radius: 999px;
  background: var(--gold);
}

.slide-card h2 {
  margin: 0 0 10px;
  font-size: clamp(1.8rem, 4vw, 2.7rem);
}

.startup-loader-overlay {
  position: fixed;
  inset: 0;
  z-index: 2147483647;
  display: grid;
  place-items: center;
  background: rgba(255, 250, 242, 0.2);
  pointer-events: all;
  opacity: 1;
  transition: opacity 420ms ease;
}

.startup-loader-overlay.is-standby,
.startup-loader-overlay[hidden] {
  opacity: 0;
  pointer-events: none;
  visibility: hidden;
}

.startup-loader-overlay.is-finished {
  opacity: 0;
  pointer-events: none;
}

.startup-loader-video {
  width: min(72vw, 520px);
  max-width: 92vw;
  max-height: 86vh;
  object-fit: contain;
  filter: drop-shadow(0 26px 42px rgba(65, 42, 23, 0.22));
}

.startup-loader-sr {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
}

.chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}

.chip-row span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  border-radius: 999px;
  background: rgba(200, 156, 68, 0.16);
  color: var(--bg);
  font-weight: 700;
}

.alpaca-list {
  display: grid;
  gap: 12px;
  margin-top: 18px;
}

.alpaca-li {
  display: grid;
  grid-template-columns: 24px minmax(0, 1fr);
  gap: 12px;
  align-items: start;
}

.alpaca-bullet {
  width: 22px;
  height: 22px;
  margin-top: 2px;
  background: center / contain no-repeat url("./assets/icons/ui/alpaca-bullet-update.png");
}

.alpaca-bullet::before,
.alpaca-bullet::after {
  content: none;
}

.raw-content-shell .alpaca-li {
  position: relative;
  display: block;
  min-height: 0;
  padding-left: 52px;
}

.raw-content-shell .alpaca-bullet {
  position: absolute;
  left: 0;
  top: 0.12em;
  width: 42px;
  height: 42px;
  margin-top: 0;
}

.slide-actions,
.feedback-actions,
.result-actions,
.run-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 18px;
}

.mindmap-shell {
  padding: 22px;
  display: grid;
  gap: 22px;
}

.alpacard-shell {
  display: grid;
  gap: 16px;
  padding: 18px;
  border-radius: 28px;
  border: 1px solid rgba(107, 78, 22, 0.14);
  background:
    radial-gradient(circle at 16% 12%, rgba(255, 250, 238, 0.72), transparent 32%),
    radial-gradient(circle at 86% 86%, rgba(200, 156, 68, 0.18), transparent 34%),
    linear-gradient(135deg, rgba(250, 239, 211, 0.88), rgba(229, 195, 129, 0.72));
}

.alpacard-meta-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  color: var(--ink-soft);
  font-weight: 800;
}

.alpacard-meta-row strong {
  margin-left: auto;
  color: var(--bg);
}

.alpacard-badge {
  display: inline-flex;
  align-items: center;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(107, 78, 22, 0.1);
  color: var(--bg);
  font-size: 0.76rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.alpacard-stage {
  height: clamp(520px, 72vh, 760px);
  perspective: 1800px;
}

.alpacard-carousel {
  display: grid;
  gap: 12px;
}

.alpacard-viewport {
  position: relative;
  overflow: hidden;
  border-radius: 24px;
  background:
    linear-gradient(135deg, rgba(255, 250, 238, 0.5), rgba(200, 156, 68, 0.16)),
    rgba(97, 61, 29, 0.08);
  box-shadow: 0 18px 38px rgba(65, 42, 23, 0.16);
}

.alpacard-track {
  display: flex;
  transition: transform 420ms cubic-bezier(0.22, 0.72, 0.24, 1);
  will-change: transform;
}

.alpacard-slide {
  flex: 0 0 100%;
  min-width: 100%;
  padding: 2px;
}

.alpacard-flip-inner {
  position: relative;
  width: 100%;
  height: 100%;
  transform-style: preserve-3d;
  transition: transform 560ms cubic-bezier(0.22, 0.72, 0.24, 1);
}

.alpacard-stage.is-flipped .alpacard-flip-inner {
  transform: rotateY(180deg);
}

.alpacard-card {
  height: 100%;
  display: grid;
  gap: 12px;
  padding: clamp(14px, 2.2vw, 22px);
  border-radius: 22px;
  border: 1px solid rgba(107, 78, 22, 0.16);
  background: rgba(255, 250, 238, 0.82);
  box-shadow: inset 0 0 0 1px rgba(255, 247, 232, 0.46), 0 22px 44px rgba(65, 42, 23, 0.1);
}

.alpacard-face {
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}

.alpacard-front {
  position: relative;
  grid-template-rows: minmax(0, 1fr);
}

.alpacard-image-wrap {
  position: relative;
  isolation: isolate;
  height: 100%;
  min-height: 0;
  display: grid;
  place-items: center;
  overflow: hidden;
  border-radius: 16px;
  background: rgba(247, 234, 204, 0.58);
}

.alpacard-image-wrap::before {
  content: "";
  position: absolute;
  inset: -28px;
  z-index: -2;
  background-image: var(--alpacard-image-url);
  background-position: center;
  background-size: cover;
  filter: blur(22px) saturate(1.24);
  transform: scale(1.08);
}

.alpacard-image-wrap::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    linear-gradient(180deg, rgba(255, 250, 238, 0.16), rgba(255, 250, 238, 0.28)),
    rgba(65, 42, 23, 0.08);
}

.alpacard-image {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  display: block;
  user-select: none;
}

.alpacard-back-heading {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.alpacard-back-heading span,
.alpacard-field span {
  color: rgba(107, 78, 22, 0.74);
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.alpacard-back {
  position: absolute;
  inset: 0;
  grid-template-rows: auto minmax(0, 1fr) auto;
  align-content: start;
  overflow: hidden;
  transform: rotateY(180deg);
}

.alpacard-back-heading {
  align-items: end;
  flex-wrap: wrap;
}

.alpacard-back-heading h3 {
  margin: 0;
  color: var(--bg);
  font-family: "Cardo", Georgia, serif;
  font-size: clamp(2rem, 3vw, 2.8rem);
  line-height: 1;
}

.alpacard-back-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  min-height: 0;
  overflow: auto;
  padding-right: 4px;
  align-content: start;
}

.alpacard-field {
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(247, 234, 204, 0.66);
  border: 1px solid rgba(107, 78, 22, 0.1);
}

.alpacard-field p {
  margin: 4px 0 0;
  color: var(--ink);
  line-height: 1.32;
}

.alpacard-connection-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}

.alpacard-connection-row span {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(107, 78, 22, 0.12);
  background: rgba(200, 156, 68, 0.14);
  color: var(--bg);
  font-size: 0.82rem;
  font-weight: 900;
  line-height: 1.1;
}

.alpacard-controls {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
}

.alpacard-flip-button {
  justify-self: center;
  min-width: 132px;
}

.alpacard-nav-button {
  position: absolute;
  top: 50%;
  z-index: 2;
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  padding: 0;
  border-radius: 50%;
  border: 1px solid rgba(65, 42, 23, 0.16);
  background: rgba(255, 250, 238, 0.82);
  color: var(--ink);
  box-shadow: 0 12px 28px rgba(65, 42, 23, 0.22);
  opacity: 0.84;
  transform: translateY(-50%);
  transition: transform 180ms ease, opacity 180ms ease, background 180ms ease;
}

.alpacard-nav-button--previous {
  left: 16px;
}

.alpacard-nav-button--next {
  right: 16px;
}

.alpacard-nav-button svg {
  width: 24px;
  height: 24px;
}

.alpacard-nav-button path {
  fill: none;
  stroke: currentColor;
  stroke-width: 2.2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.alpacard-nav-button:hover,
.alpacard-nav-button:focus-visible {
  opacity: 1;
  background: rgba(255, 250, 238, 0.96);
  transform: translateY(-50%) scale(1.08);
}

.alpacard-nav-button:disabled {
  opacity: 0.38;
  cursor: not-allowed !important;
  transform: translateY(-50%);
}

.alpacard-thumbnails {
  overflow-x: auto;
  padding: 2px 1px 8px;
  scrollbar-width: none;
}

.alpacard-thumbnails::-webkit-scrollbar {
  display: none;
}

.alpacard-thumbnail-track {
  width: max-content;
  height: 80px;
  display: flex;
  align-items: stretch;
  gap: 4px;
}

.alpacard-thumb {
  flex: 0 0 auto;
  width: 36px;
  height: 80px;
  padding: 0;
  overflow: hidden;
  border: 1px solid rgba(107, 78, 22, 0.12);
  border-radius: 8px;
  background: rgba(255, 250, 238, 0.76);
  box-shadow: 0 8px 18px rgba(65, 42, 23, 0.1);
  opacity: 0.66;
  transition: width 280ms ease, opacity 180ms ease, transform 180ms ease, border-color 180ms ease, box-shadow 180ms ease;
}

.alpacard-thumb.is-active {
  width: 122px;
  border-color: rgba(138, 99, 56, 0.62);
  box-shadow: 0 12px 26px rgba(65, 42, 23, 0.2);
  opacity: 1;
}

.alpacard-thumb:hover,
.alpacard-thumb:focus-visible {
  transform: translateY(-2px);
  opacity: 1;
}

.alpacard-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  pointer-events: none;
  user-select: none;
}

@media (prefers-reduced-motion: reduce) {
  .alpacard-track,
  .alpacard-flip-inner,
  .alpacard-thumb,
  .alpacard-nav-button {
    transition-duration: 0.01ms;
  }
}

.alpacard-empty {
  display: grid;
  gap: 12px;
  justify-items: start;
  padding: clamp(22px, 4vw, 42px);
  border-radius: 26px;
  background: rgba(255, 250, 238, 0.74);
}

.alpacard-empty h3,
.alpacard-empty p {
  margin: 0;
}

.alpacard-empty h3 {
  color: var(--bg);
  font-family: "Cardo", Georgia, serif;
  font-size: clamp(1.7rem, 3vw, 2.4rem);
}

.mindmap-center {
  width: min(760px, 100%);
  display: grid;
  grid-template-columns: 92px minmax(0, 1fr);
  gap: 18px;
  align-items: center;
  justify-self: center;
  padding: 18px 22px;
  border-radius: 28px;
  background:
    radial-gradient(circle at top right, rgba(255, 247, 232, 0.42), transparent 36%),
    linear-gradient(135deg, rgba(138, 99, 56, 0.96), rgba(200, 156, 68, 0.94));
  color: var(--ink);
  box-shadow: 0 22px 42px rgba(65, 42, 23, 0.14);
}

.mindmap-center .challenge-label,
.mindmap-center h2,
.mindmap-center p {
  color: var(--white);
}

.mindmap-center h2 {
  margin: 0 0 8px;
  font-family: "Cardo", Georgia, serif;
  font-size: clamp(1.8rem, 4vw, 2.6rem);
}

.mindmap-radial-set {
  display: grid;
  gap: 28px;
}

.mindmap-radial-map {
  display: grid;
  gap: 14px;
}

.mindmap-radial-heading {
  width: min(560px, 100%);
  justify-self: center;
  display: grid;
  gap: 5px;
  justify-items: center;
  text-align: center;
}

.mindmap-radial-heading span,
.mindmap-radial-center span,
.mindmap-radial-branch span {
  color: rgba(107, 78, 22, 0.72);
  font-size: 0.74rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.mindmap-radial-heading h3 {
  margin: 0;
  font-family: "Cardo", Georgia, serif;
  color: var(--bg);
  font-size: clamp(1.55rem, 3vw, 2.15rem);
}

.mindmap-radial-heading p {
  margin: 0;
  color: var(--ink-soft);
  font-weight: 700;
}

.mindmap-radial-scroll {
  position: relative;
  max-width: 100%;
  height: min(78vh, 820px);
  min-height: 620px;
  overflow: auto;
  padding: 18px;
  border-radius: 38px;
  border: 1px solid rgba(107, 78, 22, 0.14);
  background:
    radial-gradient(circle at 22% 20%, rgba(255, 247, 232, 0.92), transparent 30%),
    radial-gradient(circle at 78% 74%, rgba(200, 156, 68, 0.18), transparent 28%),
    linear-gradient(135deg, rgba(243, 227, 188, 0.84), rgba(236, 217, 170, 0.62));
  box-shadow: inset 0 0 0 1px rgba(255, 247, 232, 0.36), 0 22px 44px rgba(65, 42, 23, 0.1);
  -webkit-overflow-scrolling: touch;
}

.mindmap-radial-stage {
  position: relative;
  width: var(--map-size);
  height: var(--map-size);
  min-width: var(--map-size);
  min-height: var(--map-size);
  margin: 0 auto;
  border-radius: 50%;
  background:
    radial-gradient(circle at center, rgba(255, 247, 232, 0.58) 0 12%, transparent 12% 100%),
    radial-gradient(circle at center, transparent 0 34%, rgba(185, 137, 83, 0.08) 34.2% 34.6%, transparent 34.8% 100%),
    radial-gradient(circle at center, transparent 0 53%, rgba(138, 99, 56, 0.07) 53.2% 53.6%, transparent 53.8% 100%);
}

.mindmap-radial-lines {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  overflow: visible;
  pointer-events: none;
}

.mindmap-radial-path {
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.mindmap-radial-path.main {
  stroke: rgba(138, 99, 56, 0.48);
  stroke-width: 4;
}

.mindmap-radial-path.entry {
  stroke: rgba(185, 137, 83, 0.58);
  stroke-width: 4;
}

.mindmap-radial-center,
.mindmap-radial-branch,
.mindmap-radial-entry {
  position: absolute;
  z-index: 1;
  transform: translate(-50%, -50%);
  text-align: center;
}

.mindmap-radial-center {
  width: 220px;
  min-height: 164px;
  display: grid;
  gap: 8px;
  place-items: center;
  align-content: center;
  padding: 26px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 32% 22%, rgba(247, 234, 204, 0.24), transparent 34%),
    linear-gradient(135deg, rgba(138, 99, 56, 0.98), rgba(107, 78, 22, 0.96));
  border: 1px solid rgba(247, 234, 204, 0.22);
  color: var(--white);
  cursor: pointer;
  font: inherit;
  box-shadow: 0 24px 38px rgba(65, 42, 23, 0.2);
}

.mindmap-radial-center:disabled {
  cursor: default;
}

.mindmap-radial-center:not(:disabled):hover,
.mindmap-radial-center:not(:disabled):focus-visible {
  outline: none;
  border-color: rgba(106, 178, 125, 0.64);
  box-shadow: 0 26px 42px rgba(65, 42, 23, 0.24);
}

.mindmap-radial-center span {
  color: rgba(247, 234, 204, 0.82);
}

.mindmap-radial-center strong {
  max-width: 170px;
  color: var(--white);
  font-family: "Cardo", Georgia, serif;
  font-size: 1.34rem;
  line-height: 1.04;
}

.mindmap-radial-branch {
  width: var(--bubble-width);
  min-height: var(--bubble-height);
  display: grid;
  gap: 4px;
  place-items: center;
  align-content: center;
  padding: 16px 20px;
  border: 2px solid rgba(138, 99, 56, 0.52);
  border-radius: 50%;
  background: rgba(236, 217, 170, 0.96);
  box-shadow: 0 18px 28px rgba(65, 42, 23, 0.1);
}

.mindmap-radial-branch.branch-1 {
  background: rgba(247, 234, 204, 0.96);
}

.mindmap-radial-branch.branch-2 {
  background: rgba(225, 190, 103, 0.45);
}

.mindmap-radial-branch.branch-3 {
  background: rgba(185, 137, 83, 0.24);
}

.mindmap-radial-branch strong {
  color: var(--navy);
  font-weight: 900;
  line-height: 1.08;
}

.mindmap-radial-branch em {
  color: rgba(65, 42, 23, 0.66);
  font-size: 0.78rem;
  font-style: normal;
  font-weight: 800;
}

.mindmap-radial-entry {
  width: var(--bubble-width);
  min-height: var(--bubble-height);
  display: grid;
  gap: 3px;
  place-items: center;
  align-content: center;
  padding: 11px 15px;
  border: 2px solid rgba(185, 137, 83, 0.58);
  border-radius: 999px;
  background:
    radial-gradient(circle at 28% 24%, rgba(255, 255, 255, 0.7), transparent 36%),
    rgba(255, 243, 209, 0.98);
  color: var(--navy);
  cursor: pointer;
  box-shadow: 0 12px 22px rgba(65, 42, 23, 0.09);
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease, background 180ms ease;
}

.mindmap-radial-entry:hover,
.mindmap-radial-entry:focus-visible {
  transform: translate(-50%, -50%) scale(1.04);
  border-color: rgba(138, 99, 56, 0.82);
  background:
    radial-gradient(circle at 28% 24%, rgba(255, 255, 255, 0.82), transparent 36%),
    rgba(247, 234, 204, 1);
  box-shadow: 0 18px 30px rgba(65, 42, 23, 0.16);
  outline: none;
}

.mindmap-radial-entry span {
  color: var(--navy);
  font-size: 0.83rem;
  font-weight: 900;
  line-height: 1.08;
}

.mindmap-radial-entry em {
  max-width: 100%;
  color: rgba(65, 42, 23, 0.64);
  font-size: 0.7rem;
  font-style: normal;
  font-weight: 800;
  line-height: 1.04;
}

.mindmap-entry-window {
  width: min(920px, calc(100vw - 28px));
  max-height: min(88vh, 860px);
  overflow-y: auto;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
}

.mindmap-entry-stack {
  gap: 16px;
}

.mindmap-entry-stack h3 {
  margin: 0;
  font-family: "Cardo", Georgia, serif;
  font-size: clamp(1.8rem, 4vw, 2.3rem);
  color: var(--bg);
}

.map-prompts {
  display: grid;
  gap: 12px;
}

.map-prompt {
  padding: 16px;
  border-radius: 18px;
  background: rgba(247, 234, 204, 0.84);
  border: 1px solid rgba(107, 78, 22, 0.12);
}

.mode-shell {
  display: grid;
  gap: 18px;
}

.mode-topbar {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: start;
}

.mode-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.mode-stats span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  border-radius: 999px;
  background: rgba(200, 156, 68, 0.16);
  color: var(--bg);
  font-weight: 800;
}

.challenge-card {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr);
  gap: 18px;
  padding: 20px;
}

.question-popup-overlay {
  position: fixed;
  inset: 0;
  z-index: 1200;
  display: grid;
  align-items: center;
  justify-items: center;
  overflow-y: auto;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
  padding: 24px;
  background:
    linear-gradient(180deg, rgba(75, 47, 33, 0.2), rgba(75, 47, 33, 0.34));
  backdrop-filter: blur(6px);
}

.question-popup-window {
  position: relative;
  width: min(1176px, calc(100vw - 28px));
  max-height: calc(100vh - 24px);
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  border-radius: 28px;
  padding: 64px 22px 22px;
  background:
    radial-gradient(circle at top right, rgba(200, 156, 68, 0.14), transparent 28%),
    linear-gradient(180deg, rgba(247, 234, 204, 0.98), rgba(243, 227, 188, 0.98));
  border: 1px solid rgba(107, 78, 22, 0.16);
  box-shadow:
    0 32px 64px rgba(75, 47, 33, 0.24),
    inset 0 1px 0 rgba(255, 248, 232, 0.4);
}

.question-popup-stack {
  display: grid;
  gap: 14px;
}

.popup-close-button,
.panel-close-button,
.result-close-button {
  position: absolute;
  top: 14px;
  right: 14px;
  z-index: 3;
  width: 40px;
  height: 40px;
  display: inline-grid;
  place-items: center;
  border: 1px solid rgba(107, 78, 22, 0.16);
  border-radius: 999px;
  background: rgba(247, 234, 204, 0.96);
  color: var(--bg);
  box-shadow: 0 8px 18px rgba(75, 47, 33, 0.12);
  cursor: pointer;
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 1;
}

.popup-close-button:hover,
.panel-close-button:hover,
.result-close-button:hover {
  background: rgba(236, 214, 165, 0.98);
  border-color: rgba(200, 156, 68, 0.36);
}

.question-popup-window .challenge-card,
.question-popup-window .feedback-card {
  margin: 0;
  border-radius: 24px;
  border: 1px solid rgba(107, 78, 22, 0.12);
  background: rgba(249, 239, 214, 0.94);
  box-shadow: 0 12px 24px rgba(75, 47, 33, 0.08);
}

.question-popup-overlay.run {
  align-items: end;
  justify-items: end;
  padding: 22px 28px 26px;
  background:
    linear-gradient(180deg, rgba(75, 47, 33, 0.02), rgba(75, 47, 33, 0.08) 56%, rgba(75, 47, 33, 0.16));
  backdrop-filter: none;
}

.question-popup-window.run {
  width: min(792px, calc(100vw - 28px));
  max-height: min(86vh, calc(100vh - 24px));
  background:
    radial-gradient(circle at top right, rgba(200, 156, 68, 0.12), transparent 32%),
    linear-gradient(180deg, rgba(247, 234, 204, 0.92), rgba(243, 227, 188, 0.9));
  border-color: rgba(107, 78, 22, 0.18);
  box-shadow:
    0 26px 52px rgba(75, 47, 33, 0.18),
    inset 0 1px 0 rgba(255, 248, 232, 0.28);
}

.question-popup-window.run .challenge-card,
.question-popup-window.run .feedback-card {
  background: rgba(249, 239, 214, 0.88);
  border-color: rgba(107, 78, 22, 0.16);
}

.question-popup-window.run .challenge-card {
  grid-template-columns: 184px minmax(0, 1fr);
}

.challenge-card.relay-no-mascot {
  grid-template-columns: 1fr;
}

.question-popup-window.race .challenge-card,
.race-question-card {
  grid-template-columns: 1fr;
}

.race-question-pills {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.race-question-pills span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 9px 12px;
  border-radius: 999px;
  background: rgba(236, 214, 165, 0.66);
  border: 1px solid rgba(107, 78, 22, 0.12);
  color: var(--bg);
  font-weight: 900;
}

.question-popup-window.run .challenge-mascot {
  background:
    linear-gradient(160deg, rgba(247, 234, 204, 0.9), rgba(235, 210, 153, 0.88));
}

.question-popup-window.buildcase {
  width: min(1248px, calc(100vw - 28px));
}

.question-popup-window.buildcase .challenge-card {
  grid-template-columns: 220px minmax(0, 1fr);
}

.challenge-mascot {
  display: grid;
  gap: 12px;
  align-content: start;
  justify-items: center;
  padding: 18px;
  border-radius: 20px;
  background:
    linear-gradient(160deg, rgba(247, 234, 204, 0.96), rgba(235, 210, 153, 0.95));
  border: 1px solid rgba(107, 78, 22, 0.12);
}

.mascot-slot {
  display: grid;
  place-items: center;
}

.mascot-slot-small {
  width: 52px;
}

.mascot-slot-medium {
  width: 88px;
}

.mascot-slot-large {
  width: 132px;
}

.mascot-slot-hero {
  width: 180px;
}

.mascot-asset {
  width: 100%;
  height: auto;
  object-fit: contain;
}

.challenge-label {
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: 0.13em;
  font-weight: 800;
  color: var(--navy);
}

.game-note-list {
  width: 100%;
  display: grid;
  gap: 8px;
  margin-top: 6px;
}

.game-note-item {
  display: grid;
  grid-template-columns: 20px minmax(0, 1fr);
  gap: 8px;
  align-items: start;
  text-align: center;
  color: var(--ink-soft);
  font-size: 0.83rem;
  line-height: 1.4;
}

.game-note-item .alpaca-bullet {
  width: 18px;
  height: 18px;
  margin-top: 1px;
}

.challenge-copy h2 {
  margin: 0 0 10px;
  font-size: clamp(1.35rem, 3vw, 2rem);
  color: var(--ink);
}

.popup-question-panel {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 16px;
  align-items: center;
  margin-bottom: 16px;
  padding: 14px 16px;
  border-radius: 20px;
  background:
    linear-gradient(180deg, rgba(247, 234, 204, 0.92), rgba(239, 221, 180, 0.9));
  border: 1px solid rgba(107, 78, 22, 0.14);
  box-shadow: inset 0 1px 0 rgba(255, 248, 232, 0.34);
}

.popup-question-panel.warning {
  border-color: rgba(200, 156, 68, 0.32);
  background:
    radial-gradient(circle at top right, rgba(200, 156, 68, 0.14), transparent 34%),
    linear-gradient(180deg, rgba(247, 234, 204, 0.94), rgba(239, 221, 180, 0.92));
}

.popup-question-panel.danger {
  border-color: rgba(109, 31, 38, 0.28);
  background:
    radial-gradient(circle at top right, rgba(109, 31, 38, 0.08), transparent 36%),
    linear-gradient(180deg, rgba(247, 234, 204, 0.96), rgba(235, 210, 168, 0.94));
}

.popup-question-copy {
  min-width: 0;
  display: grid;
  gap: 0;
}

.popup-question-text {
  margin: 0;
  color: var(--bg);
  font-size: clamp(1.08rem, 0.68vw + 0.94rem, 1.55rem);
  line-height: 1.22;
}

.popup-question-timer {
  display: grid;
  place-items: center;
}

.popup-question-panel .race-timer-widget {
  width: min(100%, 148px);
  margin: 0;
}

.question-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 14px;
}

.meta-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border-radius: 999px;
  font-size: 0.8rem;
  font-weight: 800;
}

.meta-pill.section {
  background: rgba(138, 99, 56, 0.1);
  color: var(--bg);
}

.meta-pill.subject {
  background: var(--subject-soft, rgba(200, 156, 68, 0.12));
  color: var(--subject-color, var(--bg));
}

.meta-pill.timer {
  background: rgba(200, 156, 68, 0.16);
  color: var(--bg);
}

.options-grid {
  display: grid;
  gap: 12px;
  margin-top: 20px;
}

.answer-options-grid,
.raw-quiz-options {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-template-rows: repeat(2, auto);
  grid-auto-flow: column;
}

.option-button,
.tile-button {
  width: 100%;
  text-align: left;
  border-radius: 18px;
  border: 1px solid rgba(107, 78, 22, 0.12);
  background: rgba(247, 234, 204, 0.9);
  cursor: pointer;
}

.option-button {
  display: grid;
  grid-template-columns: 38px minmax(0, 1fr);
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
}

.answer-options-grid .option-button,
.raw-quiz-option {
  text-align: center;
}

.answer-options-grid .option-button > span:last-child,
.raw-quiz-option > span:last-child {
  justify-self: center;
  align-self: center;
  text-align: center;
}

.option-button.active {
  border-color: rgba(107, 78, 22, 0.28);
  background: linear-gradient(180deg, rgba(247, 234, 204, 0.98), rgba(236, 214, 165, 0.96));
  box-shadow: 0 14px 24px rgba(75, 47, 33, 0.08);
}

.option-token {
  width: 38px;
  min-width: 38px;
  height: 38px;
  display: grid;
  place-items: center;
  flex-shrink: 0;
}

.option-token.text {
  border-radius: 50%;
  background: rgba(138, 99, 56, 0.12);
  color: var(--bg);
  font-weight: 800;
}

.option-token-image {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.option-button.correct {
  background: rgba(225, 196, 119, 0.28);
  border-color: rgba(185, 137, 83, 0.28);
}

.option-button.wrong {
  background: rgba(196, 162, 130, 0.24);
  border-color: rgba(122, 90, 51, 0.24);
}

.option-button.disabled {
  opacity: 0.88;
  cursor: default;
}

.question-popup-window.relay .option-button.awaiting-buzz,
.question-popup-window.relay .option-button.awaiting-buzz:disabled {
  opacity: 1;
  color: #4b2f21;
  -webkit-text-fill-color: #4b2f21;
}

.question-popup-window.relay .option-button.awaiting-buzz span,
.question-popup-window.relay .option-button.awaiting-buzz:disabled span {
  color: #4b2f21;
}

.feedback-card {
  display: grid;
  grid-template-columns: 140px minmax(0, 1fr);
  gap: 16px;
  padding: 18px;
  margin-top: 16px;
}

.checkpoint-visual,
.result-visual {
  display: grid;
  place-items: center;
}

.checkpoint-visual-slot {
  width: min(124px, 100%);
}

.checkpoint-visual-image,
.board-decoration-image,
.run-decoration-image {
  width: 100%;
  height: auto;
  object-fit: contain;
}

.feedback-card.correct {
  background: rgba(242, 230, 192, 0.96);
  border-color: rgba(185, 137, 83, 0.22);
}

.feedback-card.wrong {
  background: rgba(238, 221, 199, 0.96);
  border-color: rgba(138, 99, 56, 0.2);
}

.feedback-card h3 {
  margin: 0 0 8px;
  color: var(--bg);
}

.relay-answer-popup {
  position: sticky;
  bottom: 0;
  z-index: 4;
  margin-top: 18px;
  background:
    radial-gradient(circle at top right, rgba(252, 209, 39, 0.2), transparent 32%),
    linear-gradient(180deg, rgba(247, 234, 204, 0.98), rgba(243, 227, 188, 0.97));
  border-color: rgba(107, 78, 22, 0.2);
  box-shadow: 0 28px 56px rgba(75, 47, 33, 0.24);
}

.result-shell {
  position: relative;
  padding: 20px;
}

.result-banner {
  display: grid;
  grid-template-columns: 150px minmax(0, 1fr);
  gap: 18px;
  align-items: center;
  padding: 18px;
  border-radius: 22px;
  background:
    radial-gradient(circle at top right, rgba(200, 156, 68, 0.24), transparent 28%),
    linear-gradient(135deg, rgba(245, 232, 197, 0.98), rgba(214, 183, 120, 0.95));
  color: var(--ink);
}

.result-banner h2 {
  margin: 0 0 8px;
  font-size: clamp(1.8rem, 4vw, 2.7rem);
}

.result-metrics {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-top: 18px;
}

.metric-card {
  padding: 16px;
  border-radius: 18px;
  background: rgba(247, 234, 204, 0.9);
  border: 1px solid rgba(107, 78, 22, 0.12);
}

.metric-card span {
  display: block;
  margin-bottom: 8px;
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--ink-soft);
}

.metric-card strong {
  font-size: 1.45rem;
  color: var(--bg);
}

.breakdown-columns {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  margin-top: 18px;
}

.breakdown-column h3 {
  margin: 0 0 10px;
  color: var(--bg);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.9rem;
}

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

.breakdown-row {
  padding: 14px 16px;
  border-radius: 18px;
  background: rgba(247, 234, 204, 0.88);
  border: 1px solid rgba(107, 78, 22, 0.12);
}

.breakdown-head {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 10px;
  font-weight: 800;
}

.breakdown-progress {
  height: 10px;
  border-radius: 999px;
  background: rgba(138, 99, 56, 0.12);
  overflow: hidden;
}

.breakdown-progress span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--bg), var(--gold));
}

.jeopardy-team-shell {
  display: grid;
  gap: 14px;
}

.jeopardy-team-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}

.jeopardy-turn-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(200, 156, 68, 0.14);
  color: var(--bg);
  font-weight: 800;
}

.jeopardy-turn-pill.danger,
.meta-pill.timer.danger {
  background: rgba(168, 118, 69, 0.18);
  color: var(--ink);
}

.jeopardy-team-grid,
.jeopardy-standings {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
}

.jeopardy-team-card,
.jeopardy-standing-card {
  display: grid;
  gap: 6px;
  padding: 16px;
  border-radius: 20px;
  background: rgba(247, 234, 204, 0.9);
  border: 1px solid rgba(107, 78, 22, 0.12);
  text-align: left;
  color: var(--ink);
}

.jeopardy-team-card {
  cursor: pointer;
}

.jeopardy-team-card strong,
.jeopardy-standing-card strong {
  font-size: 1.6rem;
  color: var(--bg);
}

.jeopardy-team-card .team-label,
.jeopardy-standing-card .team-label {
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-weight: 800;
  color: var(--navy);
}

.jeopardy-team-card.active {
  border-color: rgba(200, 156, 68, 0.48);
  background: linear-gradient(180deg, rgba(247, 234, 204, 0.98), rgba(236, 214, 165, 0.96));
  box-shadow: 0 0 0 4px rgba(200, 156, 68, 0.12);
}

.jeopardy-team-card.leader,
.jeopardy-standing-card.winner {
  border-color: rgba(200, 156, 68, 0.42);
}

.jeopardy-board-shell {
  display: grid;
  gap: 18px;
  overflow-x: auto;
  padding: 4px 2px 2px;
}

.jeopardy-board {
  display: grid;
  grid-template-columns: repeat(var(--jeopardy-columns, 4), minmax(220px, 1fr));
  gap: 18px;
  min-width: max-content;
  width: max-content;
  margin-inline: auto;
  align-items: start;
}

.board-decoration {
  min-height: 0;
}

.board-decoration .asset-slot {
  width: 100%;
}

.board-decoration-image {
  max-height: 180px;
}

.jeopardy-category {
  padding: 18px;
  border-radius: 22px;
  background:
    linear-gradient(180deg, rgba(247, 234, 204, 0.96), rgba(240, 224, 181, 0.94));
  border: 1px solid rgba(107, 78, 22, 0.14);
}

.jeopardy-category-heading {
  position: relative;
  margin: 0 0 16px;
  width: 100%;
  aspect-ratio: 320 / 120;
  min-height: 0;
}

.jeopardy-category-art {
  position: absolute;
  inset: 0;
}

.jeopardy-category-art .asset-slot {
  width: 100%;
  height: 100%;
}

.jeopardy-category-art-image {
  width: 100%;
  height: 100%;
  object-fit: fill;
}

.jeopardy-category-safe-area {
  position: absolute;
  left: 10.625%;
  top: 25%;
  width: 78.75%;
  height: 51.6667%;
  z-index: 1;
  display: grid;
  place-items: center;
  padding: 0 14px;
}

.jeopardy-category-label {
  width: 100%;
  height: 100%;
  display: grid;
  place-items: center;
  text-align: center;
  color: var(--ink);
  font-size: clamp(0.8rem, 0.28vw + 0.74rem, 0.98rem);
  font-weight: 900;
  line-height: 1.08;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  overflow-wrap: anywhere;
  text-wrap: balance;
}

.jeopardy-category-label.tight {
  font-size: clamp(0.72rem, 0.24vw + 0.68rem, 0.88rem);
  letter-spacing: 0.03em;
}

.jeopardy-category-label.compact {
  font-size: clamp(0.66rem, 0.22vw + 0.62rem, 0.8rem);
  letter-spacing: 0.02em;
  line-height: 1.02;
}

.jeopardy-stack {
  display: grid;
  gap: 10px;
}

.tile-button {
  position: relative;
  overflow: hidden;
  display: grid;
  place-items: center;
  padding: 10px 12px;
  text-align: center;
  min-height: 0;
}

.tile-button.done {
  background: rgba(247, 234, 204, 0.7);
  cursor: default;
}

.tile-button.active {
  border-color: rgba(107, 78, 22, 0.24);
  background: rgba(200, 156, 68, 0.12);
  box-shadow: 0 0 0 4px rgba(200, 156, 68, 0.12);
}

.jeopardy-tile-face {
  position: relative;
  width: 100%;
  display: block;
  min-height: 0;
}

.jeopardy-tile-face.open {
  aspect-ratio: 320 / 140;
}

.jeopardy-tile-face.done {
  aspect-ratio: 320 / 120;
}

.jeopardy-tile-art {
  position: absolute;
  inset: 0;
}

.jeopardy-tile-art .asset-slot {
  width: 100%;
  height: 100%;
}

.jeopardy-tile-art-image {
  width: 100%;
  height: 100%;
  object-fit: fill;
}

.jeopardy-tile-safe-area {
  position: absolute;
  left: 10.625%;
  top: 21.4286%;
  width: 78.75%;
  height: 45.7143%;
  z-index: 1;
  display: grid;
  place-items: center;
  padding: 0 12px;
}

.jeopardy-tile-copy {
  width: 100%;
  height: 100%;
  display: grid;
  place-items: center;
  padding: 0;
  color: var(--ink);
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  text-shadow: 0 1px 0 rgba(247, 234, 204, 0.35);
}

.jeopardy-tile-copy.value {
  font-size: clamp(1.7rem, 0.85vw + 1.42rem, 2.1rem);
  line-height: 1;
  color: #4b2f21;
  transform: none;
}

.jeopardy-focus {
  padding: 0;
  margin-top: 0;
}

.relay-team-shell {
  position: relative;
  display: grid;
  gap: 14px;
}

.relay-overlay {
  min-height: 0;
}

.relay-overlay .asset-slot {
  width: 100%;
}

.relay-overlay-image {
  width: 100%;
  max-height: 180px;
  object-fit: contain;
}

.relay-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}

.relay-toolbar-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(200, 156, 68, 0.14);
  color: var(--bg);
  font-weight: 800;
}

.relay-team-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
}

.relay-launch-panel {
  position: relative;
  display: grid;
  gap: 14px;
  padding: 22px;
}

.relay-launch-kicker,
.relay-popup-team-kicker {
  margin: 0;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 0.78rem;
  font-weight: 800;
  color: var(--gold);
}

.relay-launch-panel h3,
.relay-popup-team-header h3 {
  margin: 0;
  color: var(--bg);
  font-size: clamp(1.2rem, 2vw, 1.55rem);
}

.relay-launch-panel p:not(.relay-launch-kicker) {
  margin: 0;
  color: var(--ink-soft);
  max-width: 68ch;
}

.relay-launch-pills {
  display: grid;
  gap: 10px;
}

.relay-launch-pills span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(200, 156, 68, 0.14);
  color: var(--bg);
  font-weight: 800;
}

.relay-popup-team-shell {
  display: grid;
  gap: 14px;
}

.relay-popup-team-shell.buzzed {
  gap: 0;
}

.relay-popup-team-toprow {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) minmax(320px, 390px) auto;
  align-items: start;
  gap: 14px;
}

.relay-popup-team-intro {
  display: grid;
  gap: 6px;
  align-self: start;
  padding-top: 2px;
}

.relay-popup-team-focus {
  display: grid;
  align-self: start;
}

.relay-popup-timer-wrap {
  display: flex;
  justify-content: flex-end;
  align-items: flex-start;
}

.relay-popup-team-header {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 12px;
}

.relay-popup-team-header > div {
  display: grid;
  gap: 6px;
}

.relay-popup-team-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 12px;
}

.relay-popup-team-grid.solo {
  grid-template-columns: minmax(280px, 380px);
  justify-content: center;
}

.relay-team-card {
  position: relative;
  overflow: hidden;
  display: grid;
  gap: 8px;
  min-height: 150px;
  padding: 22px 18px 20px 118px;
  border-radius: 20px;
  background: rgba(247, 234, 204, 0.92);
  border: 1px solid rgba(107, 78, 22, 0.12);
  text-align: left;
  color: var(--ink);
  cursor: pointer;
}

.relay-team-card.popup {
  min-height: 168px;
  padding: 34px 22px 24px 132px;
  border-color: rgba(107, 78, 22, 0.18);
  box-shadow: 0 12px 24px rgba(75, 47, 33, 0.08);
}

.relay-team-card.popup .team-label {
  font-size: 0.88rem;
}

.relay-team-card.popup .relay-score {
  font-size: 1.75rem;
}

.relay-team-card.popup .relay-state {
  font-size: 0.92rem;
}

.relay-team-card > * {
  position: relative;
  z-index: 1;
}

.relay-team-card-skin {
  position: absolute;
  inset: 10px;
  z-index: 0;
  opacity: 0.28;
  pointer-events: none;
}

.relay-team-card-skin .asset-slot {
  width: 100%;
  height: 100%;
}

.relay-team-card-skin-image {
  width: 100%;
  height: 100%;
  object-fit: fill;
  object-position: center;
}

.relay-team-card .team-label {
  font-size: 0.9rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-weight: 800;
  color: #4b2f21;
}

.relay-score {
  font-size: 1.55rem;
  line-height: 1;
  color: #4b2f21;
}

.relay-state {
  color: #5a3726;
  font-size: 0.94rem;
  font-weight: 700;
}

.relay-team-card.active {
  border-color: rgba(200, 156, 68, 0.48);
  background: linear-gradient(180deg, rgba(247, 234, 204, 0.98), rgba(236, 214, 165, 0.96));
  box-shadow: 0 0 0 4px rgba(200, 156, 68, 0.12);
}

.relay-team-card.active .relay-team-card-skin {
  opacity: 0.2;
}

.relay-team-card.leader {
  border-color: rgba(168, 118, 69, 0.34);
}

.relay-keycap {
  position: absolute;
  top: 28px;
  left: 28px;
  width: 56px;
  height: 56px;
  display: grid;
  place-items: center;
  color: #4b2f21;
  font-weight: 900;
}

.relay-keycap.asset-slot {
  pointer-events: none;
}

.relay-keycap:not(.asset-slot) {
  border-radius: 12px;
  background: rgba(138, 99, 56, 0.12);
}

.relay-keycap-image {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.relay-team-card.popup .relay-keycap {
  top: 34px;
  left: 32px;
  width: 64px;
  height: 64px;
}

.relay-buzz-banner,
.relay-answer-status,
.race-timer-card,
.race-lives-card {
  padding: 16px 18px;
  border-radius: 20px;
  background: rgba(247, 234, 204, 0.9);
  border: 1px solid rgba(107, 78, 22, 0.12);
}

.relay-buzz-banner strong,
.relay-answer-status {
  color: var(--bg);
}

.relay-buzz-banner p {
  margin: 6px 0 0;
  color: var(--ink-soft);
}

.relay-answer-status {
  display: flex;
  gap: 12px;
  align-items: center;
  font-weight: 800;
}

.question-popup-window.relay {
  width: min(1120px, calc(100vw - 36px));
}

.setup-option-mascot {
  width: min(84px, 100%);
}

.setup-option-mascot-image {
  width: 100%;
  max-height: 84px;
  object-fit: contain;
}

.setup-card {
  display: grid;
  gap: 18px;
}

.setup-card-header {
  display: grid;
  grid-template-columns: 120px minmax(0, 1fr);
  gap: 16px;
  align-items: center;
}

.setup-block {
  display: grid;
  gap: 10px;
}

.setup-block strong {
  color: var(--bg);
}

.setup-helper {
  margin: 0;
  color: var(--ink-soft);
  font-weight: 700;
}

.setup-count-grid,
.setup-option-grid {
  display: grid;
  gap: 10px;
}

.setup-count-grid {
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
}

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

.setup-count-button,
.setup-option-button {
  border: 1px solid rgba(107, 78, 22, 0.14);
  border-radius: 18px;
  background: rgba(247, 234, 204, 0.9);
  color: var(--bg);
  cursor: pointer;
  transition:
    transform 180ms ease,
    border-color 180ms ease,
    box-shadow 180ms ease,
    background-color 180ms ease;
}

.setup-count-button {
  padding: 14px 16px;
  font-weight: 800;
}

.setup-option-button {
  display: grid;
  justify-items: center;
  gap: 8px;
  padding: 14px 12px;
  text-align: center;
}

.setup-option-button .mascot-slot {
  width: min(74px, 100%);
}

.setup-count-button.active,
.setup-option-button.active {
  border-color: rgba(107, 78, 22, 0.26);
  background: linear-gradient(180deg, rgba(247, 234, 204, 0.98), rgba(236, 214, 165, 0.96));
  box-shadow: 0 16px 28px rgba(75, 47, 33, 0.08);
}

.setup-rule-list {
  display: grid;
  gap: 8px;
}

.setup-rule-list p {
  margin: 0;
  color: var(--ink-soft);
}

.live-lobby-panel {
  display: grid;
  gap: 14px;
  padding: 16px;
  border-radius: 22px;
  border: 1px solid rgba(107, 78, 22, 0.16);
  background:
    linear-gradient(135deg, rgba(255, 248, 232, 0.94), rgba(236, 214, 165, 0.72));
}

.live-lobby-header {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.live-lobby-header p,
.live-lobby-note,
.live-lobby-error {
  margin: 4px 0 0;
  color: var(--ink-soft);
  font-weight: 700;
}

.live-lobby-error {
  color: #7c2d1d;
}

.live-lobby-actions {
  justify-content: flex-start;
}

.live-room-list,
.live-player-grid {
  display: grid;
  gap: 10px;
}

.live-room-row,
.live-player-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px;
  border-radius: 18px;
  border: 1px solid rgba(107, 78, 22, 0.12);
  background: rgba(255, 252, 242, 0.78);
}

.live-room-row div,
.live-player-card {
  min-width: 0;
}

.live-room-row strong,
.live-player-card strong {
  display: block;
  color: var(--bg);
}

.live-room-row span,
.live-room-row small,
.live-player-card span,
.live-player-card small {
  display: block;
  color: var(--ink-soft);
  font-weight: 700;
}

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

.live-player-card {
  display: grid;
  align-items: start;
  justify-content: stretch;
}

.live-player-card.self {
  border-color: rgba(200, 156, 68, 0.44);
  box-shadow: 0 0 0 4px rgba(200, 156, 68, 0.12);
}

.live-chat-panel {
  display: grid;
  gap: 12px;
  padding: 16px;
  border-radius: 22px;
  border: 1px solid rgba(45, 62, 80, 0.12);
  background: rgba(255, 252, 242, 0.84);
}

.live-chat-log {
  display: grid;
  gap: 8px;
  max-height: 220px;
  overflow: auto;
}

.live-chat-message {
  display: grid;
  gap: 3px;
  padding: 10px 12px;
  border-radius: 16px;
  background: rgba(247, 234, 204, 0.8);
  color: var(--ink);
}

.live-chat-message.self {
  background: rgba(200, 156, 68, 0.18);
}

.live-chat-message strong {
  color: var(--bg);
  font-size: 0.82rem;
}

.live-chat-form {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
}

.live-chat-form input {
  width: 100%;
  border: 1px solid rgba(107, 78, 22, 0.18);
  border-radius: 999px;
  padding: 12px 14px;
  background: rgba(255, 252, 242, 0.95);
  color: var(--ink);
  font: inherit;
}

.online-hub-shell {
  display: grid;
  grid-template-columns: minmax(210px, 0.42fr) minmax(0, 1.58fr);
  gap: 16px;
  align-items: start;
  padding: clamp(14px, 2vw, 22px);
}

.online-hub-shell-home {
  grid-template-columns: minmax(210px, 0.34fr) minmax(0, 1.66fr);
}

.online-connected-count {
  margin: 0 0 8px;
  color: var(--bg);
  font-size: 0.82rem;
  font-weight: 900;
}

.online-hub-card {
  display: grid;
  gap: 14px;
  padding: clamp(16px, 2vw, 22px);
  border-radius: 26px;
  border: 1px solid rgba(107, 78, 22, 0.14);
  background:
    radial-gradient(circle at top right, rgba(255, 250, 242, 0.72), transparent 40%),
    rgba(247, 234, 204, 0.78);
  box-shadow: 0 18px 36px rgba(75, 47, 33, 0.08);
}

.online-feature-card {
  min-height: 420px;
  align-content: start;
}

.online-hub-main-wide {
  min-width: 0;
}

.online-feature-card h2,
.online-hub-card h3 {
  margin: 0;
  color: var(--bg);
}

.online-feature-card h2 {
  font-size: clamp(2rem, 4vw, 3.3rem);
  line-height: 0.95;
}

.online-feature-card p,
.online-game-group span,
.online-muted,
.online-roster-row span,
.online-current-room small {
  margin: 0;
  color: var(--ink-soft);
  font-weight: 750;
}

.online-game-group,
.online-room-mini,
.online-roster-row,
.online-current-room {
  display: grid;
  gap: 6px;
  padding: 14px;
  border-radius: 18px;
  border: 1px solid rgba(107, 78, 22, 0.12);
  background: rgba(255, 252, 242, 0.72);
}

.online-game-group.disabled {
  opacity: 0.58;
}

.online-game-group strong,
.online-room-mini strong,
.online-roster-row strong,
.online-current-room strong {
  color: var(--bg);
}

.online-room-stack,
.online-roster-stack {
  display: grid;
  gap: 10px;
}

.online-room-mini,
.online-current-room {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
}

.online-current-room {
  grid-template-columns: 1fr;
}

.online-action-grid {
  display: grid;
  gap: 14px;
}

.online-join-form {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
}

.online-join-form.compact {
  align-items: center;
}

.online-join-form input {
  width: 100%;
  border: 1px solid rgba(107, 78, 22, 0.18);
  border-radius: 999px;
  padding: 12px 14px;
  background: rgba(255, 252, 242, 0.95);
  color: var(--ink);
  font: inherit;
  text-transform: uppercase;
}

.online-create-game-panel {
  gap: 18px;
}

.online-create-heading {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 4px;
  flex-wrap: wrap;
}

.online-create-heading > p,
.online-create-heading > h2 {
  width: 100%;
}

.online-home-game-board {
  display: grid;
  gap: clamp(16px, 2vw, 24px);
}

.online-home-heading {
  display: grid;
  gap: 4px;
}

.online-home-heading h2 {
  margin: 0;
  color: var(--bg);
  font-size: clamp(2.4rem, 5vw, 4.5rem);
  line-height: 0.92;
}

.online-home-game-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(128px, 1fr));
  gap: clamp(12px, 1.5vw, 18px);
}

.online-mode-card {
  min-height: 210px;
}

.online-create-game-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
}

.online-create-game-card {
  display: grid;
  align-content: start;
  justify-items: center;
  gap: 8px;
  min-height: 132px;
  padding: 12px 8px;
  border: 1px solid rgba(107, 78, 22, 0.14);
  border-radius: 18px;
  background: rgba(255, 252, 242, 0.72);
  color: var(--ink);
  font: inherit;
  text-align: center;
}

.online-create-game-card.active {
  border-color: rgba(200, 156, 68, 0.44);
  background:
    radial-gradient(circle at top, rgba(200, 156, 68, 0.2), transparent 44%),
    rgba(255, 252, 242, 0.92);
}

.online-create-game-card.disabled {
  cursor: not-allowed;
  opacity: 0.55;
  filter: grayscale(0.2);
}

.online-create-game-card strong {
  color: var(--bg);
  font-size: 0.86rem;
  line-height: 1.05;
}

.online-create-game-card span {
  color: var(--ink-soft);
  font-size: 0.72rem;
  font-weight: 850;
}

.online-create-game-icon {
  width: 58px;
  aspect-ratio: 1;
  display: grid;
  place-items: center;
}

.online-arcade-setup,
.live-run-shell,
.live-kahoot-shell,
.live-race-shell,
.live-alpaquiz-shell {
  display: grid;
  gap: 16px;
}

.online-game-list {
  display: grid;
  gap: 12px;
}

.live-color-picker {
  display: grid;
  gap: 10px;
}

.live-color-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 8px;
}

.live-color-chip {
  display: grid;
  justify-items: center;
  gap: 4px;
  padding: 8px;
  border: 1px solid rgba(107, 78, 22, 0.16);
  border-radius: 16px;
  background: rgba(255, 252, 242, 0.72);
  color: var(--ink);
  font: inherit;
  font-size: 0.72rem;
  font-weight: 850;
  cursor: pointer;
}

.live-color-chip.active {
  border-color: rgba(200, 156, 68, 0.58);
  box-shadow: inset 0 0 0 2px rgba(200, 156, 68, 0.22);
}

.live-color-chip:disabled {
  cursor: not-allowed;
  opacity: 0.42;
  filter: grayscale(0.6);
}

.live-alpaca-token {
  display: inline-grid;
  place-items: center;
  border-radius: 999px;
  background: color-mix(in srgb, var(--alpaca-color) 48%, #fffaf0);
  border: 1px solid rgba(107, 78, 22, 0.16);
  box-shadow: 0 10px 20px rgba(54, 35, 22, 0.12);
}

.live-alpaca-token.small {
  width: 44px;
  height: 44px;
}

.live-alpaca-token.map {
  width: 56px;
  height: 56px;
}

.live-alpaca-token img {
  width: 82%;
  height: 82%;
  object-fit: contain;
  filter: var(--alpaca-filter);
}

.live-run-map {
  position: relative;
  min-height: 150px;
  border-radius: 24px;
  border: 1px solid rgba(107, 78, 22, 0.14);
  background:
    linear-gradient(90deg, rgba(255, 252, 242, 0.72), rgba(236, 214, 165, 0.72)),
    radial-gradient(circle at 12% 40%, rgba(200, 156, 68, 0.2), transparent 24%);
  overflow: hidden;
}

.live-run-map-stage {
  min-height: min(56vw, 520px);
  border: 1px solid rgba(107, 78, 22, 0.14);
  box-shadow: 0 18px 36px rgba(75, 47, 33, 0.1);
}

.live-run-player-marker {
  display: grid;
  justify-items: center;
  gap: 2px;
  transform: translate(calc(-50% + var(--live-run-offset, 0px)), -82%);
}

.live-run-player-marker span {
  max-width: 110px;
  padding: 3px 7px;
  border-radius: 999px;
  background: rgba(255, 252, 242, 0.86);
  color: var(--bg);
  font-size: 0.68rem;
  font-weight: 900;
  text-align: center;
  box-shadow: 0 8px 14px rgba(54, 35, 22, 0.12);
}

.live-run-player-area {
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) minmax(180px, 0.7fr);
  gap: 14px;
  align-items: start;
}

.live-run-opponent-status {
  display: grid;
  gap: 10px;
}

.live-run-opponent-status article {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 10px;
  padding: 12px;
  border: 1px solid rgba(107, 78, 22, 0.14);
  border-radius: 20px;
  background: rgba(255, 252, 242, 0.72);
}

.live-run-opponent-status strong,
.live-run-opponent-status span {
  display: block;
}

.live-run-opponent-status strong {
  color: var(--bg);
}

.live-run-opponent-status span {
  color: var(--ink-soft);
  font-size: 0.78rem;
  font-weight: 850;
}

.live-run-track {
  position: absolute;
  left: 8%;
  right: 8%;
  top: 52%;
  height: 8px;
  border-radius: 999px;
  background: rgba(107, 78, 22, 0.18);
}

.live-run-map-alpaca {
  position: absolute;
  top: 42%;
  display: grid;
  justify-items: center;
  gap: 2px;
  transform: translate(-50%, -50%);
  transition: left 280ms ease;
  color: var(--bg);
  font-weight: 900;
  font-size: 0.76rem;
}

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

.live-question-panel,
.live-winner-card {
  display: grid;
  gap: 12px;
  padding: 16px;
  border-radius: 22px;
  border: 1px solid rgba(107, 78, 22, 0.14);
  background: rgba(255, 252, 242, 0.78);
}

.live-question-panel.opponent {
  opacity: 0.82;
}

.live-question-head,
.live-race-lives,
.live-kahoot-question {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.live-kahoot-options,
.live-answer-status-grid,
.live-round-results,
.live-leaderboard {
  display: grid;
  gap: 10px;
}

.live-kahoot-options {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.live-kahoot-option,
.live-answer-status-grid article,
.live-round-results article,
.live-leaderboard article,
.live-race-lives article {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 12px 14px;
  border-radius: 18px;
  border: 1px solid rgba(107, 78, 22, 0.14);
  background: rgba(255, 252, 242, 0.72);
  color: var(--ink);
  font: inherit;
  font-weight: 850;
}

.live-kahoot-option.active,
.live-answer-status-grid article.answered,
.live-leaderboard article.leader,
.live-race-lives article.active {
  border-color: rgba(200, 156, 68, 0.48);
  background: rgba(240, 211, 143, 0.54);
}

.live-kahoot-option.correct,
.live-round-results article.correct {
  border-color: rgba(59, 142, 91, 0.38);
  background: rgba(208, 238, 218, 0.76);
}

.live-round-results article.wrong {
  border-color: rgba(146, 45, 36, 0.3);
  background: rgba(250, 221, 213, 0.72);
}

.live-timer-pill {
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(107, 78, 22, 0.1);
  color: var(--bg);
}

.live-buzz-button {
  justify-self: center;
  min-width: min(260px, 100%);
}

@media (max-width: 780px) {
  .live-color-grid,
  .online-create-game-grid,
  .online-home-game-grid,
  .live-kahoot-options,
  .live-split-board,
  .live-run-player-area {
    grid-template-columns: 1fr;
  }
}

.online-create-game-image {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.online-alpacapardy-setup .panel-title {
  margin-bottom: 12px;
}

.online-alpacapardy-setup .panel-title h2 {
  font-size: clamp(1.8rem, 3vw, 2.6rem);
}

.online-alpacapardy-setup .mode-shell {
  margin: 0;
}

.online-alpacapardy-setup .alpacapardy-setup-card {
  box-shadow: none;
}

.online-waiting-popup {
  display: grid;
  gap: 16px;
  padding: clamp(18px, 2.5vw, 26px);
  border-radius: 24px;
  border: 1px solid rgba(200, 156, 68, 0.28);
  background:
    radial-gradient(circle at top right, rgba(200, 156, 68, 0.18), transparent 38%),
    rgba(255, 252, 242, 0.9);
  box-shadow: 0 18px 36px rgba(75, 47, 33, 0.1);
}

.online-waiting-popup h3 {
  margin: 0;
  color: var(--bg);
  font-size: clamp(1.8rem, 3vw, 2.8rem);
  line-height: 0.95;
}

.online-waiting-popup p {
  margin: 6px 0 0;
  color: var(--ink-soft);
  font-weight: 800;
}

.online-hub-footer {
  display: flex;
  justify-content: center;
  padding: 0 0 20px;
}

@media (max-width: 980px) {
  .online-hub-shell {
    grid-template-columns: 1fr;
  }

  .online-home-game-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .online-create-game-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 700px) {
  .app-entry-gate-window {
    grid-template-columns: 1fr;
  }

  .app-entry-choice-grid,
  .app-entry-auth-panel .auth-form-grid,
  .online-join-form,
  .online-room-mini,
  .online-current-room {
    grid-template-columns: 1fr;
  }
}

.relay-buzz-winner {
  width: 54px;
}

.relay-buzz-winner .asset-slot {
  width: 100%;
}

.relay-buzz-winner-image {
  width: 100%;
  max-height: 54px;
  object-fit: contain;
}

.relay-buzz-winner-card {
  position: absolute;
  inset: -12px;
  z-index: 0;
  pointer-events: none;
  width: auto;
  opacity: 0.96;
}

.relay-buzz-winner-card .asset-slot {
  width: 100%;
  height: 100%;
}

.relay-buzz-winner-image-card {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.buildcase-card {
  grid-template-columns: 220px minmax(0, 1fr);
  align-items: start;
}

.buildcase-entry-title {
  margin: 4px 0 0;
  color: var(--bg);
  font-weight: 800;
}

.buildcase-phase-copy {
  display: grid;
  gap: 8px;
  margin: 10px 0 4px;
}

.buildcase-phase-copy strong {
  color: var(--bg);
}

.buildcase-phase-copy p {
  margin: 0;
  color: var(--ink-soft);
}

.buildcase-camp-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-top: 12px;
}

.buildcase-feedback {
  display: grid;
  gap: 16px;
}

.question-popup-window.debate-lab {
  width: min(1320px, calc(100vw - 28px));
}

.debate-lab-shell {
  min-height: 0;
}

.debate-topic-card,
.debate-spinner-card,
.debate-case-card {
  display: grid;
  gap: 20px;
}

.debate-topic-card {
  grid-template-columns: minmax(190px, 0.26fr) minmax(0, 1fr);
  align-items: stretch;
}

.debate-topic-side {
  display: grid;
  align-content: start;
  justify-items: center;
  gap: 14px;
  padding: 18px;
  border-radius: 22px;
  border: 1px solid rgba(107, 78, 22, 0.14);
  background:
    radial-gradient(circle at 50% 0%, rgba(200, 156, 68, 0.2), transparent 54%),
    rgba(247, 234, 204, 0.72);
}

.debate-topic-counter {
  display: grid;
  gap: 2px;
  justify-items: center;
  color: var(--ink-soft);
  font-weight: 800;
  text-transform: uppercase;
  font-size: 0.72rem;
}

.debate-topic-counter strong {
  color: var(--bg);
  font-size: 1.35rem;
}

.debate-pdf-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 10px 14px;
  border-radius: 999px;
  color: #5f3f22;
  background: rgba(255, 248, 232, 0.78);
  border: 1px solid rgba(107, 78, 22, 0.16);
  font-weight: 900;
  text-align: center;
  text-decoration: none;
}

.debate-topic-main {
  display: grid;
  align-content: center;
  gap: 14px;
}

.debate-topic-main h2,
.debate-spinner-copy h2,
.debate-case-header h2 {
  margin: 0;
  color: var(--ink);
  font-size: clamp(2rem, 4vw, 4.1rem);
  line-height: 0.98;
  text-wrap: balance;
}

.debate-core-issue,
.debate-spinner-copy p,
.debate-case-header p {
  margin: 0;
  color: var(--ink-soft);
  font-size: clamp(1rem, 1.7vw, 1.24rem);
  line-height: 1.45;
}

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

.debate-topic-grid section,
.debate-side-panel,
.debate-clash-card > div,
.debate-speaker-jobs,
.debate-judge-prep,
.debate-connection-deck {
  border-radius: 18px;
  border: 1px solid rgba(107, 78, 22, 0.12);
  background: rgba(255, 248, 232, 0.66);
  padding: 14px;
}

.debate-topic-grid h3,
.debate-side-panel h3,
.debate-clash-card h3,
.debate-speaker-jobs h3 {
  margin: 0 0 8px;
  color: var(--bg);
  font-size: 0.95rem;
  text-transform: uppercase;
}

.debate-mini-list {
  display: grid;
  gap: 8px;
  margin: 0;
  padding-left: 18px;
  color: var(--ink-soft);
  line-height: 1.35;
}

.debate-muted {
  margin: 0;
  color: var(--ink-soft);
}

.debate-topic-actions,
.debate-spinner-actions,
.debate-case-actions {
  justify-content: end;
}

.debate-spinner-card {
  grid-template-columns: minmax(0, 0.95fr) minmax(320px, 0.8fr);
  align-items: center;
}

.debate-spinner-copy {
  display: grid;
  gap: 14px;
}

.debate-orbit-shell {
  position: relative;
  width: min(440px, 82vw);
  aspect-ratio: 1;
  justify-self: center;
  border-radius: 50%;
  background:
    radial-gradient(circle at center, rgba(255, 248, 232, 0.94) 0 29%, transparent 30%),
    conic-gradient(from 0deg, rgba(200, 156, 68, 0.22), rgba(138, 99, 56, 0.1), rgba(200, 156, 68, 0.22), rgba(138, 99, 56, 0.1), rgba(200, 156, 68, 0.22));
  border: 2px solid rgba(107, 78, 22, 0.2);
  box-shadow: inset 0 0 0 14px rgba(255, 248, 232, 0.42), 0 24px 52px rgba(65, 42, 23, 0.16);
  overflow: hidden;
}

.debate-orbit-marker {
  position: absolute;
  top: 10px;
  left: 50%;
  z-index: 5;
  display: grid;
  justify-items: center;
  gap: 5px;
  color: var(--bg);
  transform: translateX(-50%);
  font-size: 0.72rem;
  font-weight: 900;
  text-transform: uppercase;
}

.debate-orbit-marker span {
  width: 0;
  height: 0;
  border-left: 13px solid transparent;
  border-right: 13px solid transparent;
  border-top: 18px solid #5f3f22;
  filter: drop-shadow(0 4px 5px rgba(65, 42, 23, 0.18));
}

.debate-side-rotor {
  position: absolute;
  inset: 9%;
  z-index: 3;
  transform: rotate(0deg);
  transform-origin: center;
}

.debate-side-rotor.is-spinning {
  animation: debate-orbit-spin 620ms linear infinite;
}

.debate-side-rotor.is-stopping {
  transform: rotate(var(--debate-spin-target-angle));
  transition: transform 3s cubic-bezier(0.08, 0.72, 0.12, 1);
}

.debate-side-line {
  position: absolute;
  top: 6%;
  bottom: 6%;
  left: 50%;
  width: 8px;
  border-radius: 999px;
  background: linear-gradient(180deg, #7b5130, #c89c44, #7b5130);
  transform: translateX(-50%);
  box-shadow: 0 0 0 6px rgba(255, 248, 232, 0.42);
}

.debate-side-node {
  position: absolute;
  left: 50%;
  display: grid;
  grid-template-columns: auto auto;
  align-items: center;
  gap: 8px;
  min-width: 128px;
  min-height: 54px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(255, 248, 232, 0.95);
  border: 1px solid rgba(107, 78, 22, 0.2);
  box-shadow: 0 14px 30px rgba(65, 42, 23, 0.14);
  color: #5f3f22;
  font-weight: 950;
}

.debate-side-node-pro {
  top: 0;
  transform: translate(-50%, -50%);
}

.debate-side-node-con {
  bottom: 0;
  transform: translate(-50%, 50%) rotate(180deg);
}

.debate-side-icon-slot {
  width: 42px;
  height: 42px;
}

.debate-side-icon {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.debate-orbit-core {
  position: absolute;
  inset: 35%;
  z-index: 4;
  display: grid;
  place-items: center;
  align-content: center;
  border-radius: 50%;
  background:
    linear-gradient(180deg, rgba(247, 234, 204, 0.98), rgba(236, 217, 170, 0.98));
  border: 1px solid rgba(107, 78, 22, 0.18);
  color: var(--ink-soft);
  font-weight: 900;
  text-transform: uppercase;
}

.debate-orbit-core strong {
  color: var(--bg);
  font-size: clamp(1.7rem, 4vw, 3rem);
}

@keyframes debate-orbit-spin {
  to {
    transform: rotate(360deg);
  }
}

.debate-case-card {
  gap: 18px;
}

.debate-case-header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 18px;
  align-items: center;
}

.debate-side-badge {
  display: grid;
  justify-items: center;
  gap: 8px;
  min-width: 112px;
  padding: 14px;
  border-radius: 20px;
  border: 1px solid rgba(107, 78, 22, 0.14);
  background: rgba(255, 248, 232, 0.78);
  color: var(--bg);
  font-weight: 950;
}

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

.debate-case-layout main,
.debate-case-layout aside {
  display: grid;
  gap: 14px;
  min-width: 0;
}

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

.debate-clash-card > div:nth-child(3) {
  grid-column: 1 / -1;
}

.debate-clash-card p,
.debate-side-panel p,
.debate-speaker-jobs p,
.debate-judge-prep p {
  margin: 0;
  color: var(--ink-soft);
  line-height: 1.42;
}

.debate-source-links {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}

.debate-source-links a {
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(236, 217, 170, 0.72);
  color: #5f3f22;
  font-weight: 900;
  text-decoration: none;
}

.debate-argument-deck,
.debate-argument-group,
.debate-connection-deck,
.debate-judge-prep {
  border-radius: 18px;
  border: 1px solid rgba(107, 78, 22, 0.14);
  background: rgba(255, 248, 232, 0.58);
  overflow: hidden;
}

.debate-argument-deck > summary,
.debate-argument-group > summary,
.debate-connection-deck > summary,
.debate-judge-prep > summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  min-height: 50px;
  padding: 12px 14px;
  cursor: pointer;
  color: var(--bg);
  font-weight: 950;
}

.debate-argument-groups,
.debate-connection-list,
.debate-judge-prep-list {
  display: grid;
  gap: 12px;
  padding: 0 14px 14px;
}

.debate-argument-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 12px;
  padding: 0 12px 12px;
}

.debate-argument-card,
.debate-connection-list article,
.debate-judge-prep-list article,
.debate-speaker-jobs article {
  display: grid;
  gap: 10px;
  padding: 13px;
  border-radius: 14px;
  border: 1px solid rgba(107, 78, 22, 0.1);
  background: rgba(247, 234, 204, 0.7);
}

.debate-argument-card header {
  display: grid;
  gap: 4px;
  color: var(--bg);
}

.debate-argument-card header span,
.debate-connection-list article span,
.debate-speaker-jobs article span {
  color: #7b5130;
  font-size: 0.78rem;
  font-weight: 950;
  text-transform: uppercase;
}

.debate-argument-main {
  margin: 0;
  color: var(--ink);
  font-size: 1.02rem;
  font-weight: 800;
  line-height: 1.32;
}

.debate-argument-card dl {
  display: grid;
  gap: 8px;
  margin: 0;
}

.debate-argument-card dl div {
  display: grid;
  gap: 2px;
}

.debate-argument-card dt {
  color: var(--bg);
  font-size: 0.76rem;
  font-weight: 950;
  text-transform: uppercase;
}

.debate-argument-card dd {
  margin: 0;
  color: var(--ink-soft);
  line-height: 1.36;
}

.debate-connection-list strong,
.debate-judge-prep-list strong {
  color: var(--ink);
}

.debate-connection-list p,
.debate-connection-list small,
.debate-judge-prep-list small {
  margin: 0;
  color: var(--ink-soft);
  line-height: 1.36;
}

@media (prefers-reduced-motion: reduce) {
  .debate-side-rotor.is-spinning {
    animation-duration: 1.8s;
  }

  .debate-side-rotor.is-stopping {
    transition-duration: 0.2s;
  }
}

@media (max-width: 940px) {
  .debate-topic-card,
  .debate-spinner-card,
  .debate-case-header,
  .debate-case-layout {
    grid-template-columns: 1fr;
  }

  .debate-topic-side {
    grid-template-columns: auto 1fr;
    align-items: center;
    justify-items: start;
  }

  .debate-topic-side .debate-pdf-link {
    grid-column: 1 / -1;
    width: 100%;
  }

  .debate-topic-grid,
  .debate-clash-card {
    grid-template-columns: 1fr;
  }

  .debate-clash-card > div:nth-child(3) {
    grid-column: auto;
  }

  .debate-side-badge {
    justify-self: start;
    grid-template-columns: auto auto;
    align-items: center;
  }

  .debate-topic-actions,
  .debate-spinner-actions,
  .debate-case-actions {
    justify-content: stretch;
  }

  .debate-topic-actions .button,
  .debate-spinner-actions .button,
  .debate-case-actions .button {
    width: 100%;
  }
}

@media (max-width: 560px) {
  .question-popup-window.debate-lab {
    width: min(100%, calc(100vw - 20px));
  }

  .debate-topic-main h2,
  .debate-spinner-copy h2,
  .debate-case-header h2 {
    font-size: clamp(1.55rem, 9vw, 2.35rem);
  }

  .debate-topic-side {
    grid-template-columns: 1fr;
    justify-items: center;
  }

  .debate-orbit-shell {
    width: min(330px, 78vw);
  }

  .debate-side-node {
    min-width: 106px;
    min-height: 48px;
    padding: 7px 10px;
  }

  .debate-side-icon-slot {
    width: 34px;
    height: 34px;
  }

  .debate-argument-grid {
    grid-template-columns: 1fr;
    padding: 0 10px 10px;
  }
}

.debate-topic-card-clean {
  grid-template-columns: 1fr;
  grid-template-rows: minmax(0, 1fr) minmax(190px, 0.92fr);
  align-items: stretch;
  min-height: min(580px, calc(100vh - 150px));
}

.debate-topic-card-clean .debate-topic-main {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-content: center;
  align-items: start;
  gap: 18px;
  min-width: 0;
}

.debate-topic-card-clean .debate-topic-main h2 {
  max-width: 920px;
}

.debate-topic-spin-zone {
  display: grid;
  place-items: center;
  min-width: 0;
}

.debate-slot-card {
  display: grid;
  gap: 16px;
  justify-items: center;
  width: min(100%, 360px);
}

.debate-slot-window {
  --tile-height: 118px;
  position: relative;
  width: min(100%, 292px);
  height: var(--tile-height);
  overflow: hidden;
  border-radius: 8px;
  border: 3px solid rgba(95, 63, 34, 0.92);
  background: #1f463f;
  box-shadow:
    inset 0 14px 22px rgba(0, 0, 0, 0.26),
    inset 0 -14px 22px rgba(0, 0, 0, 0.22);
}

.debate-slot-window::before,
.debate-slot-window::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  z-index: 3;
  height: 30px;
  pointer-events: none;
}

.debate-slot-window::before {
  top: 0;
  background: linear-gradient(180deg, rgba(31, 70, 63, 0.94), transparent);
}

.debate-slot-window::after {
  bottom: 0;
  background: linear-gradient(0deg, rgba(31, 70, 63, 0.94), transparent);
}

.debate-slot-reel {
  --debate-slot-stop: 0;
  display: grid;
  transform: translateY(calc(var(--debate-slot-stop) * var(--tile-height) * -1));
  will-change: transform;
}

.debate-slot-reel.is-spinning {
  animation: debate-slot-reel-spin 500ms linear infinite;
}

.debate-slot-reel.is-stopping {
  animation: debate-slot-reel-stop 3.15s cubic-bezier(0.08, 0.68, 0.08, 1) both;
}

.debate-slot-reel.is-locked {
  transform: translateY(calc(var(--debate-slot-stop) * var(--tile-height) * -1));
}

.debate-slot-tile {
  display: grid;
  grid-template-columns: 82px minmax(0, 1fr);
  align-items: center;
  gap: 12px;
  height: var(--tile-height);
  padding: 10px 16px;
  border-top: 1px solid rgba(255, 248, 232, 0.3);
  border-bottom: 1px solid rgba(65, 42, 23, 0.16);
  color: #fff8e8;
  background:
    linear-gradient(90deg, rgba(255, 248, 232, 0.08), transparent 38%),
    #2d5f56;
}

.debate-slot-tile.con {
  background:
    linear-gradient(90deg, rgba(255, 248, 232, 0.1), transparent 38%),
    #8f3b30;
}

.debate-slot-logo-slot {
  width: 78px;
  height: 78px;
  border-radius: 8px;
  overflow: hidden;
  background: #f7eacc;
  box-shadow: 0 8px 18px rgba(31, 22, 18, 0.22);
}

.debate-slot-logo {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.debate-slot-tile strong {
  min-width: 0;
  font-size: 1.65rem;
  line-height: 1;
  letter-spacing: 0;
}

.debate-slot-payline {
  display: none;
}

.debate-slot-payline::before,
.debate-slot-payline::after {
  content: "";
  position: absolute;
  top: 50%;
  width: 0;
  height: 0;
  border-top: 9px solid transparent;
  border-bottom: 9px solid transparent;
  transform: translateY(-50%);
}

.debate-slot-payline::before {
  left: 0;
  border-left: 14px solid #f2bd42;
}

.debate-slot-payline::after {
  right: 0;
  border-right: 14px solid #f2bd42;
}

.debate-slot-controls {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  width: 100%;
}

.debate-slot-controls .button {
  min-width: 128px;
}

@keyframes debate-slot-reel-spin {
  from {
    transform: translateY(0);
  }

  to {
    transform: translateY(calc(var(--tile-height) * -2));
  }
}

@keyframes debate-slot-reel-stop {
  0% {
    transform: translateY(0);
  }

  18% {
    transform: translateY(calc(var(--tile-height) * -2.2));
  }

  48% {
    transform: translateY(calc(var(--tile-height) * -6.7));
  }

  100% {
    transform: translateY(calc(var(--debate-slot-stop) * var(--tile-height) * -1));
  }
}

.whatspwaap-shell {
  display: grid;
  gap: 16px;
}

.whatspwaap-page-title {
  display: block;
}

.whatspwaap-page-title h2 {
  margin: 0;
  color: var(--ink);
  font-size: clamp(1.8rem, 3.2vw, 3.3rem);
  line-height: 1.02;
  text-wrap: balance;
}

.whatspwaap-motion-line {
  display: flex;
  align-items: center;
  gap: 14px;
  min-width: 0;
}

.whatspwaap-motion-line h2 {
  flex: 1 1 auto;
}

.debate-side-inline {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  flex: 0 0 auto;
  color: var(--bg);
  font-weight: 950;
}

.debate-side-inline-slot {
  width: 58px;
  height: 58px;
}

.debate-side-inline-icon {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

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

.whatspwaap-suggestions,
.whatspwaap-result,
.whatspwaap-chat {
  border-radius: 8px;
  border: 1px solid rgba(65, 42, 23, 0.12);
  background: rgba(255, 248, 232, 0.72);
  box-shadow: 0 14px 34px rgba(65, 42, 23, 0.1);
}

.whatspwaap-suggestions,
.whatspwaap-result {
  display: grid;
  gap: 14px;
  padding: 16px;
}

.whatspwaap-suggestions header,
.whatspwaap-result h3,
.whatspwaap-result p {
  margin: 0;
}

.whatspwaap-suggestions h3,
.whatspwaap-result h3 {
  margin: 0;
  color: var(--ink);
  font-size: 1.45rem;
}

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

.debate-suggestion-card {
  display: grid;
  gap: 8px;
  min-height: 144px;
  padding: 14px;
  border: 1px solid rgba(65, 42, 23, 0.14);
  border-radius: 8px;
  background: rgba(255, 252, 241, 0.9);
  color: var(--ink);
  text-align: left;
  box-shadow: 0 8px 20px rgba(65, 42, 23, 0.07);
  cursor: pointer;
}

.debate-suggestion-card span {
  color: #226e73;
  font-size: 0.78rem;
  font-weight: 950;
  text-transform: uppercase;
}

.debate-suggestion-card strong {
  font-size: 1rem;
  line-height: 1.22;
}

.debate-suggestion-card p {
  margin: 0;
  color: var(--ink-soft);
  line-height: 1.35;
}

.debate-suggestion-card.selected {
  border-color: #226e73;
  background: #e9f4ef;
  box-shadow: 0 0 0 3px rgba(34, 110, 115, 0.14);
}

.debate-suggestion-card:disabled {
  cursor: default;
  opacity: 0.78;
}

.whatspwaap-actions {
  justify-content: end;
}

.whatspwaap-chat {
  position: sticky;
  top: 12px;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  height: min(72vh, 760px);
  min-height: 520px;
  overflow: hidden;
  background:
    linear-gradient(180deg, rgba(250, 247, 238, 0.92), rgba(238, 232, 218, 0.92)),
    repeating-linear-gradient(135deg, rgba(34, 110, 115, 0.08) 0 8px, transparent 8px 18px);
}

.whatspwaap-chat > header {
  display: grid;
  gap: 3px;
  padding: 13px 15px;
  background: #1f6b5f;
  color: #fff8e8;
}

.whatspwaap-chat > header strong {
  font-size: 1.05rem;
}

.whatspwaap-chat > header p {
  margin: 0;
  color: rgba(255, 248, 232, 0.84);
  font-size: 0.82rem;
  line-height: 1.24;
}

.whatspwaap-messages {
  display: grid;
  align-content: start;
  gap: 10px;
  min-height: 0;
  padding: 14px;
  overflow: auto;
}

.whatspwaap-round-label {
  justify-self: center;
  padding: 5px 10px;
  border-radius: 999px;
  background: rgba(255, 248, 232, 0.9);
  color: rgba(65, 42, 23, 0.7);
  font-size: 0.72rem;
  font-weight: 900;
  text-transform: uppercase;
}

.whatspwaap-bubble {
  display: grid;
  gap: 5px;
  max-width: 88%;
  padding: 10px 12px;
  border-radius: 8px;
  color: var(--ink);
  box-shadow: 0 6px 14px rgba(40, 34, 28, 0.09);
  animation: whatspwaap-bubble-in 180ms ease both;
  animation-delay: var(--bubble-delay);
}

.whatspwaap-bubble.user {
  justify-self: end;
  background: #d9f4c9;
  border-bottom-right-radius: 2px;
}

.whatspwaap-bubble.npg {
  justify-self: start;
  background: #fffdf6;
  border-bottom-left-radius: 2px;
}

.whatspwaap-bubble span {
  color: rgba(65, 42, 23, 0.66);
  font-size: 0.72rem;
  font-weight: 900;
}

.whatspwaap-bubble strong {
  font-size: 0.95rem;
  line-height: 1.2;
}

.whatspwaap-bubble p {
  margin: 0;
  color: var(--ink-soft);
  line-height: 1.32;
}

.whatspwaap-bubble.typing {
  min-width: 72px;
  justify-items: center;
}

.whatspwaap-bubble.typing strong {
  font-size: 1.45rem;
}

.whatspwaap-status {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 42px;
  padding: 8px 14px 12px;
  color: rgba(65, 42, 23, 0.72);
  font-size: 0.82rem;
  font-weight: 900;
}

.whatspwaap-status.empty {
  min-height: 12px;
  padding-block: 0 10px;
}

.whatspwaap-status-logo-slot {
  width: 34px;
  height: 34px;
  flex: 0 0 auto;
}

.whatspwaap-status-logo {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

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

.whatspwaap-feedback-grid section {
  display: grid;
  gap: 8px;
  padding: 12px;
  border-radius: 8px;
  background: rgba(255, 252, 241, 0.78);
  border: 1px solid rgba(65, 42, 23, 0.1);
}

.whatspwaap-feedback-grid h4,
.whatspwaap-feedback-grid p {
  margin: 0;
}

.whatspwaap-feedback-grid h4 {
  color: var(--bg);
}

.whatspwaap-feedback-grid p {
  color: var(--ink-soft);
  line-height: 1.34;
}

@keyframes whatspwaap-bubble-in {
  from {
    opacity: 0;
    transform: translateY(6px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (prefers-reduced-motion: reduce) {
  .debate-slot-reel.is-spinning {
    animation-duration: 1.8s;
  }

  .debate-slot-reel.is-stopping {
    animation-duration: 0.2s;
  }

  .whatspwaap-bubble {
    animation: none;
  }
}

@media (max-width: 980px) {
  .debate-topic-card-clean,
  .whatspwaap-layout,
  .whatspwaap-feedback-grid {
    grid-template-columns: 1fr;
  }

  .whatspwaap-chat {
    position: static;
    height: auto;
    min-height: 480px;
  }

  .whatspwaap-actions,
  .debate-case-actions {
    justify-content: stretch;
  }

  .whatspwaap-actions .button,
  .debate-case-actions .button {
    width: 100%;
  }
}

@media (max-width: 640px) {
  .debate-topic-card-clean {
    grid-template-rows: auto auto;
    min-height: auto;
  }

  .debate-topic-card-clean .debate-topic-main,
  .whatspwaap-motion-line {
    grid-template-columns: 1fr;
    flex-direction: column;
    align-items: flex-start;
  }

  .debate-topic-card-clean .debate-topic-main .button {
    width: 100%;
  }

  .debate-suggestion-grid {
    grid-template-columns: 1fr;
  }

  .debate-slot-card {
    width: 100%;
  }

  .debate-slot-window {
    --tile-height: 104px;
  }

  .debate-slot-tile {
    grid-template-columns: 66px minmax(0, 1fr);
    gap: 10px;
    padding: 8px 12px;
  }

  .debate-slot-logo-slot {
    width: 64px;
    height: 64px;
  }

  .debate-slot-tile strong {
    font-size: 1.35rem;
  }

  .whatspwaap-bubble {
    max-width: 94%;
  }
}

.relay-buzz-winner-status {
  width: 96px;
  flex: 0 0 96px;
}

.relay-buzz-winner-image-status {
  width: 100%;
  max-height: 54px;
  object-fit: contain;
}

.race-shell {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 280px;
  gap: 14px;
}

.race-launch-panel {
  position: relative;
  display: grid;
  gap: 14px;
  padding: 22px;
}

.race-launch-kicker {
  margin: 0;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 0.78rem;
  font-weight: 800;
  color: var(--gold);
}

.race-launch-panel h3 {
  margin: 0;
  color: var(--bg);
  font-size: clamp(1.2rem, 2vw, 1.55rem);
}

.race-launch-panel p:not(.race-launch-kicker) {
  margin: 0;
  color: var(--ink-soft);
  max-width: 66ch;
}

.race-launch-pills {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
}

.race-card-selector {
  display: grid;
  gap: 10px;
}

.race-card-select-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(118px, 1fr));
  gap: 10px;
}

.race-card-select-button {
  min-height: 118px;
  display: grid;
  place-items: center;
  gap: 6px;
  padding: 10px;
  border-radius: 18px;
  border: 1px solid rgba(107, 78, 22, 0.14);
  background: rgba(247, 234, 204, 0.58);
  color: rgba(75, 47, 33, 0.68);
  cursor: pointer;
  box-shadow: 0 10px 18px rgba(75, 47, 33, 0.06);
  transition: transform 160ms ease, background 160ms ease, border-color 160ms ease;
}

.race-card-select-button.active {
  background: rgba(247, 234, 204, 0.95);
  border-color: rgba(138, 99, 56, 0.3);
  color: var(--bg);
  box-shadow: 0 16px 28px rgba(75, 47, 33, 0.12);
}

.race-card-select-button:hover {
  transform: translateY(-2px);
}

.race-card-select-button .mascot-slot {
  width: 54px;
  height: 54px;
}

.race-card-select-button span {
  font-size: 0.8rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.race-launch-pills span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 30px;
  padding: 6px 9px;
  border-radius: 999px;
  background: rgba(200, 156, 68, 0.14);
  color: var(--bg);
  font-weight: 800;
  font-size: 0.72rem;
  line-height: 1.08;
}

.race-target-grid {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.race-target-button {
  min-width: 0;
  padding: 9px 7px;
}

.race-target-button .mascot-slot {
  width: 48px;
  height: 48px;
}

.race-target-button span {
  font-size: 0.76rem;
  line-height: 1.04;
}

.race-timer-card,
.race-lives-card {
  position: relative;
  overflow: hidden;
}

.race-timer-card {
  display: grid;
  gap: 12px;
}

.race-timer-card.warning {
  border-color: rgba(185, 137, 83, 0.28);
}

.race-timer-card.danger {
  border-color: rgba(138, 99, 56, 0.28);
  box-shadow: 0 0 0 4px rgba(138, 99, 56, 0.08);
}

.race-timer-card > *,
.race-lives-card > * {
  position: relative;
  z-index: 1;
}

.race-card-art {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}

.race-card-art {
  opacity: 0.16;
}

.race-card-art .asset-slot {
  width: 100%;
  height: 100%;
}

.race-card-art-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.race-timer-top {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  margin-bottom: 10px;
  color: var(--bg);
  font-weight: 800;
}

.race-timer-top strong {
  color: #5a3726;
  font-size: 0.92rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.race-timer-top span {
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.78rem;
  color: var(--ink-soft);
}

.race-timer-widget {
  position: relative;
  width: min(100%, 212px);
  aspect-ratio: 1;
  min-height: 0;
  margin: 0 auto;
  display: grid;
  place-items: center;
  transform-origin: center;
  transition: transform 180ms ease, filter 180ms ease;
  filter: drop-shadow(0 10px 18px rgba(75, 47, 33, 0.08));
}

.race-timer-widget-svg {
  width: 100%;
  height: 100%;
  display: block;
}

.race-timer-widget.normal .race-timer-widget-svg {
  filter: none;
}

.race-timer-widget.warning {
  animation: raceTimerBreathe 2.35s ease-in-out infinite;
}

.race-timer-widget.warning .race-timer-widget-svg {
  filter:
    drop-shadow(0 10px 16px rgba(216, 177, 63, 0.12))
    drop-shadow(0 4px 10px rgba(109, 31, 38, 0.06));
}

.race-timer-widget.danger {
  animation: raceTimerCriticalPulse 0.82s cubic-bezier(0.24, 0, 0.18, 1) infinite;
}

.race-timer-widget.danger .race-timer-widget-svg {
  filter:
    drop-shadow(0 12px 20px rgba(87, 23, 29, 0.18))
    drop-shadow(0 6px 12px rgba(75, 47, 33, 0.14))
    contrast(1.04)
    saturate(1.02);
}

@keyframes raceTimerBreathe {
  0%,
  100% {
    transform: scale(1);
  }

  50% {
    transform: scale(1.018);
  }
}

@keyframes raceTimerCriticalPulse {
  0%,
  100% {
    transform: scale(1) translateY(0);
  }

  24% {
    transform: scale(1.032) translateY(-1px);
  }

  56% {
    transform: scale(0.996) translateY(0);
  }
}

.race-timer-bar {
  height: 18px;
  border-radius: 999px;
  background: rgba(138, 99, 56, 0.12);
  overflow: hidden;
}

.race-timer-bar span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--gold), #e2b95e);
}

.race-timer-bar.warning span,
.meta-pill.timer.warning {
  background: rgba(185, 137, 83, 0.28);
  color: var(--ink);
}

.race-timer-bar.danger span {
  background: linear-gradient(90deg, #b98953, #8a6338);
}

.race-lives-card span {
  display: block;
  margin-bottom: 10px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.78rem;
  color: var(--ink-soft);
}

.race-lives-row {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.race-life {
  position: relative;
  width: 28px;
  height: 28px;
  display: grid;
  place-items: center;
  overflow: hidden;
  border-radius: 46% 46% 44% 44%;
  border: 2px solid rgba(107, 78, 22, 0.28);
  background: rgba(247, 234, 204, 0.4);
}

.race-life::before,
.race-life::after {
  content: "";
  position: absolute;
  top: -5px;
  width: 6px;
  height: 10px;
  border-radius: 999px;
  border: 2px solid rgba(107, 78, 22, 0.28);
  background: rgba(247, 234, 204, 0.4);
}

.race-life::before {
  left: 1px;
  transform: rotate(-18deg);
}

.race-life::after {
  right: 1px;
  transform: rotate(18deg);
}

.race-life.full,
.race-life.full::before,
.race-life.full::after {
  background: #fff5dd;
}

.race-life.empty,
.race-life.empty::before,
.race-life.empty::after {
  opacity: 0.35;
}

.race-life.with-asset {
  overflow: visible;
  border: 0;
  background: transparent;
}

.race-life.with-asset::before,
.race-life.with-asset::after {
  display: none;
}

.race-life-asset {
  position: absolute;
  inset: -4px;
  z-index: 1;
  pointer-events: none;
}

.race-life-asset.empty {
  opacity: 0.72;
}

.race-life-asset.warning {
  transform: scale(1.06);
}

.race-life-asset .asset-slot {
  width: 100%;
  height: 100%;
}

.race-life-asset-image {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.race-fail-visual {
  width: min(120px, 100%);
}

.race-fail-visual .asset-slot {
  width: 100%;
}

.race-fail-visual-image {
  width: 100%;
  height: auto;
  object-fit: contain;
}

.jump-shell {
  display: grid;
  gap: 16px;
}

.jump-stage {
  position: relative;
  min-height: 560px;
  overflow: hidden;
  border-radius: 26px;
  border: 1px solid rgba(107, 78, 22, 0.16);
  background: #d9ad6a;
  box-shadow: 0 24px 58px rgba(75, 47, 33, 0.18);
}

.jump-background,
.jump-background .asset-slot,
.jump-background-placeholder {
  position: absolute;
  inset: 0;
}

.jump-background-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  image-rendering: auto;
}

.jump-background-placeholder {
  background:
    linear-gradient(180deg, rgba(95, 176, 214, 0.88) 0%, rgba(242, 195, 107, 0.94) 58%, rgba(190, 128, 63, 0.96) 100%);
}

.jump-stage::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(180deg, rgba(255, 248, 221, 0.08), transparent 42%),
    radial-gradient(circle at 20% 88%, rgba(255, 233, 167, 0.22), transparent 24%),
    radial-gradient(circle at 85% 82%, rgba(117, 72, 38, 0.16), transparent 24%);
}

.jump-hud {
  position: relative;
  z-index: 4;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  padding: 16px;
}

.jump-hud-card {
  min-height: 72px;
  padding: 12px 14px;
  border-radius: 18px;
  background: rgba(247, 234, 204, 0.78);
  border: 1px solid rgba(107, 78, 22, 0.14);
  box-shadow: 0 14px 30px rgba(75, 47, 33, 0.08);
  backdrop-filter: blur(4px);
}

.jump-hud-card span {
  display: block;
  margin-bottom: 8px;
  color: var(--ink-soft);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.jump-hud-card strong {
  color: var(--bg);
  font-size: 1.28rem;
  line-height: 1;
}

.jump-lives {
  gap: 8px;
}

.jump-world {
  position: absolute;
  z-index: 3;
  inset: 0;
}

.jump-ground {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 23%;
  background:
    linear-gradient(180deg, rgba(220, 162, 81, 0), rgba(157, 94, 44, 0.24) 24%),
    repeating-linear-gradient(
      -8deg,
      rgba(255, 229, 156, 0.34) 0,
      rgba(255, 229, 156, 0.34) 12px,
      rgba(145, 88, 41, 0.1) 13px,
      rgba(145, 88, 41, 0.1) 22px
    );
  border-top: 5px solid rgba(91, 58, 34, 0.24);
}

.jump-runner {
  position: absolute;
  left: 11%;
  bottom: 15%;
  z-index: 5;
  width: clamp(118px, 15vw, 190px);
  transform-origin: bottom center;
  transition: filter 120ms ease;
  filter: drop-shadow(0 14px 18px rgba(58, 38, 22, 0.28));
}

.jump-runner.state-ducking {
  width: clamp(132px, 17vw, 214px);
  filter: drop-shadow(0 9px 14px rgba(58, 38, 22, 0.24));
}

.jump-runner.state-hurting {
  width: clamp(136px, 18vw, 228px);
  animation: jumpRunnerDamageFlash 2s ease both;
}

.jump-runner-viewport {
  width: 100%;
  aspect-ratio: var(--jump-runner-aspect, 1.25 / 1);
  position: relative;
}

.jump-runner-image {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.jump-runner.state-running .jump-runner-image,
.jump-runner.state-jumping .jump-runner-image {
  animation: jumpRunnerFloat 560ms ease-in-out infinite;
  transform-origin: 50% 85%;
}

.jump-runner.state-ducking .jump-runner-image,
.jump-runner.state-hurting .jump-runner-image {
  animation: none;
}

.jump-obstacle {
  position: absolute;
  z-index: 4;
  width: clamp(88px, 9vw, 132px);
  height: clamp(72px, 7.5vw, 108px);
  transform: translateX(-50%);
  filter: drop-shadow(0 12px 14px rgba(45, 31, 25, 0.24));
}

.jump-obstacle.ground {
  bottom: 15%;
}

.jump-obstacle.flying {
  bottom: 42%;
  width: clamp(104px, 10vw, 146px);
  height: clamp(70px, 7vw, 106px);
}

.jump-obstacle.checkpoint {
  bottom: 15%;
  width: clamp(82px, 8vw, 116px);
  height: clamp(108px, 11vw, 154px);
}

.jump-monster,
.jump-question-genie,
.jump-monster .asset-slot {
  position: absolute;
  inset: 0;
}

.jump-monster-image,
.jump-question-genie-image {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.jump-dark-alpaca-body {
  position: absolute;
  inset: 22% 5% 10%;
  display: block;
  border-radius: 44% 48% 38% 42%;
  background: linear-gradient(145deg, #1c1718, #4b2827 72%, #171111);
  border: 2px solid rgba(255, 238, 194, 0.24);
}

.jump-dark-alpaca-body::before,
.jump-dark-alpaca-body::after {
  content: "";
  position: absolute;
  background: #171111;
}

.jump-dark-alpaca-body::before {
  right: -12%;
  top: -36%;
  width: 42%;
  height: 56%;
  border-radius: 46% 46% 38% 38%;
  box-shadow:
    -8px -14px 0 -3px #171111,
    6px -12px 0 -3px #171111;
}

.jump-dark-alpaca-body::after {
  left: 16%;
  right: 18%;
  bottom: -18%;
  height: 28%;
  border-radius: 999px;
  box-shadow:
    -14px 10px 0 -2px #171111,
    18px 10px 0 -2px #171111;
}

.jump-obstacle.flying .jump-dark-alpaca-body,
.jump-obstacle.flying .jump-monster {
  animation: jumpFlyingBob 900ms ease-in-out infinite;
}

.jump-question-genie .asset-slot {
  position: absolute;
  inset: 0;
}

.jump-obstacle.checkpoint .jump-dark-alpaca-body {
  inset: 0;
  display: grid;
  place-items: center;
  border-radius: 16px;
  background:
    linear-gradient(145deg, rgba(255, 232, 149, 0.98), rgba(194, 126, 52, 0.98)),
    #e6b450;
  border: 4px solid rgba(86, 52, 25, 0.72);
  box-shadow:
    inset 0 0 0 4px rgba(255, 246, 198, 0.38),
    0 12px 0 rgba(86, 52, 25, 0.22);
}

.jump-obstacle.checkpoint .jump-dark-alpaca-body::before {
  content: "?";
  position: static;
  width: auto;
  height: auto;
  background: transparent;
  box-shadow: none;
  color: #563419;
  font-size: clamp(2rem, 4vw, 3.8rem);
  font-weight: 1000;
  line-height: 1;
}

.jump-obstacle.checkpoint .jump-dark-alpaca-body::after {
  display: none;
}

.jump-controls {
  position: absolute;
  z-index: 6;
  left: 16px;
  right: 16px;
  bottom: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;
}

.jump-controls .button {
  min-width: 112px;
  box-shadow: 0 12px 28px rgba(75, 47, 33, 0.12);
}

.question-popup-overlay.jump {
  background: rgba(49, 32, 24, 0.58);
}

.question-popup-window.jump {
  width: min(920px, calc(100vw - 28px));
}

.jump-question-card {
  display: grid;
  gap: 16px;
}

.jump-question-genie-card {
  width: clamp(96px, 16vw, 148px);
}

.jump-question-genie-card-image {
  filter: drop-shadow(0 14px 18px rgba(75, 47, 33, 0.18));
}

.jump-question-card .options-grid,
.jump-question-card .feedback-card {
  grid-column: 1 / -1;
}

.jump-question-card .options-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

@keyframes jumpFlyingBob {
  0%,
  100% {
    transform: translateY(0);
  }

  50% {
    transform: translateY(-8px);
  }
}

@keyframes jumpRunnerFloat {
  0% {
    transform: translateY(0) rotate(-0.6deg);
  }

  50% {
    transform: translateY(-5px) rotate(0.8deg);
  }

  100% {
    transform: translateY(0) rotate(-0.6deg);
  }
}

@keyframes jumpRunnerDamageFlash {
  0%,
  100% {
    filter: drop-shadow(0 14px 18px rgba(58, 38, 22, 0.28));
  }

  12%,
  34%,
  56%,
  78% {
    filter:
      drop-shadow(0 14px 18px rgba(58, 38, 22, 0.28))
      sepia(1)
      saturate(2.8)
      hue-rotate(-35deg)
      opacity(0.72);
  }

  23%,
  45%,
  67%,
  89% {
    filter:
      drop-shadow(0 14px 18px rgba(58, 38, 22, 0.28))
      sepia(0.4)
      saturate(1.7)
      hue-rotate(-15deg)
      opacity(1);
  }
}

.run-shell {
  display: grid;
  gap: 18px;
}

.run-map-shell {
  position: relative;
  padding: 18px;
  border-radius: 24px;
  background:
    linear-gradient(160deg, rgba(247, 234, 204, 0.96), rgba(235, 210, 153, 0.95));
  border: 1px solid rgba(107, 78, 22, 0.12);
}

.run-map-stage {
  position: relative;
  aspect-ratio: 3 / 2;
  min-height: 420px;
  border-radius: 22px;
  overflow: hidden;
  background:
    radial-gradient(circle at 15% 20%, rgba(200, 156, 68, 0.18), transparent 18%),
    radial-gradient(circle at 78% 30%, rgba(185, 137, 83, 0.16), transparent 22%),
    linear-gradient(180deg, rgba(247, 234, 204, 0.98), rgba(236, 216, 172, 0.96));
}

.run-map-background {
  position: absolute;
  inset: 0;
}

.run-map-background .asset-slot {
  width: 100%;
  height: 100%;
}

.run-map-background-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.run-map-placeholder {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 18% 28%, rgba(138, 99, 56, 0.12), transparent 14%),
    radial-gradient(circle at 48% 20%, rgba(138, 99, 56, 0.08), transparent 12%),
    radial-gradient(circle at 82% 36%, rgba(138, 99, 56, 0.12), transparent 12%),
    radial-gradient(circle at 30% 64%, rgba(138, 99, 56, 0.1), transparent 16%),
    repeating-linear-gradient(
      90deg,
      transparent 0,
      transparent 8%,
      rgba(107, 78, 22, 0.03) 8%,
      rgba(107, 78, 22, 0.03) 8.8%
    );
}

.run-map-stop {
  position: absolute;
  transform: translate(-50%, -50%);
  display: grid;
  justify-items: center;
  z-index: 2;
}

.run-map-stop-marker {
  width: 54px;
  height: 54px;
  display: grid;
  place-items: center;
  transition:
    transform 180ms ease,
    filter 180ms ease,
    opacity 180ms ease;
}

.run-map-stop.regional .run-map-stop-marker {
  width: 54px;
  height: 54px;
}

.run-map-stop.global .run-map-stop-marker {
  width: 58px;
  height: 58px;
}

.run-map-stop.goal .run-map-stop-marker {
  width: 76px;
  height: 76px;
}

.run-map-stop.done .run-map-stop-marker {
  opacity: 0.9;
}

.run-map-stop.current .run-map-stop-marker {
  transform: scale(1.05);
  filter: drop-shadow(0 0 10px rgba(252, 209, 39, 0.34));
}

.run-map-stop-marker svg {
  width: 100%;
  height: 100%;
  display: block;
}

.run-stop-svg {
  overflow: visible;
}

.run-map-stop-token {
  font-size: 0.82rem;
  font-weight: 900;
}

.run-map-stop-icon-slot,
.run-map-stop-icon-slot .asset-image {
  width: 100%;
  height: 100%;
}

.run-travel-marker {
  position: absolute;
  transform: translate(-50%, -82%);
  z-index: 4;
  transition: left 280ms ease, top 280ms ease;
}

.run-travel-marker-slot {
  width: 82px;
}

.run-travel-marker-slot .asset-slot {
  width: 100%;
}

.run-travel-marker-image {
  width: 100%;
  height: auto;
  object-fit: contain;
  filter: drop-shadow(0 8px 18px rgba(65, 42, 23, 0.24));
}

.run-status-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-top: 10px;
}

.run-map-stage > .run-status-row {
  position: absolute;
  left: clamp(12px, 2vw, 24px);
  right: clamp(12px, 2vw, 24px);
  bottom: clamp(12px, 2vw, 22px);
  z-index: 6;
  margin-top: 0;
}

.run-status-card {
  padding: 14px 16px;
  border-radius: 18px;
  background: rgba(247, 234, 204, 0.88);
  border: 1px solid rgba(107, 78, 22, 0.12);
}

.run-map-stage > .run-status-row .run-status-card {
  padding: 10px 12px;
  background: rgba(247, 234, 204, 0.9);
  border-color: rgba(107, 78, 22, 0.18);
  box-shadow: 0 12px 24px rgba(65, 42, 23, 0.13);
  backdrop-filter: blur(10px);
}

.run-status-card strong {
  line-height: 1.25;
}

.run-status-card span {
  display: block;
  margin-bottom: 8px;
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--ink-soft);
}

.run-map-stage > .run-status-row .run-status-card span {
  margin-bottom: 4px;
  font-size: 0.68rem;
}

.run-status-card strong {
  font-size: 1.3rem;
  color: var(--bg);
}

.run-map-stage > .run-status-row .run-status-card strong {
  font-size: clamp(0.92rem, 1.45vw, 1.08rem);
}

.run-inline-shell {
  position: absolute;
  z-index: 7;
  top: 50%;
  left: 50%;
  right: auto;
  width: min(760px, calc(100% - 56px));
  transform: translate(-50%, -50%);
  display: grid;
  gap: 14px;
}

.run-inline-card {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 164px;
  gap: 18px;
  align-items: start;
  padding: 22px;
  border-radius: 24px;
  background: rgba(247, 234, 204, 0.6);
  border: 1px solid rgba(107, 78, 22, 0.12);
  box-shadow: 0 24px 54px rgba(75, 47, 33, 0.18);
  backdrop-filter: blur(2px);
}

.run-inline-question h2 {
  margin: 0;
  color: var(--ink);
  font-size: clamp(1.36rem, 0.9vw + 1.12rem, 2rem);
  line-height: 1.28;
}

.run-inline-options {
  margin-top: 20px;
}

.run-inline-options .option-button {
  background: rgba(249, 239, 214, 0.72);
}

.run-inline-footer {
  grid-column: 2;
  grid-row: 1 / span 2;
  display: grid;
  justify-items: stretch;
  align-items: start;
  gap: 12px;
  margin-top: 0;
}

.run-inline-timer {
  display: inline-grid;
  gap: 6px;
  min-width: 128px;
  padding: 12px 14px;
  border-radius: 18px;
  background: rgba(236, 214, 165, 0.9);
  border: 1px solid rgba(107, 78, 22, 0.14);
}

.run-inline-timer span {
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.72rem;
  font-weight: 800;
  color: var(--ink-soft);
}

.run-inline-timer strong {
  color: var(--bg);
  font-size: 1.3rem;
  line-height: 1;
}

.run-inline-timer.warning {
  border-color: rgba(200, 156, 68, 0.3);
}

.run-inline-timer.danger {
  border-color: rgba(109, 31, 38, 0.28);
  background: rgba(236, 205, 171, 0.9);
}

.compact-race-timer-card {
  display: inline-grid;
  justify-items: center;
  gap: 8px;
  min-width: 144px;
  padding: 12px 14px;
  border-radius: 20px;
  background: rgba(236, 214, 165, 0.46);
  border: 1px solid rgba(107, 78, 22, 0.14);
  box-shadow: 0 12px 22px rgba(75, 47, 33, 0.07);
}

.compact-race-timer-card > span {
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.72rem;
  font-weight: 800;
  color: var(--ink-soft);
}

.compact-race-timer-card > strong {
  color: var(--bg);
  font-size: 1.05rem;
  line-height: 1;
}

.compact-race-timer-card .race-timer-widget {
  width: min(100%, 118px);
  margin: 0;
}

.compact-race-timer-card.warning {
  border-color: rgba(200, 156, 68, 0.3);
}

.compact-race-timer-card.danger {
  border-color: rgba(109, 31, 38, 0.28);
  background: rgba(236, 205, 171, 0.9);
}

.compact-race-timer-card.relay {
  justify-self: end;
}

.raw-content-shell {
  display: grid;
  gap: 16px;
}

.regular-guide-shell {
  display: grid;
  gap: 16px;
}

.regular-guide-card {
  display: grid;
  gap: 18px;
}

.regular-guide-document {
  max-height: min(78vh, 860px);
  overflow: auto;
  padding: clamp(18px, 3vw, 30px);
  border: 1px solid rgba(107, 78, 22, 0.14);
  border-radius: 12px;
  background: rgba(255, 250, 242, 0.82);
  color: var(--ink);
}

.regular-guide-document-inner {
  display: grid;
  gap: 12px;
  max-width: 980px;
  margin: 0 auto;
}

.regular-guide-document h2,
.regular-guide-document h3,
.regular-guide-document h4,
.regular-guide-document h5 {
  margin: 0;
  color: var(--bg);
  letter-spacing: 0;
  line-height: 1.15;
}

.regular-guide-document h2 {
  font-family: "Cardo", serif;
  font-size: clamp(1.65rem, 3vw, 2.25rem);
}

.regular-guide-document h3 {
  margin-top: 12px;
  font-size: clamp(1.18rem, 2vw, 1.45rem);
}

.regular-guide-document h4 {
  margin-top: 8px;
  font-size: 1.02rem;
}

.regular-guide-document h5 {
  margin-top: 6px;
  font-size: 0.95rem;
}

.regular-guide-document p {
  margin: 0;
  font-size: 0.95rem;
  line-height: 1.62;
}

.regular-guide-doc-list-line {
  padding-left: 14px;
  border-left: 3px solid rgba(200, 156, 68, 0.34);
}

.regular-guide-doc-table-wrap {
  overflow-x: auto;
  margin: 4px 0 8px;
  border-radius: 10px;
  border: 1px solid rgba(107, 78, 22, 0.12);
}

.regular-guide-doc-table {
  width: 100%;
  min-width: 620px;
  border-collapse: collapse;
  font-size: 0.88rem;
  line-height: 1.45;
}

.regular-guide-doc-table th,
.regular-guide-doc-table td {
  padding: 10px 11px;
  border: 1px solid rgba(107, 78, 22, 0.12);
  text-align: left;
  vertical-align: top;
}

.regular-guide-doc-table th {
  background: rgba(200, 156, 68, 0.2);
  color: var(--bg);
  font-weight: 900;
}

.regular-guide-doc-table td {
  background: rgba(255, 250, 242, 0.48);
}

.regular-guide-document-empty {
  display: grid;
  gap: 12px;
}

.regular-guide-nav {
  display: grid;
  gap: 12px;
  margin-top: 18px;
  padding-top: 16px;
  border-top: 1px solid rgba(107, 78, 22, 0.12);
}

.regular-guide-nav > strong {
  color: var(--bg);
}

.regular-guide-nav-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.regular-guide-nav-chip {
  border: 1px solid rgba(107, 78, 22, 0.16);
  border-radius: 999px;
  background: rgba(255, 250, 242, 0.62);
  color: var(--bg);
  cursor: pointer;
  font: inherit;
  font-size: 0.84rem;
  font-weight: 800;
  letter-spacing: 0;
  padding: 8px 11px;
}

.regular-guide-nav-chip:hover,
.regular-guide-nav-chip:focus-visible {
  border-color: rgba(138, 99, 56, 0.38);
  background: rgba(255, 250, 242, 0.86);
  outline: none;
}

.regular-guide-nav-chip.active {
  background: rgba(200, 156, 68, 0.22);
  border-color: rgba(200, 156, 68, 0.36);
}

.transfer-table-block {
  display: grid;
  gap: 12px;
}

.transfer-table-block > p {
  margin: 0;
}

.transfer-table-details summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  color: var(--bg);
  cursor: pointer;
  font-weight: 900;
  list-style: none;
}

.transfer-table-details summary::-webkit-details-marker {
  display: none;
}

.transfer-table-details summary span:last-child {
  flex: 0 0 auto;
  padding: 5px 9px;
  border-radius: 999px;
  background: rgba(200, 156, 68, 0.18);
  color: var(--ink-soft);
  font-size: 0.78rem;
}

.transfer-table-scroll {
  overflow-x: auto;
  border: 1px solid rgba(107, 78, 22, 0.12);
  border-radius: 14px;
  background: rgba(255, 250, 242, 0.62);
}

.transfer-table {
  width: 100%;
  min-width: 920px;
  border-collapse: collapse;
  color: var(--bg);
  font-size: 0.86rem;
  line-height: 1.42;
}

.transfer-table th,
.transfer-table td {
  padding: 10px 11px;
  border: 1px solid rgba(107, 78, 22, 0.12);
  text-align: left;
  vertical-align: top;
}

.transfer-table th {
  background: rgba(200, 156, 68, 0.18);
  color: var(--bg);
  font-weight: 900;
}

.transfer-table td {
  background: rgba(255, 250, 242, 0.44);
}

.regular-guide-shell-list {
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.regular-guide-list-card {
  min-height: 140px;
}

.raw-source-card,
.raw-section-card,
.raw-atom-card {
  padding: 22px;
  border-radius: 24px;
  background: rgba(247, 234, 204, 0.94);
  border: 1px solid rgba(107, 78, 22, 0.12);
  box-shadow: var(--shadow);
}

.raw-content-shell {
  position: relative;
}

.raw-source-top,
.raw-atom-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
}

.raw-source-card h3,
.raw-section-card h3,
.raw-atom-card h3 {
  margin: 0;
  color: var(--bg);
  font-size: clamp(1.24rem, 0.65vw + 1.08rem, 1.72rem);
}

.raw-source-card p,
.raw-section-card p,
.raw-atom-card p {
  color: var(--ink-soft);
  line-height: 1.6;
}

.raw-section-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-top: 18px;
}

.raw-section-grid strong,
.raw-block strong {
  display: block;
  margin-bottom: 8px;
  color: var(--bg);
}

.raw-core {
  margin: 12px 0 0;
  font-size: 1rem;
}

.raw-block {
  margin-top: 16px;
}

.raw-mastery-row {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 14px;
  margin-top: 18px;
  padding-top: 16px;
  border-top: 1px solid rgba(107, 78, 22, 0.12);
}

.raw-mastery-row.with-back-to-top {
  justify-content: space-between;
}

.raw-entry-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
}

.raw-entry-back-to-top {
  width: clamp(64px, 6.2vw, 84px);
  aspect-ratio: 292 / 420;
  padding: 0;
  border: 0;
  background: transparent;
  cursor: pointer;
  filter: drop-shadow(0 10px 14px rgba(65, 42, 23, 0.18));
  transition:
    transform 180ms ease,
    filter 180ms ease;
}

.raw-entry-back-to-top:hover {
  transform: translateY(-3px);
  filter: drop-shadow(0 14px 18px rgba(65, 42, 23, 0.24));
}

.raw-entry-back-to-top:focus-visible {
  outline: 3px solid rgba(107, 78, 22, 0.9);
  outline-offset: 4px;
  border-radius: 16px;
}

.raw-entry-back-to-top img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.raw-entry-channel-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 42px;
  padding: 6px 11px 6px 7px;
  border: 1px solid rgba(107, 78, 22, 0.16);
  border-radius: 999px;
  background: rgba(255, 250, 242, 0.84);
  color: var(--bg);
  cursor: pointer;
  font: inherit;
  font-size: 0.86rem;
  font-weight: 900;
  text-decoration: none;
  box-shadow: 0 8px 18px rgba(65, 42, 23, 0.12);
  transition:
    transform 180ms ease,
    box-shadow 180ms ease,
    border-color 180ms ease;
}

.raw-entry-channel-link:hover {
  transform: translateY(-2px);
  border-color: rgba(107, 78, 22, 0.28);
  box-shadow: 0 12px 22px rgba(65, 42, 23, 0.18);
}

.raw-entry-channel-link:focus-visible {
  outline: 3px solid rgba(107, 78, 22, 0.9);
  outline-offset: 3px;
}

.raw-entry-channel-link img {
  width: 34px;
  height: 34px;
  object-fit: contain;
}

.raw-entry-channel-count {
  display: inline-flex;
  align-items: center;
  min-height: 22px;
  padding: 3px 8px;
  border-radius: 999px;
  background: rgba(200, 156, 68, 0.18);
  color: var(--ink-soft);
  font-size: 0.72rem;
  line-height: 1;
  white-space: nowrap;
}

.regular-guide-channel-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid rgba(107, 78, 22, 0.12);
}

.guide-channel-link {
  width: fit-content;
}

.raw-mastery-label {
  color: var(--ink-soft);
  font-size: 0.78rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.12em;
}

.raw-mastery-toggle {
  position: relative;
  display: inline-grid;
  grid-template-columns: 1fr 1fr;
  min-width: min(100%, 300px);
  padding: 4px;
  border: 1px solid rgba(107, 78, 22, 0.16);
  border-radius: 999px;
  background: rgba(236, 214, 165, 0.7);
  color: var(--bg);
  cursor: pointer;
  font-weight: 800;
}

.raw-mastery-toggle::before {
  content: "";
  position: absolute;
  top: 4px;
  left: 4px;
  bottom: 4px;
  width: calc(50% - 4px);
  border-radius: inherit;
  background: rgba(247, 234, 204, 0.96);
  box-shadow: 0 8px 16px rgba(75, 47, 33, 0.12);
  transition: transform 180ms ease, background 180ms ease;
}

.raw-mastery-toggle.mastered::before {
  transform: translateX(100%);
  background: rgba(252, 209, 39, 0.84);
}

.raw-mastery-toggle span {
  position: relative;
  z-index: 1;
  display: grid;
  place-items: center;
  min-height: 34px;
  padding: 0 12px;
  font-size: 0.86rem;
  line-height: 1.1;
  text-align: center;
}

.raw-visual-gallery {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 12px;
  margin-top: 14px;
}

.raw-feature-stack,
.raw-visual-sections {
  display: grid;
  gap: 18px;
  margin-top: 14px;
}

.raw-feature-card,
.raw-visual-section {
  display: grid;
  gap: 14px;
  padding: 18px;
  border-radius: 22px;
  background: rgba(236, 205, 171, 0.26);
  border: 1px solid rgba(107, 78, 22, 0.1);
}

.raw-feature-head {
  display: grid;
  gap: 4px;
}

.raw-feature-head h4 {
  margin: 0;
  color: var(--bg);
  font-size: clamp(1.1rem, 1.9vw, 1.45rem);
}

.raw-feature-note {
  margin: 0;
  color: var(--ink-soft);
  line-height: 1.6;
}

.raw-feature-note--center {
  text-align: center;
}

.raw-timeline-shell {
  display: grid;
  gap: 16px;
}

.raw-timeline-track {
  height: 10px;
  border-radius: 999px;
  background:
    linear-gradient(90deg, rgba(234, 216, 183, 0.92), rgba(234, 216, 183, 0.92)),
    linear-gradient(90deg, #5a3726 0%, #6d1f26 45%, #d8b13f 100%);
  box-shadow: inset 0 0 0 1px rgba(107, 78, 22, 0.06);
  position: relative;
}

.raw-timeline-track::after {
  content: "";
  position: absolute;
  inset: 2px;
  border-radius: inherit;
  background: linear-gradient(90deg, #5a3726 0%, #6d1f26 45%, #d8b13f 100%);
}

.raw-timeline-points {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(128px, 1fr));
  gap: 10px;
}

.raw-timeline-point {
  display: grid;
  justify-items: center;
  gap: 8px;
  padding: 12px 10px;
  border-radius: 18px;
  border: 1px solid rgba(107, 78, 22, 0.12);
  background: rgba(255, 250, 242, 0.82);
  color: var(--bg);
  cursor: pointer;
  text-align: center;
  font: inherit;
}

.raw-timeline-point.active,
.raw-route-map-pin.active {
  background: rgba(216, 177, 63, 0.22);
  border-color: rgba(109, 31, 38, 0.24);
}

.raw-timeline-point-index {
  display: grid;
  place-items: center;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: rgba(109, 31, 38, 0.16);
  font-weight: 800;
}

.raw-timeline-point-label {
  font-size: 0.92rem;
  font-weight: 700;
  line-height: 1.3;
}

.raw-timeline-detail,
.raw-route-map-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(280px, 0.8fr);
  gap: 18px;
  align-items: start;
}

.raw-timeline-image-shell,
.raw-feature-image-shell,
.raw-route-map-figure {
  padding: 14px;
  border-radius: 22px;
  background: rgba(255, 250, 242, 0.9);
  border: 1px solid rgba(107, 78, 22, 0.08);
}

.raw-timeline-image,
.raw-feature-image,
.raw-route-map-image {
  display: block;
  width: 100%;
  border-radius: 16px;
  object-fit: contain;
}

.raw-timeline-image--original,
.raw-feature-image--original,
.raw-route-map-image--original {
  filter: none;
}

.raw-timeline-copy,
.raw-route-map-detail {
  display: grid;
  gap: 10px;
  padding: 14px 16px;
  border-radius: 20px;
  background: rgba(255, 250, 242, 0.7);
  border: 1px solid rgba(107, 78, 22, 0.08);
}

.raw-timeline-copy h5,
.raw-route-map-detail h5 {
  margin: 0;
  color: var(--bg);
  font-size: 1.08rem;
}

.raw-timeline-copy p,
.raw-route-map-detail p {
  margin: 0;
  color: var(--ink-soft);
  line-height: 1.6;
}

.raw-route-map-figure {
  position: relative;
}

.raw-route-map-pin {
  position: absolute;
  transform: translate(-50%, -50%);
  width: 34px;
  height: 34px;
  border-radius: 50%;
  border: 2px solid rgba(109, 31, 38, 0.55);
  background: rgba(255, 250, 242, 0.92);
  color: var(--bg);
  font-weight: 800;
  box-shadow: 0 10px 24px rgba(75, 47, 33, 0.18);
  cursor: pointer;
}

.raw-feature-inline-answer {
  display: grid;
  gap: 10px;
  justify-items: center;
  margin-top: 14px;
  padding: 18px 20px;
  border-radius: 22px;
  border: 1px solid rgba(107, 78, 22, 0.1);
  background: rgba(236, 205, 171, 0.24);
  text-align: center;
}

.raw-feature-inline-answer strong {
  color: var(--bg);
  font-size: 1.08rem;
}

.raw-feature-inline-answer p {
  margin: 0;
  color: var(--ink-soft);
  line-height: 1.6;
  max-width: 760px;
}

.raw-visual-card {
  display: grid;
  gap: 10px;
  padding: 12px;
  border-radius: 18px;
  background: rgba(236, 205, 171, 0.34);
  border: 1px solid rgba(107, 78, 22, 0.1);
  text-align: left;
  cursor: pointer;
  appearance: none;
  font: inherit;
  color: inherit;
}

.raw-visual-card--embedded-video {
  cursor: default;
}

.raw-visual-preview {
  min-height: 132px;
  padding: 14px;
  border-radius: 16px;
  background: rgba(255, 250, 242, 0.88);
  border: 1px solid rgba(107, 78, 22, 0.08);
  display: grid;
  place-items: center;
}

.raw-visual-image {
  display: block;
  width: 100%;
  max-height: 170px;
  object-fit: contain;
  filter: grayscale(1) sepia(1) saturate(1.65) hue-rotate(-8deg) brightness(1.03) contrast(0.94);
}

.raw-visual-image--original {
  filter: none;
}

.raw-visual-title {
  color: var(--bg);
  font-weight: 700;
  line-height: 1.3;
}

@media (max-width: 900px) {
  .raw-timeline-detail,
  .raw-route-map-layout {
    grid-template-columns: 1fr;
  }
}

body.is-local-mode .hero,
body.is-online-mode .hero {
  min-height: clamp(138px, 13vw, 166px) !important;
  padding: 0 !important;
}

body.is-local-mode .hero-layout,
body.is-online-mode .hero-layout {
  position: relative !important;
  display: block !important;
  min-height: clamp(138px, 13vw, 166px) !important;
}

body.is-local-mode .hero-copy,
body.is-online-mode .hero-copy {
  position: absolute !important;
  left: 50% !important;
  top: 50% !important;
  width: min(42vw, 520px) !important;
  display: grid !important;
  text-align: center !important;
  transform: translate(-50%, -50%) !important;
  pointer-events: auto !important;
}

body.is-local-mode .hero-links,
body.is-online-mode .hero-links {
  position: absolute !important;
  left: 0 !important;
  top: 0 !important;
  display: block !important;
  width: 230px !important;
  height: 230px !important;
  padding: 0 !important;
  pointer-events: none !important;
  overflow: visible !important;
}

body.is-local-mode .hero-links img,
body.is-online-mode .hero-links img,
body.is-local-mode .hero-links .session-controls img,
body.is-online-mode .hero-links .session-controls img,
body.is-local-mode .hero-links .session-signout-button img,
body.is-online-mode .hero-links .session-signout-button img,
body.is-local-mode .hero-links .hero-link-icon img,
body.is-online-mode .hero-links .hero-link-icon img,
body.is-local-mode .hero-links .hero-discord-link img,
body.is-online-mode .hero-links .hero-discord-link img {
  width: 40px !important;
  height: 40px !important;
  max-width: 40px !important;
  max-height: 40px !important;
  object-fit: contain !important;
}

/* Absolute last overrides for May 23 path staging. */
body.is-local-mode .hero,
body.is-online-mode .hero,
.hero {
  background: linear-gradient(180deg, rgba(96, 62, 33, 0.98), rgba(75, 48, 27, 0.98)) !important;
  border: 0 !important;
  border-radius: 0 !important;
  color: #fff1cf !important;
  min-height: 150px !important;
  padding: 0 !important;
}

.hero h1,
.hero-progress-circles .stat-progress-circle-copy span,
.hero-progress-circles .stat-progress-circle-copy strong,
.hero-progress-circles .stat-progress-circle-copy em {
  color: #fff1cf !important;
}

.hero-online-mount {
  position: absolute !important;
  left: clamp(-150px, -12vw, -70px) !important;
  top: 50% !important;
  transform: translate(-50%, -50%) !important;
}

.hero-online-button {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  color: #fff1cf !important;
  flex-direction: column !important;
  height: auto !important;
  padding: 0 !important;
}

.hero-online-button img {
  height: 38px !important;
  width: 38px !important;
}

.hero-online-button span {
  color: #fff1cf !important;
  max-height: none !important;
  opacity: 1 !important;
  overflow: visible !important;
}

.hero-links,
body.is-local-mode .hero-links,
body.is-online-mode .hero-links {
  height: 150px !important;
  width: 430px !important;
}

.hero-menu-trigger {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  height: 58px !important;
  left: 22px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 58px !important;
}

.hero-menu-trigger span {
  background: #fff1cf !important;
  height: 4px !important;
}

.hero-links.is-open .hero-menu-trigger span {
  background: #5a391f !important;
}

.hero-links::before {
  background: #fff1cf !important;
  border-radius: 50% !important;
  height: 430px !important;
  left: -276px !important;
  opacity: 0 !important;
  top: 50% !important;
  transform: translate(-22%, -50%) scale(0.16) !important;
  transform-origin: left center !important;
  width: 430px !important;
}

.hero-links.is-open::before {
  opacity: 1 !important;
  transform: translate(0, -50%) scale(1) !important;
}

.hero-links > :not(.hero-menu-trigger),
body.is-local-mode .hero-links > :not(.hero-menu-trigger),
body.is-online-mode .hero-links > :not(.hero-menu-trigger) {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  color: #5a391f !important;
  flex-direction: column !important;
  gap: 3px !important;
  height: 58px !important;
  min-height: 58px !important;
  min-width: 82px !important;
  width: 82px !important;
}

.hero-links.is-open > .hero-discord-link {
  transform: translate(122px, -106px) scale(1) !important;
}

.hero-links.is-open > .session-controls {
  transform: translate(104px, -32px) scale(1) !important;
}

.hero-links.is-open > button.hero-link-icon {
  transform: translate(126px, 42px) scale(1) !important;
}

.hero-links.is-open > a.hero-link-icon {
  transform: translate(168px, 104px) scale(1) !important;
}

.hero-discord-link::after {
  content: "Discord" !important;
}

.hero-links > button.hero-link-icon::after {
  content: "Links" !important;
}

.hero-links > a.hero-link-icon::after {
  content: "Contact" !important;
}

.hero-links > .session-controls::after {
  content: "Log in" !important;
}

.hero-discord-link::after,
.hero-links > button.hero-link-icon::after,
.hero-links > a.hero-link-icon::after,
.hero-links > .session-controls::after {
  color: #5a391f !important;
  display: block !important;
  font-size: 0.64rem !important;
  font-weight: 900 !important;
}

.mode-choice-board {
  display: block !important;
  margin: 0 auto !important;
  min-height: clamp(520px, 50vw, 640px) !important;
  position: relative !important;
  width: min(100%, 1120px) !important;
}

.mode-choice-board.no-section-selection .mode-choice-column {
  opacity: 0.48 !important;
}

.mode-choice-board.no-section-selection .mode-choice-heading,
.mode-choice-board.no-section-selection .mode-choice-heading * {
  cursor: not-allowed !important;
  pointer-events: none !important;
}

.mode-choice-column,
.mode-choice-column-learn,
.mode-choice-column-play,
.mode-choice-column-train {
  height: clamp(250px, 24vw, 315px) !important;
  min-width: 0 !important;
  position: absolute !important;
  top: clamp(76px, 7vw, 100px) !important;
  width: clamp(250px, 24vw, 315px) !important;
}

.mode-choice-column-learn {
  left: 20% !important;
  transform: translateX(-50%) !important;
}

.mode-choice-column-play {
  left: 50% !important;
  transform: translateX(-50%) !important;
}

.mode-choice-column-train {
  left: 80% !important;
  transform: translateX(-50%) !important;
}

.mode-choice-heading {
  height: clamp(148px, 14vw, 186px) !important;
  width: clamp(148px, 14vw, 186px) !important;
}

.mode-choice-board[data-active-path] .mode-choice-column,
.mode-choice-board:has(.mode-choice-column.is-open) .mode-choice-column {
  height: 112px !important;
  left: clamp(4px, 1vw, 14px) !important;
  opacity: 0.68 !important;
  transform: none !important;
  width: 112px !important;
}

.mode-choice-board[data-active-path] .mode-choice-column-learn,
.mode-choice-board:has(.mode-choice-column.is-open) .mode-choice-column-learn {
  top: 44px !important;
}

.mode-choice-board[data-active-path] .mode-choice-column-play,
.mode-choice-board:has(.mode-choice-column.is-open) .mode-choice-column-play {
  top: 172px !important;
}

.mode-choice-board[data-active-path] .mode-choice-column-train,
.mode-choice-board:has(.mode-choice-column.is-open) .mode-choice-column-train {
  top: 300px !important;
}

.mode-choice-board[data-active-path="learn"] .mode-choice-column-learn,
.mode-choice-board[data-active-path="play"] .mode-choice-column-play,
.mode-choice-board[data-active-path="train"] .mode-choice-column-train,
.mode-choice-board:has(.mode-choice-column-learn.is-open) .mode-choice-column-learn,
.mode-choice-board:has(.mode-choice-column-play.is-open) .mode-choice-column-play,
.mode-choice-board:has(.mode-choice-column-train.is-open) .mode-choice-column-train {
  height: clamp(390px, 41vw, 520px) !important;
  left: 46% !important;
  opacity: 1 !important;
  top: clamp(44px, 4vw, 68px) !important;
  transform: translateX(-50%) !important;
  width: clamp(370px, 38vw, 460px) !important;
}

.mode-choice-board[data-active-path] .mode-choice-column:not(.is-open) .mode-choice-heading {
  height: 84px !important;
  opacity: 0.82 !important;
  width: 84px !important;
}

.mode-choice-board[data-active-path] .mode-choice-column.is-targeting .mode-choice-heading,
.mode-choice-board[data-active-path] .mode-choice-column.is-open .mode-choice-heading {
  height: clamp(104px, 10vw, 128px) !important;
  left: 30% !important;
  top: 50% !important;
  width: clamp(104px, 10vw, 128px) !important;
}

.mode-choice-card-grid .wizard-choice-card,
.mode-choice-column-play .mode-choice-card-grid .wizard-choice-card,
.mode-choice-column-train .mode-choice-card-grid .wizard-choice-card,
.mode-choice-column-learn .mode-choice-card-grid .wizard-choice-card {
  height: clamp(118px, 13vw, 150px) !important;
  width: clamp(118px, 13vw, 150px) !important;
}

.mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(1) {
  --menu-x: 12%;
  --menu-y: -206%;
}

.mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(2) {
  --menu-x: 92%;
  --menu-y: -132%;
}

.mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(3) {
  --menu-x: 126%;
  --menu-y: -26%;
}

.mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(4) {
  --menu-x: 92%;
  --menu-y: 82%;
}

.mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(5) {
  --menu-x: 12%;
  --menu-y: 160%;
}

.hero-links > :not(.hero-menu-trigger),
body.is-local-mode .hero-links > :not(.hero-menu-trigger),
body.is-online-mode .hero-links > :not(.hero-menu-trigger) {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 3px !important;
  height: 58px !important;
  min-height: 58px !important;
  min-width: 82px !important;
  opacity: 0 !important;
  pointer-events: none !important;
  width: 82px !important;
}

.hero-links.is-open > :not(.hero-menu-trigger),
body.is-local-mode .hero-links.is-open > :not(.hero-menu-trigger),
body.is-online-mode .hero-links.is-open > :not(.hero-menu-trigger) {
  opacity: 1 !important;
  pointer-events: auto !important;
}

.hero-links img,
body.is-local-mode .hero-links img,
body.is-online-mode .hero-links img,
.hero-links .session-controls img,
body.is-local-mode .hero-links .session-controls img,
body.is-online-mode .hero-links .session-controls img,
.hero-links .session-signout-button img,
body.is-local-mode .hero-links .session-signout-button img,
body.is-online-mode .hero-links .session-signout-button img,
.hero-links .hero-link-icon img,
body.is-local-mode .hero-links .hero-link-icon img,
body.is-online-mode .hero-links .hero-link-icon img,
.hero-links .hero-discord-link img,
body.is-local-mode .hero-links .hero-discord-link img,
body.is-online-mode .hero-links .hero-discord-link img {
  height: 36px !important;
  max-height: 36px !important;
  max-width: 36px !important;
  object-fit: contain !important;
  width: 36px !important;
}

/* Final final pass: these rules must stay last. */
.hero,
body.is-local-mode .hero,
body.is-online-mode .hero {
  width: 100% !important;
  min-height: 150px !important;
  margin: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  padding: 0 !important;
  background: linear-gradient(180deg, rgba(96, 62, 33, 0.98), rgba(75, 48, 27, 0.98)) !important;
  color: #fff1cf !important;
}

.hero h1,
.hero-progress-circles .stat-progress-circle-copy span,
.hero-progress-circles .stat-progress-circle-copy strong,
.hero-progress-circles .stat-progress-circle-copy em {
  color: #fff1cf !important;
}

.hero-online-mount {
  position: absolute !important;
  left: clamp(-150px, -12vw, -70px) !important;
  top: 50% !important;
  transform: translate(-50%, -50%) !important;
  min-height: 58px !important;
}

.hero-online-button {
  height: auto !important;
  min-width: 70px !important;
  padding: 0 !important;
  display: inline-flex !important;
  flex-direction: column !important;
  gap: 4px !important;
  border: 0 !important;
  background: transparent !important;
  color: #fff1cf !important;
  box-shadow: none !important;
}

.hero-online-button img {
  width: 38px !important;
  height: 38px !important;
}

.hero-online-button span,
.session-mode-button.hero-online-button span {
  max-height: none !important;
  overflow: visible !important;
  opacity: 1 !important;
  color: #fff1cf !important;
}

.hero-links,
body.is-local-mode .hero-links,
body.is-online-mode .hero-links {
  position: absolute !important;
  left: 0 !important;
  top: 0 !important;
  z-index: 42 !important;
  width: 430px !important;
  height: 150px !important;
  display: block !important;
  padding: 0 !important;
  pointer-events: none !important;
  overflow: visible !important;
}

.hero-links::before {
  content: "" !important;
  position: absolute !important;
  left: -276px !important;
  top: 50% !important;
  width: 430px !important;
  height: 430px !important;
  border-radius: 50% !important;
  background: #fff1cf !important;
  border: 1px solid rgba(83, 54, 27, 0.14) !important;
  box-shadow: 22px 24px 42px rgba(43, 27, 14, 0.22) !important;
  opacity: 0 !important;
  transform: translate(-22%, -50%) scale(0.16) !important;
  transform-origin: left center !important;
  transition: opacity 240ms ease, transform 800ms cubic-bezier(0.76, 0, 0.24, 1) !important;
  pointer-events: none !important;
}

.hero-links.is-open::before {
  opacity: 1 !important;
  transform: translate(0, -50%) scale(1) !important;
}

.hero-menu-trigger {
  left: 22px !important;
  top: 50% !important;
  width: 58px !important;
  height: 58px !important;
  padding: 12px !important;
  border: 0 !important;
  border-radius: 14px !important;
  background: transparent !important;
  box-shadow: none !important;
  transform: translateY(-50%) !important;
}

.hero-menu-trigger span {
  height: 4px !important;
  background: #fff1cf !important;
}

.hero-links.is-open .hero-menu-trigger span {
  background: #5a391f !important;
}

.hero-links.is-open .hero-menu-trigger span:nth-child(1) {
  transform: translateY(15px) rotate(45deg) !important;
}

.hero-links.is-open .hero-menu-trigger span:nth-child(3) {
  transform: translateY(-15px) rotate(-45deg) !important;
}

.hero-links > :not(.hero-menu-trigger),
body.is-local-mode .hero-links > :not(.hero-menu-trigger),
body.is-online-mode .hero-links > :not(.hero-menu-trigger) {
  position: absolute !important;
  left: 26px !important;
  top: 50% !important;
  z-index: 7 !important;
  width: 82px !important;
  height: 58px !important;
  min-width: 82px !important;
  min-height: 58px !important;
  padding: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 3px !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  color: #5a391f !important;
  opacity: 0 !important;
  pointer-events: none !important;
  transform: translate(0, -50%) scale(0.25) !important;
}

.hero-links.is-open > :not(.hero-menu-trigger) {
  opacity: 1 !important;
  pointer-events: auto !important;
}

.hero-links.is-open > .hero-discord-link {
  transform: translate(122px, -106px) scale(1) !important;
}

.hero-links.is-open > .session-controls {
  transform: translate(104px, -32px) scale(1) !important;
}

.hero-links.is-open > button.hero-link-icon {
  transform: translate(126px, 42px) scale(1) !important;
}

.hero-links.is-open > a.hero-link-icon {
  transform: translate(168px, 104px) scale(1) !important;
}

.hero-links img,
body.is-local-mode .hero-links img,
body.is-online-mode .hero-links img {
  width: 36px !important;
  height: 36px !important;
  max-width: 36px !important;
  max-height: 36px !important;
  object-fit: contain !important;
}

.hero-discord-link::after,
.hero-links > button.hero-link-icon::after,
.hero-links > a.hero-link-icon::after,
.hero-links > .session-controls::after {
  display: block !important;
  color: #5a391f !important;
  font-size: 0.64rem !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  text-align: center !important;
  white-space: nowrap !important;
}

.hero-discord-link::after {
  content: "Discord" !important;
}

.hero-links > button.hero-link-icon::after {
  content: "Links" !important;
}

.hero-links > a.hero-link-icon::after {
  content: "Contact" !important;
}

.hero-links > .session-controls::after {
  content: "Log in" !important;
}

.mode-choice-board {
  position: relative !important;
  display: block !important;
  min-height: clamp(520px, 50vw, 640px) !important;
  width: min(100%, 1120px) !important;
  margin: 0 auto !important;
  overflow: visible !important;
}

.mode-choice-board.no-section-selection .mode-choice-column {
  opacity: 0.48 !important;
}

.mode-choice-board.no-section-selection .mode-choice-heading,
.mode-choice-board.no-section-selection .mode-choice-heading * {
  pointer-events: none !important;
  cursor: not-allowed !important;
}

.mode-choice-column,
.mode-choice-column-learn,
.mode-choice-column-play,
.mode-choice-column-train {
  position: absolute !important;
  top: clamp(76px, 7vw, 100px) !important;
  width: clamp(250px, 24vw, 315px) !important;
  height: clamp(250px, 24vw, 315px) !important;
  min-width: 0 !important;
  opacity: 1 !important;
  transition:
    left 1s cubic-bezier(0.76, 0, 0.24, 1),
    top 1s cubic-bezier(0.76, 0, 0.24, 1),
    width 1s cubic-bezier(0.76, 0, 0.24, 1),
    height 1s cubic-bezier(0.76, 0, 0.24, 1),
    transform 1s cubic-bezier(0.76, 0, 0.24, 1),
    opacity 360ms ease !important;
}

.mode-choice-column-learn {
  left: 20% !important;
  transform: translateX(-50%) !important;
}

.mode-choice-column-play {
  left: 50% !important;
  transform: translateX(-50%) !important;
}

.mode-choice-column-train {
  left: 80% !important;
  transform: translateX(-50%) !important;
}

.mode-choice-heading {
  width: clamp(148px, 14vw, 186px) !important;
  height: clamp(148px, 14vw, 186px) !important;
}

.mode-choice-board[data-active-path] .mode-choice-column,
.mode-choice-board:has(.mode-choice-column.is-open) .mode-choice-column {
  left: clamp(4px, 1vw, 14px) !important;
  width: 112px !important;
  height: 112px !important;
  opacity: 0.68 !important;
  transform: none !important;
}

.mode-choice-board[data-active-path] .mode-choice-column-learn,
.mode-choice-board:has(.mode-choice-column.is-open) .mode-choice-column-learn {
  top: 44px !important;
}

.mode-choice-board[data-active-path] .mode-choice-column-play,
.mode-choice-board:has(.mode-choice-column.is-open) .mode-choice-column-play {
  top: 172px !important;
}

.mode-choice-board[data-active-path] .mode-choice-column-train,
.mode-choice-board:has(.mode-choice-column.is-open) .mode-choice-column-train {
  top: 300px !important;
}

.mode-choice-board[data-active-path="learn"] .mode-choice-column-learn,
.mode-choice-board[data-active-path="play"] .mode-choice-column-play,
.mode-choice-board[data-active-path="train"] .mode-choice-column-train,
.mode-choice-board:has(.mode-choice-column-learn.is-open) .mode-choice-column-learn,
.mode-choice-board:has(.mode-choice-column-play.is-open) .mode-choice-column-play,
.mode-choice-board:has(.mode-choice-column-train.is-open) .mode-choice-column-train {
  left: 46% !important;
  top: clamp(44px, 4vw, 68px) !important;
  width: clamp(370px, 38vw, 460px) !important;
  height: clamp(390px, 41vw, 520px) !important;
  opacity: 1 !important;
  transform: translateX(-50%) !important;
}

.mode-choice-board[data-active-path] .mode-choice-column:not(.is-open):not(.is-targeting) .mode-choice-card-grid {
  display: none !important;
}

.mode-choice-board[data-active-path] .mode-choice-column:not(.is-open) .mode-choice-heading {
  width: 84px !important;
  height: 84px !important;
  opacity: 0.82 !important;
}

.mode-choice-board[data-active-path] .mode-choice-column.is-targeting .mode-choice-heading,
.mode-choice-board[data-active-path] .mode-choice-column.is-open .mode-choice-heading {
  left: 30% !important;
  top: 50% !important;
  width: clamp(104px, 10vw, 128px) !important;
  height: clamp(104px, 10vw, 128px) !important;
}

.mode-choice-card-grid .wizard-choice-card,
.mode-choice-column-play .mode-choice-card-grid .wizard-choice-card,
.mode-choice-column-train .mode-choice-card-grid .wizard-choice-card,
.mode-choice-column-learn .mode-choice-card-grid .wizard-choice-card {
  width: clamp(118px, 13vw, 150px) !important;
  height: clamp(118px, 13vw, 150px) !important;
  padding: 10px !important;
  border-radius: 16px !important;
}

.mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(1) {
  --menu-x: 12%;
  --menu-y: -206%;
}

.mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(2) {
  --menu-x: 92%;
  --menu-y: -132%;
}

.mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(3) {
  --menu-x: 126%;
  --menu-y: -26%;
}

.mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(4) {
  --menu-x: 92%;
  --menu-y: 82%;
}

.mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(5) {
  --menu-x: 12%;
  --menu-y: 160%;
}

.mode-choice-board.is-menu-switching .mode-choice-column.is-closing .mode-choice-card-grid .wizard-choice-card,
.mode-choice-board.is-menu-closing .mode-choice-column.is-closing .mode-choice-card-grid .wizard-choice-card {
  opacity: 0 !important;
  filter: blur(2px) !important;
  transform: translate(var(--menu-x), var(--menu-y)) scale(0.78) !important;
  transition-duration: 500ms !important;
}

.mode-choice-card-grid .wizard-choice-card .wizard-choice-slot {
  width: clamp(58px, 6.2vw, 74px) !important;
  height: clamp(58px, 6.2vw, 74px) !important;
}

.mode-choice-card-grid .wizard-choice-card .wizard-choice-copy h3 {
  max-width: 124px !important;
  font-size: clamp(0.72rem, 0.95vw, 0.95rem) !important;
}

.hero-online-button span,
.session-mode-button.hero-online-button span {
  max-height: none !important;
  overflow: visible !important;
  opacity: 1 !important;
  color: #76592f !important;
  font-size: 0.64rem !important;
  font-weight: 850 !important;
  line-height: 1 !important;
}

.hero-progress-circles .progress-circle-card {
  grid-template-columns: auto minmax(0, 1fr) !important;
}

.hero-progress-circles .stat-progress-circle-copy {
  min-width: 0 !important;
  max-width: 150px !important;
}

.hero-progress-circles .stat-progress-circle-copy span {
  font-size: clamp(0.56rem, 0.72vw, 0.72rem) !important;
  white-space: normal !important;
}

/* May 23 pass 2: dark header, left radial nav, delayed path staging. */
.hero,
body.is-local-mode .hero,
body.is-online-mode .hero {
  width: 100% !important;
  min-height: 150px !important;
  margin: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background:
    linear-gradient(180deg, rgba(96, 62, 33, 0.98), rgba(75, 48, 27, 0.98)) !important;
  box-shadow: 0 12px 26px rgba(56, 35, 18, 0.18) !important;
  color: #fff1cf !important;
}

.hero h1 {
  color: #fff1cf !important;
  text-shadow: none !important;
}

.hero-progress-circles,
body.is-local-mode .hero-progress-circles,
body.is-online-mode .hero-progress-circles {
  color: #fff1cf !important;
}

.hero-progress-circles .stat-progress-circle-copy span,
.hero-progress-circles .stat-progress-circle-copy strong,
.hero-progress-circles .stat-progress-circle-copy em {
  color: #fff1cf !important;
}

.hero-online-mount {
  position: absolute !important;
  left: clamp(-150px, -12vw, -70px) !important;
  top: 50% !important;
  min-height: 58px !important;
  transform: translate(-50%, -50%) !important;
}

.hero-online-button {
  height: auto !important;
  min-width: 70px !important;
  padding: 0 !important;
  flex-direction: column !important;
  gap: 4px !important;
  border: 0 !important;
  background: transparent !important;
  color: #fff1cf !important;
  box-shadow: none !important;
}

.hero-online-button img {
  width: 38px !important;
  height: 38px !important;
}

.hero-online-button span,
.session-mode-button.hero-online-button span {
  color: #fff1cf !important;
  font-size: 0.66rem !important;
}

.hero-links,
body.is-local-mode .hero-links,
body.is-online-mode .hero-links {
  position: absolute !important;
  left: 0 !important;
  top: 0 !important;
  z-index: 42 !important;
  width: 430px !important;
  height: 150px !important;
  display: block !important;
  padding: 0 !important;
  pointer-events: none !important;
  overflow: visible !important;
}

.hero-links::before {
  left: -276px !important;
  top: 50% !important;
  width: 430px !important;
  height: 430px !important;
  border-radius: 50% !important;
  background: #fff1cf !important;
  border: 1px solid rgba(83, 54, 27, 0.14) !important;
  box-shadow: 22px 24px 42px rgba(43, 27, 14, 0.22) !important;
  opacity: 0 !important;
  transform: translate(-22%, -50%) scale(0.16) !important;
  transform-origin: left center !important;
  transition: opacity 240ms ease, transform 800ms cubic-bezier(0.76, 0, 0.24, 1) !important;
}

.hero-links.is-open::before {
  opacity: 1 !important;
  transform: translate(0, -50%) scale(1) !important;
}

.hero-menu-trigger {
  left: 22px !important;
  top: 50% !important;
  width: 58px !important;
  height: 58px !important;
  padding: 12px !important;
  border: 0 !important;
  border-radius: 14px !important;
  background: transparent !important;
  box-shadow: none !important;
  transform: translateY(-50%) !important;
}

.hero-menu-trigger span {
  height: 4px !important;
  background: #fff1cf !important;
}

.hero-links.is-open .hero-menu-trigger span {
  background: #5a391f !important;
}

.hero-links.is-open .hero-menu-trigger span:nth-child(1) {
  transform: translateY(15px) rotate(45deg) !important;
}

.hero-links.is-open .hero-menu-trigger span:nth-child(3) {
  transform: translateY(-15px) rotate(-45deg) !important;
}

.hero-links > :not(.hero-menu-trigger),
body.is-local-mode .hero-links > :not(.hero-menu-trigger),
body.is-online-mode .hero-links > :not(.hero-menu-trigger) {
  left: 26px !important;
  top: 50% !important;
  width: 82px !important;
  height: 58px !important;
  min-width: 82px !important;
  min-height: 58px !important;
  padding: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 3px !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  color: #5a391f !important;
  opacity: 0 !important;
  pointer-events: none !important;
  transform: translate(0, -50%) scale(0.25) !important;
}

.hero-links.is-open > :not(.hero-menu-trigger) {
  opacity: 1 !important;
  pointer-events: auto !important;
}

.hero-links.is-open > .hero-discord-link {
  transform: translate(122px, -106px) scale(1) !important;
}

.hero-links.is-open > .session-controls {
  transform: translate(104px, -32px) scale(1) !important;
}

.hero-links.is-open > button.hero-link-icon {
  transform: translate(126px, 42px) scale(1) !important;
}

.hero-links.is-open > a.hero-link-icon {
  transform: translate(168px, 104px) scale(1) !important;
}

.hero-links img,
body.is-local-mode .hero-links img,
body.is-online-mode .hero-links img,
.hero-links .session-controls img,
body.is-local-mode .hero-links .session-controls img,
body.is-online-mode .hero-links .session-controls img,
.hero-links .session-signout-button img,
body.is-local-mode .hero-links .session-signout-button img,
body.is-online-mode .hero-links .session-signout-button img,
.hero-links .hero-link-icon img,
body.is-local-mode .hero-links .hero-link-icon img,
body.is-online-mode .hero-links .hero-link-icon img,
.hero-links .hero-discord-link img,
body.is-local-mode .hero-links .hero-discord-link img,
body.is-online-mode .hero-links .hero-discord-link img {
  width: 36px !important;
  height: 36px !important;
  max-width: 36px !important;
  max-height: 36px !important;
  object-fit: contain !important;
}

.hero-discord-link::after,
.hero-links > button.hero-link-icon::after,
.hero-links > a.hero-link-icon::after,
.hero-links > .session-controls::after {
  display: block !important;
  color: #5a391f !important;
  font-size: 0.64rem !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  text-align: center !important;
  white-space: nowrap !important;
}

.hero-discord-link::after {
  content: "Discord" !important;
}

.hero-links > button.hero-link-icon::after {
  content: "Links" !important;
}

.hero-links > a.hero-link-icon::after {
  content: "Contact" !important;
}

.hero-links > .session-controls::after {
  content: "Log in" !important;
}

.hero-links .session-controls .hero-link-icon,
.hero-links .session-controls .session-signout-button {
  width: 42px !important;
  height: 38px !important;
  min-width: 42px !important;
  min-height: 38px !important;
  padding: 0 !important;
}

.mode-choice-board {
  position: relative !important;
  display: block !important;
  min-height: clamp(520px, 50vw, 640px) !important;
  width: min(100%, 1120px) !important;
  margin: 0 auto !important;
  overflow: visible !important;
}

.mode-choice-board.no-section-selection .mode-choice-column {
  opacity: 0.48 !important;
}

.mode-choice-board.no-section-selection .mode-choice-heading,
.mode-choice-board.no-section-selection .mode-choice-heading * {
  pointer-events: none !important;
  cursor: not-allowed !important;
}

.mode-choice-board.needs-section-selection .mode-choice-column {
  animation: mode-needs-section-wiggle 420ms ease !important;
}

@keyframes mode-needs-section-wiggle {
  0%, 100% { filter: none; }
  50% { filter: sepia(0.25) brightness(0.92); }
}

.mode-choice-column,
.mode-choice-column-learn,
.mode-choice-column-play,
.mode-choice-column-train {
  position: absolute !important;
  top: clamp(76px, 7vw, 100px) !important;
  width: clamp(250px, 24vw, 315px) !important;
  height: clamp(250px, 24vw, 315px) !important;
  min-width: 0 !important;
  opacity: 1 !important;
  transition:
    left 1s cubic-bezier(0.76, 0, 0.24, 1),
    top 1s cubic-bezier(0.76, 0, 0.24, 1),
    width 1s cubic-bezier(0.76, 0, 0.24, 1),
    height 1s cubic-bezier(0.76, 0, 0.24, 1),
    transform 1s cubic-bezier(0.76, 0, 0.24, 1),
    opacity 360ms ease !important;
}

.mode-choice-column-learn {
  left: 20% !important;
  transform: translateX(-50%) !important;
}

.mode-choice-column-play {
  left: 50% !important;
  transform: translateX(-50%) !important;
}

.mode-choice-column-train {
  left: 80% !important;
  transform: translateX(-50%) !important;
}

.mode-choice-heading {
  width: clamp(148px, 14vw, 186px) !important;
  height: clamp(148px, 14vw, 186px) !important;
  transition:
    width 1s cubic-bezier(0.76, 0, 0.24, 1),
    height 1s cubic-bezier(0.76, 0, 0.24, 1),
    transform 1s cubic-bezier(0.76, 0, 0.24, 1),
    opacity 360ms ease !important;
}

.mode-choice-board[data-active-path] .mode-choice-column {
  left: clamp(4px, 1vw, 14px) !important;
  width: 112px !important;
  height: 112px !important;
  opacity: 0.68 !important;
  transform: none !important;
}

.mode-choice-board[data-active-path] .mode-choice-column-learn {
  top: 44px !important;
}

.mode-choice-board[data-active-path] .mode-choice-column-play {
  top: 172px !important;
}

.mode-choice-board[data-active-path] .mode-choice-column-train {
  top: 300px !important;
}

.mode-choice-board[data-active-path="learn"] .mode-choice-column-learn,
.mode-choice-board[data-active-path="play"] .mode-choice-column-play,
.mode-choice-board[data-active-path="train"] .mode-choice-column-train {
  left: 46% !important;
  top: clamp(44px, 4vw, 68px) !important;
  width: clamp(370px, 38vw, 460px) !important;
  height: clamp(390px, 41vw, 520px) !important;
  opacity: 1 !important;
  transform: translateX(-50%) !important;
}

.mode-choice-board[data-active-path] .mode-choice-column:not(.is-open):not(.is-targeting) .mode-choice-card-grid {
  display: none !important;
}

.mode-choice-board[data-active-path] .mode-choice-column:not(.is-open) .mode-choice-heading {
  width: 84px !important;
  height: 84px !important;
  opacity: 0.82 !important;
}

.mode-choice-board[data-active-path] .mode-choice-column.is-targeting .mode-choice-heading,
.mode-choice-board[data-active-path] .mode-choice-column.is-open .mode-choice-heading {
  left: 30% !important;
  top: 50% !important;
  width: clamp(104px, 10vw, 128px) !important;
  height: clamp(104px, 10vw, 128px) !important;
}

.mode-choice-board[data-active-path] .mode-choice-column.is-open .mode-choice-heading h3,
.mode-choice-board[data-active-path] .mode-choice-column.is-targeting .mode-choice-heading h3 {
  font-size: clamp(0.86rem, 1vw, 1.05rem) !important;
}

.mode-choice-card-grid .wizard-choice-card,
.mode-choice-column-play .mode-choice-card-grid .wizard-choice-card,
.mode-choice-column-train .mode-choice-card-grid .wizard-choice-card,
.mode-choice-column-learn .mode-choice-card-grid .wizard-choice-card {
  width: clamp(118px, 13vw, 150px) !important;
  height: clamp(118px, 13vw, 150px) !important;
  padding: 10px !important;
  border-radius: 16px !important;
}

.mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(1) {
  --menu-x: 12%;
  --menu-y: -206%;
}

.mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(2) {
  --menu-x: 92%;
  --menu-y: -132%;
}

.mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(3) {
  --menu-x: 126%;
  --menu-y: -26%;
}

.mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(4) {
  --menu-x: 92%;
  --menu-y: 82%;
}

.mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(5) {
  --menu-x: 12%;
  --menu-y: 160%;
}

.mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:hover,
.mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:focus-visible {
  transform: translate(var(--menu-x), var(--menu-y)) scale(1.07) !important;
}

.mode-choice-board.is-menu-switching .mode-choice-column.is-closing .mode-choice-card-grid .wizard-choice-card,
.mode-choice-board.is-menu-closing .mode-choice-column.is-closing .mode-choice-card-grid .wizard-choice-card {
  opacity: 0 !important;
  filter: blur(2px) !important;
  transform: translate(var(--menu-x), var(--menu-y)) scale(0.78) !important;
  transition-duration: 500ms !important;
}

.mode-choice-card-grid .wizard-choice-card .wizard-choice-slot {
  width: clamp(58px, 6.2vw, 74px) !important;
  height: clamp(58px, 6.2vw, 74px) !important;
}

.mode-choice-card-grid .wizard-choice-card .wizard-choice-copy h3 {
  max-width: 124px !important;
  font-size: clamp(0.72rem, 0.95vw, 0.95rem) !important;
}

.raw-visual-bar-shell {
  width: min(100%, 180px);
  display: grid;
  gap: 10px;
}

.raw-visual-bar-label,
.raw-visual-bar-value,
.raw-visual-throbber-text {
  color: var(--bg);
  font-size: 0.84rem;
  font-weight: 700;
}

.raw-visual-bar-track {
  position: relative;
  display: block;
  height: 18px;
  border-radius: 999px;
  overflow: hidden;
  background: rgba(90, 55, 38, 0.14);
  border: 1px solid rgba(107, 78, 22, 0.12);
}

.raw-visual-bar-fill {
  position: absolute;
  inset: 0 auto 0 0;
  width: 72%;
  border-radius: inherit;
  background: linear-gradient(90deg, rgba(200, 156, 68, 0.92), rgba(109, 31, 38, 0.88));
}

.raw-visual-bar-track-indeterminate {
  background: rgba(90, 55, 38, 0.1);
}

.raw-visual-bar-wave {
  position: absolute;
  inset: 2px auto 2px 6%;
  width: 42%;
  border-radius: inherit;
  background:
    repeating-linear-gradient(
      135deg,
      rgba(200, 156, 68, 0.96) 0 10px,
      rgba(109, 31, 38, 0.7) 10px 18px
    );
}

.raw-visual-splash {
  width: min(100%, 180px);
  display: grid;
  justify-items: center;
  gap: 12px;
}

.raw-visual-splash-logo {
  width: 54px;
  height: 54px;
  border-radius: 18px;
  display: grid;
  place-items: center;
  font-weight: 900;
  color: var(--bg);
  background: radial-gradient(circle at 30% 30%, rgba(252, 209, 39, 0.94), rgba(200, 156, 68, 0.88));
  border: 1px solid rgba(107, 78, 22, 0.14);
}

.raw-visual-splash-line {
  width: 72%;
  height: 12px;
  border-radius: 999px;
  background: rgba(90, 55, 38, 0.12);
}

.raw-visual-splash-dots {
  display: flex;
  gap: 8px;
}

.raw-visual-splash-dots span {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: rgba(109, 31, 38, 0.78);
}

.raw-visual-console {
  width: min(100%, 190px);
  padding: 14px;
  border-radius: 16px;
  background: rgba(74, 47, 33, 0.96);
  display: grid;
  gap: 8px;
  color: rgba(234, 216, 183, 0.96);
  font-size: 0.8rem;
  font-family: "SF Mono", "IBM Plex Mono", "Fira Code", monospace;
}

.raw-visual-console-cursor {
  display: inline-block;
  width: 8px;
  height: 1em;
  margin-left: 4px;
  vertical-align: -2px;
  background: rgba(252, 209, 39, 0.88);
}

.raw-visual-skeleton {
  width: min(100%, 190px);
  display: grid;
  grid-template-columns: 34px 1fr;
  gap: 10px 12px;
  align-items: center;
}

.raw-visual-skeleton-avatar {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: rgba(200, 156, 68, 0.3);
  grid-row: span 2;
}

.raw-visual-skeleton-line {
  height: 12px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(200, 156, 68, 0.28), rgba(234, 216, 183, 0.9), rgba(200, 156, 68, 0.28));
}

.raw-visual-skeleton-line.short {
  width: 62%;
}

.raw-visual-throbber-shell {
  display: grid;
  justify-items: center;
  gap: 12px;
}

.raw-visual-throbber {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  border: 6px solid rgba(200, 156, 68, 0.22);
  border-top-color: rgba(109, 31, 38, 0.88);
  border-right-color: rgba(90, 55, 38, 0.74);
}

.raw-visual-fallback {
  display: grid;
  place-items: center;
  width: 100%;
  height: 100%;
  color: var(--bg);
  font-weight: 700;
}

.raw-visual-link-preview {
  display: grid;
  gap: 8px;
  align-content: center;
  justify-items: center;
  width: 100%;
  min-height: 132px;
  text-align: center;
}

.raw-visual-link-kicker {
  color: var(--ink-soft);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.raw-visual-link-name {
  color: var(--bg);
  font-size: 1rem;
  font-weight: 800;
  line-height: 1.3;
}

.raw-visual-video-wrap {
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  border-radius: 14px;
  background: #000;
  box-shadow: inset 0 0 0 1px rgba(107, 78, 22, 0.08);
}

.raw-visual-video-iframe {
  display: block;
  width: 100%;
  height: 100%;
  border: 0;
}

.raw-link-list,
.raw-quiz-list {
  display: grid;
  gap: 12px;
}

.raw-quiz-pager {
  display: grid;
  gap: 12px;
}

.raw-quiz-pager-head,
.raw-quiz-pager-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}

.raw-quiz-pager-head span {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 4px 9px;
  border-radius: 999px;
  background: rgba(255, 250, 242, 0.62);
  color: var(--ink-soft);
  font-size: 0.78rem;
  font-weight: 800;
}

.raw-quiz-pager-actions {
  justify-content: flex-end;
}

.raw-connection-groups {
  display: grid;
  gap: 12px;
}

.raw-connection-group {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.raw-connection-group-label {
  color: var(--bg);
  font-weight: 700;
  margin-right: 2px;
}

.raw-connection-list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

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

.raw-link-list-inline {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
}

.raw-link-pill,
.raw-connection-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 12px 16px;
  border-radius: 16px;
  border: 1px solid rgba(107, 78, 22, 0.14);
  background: rgba(236, 205, 171, 0.5);
  color: var(--bg);
  font-weight: 700;
  text-decoration: none;
  text-align: center;
  font: inherit;
  cursor: pointer;
}

.raw-link-pill-inline {
  min-height: 36px;
  padding: 8px 12px;
  border-radius: 14px;
  font-size: 0.88rem;
}

.raw-link-pill:hover,
.raw-connection-pill:hover {
  border-color: rgba(138, 99, 56, 0.34);
  background: rgba(236, 205, 171, 0.74);
}

.raw-connection-pill-static {
  cursor: default;
  pointer-events: none;
}

.raw-connection-pill-static:hover {
  border-color: rgba(107, 78, 22, 0.14);
  background: rgba(236, 205, 171, 0.5);
}

.raw-connection-pill:focus-visible {
  outline: 3px solid rgba(200, 156, 68, 0.28);
  outline-offset: 2px;
}

.raw-quiz-card {
  padding: 16px;
  border-radius: 18px;
  background: rgba(236, 205, 171, 0.42);
  border: 1px solid rgba(107, 78, 22, 0.12);
}

.raw-quiz-top {
  display: flex;
  justify-content: flex-end;
  margin-bottom: 10px;
}

.raw-quiz-level {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(200, 156, 68, 0.18);
  color: var(--bg);
  font-size: 0.84rem;
  font-weight: 800;
}

.raw-quiz-prompt {
  margin: 0 0 12px;
  color: var(--bg);
  font-weight: 700;
}

.raw-quiz-feedback {
  display: grid;
  gap: 4px;
  margin-top: 12px;
  padding: 12px;
  border-radius: 14px;
  background: rgba(255, 250, 242, 0.7);
  border: 1px solid rgba(107, 78, 22, 0.12);
}

.raw-quiz-feedback strong {
  color: var(--bg);
}

.raw-quiz-feedback p {
  margin: 0;
  color: var(--ink-soft);
  line-height: 1.45;
}

.raw-quiz-feedback .raw-quiz-takeaway {
  margin-top: 4px;
  color: var(--bg);
  font-weight: 700;
}

.raw-quiz-feedback .raw-quiz-takeaway span {
  color: var(--muted);
}

.quiz-shell {
  display: grid;
  gap: 18px;
}

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

.quiz-question-list {
  display: grid;
  gap: 14px;
}

.quiz-question-card .raw-quiz-option.active {
  border-color: rgba(138, 99, 56, 0.72);
  background: rgba(236, 217, 170, 0.55);
}

.quiz-question-top {
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.quiz-question-number {
  margin: 0;
  font-weight: 800;
  color: var(--brown);
}

.quiz-warning {
  margin: 0;
  color: #8a3b1d;
  font-weight: 800;
}

.quiz-submit-wrap {
  position: relative;
  display: inline-flex;
}

.quiz-submit-wrap.is-disabled .button {
  cursor: help;
  opacity: 0.62;
}

.quiz-submit-wrap[data-quiz-tooltip]:hover::after,
.quiz-submit-wrap[data-quiz-tooltip]:focus-within::after {
  position: absolute;
  right: 0;
  bottom: calc(100% + 10px);
  z-index: 5;
  width: max-content;
  max-width: min(260px, 70vw);
  padding: 9px 11px;
  border-radius: 10px;
  background: rgba(54, 38, 25, 0.94);
  color: #fffaf2;
  content: attr(data-quiz-tooltip);
  font-size: 0.84rem;
  font-weight: 800;
  line-height: 1.25;
  box-shadow: 0 12px 24px rgba(41, 27, 16, 0.22);
}

.quiz-results-footer {
  display: grid;
  gap: 10px;
  padding: 16px;
  border-radius: 14px;
  background: rgba(255, 250, 242, 0.72);
  border: 1px solid rgba(107, 78, 22, 0.12);
}

.quiz-results-footer h3,
.quiz-results-footer p {
  margin: 0;
}

.quiz-results-footer h3 {
  color: var(--bg);
  font-size: 1.1rem;
}

.quiz-results-footer p {
  color: var(--brown);
  font-weight: 900;
}

.quiz-difficulty-results {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.quiz-difficulty-results span {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(200, 156, 68, 0.14);
  color: var(--bg);
  font-size: 0.86rem;
  font-weight: 850;
}

.compact-actions {
  margin: 8px 0 12px;
}

.raw-quiz-media {
  display: grid;
  place-items: center;
  margin-bottom: 12px;
  padding: 10px;
  border-radius: 16px;
  background: rgba(255, 250, 242, 0.78);
  border: 1px solid rgba(107, 78, 22, 0.08);
  cursor: pointer;
  appearance: none;
}

.raw-quiz-media img {
  display: block;
  width: 100%;
  max-width: 360px;
  max-height: 240px;
  object-fit: contain;
  filter: grayscale(1) sepia(1) saturate(1.65) hue-rotate(-8deg) brightness(1.03) contrast(0.94);
}

.raw-media-lightbox-overlay {
  position: fixed;
  inset: 0;
  z-index: 72;
  display: grid;
  place-items: center;
  padding: 24px;
  background: rgba(75, 47, 33, 0.28);
  backdrop-filter: blur(4px);
}

.raw-media-lightbox-overlay--anchored {
  position: absolute;
  place-items: start;
  min-height: 100%;
  height: auto;
  padding: 0;
  background: rgba(75, 47, 33, 0.22);
}

.raw-media-lightbox-window {
  position: relative;
  width: min(1080px, calc(100vw - 32px));
  max-height: calc(100vh - 32px);
  border-radius: 30px;
  background: rgba(247, 234, 204, 0.98);
  border: 1px solid rgba(107, 78, 22, 0.16);
  box-shadow: 0 28px 56px rgba(75, 47, 33, 0.22);
  overflow: hidden;
}

.raw-media-lightbox-overlay--anchored .raw-media-lightbox-window {
  position: absolute;
  left: var(--raw-media-anchor-left, 16px);
  top: var(--raw-media-anchor-top, 16px);
  width: min(860px, calc(100vw - 32px));
  max-height: calc(100vh - 32px);
  box-shadow: 0 22px 48px rgba(75, 47, 33, 0.24);
}

.raw-media-lightbox-stack {
  display: grid;
  gap: 14px;
  padding: 28px;
}

.raw-media-lightbox-overlay--anchored .raw-media-lightbox-stack {
  gap: 10px;
  padding: 20px;
}

.raw-media-lightbox-top h3 {
  margin: 0;
  color: var(--bg);
  font-size: clamp(1.24rem, 2vw, 1.8rem);
}

.raw-media-lightbox-frame {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
}

.raw-media-lightbox-asset {
  min-height: min(68vh, 680px);
  padding: 16px;
  border-radius: 24px;
  background: rgba(255, 250, 242, 0.94);
  border: 1px solid rgba(107, 78, 22, 0.08);
  display: grid;
  place-items: center;
}

.raw-media-lightbox-overlay--anchored .raw-media-lightbox-asset {
  min-height: min(54vh, 520px);
  padding: 12px;
}

.raw-media-lightbox-asset.video-slide {
  padding: 20px;
}

.raw-media-lightbox-image {
  display: block;
  max-width: 100%;
  max-height: min(62vh, 620px);
  object-fit: contain;
  filter: grayscale(1) sepia(1) saturate(1.65) hue-rotate(-8deg) brightness(1.03) contrast(0.94);
}

.raw-media-lightbox-overlay--anchored .raw-media-lightbox-image {
  max-height: min(48vh, 470px);
}

.raw-media-lightbox-image.original-color {
  filter: none;
}

/* Online layout hardening: keep the header chrome stacked and prevent the score board from covering the title on very wide screens. */
body.is-online-mode .hero-layout {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  min-height: 0;
  gap: clamp(8px, 1.1vw, 18px);
}

body.is-online-mode .hero-links {
  order: 1;
  display: flex;
  width: 100%;
  justify-content: center;
  align-items: center;
  gap: clamp(8px, 1vw, 14px);
}

body.is-online-mode .hero-copy {
  order: 2;
  width: 100%;
  text-align: center;
  position: relative;
  z-index: 2;
}

body.is-online-mode .hero-stats {
  order: 3;
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 100%;
  justify-self: stretch;
}

body.is-online-mode .hero-best-strip {
  box-sizing: border-box;
  width: 100%;
  max-width: 100%;
  margin-top: 4px;
  transform: none;
}

body.is-online-mode .hero-best-card {
  transform: none;
}

body.is-online-mode .online-live-sidebar-card {
  font-size: 0.82rem;
  gap: 10px;
}

.online-room-list-compact,
.online-room-game-group {
  display: grid;
  gap: 8px;
}

.online-room-game-group h4 {
  margin: 0;
  color: var(--bg);
  font-size: 0.78rem;
  font-weight: 1000;
  letter-spacing: 0.07em;
  text-transform: uppercase;
}

.online-room-empty {
  margin: 0;
  color: var(--ink-soft);
  font-size: 0.78rem;
  font-weight: 850;
}

body.is-online-mode .online-room-mini {
  gap: 8px;
  padding: 10px;
  border-radius: 14px;
  font-size: 0.76rem;
}

body.is-online-mode .online-room-mini .button {
  min-width: 0;
  padding: 8px 11px;
  font-size: 0.76rem;
}

.live-waiting-overlay,
.live-launch-overlay {
  position: fixed;
  inset: 0;
  z-index: 68;
  display: grid;
  place-items: center;
  min-height: 100dvh;
  padding: clamp(16px, 2vw, 28px);
  background: rgba(75, 47, 33, 0.28);
  backdrop-filter: blur(7px);
}

.live-waiting-overlay {
  height: 100dvh;
  place-items: start center;
  overflow-y: auto;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
}

.live-launch-overlay {
  overflow: hidden;
}

.live-waiting-window {
  width: min(1180px, calc(100vw - 28px));
  max-height: none;
  margin: 0 0 clamp(28px, 4vh, 56px);
  overflow: visible;
  display: grid;
  gap: 16px;
  padding: clamp(18px, 2.2vw, 30px);
  border-radius: 32px;
  border: 1px solid rgba(107, 78, 22, 0.2);
  background:
    radial-gradient(circle at top left, rgba(255, 250, 242, 0.86), transparent 42%),
    linear-gradient(180deg, rgba(247, 234, 204, 0.98), rgba(236, 214, 165, 0.98));
  box-shadow: 0 34px 70px rgba(75, 47, 33, 0.26);
}

.live-waiting-top {
  display: grid;
  gap: 6px;
}

.live-waiting-top h2 {
  margin: 0;
  color: var(--bg);
  font-size: clamp(2rem, 4vw, 3.6rem);
  line-height: 0.95;
}

.live-waiting-top p {
  margin: 0;
  color: var(--ink-soft);
  font-weight: 850;
}

.live-waiting-channel {
  display: grid;
  gap: 12px;
}

.live-waiting-channel .channel-browser {
  box-shadow: 0 18px 44px rgba(75, 47, 33, 0.18);
}

.live-waiting-channel-actions .button {
  min-height: 54px;
  display: grid;
  gap: 2px;
  justify-items: center;
}

.live-waiting-channel-actions .button span {
  font-weight: 950;
}

.live-waiting-channel-actions .button small {
  max-width: 100%;
  overflow: hidden;
  color: currentColor;
  font-size: 0.68rem;
  font-weight: 800;
  opacity: 0.72;
  text-overflow: ellipsis;
  white-space: nowrap;
}

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

.live-waiting-video-card {
  display: grid;
  gap: 8px;
  padding: 10px;
  border-radius: 18px;
  border: 1px solid rgba(107, 78, 22, 0.12);
  background: rgba(255, 252, 242, 0.72);
}

.live-waiting-video-card strong {
  color: var(--bg);
  font-size: 0.82rem;
  line-height: 1.15;
}

.live-waiting-video-frame {
  aspect-ratio: 16 / 9;
  overflow: hidden;
  border-radius: 14px;
  background: #000;
}

.live-waiting-actions {
  justify-content: center;
}

.live-launch-overlay {
  z-index: 72;
  background:
    radial-gradient(circle at center, rgba(255, 241, 205, 0.9), rgba(75, 47, 33, 0.34));
}

.live-launch-number {
  color: #4f321d;
  font-family: "Cardo", Georgia, serif;
  font-size: clamp(5rem, 18vw, 18rem);
  font-weight: 900;
  line-height: 0.85;
  text-shadow: 0 16px 28px rgba(75, 47, 33, 0.2);
  animation: liveLaunchMelt 850ms ease forwards;
}

@keyframes liveLaunchMelt {
  0% {
    opacity: 0;
    transform: scale(1.18);
    filter: blur(8px);
  }
  42% {
    opacity: 1;
    filter: blur(0);
  }
  100% {
    opacity: 0.18;
    transform: scale(0.72) translateY(28px);
    filter: blur(2px);
  }
}

.live-answer-feedback {
  margin: 0;
  padding: 12px 14px;
  border-radius: 16px;
  font-weight: 950;
}

.live-answer-feedback.correct {
  color: #235c36;
  background: rgba(89, 180, 111, 0.2);
}

.live-answer-feedback.wrong {
  color: #7a2d22;
  background: rgba(209, 94, 68, 0.16);
}

@media (max-width: 860px) {
  .live-waiting-video-grid {
    grid-template-columns: 1fr;
  }
}

.raw-media-lightbox-video-wrap {
  width: min(100%, 900px);
  aspect-ratio: 16 / 9;
  border-radius: 18px;
  overflow: hidden;
  background: #000;
  box-shadow: inset 0 0 0 1px rgba(107, 78, 22, 0.08);
}

.raw-media-lightbox-iframe {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}

.raw-media-lightbox-asset.link-slide {
  align-items: stretch;
}

.raw-media-lightbox-link-slide {
  width: min(100%, 720px);
  min-height: min(52vh, 520px);
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 14px;
  text-align: center;
  padding: 20px;
}

.raw-media-lightbox-link-slide h4 {
  margin: 0;
  color: var(--bg);
  font-size: clamp(1.2rem, 2.2vw, 2rem);
}

.raw-media-lightbox-meta {
  display: grid;
  gap: 12px;
  justify-items: center;
}

.raw-media-lightbox-link-list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
}

.raw-media-lightbox-note {
  margin: 0;
  color: var(--ink-soft);
  font-size: 1rem;
  line-height: 1.6;
  text-align: center;
}

.raw-media-lightbox-link-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 10px 16px;
  border-radius: 999px;
  border: 1px solid rgba(107, 78, 22, 0.16);
  background: rgba(236, 205, 171, 0.58);
  color: var(--bg);
  font-weight: 800;
  text-decoration: none;
}

.raw-media-lightbox-link-button:hover {
  background: rgba(236, 205, 171, 0.8);
  border-color: rgba(138, 99, 56, 0.34);
}

.raw-media-lightbox-video-preview {
  width: min(100%, 860px);
  display: grid;
  gap: 18px;
  align-items: center;
}

.raw-media-lightbox-video-thumb {
  display: block;
  width: 100%;
  max-height: min(52vh, 520px);
  object-fit: cover;
  border-radius: 18px;
  box-shadow: 0 16px 32px rgba(65, 42, 23, 0.12);
}

.raw-media-lightbox-video-copy {
  display: grid;
  gap: 12px;
  justify-items: center;
  text-align: center;
}

.raw-media-lightbox-nav {
  width: 54px;
  height: 54px;
  border: none;
  border-radius: 50%;
  background: rgba(200, 156, 68, 0.28);
  color: var(--bg);
  font-size: 2rem;
  line-height: 1;
  cursor: pointer;
}

.raw-media-lightbox-footer {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  color: var(--ink-soft);
  font-size: 0.95rem;
}

.raw-quiz-options {
  display: grid;
  gap: 10px;
}

.raw-quiz-option {
  display: grid;
  grid-template-columns: 38px minmax(0, 1fr);
  align-items: center;
  gap: 12px;
  width: 100%;
  min-height: 52px;
  padding: 10px 12px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.38);
  border: 1px solid rgba(107, 78, 22, 0.1);
  text-align: center;
  cursor: pointer;
  color: inherit;
  font: inherit;
  appearance: none;
}

.raw-quiz-option:hover {
  border-color: rgba(138, 99, 56, 0.2);
  background: rgba(255, 255, 255, 0.48);
}

.raw-quiz-option:focus-visible {
  outline: 3px solid rgba(200, 156, 68, 0.28);
  outline-offset: 2px;
}

.raw-quiz-option.revealed-correct {
  background: rgba(225, 196, 119, 0.24);
  border-color: rgba(138, 99, 56, 0.18);
}

.raw-quiz-option.revealed-selected {
  background: rgba(196, 162, 130, 0.28);
  border-color: rgba(122, 90, 51, 0.3);
}

.raw-quiz-option.revealed-wrong {
  opacity: 0.82;
}

.raw-quiz-option.revealed-wrong span:last-child,
.raw-quiz-option.revealed-selected span:last-child {
  text-decoration: line-through;
  font-style: italic;
}

.raw-link {
  white-space: nowrap;
}

.challenge-mascot .checkpoint-visual-slot {
  width: min(132px, 100%);
}

.alpaca-avatar {
  --alpaca-size: 82px;
  position: relative;
  width: var(--alpaca-size);
  height: calc(var(--alpaca-size) * 0.92);
  display: inline-block;
}

.alpaca-avatar.small {
  --alpaca-size: 52px;
}

.alpaca-avatar.medium {
  --alpaca-size: 88px;
}

.alpaca-avatar.large {
  --alpaca-size: 118px;
}

.alpaca-avatar.hero {
  --alpaca-size: 180px;
}

.alpaca-ear {
  position: absolute;
  top: 4%;
  width: 16%;
  height: 28%;
  border-radius: 999px;
  background: #f2d8b7;
  border: 3px solid var(--bg);
  z-index: 1;
}

.alpaca-ear.left {
  left: 16%;
  transform: rotate(-18deg);
}

.alpaca-ear.right {
  right: 16%;
  transform: rotate(18deg);
}

.alpaca-fluff {
  position: absolute;
  left: 25%;
  right: 25%;
  top: 12%;
  height: 18%;
  border-radius: 999px 999px 18px 18px;
  background: #fff5e7;
  border: 3px solid var(--bg);
  z-index: 2;
}

.alpaca-face {
  position: absolute;
  inset: 18% 18% 6%;
  border-radius: 44% 44% 42% 42%;
  background: #fff7ea;
  border: 3px solid var(--bg);
  z-index: 3;
}

.alpaca-snout {
  position: absolute;
  left: 26%;
  right: 26%;
  bottom: 16%;
  height: 28%;
  border-radius: 999px;
  background: #f2d8b7;
  border: 3px solid var(--bg);
}

.alpaca-eye {
  position: absolute;
  top: 34%;
  width: 10%;
  height: 10%;
  border-radius: 50%;
  background: var(--ink);
}

.alpaca-eye.left {
  left: 28%;
}

.alpaca-eye.right {
  right: 28%;
}

.alpaca-mouth {
  position: absolute;
  left: 38%;
  width: 24%;
  bottom: 20%;
}

.alpaca-avatar.happy .alpaca-mouth {
  height: 14%;
  border-bottom: 3px solid var(--ink);
  border-radius: 0 0 999px 999px;
}

.alpaca-avatar.sad .alpaca-mouth {
  height: 14%;
  border-top: 3px solid var(--ink);
  border-radius: 999px 999px 0 0;
}

.alpaca-avatar.determined .alpaca-mouth,
.alpaca-avatar.wise .alpaca-mouth {
  height: 0;
  border-top: 3px solid var(--ink);
}

.alpaca-tear {
  position: absolute;
  top: 42%;
  right: 18%;
  width: 9%;
  height: 16%;
  border-radius: 999px 999px 999px 999px;
  background: rgba(185, 137, 83, 0.72);
  opacity: 0;
}

.alpaca-avatar.sad .alpaca-tear {
  opacity: 1;
}

.alpaca-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 999px;
  background: rgba(247, 234, 204, 0.5);
  color: var(--ink);
  font-weight: 700;
}

@media (max-width: 1120px) {
  .slide-shell,
  .challenge-card,
  .feedback-card,
  .result-banner,
  .mindmap-center,
  .race-shell {
    grid-template-columns: 1fr;
  }

  .hero-layout {
    grid-template-columns: 1fr;
    grid-template-rows: auto;
    justify-items: center;
  }

  .hero-links {
    justify-items: center;
  }

  .hero-progress-circles,
  .hero-best-strip {
    grid-column: 1;
    grid-row: auto;
    width: min(100%, 980px);
    justify-self: center;
  }

  .result-metrics,
  .breakdown-columns,
  .run-status-row,
  .auth-form-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

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

  .hero h1,
  .hero-route-title,
  .lead {
    white-space: normal;
  }

  .hero-best-strip {
    grid-template-columns: repeat(5, minmax(132px, 1fr));
  }

  .wizard-rail-mount {
    width: 100%;
  }

  .section-heading {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  .page-shell {
    width: min(100vw - 16px, 1340px);
    margin-top: 8px;
  }

  .hero,
  .wizard,
  .experience-panel {
    padding: 18px;
  }

  .step-grid.one,
  .step-grid.two,
  .step-grid.three,
  .step-grid.four,
  .step-grid.five,
  .result-metrics,
  .breakdown-columns,
  .run-status-row,
  .auth-form-grid,
  .alpaccount-brand {
    grid-template-columns: 1fr;
  }

  .step-grid.five > .mode-card,
  .step-grid.five > .mode-card:nth-last-child(-n + 2) {
    grid-column: auto;
  }

  .race-question-pills {
    grid-template-columns: 1fr;
  }

  .answer-options-grid,
  .raw-quiz-options {
    grid-template-columns: 1fr;
    grid-template-rows: none;
    grid-auto-flow: row;
  }

  .run-inline-shell {
    left: 50%;
    right: auto;
    transform: translate(-50%, -50%);
  }

  .run-inline-card {
    grid-template-columns: 1fr;
  }

  .alpacard-meta-row strong {
    width: 100%;
    margin-left: 0;
  }

  .alpacard-shell {
    padding: 12px;
    border-radius: 20px;
  }

  .alpacard-stage {
    height: min(72vh, 620px);
    min-height: 440px;
  }

  .alpacard-card {
    padding: 12px;
    border-radius: 18px;
  }

  .alpacard-image-wrap {
    min-height: 0;
  }

  .alpacard-back-heading h3 {
    font-size: 1.75rem;
  }

  .alpacard-back-grid {
    grid-template-columns: 1fr;
  }

  .alpacard-nav-button {
    width: 38px;
    height: 38px;
  }

  .alpacard-nav-button--previous {
    left: 8px;
  }

  .alpacard-nav-button--next {
    right: 8px;
  }

  .alpacard-thumbnail-track {
    height: 66px;
  }

  .alpacard-thumb {
    width: 32px;
    height: 66px;
  }

  .alpacard-thumb.is-active {
    width: 104px;
  }

  .run-inline-footer {
    grid-column: 1;
    grid-row: auto;
  }

  .jump-stage {
    min-height: 520px;
    border-radius: 20px;
  }

  .jump-hud {
    padding: 12px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 6px;
  }

  .jump-hud-card {
    min-height: auto;
    padding: 9px 8px;
  }

  .jump-hud-card span {
    margin-bottom: 6px;
    font-size: 0.58rem;
  }

  .jump-hud-card strong {
    font-size: 0.95rem;
  }

  .jump-lives {
    gap: 2px;
  }

  .jump-lives .race-life {
    width: 23px;
    height: 23px;
  }

  .jump-runner {
    left: 6%;
    width: clamp(96px, 29vw, 132px);
  }

  .jump-obstacle {
    width: clamp(62px, 19vw, 86px);
    height: clamp(54px, 17vw, 72px);
  }

  .jump-controls {
    left: 10px;
    right: 10px;
    bottom: 10px;
  }

  .jump-controls .button {
    min-width: 92px;
    padding-inline: 14px;
  }

  .jump-question-card .options-grid {
    grid-template-columns: 1fr;
  }

  .progress-circle-card {
    width: 100%;
  }

  .hero-best-strip {
    display: flex;
    overflow-x: auto;
    padding-bottom: 4px;
    scroll-snap-type: x proximity;
  }

  .hero-best-card {
    flex: 0 0 158px;
    scroll-snap-align: start;
  }

  .mindmap-radial-scroll {
    height: min(74vh, 680px);
    min-height: 460px;
    padding: 10px;
    border-radius: 28px;
  }

  .alpaccount-brand {
    justify-items: center;
    text-align: center;
  }

  .alpaccount-brand img {
    width: 118px;
  }

  .mode-topbar,
  .panel-title,
  .step-page-header {
    grid-template-columns: 1fr;
  }

  .step-page-header {
    display: grid;
    justify-content: stretch;
  }

  .route-back-button {
    width: min(100%, 320px);
  }

  .hero-note-row,
  .hero-actions,
  .panel-actions,
  .slide-actions,
  .channel-actions,
  .feedback-actions,
  .result-actions,
  .run-actions,
  .relay-toolbar {
    flex-direction: column;
    align-items: stretch;
  }

  .run-map-stage {
    min-height: 520px;
  }

  .run-inline-shell {
    top: 48%;
    width: calc(100% - 28px);
    left: 50%;
    right: auto;
    transform: translate(-50%, -50%);
  }

  .run-inline-card {
    padding: 16px;
  }

  .question-popup-overlay {
    padding: 14px;
    align-items: end;
  }

  .question-popup-window {
    width: min(100%, calc(100vw - 20px));
    max-height: calc(100vh - 18px);
    padding: 14px;
    border-radius: 22px;
  }

  .relay-popup-team-header {
    display: grid;
  }

  .relay-popup-team-toprow {
    grid-template-columns: 1fr;
  }

  .relay-popup-team-grid,
  .relay-popup-team-grid.solo {
    grid-template-columns: 1fr;
  }

  .mindmap-branch-row {
    grid-template-columns: 1fr;
  }

  .channel-empty {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .channel-empty-icon-slot {
    width: min(150px, 52vw);
    justify-self: center;
  }

  .panel-title:has(.channel-panel-title-brand) {
    min-height: 0;
  }

  .channel-panel-title-brand {
    flex-wrap: wrap;
    justify-content: center;
  }

  .channel-panel-section-chip {
    position: static;
    max-width: 100%;
    transform: none;
  }

  .channel-browser-bar {
    grid-template-columns: auto minmax(0, 1fr);
  }

  .channel-address-pill {
    max-width: none;
  }

  .channel-video-frame {
    margin-inline: 12px;
  }

  .channel-browser-footer {
    grid-template-columns: minmax(0, 0.92fr) auto minmax(0, 0.92fr);
    gap: 6px;
    padding: 0 12px 14px;
  }

  .channel-nav-button {
    min-height: 38px;
    padding: 6px 7px;
    border-radius: 12px;
  }

  .channel-nav-label {
    font-size: 0.66rem;
  }

  .channel-nav-title {
    font-size: 0.56rem;
  }

  .channel-actions {
    grid-template-columns: 1fr;
  }

  .mindmap-branch-line {
    height: 5px;
  }

  .mindmap-branch-node {
    justify-items: center;
  }

  .popup-question-panel {
    grid-template-columns: 1fr;
  }

  .popup-question-timer {
    justify-content: start;
  }

  .raw-source-top,
  .raw-atom-top {
    display: grid;
  }

  .raw-mastery-row {
    display: grid;
    justify-items: stretch;
  }

  .raw-entry-back-to-top {
    width: 58px;
    justify-self: start;
  }

  .raw-mastery-toggle {
    width: 100%;
    min-width: 0;
  }

  .raw-section-grid {
    grid-template-columns: 1fr;
  }
}

/* Local May 9 art pass: wallpaper, museum frames, and a looser route layout. */
.hero,
.wizard.card-panel {
  background: transparent;
  border: 0;
  box-shadow: none;
  overflow: visible;
}

.hero::after,
.step-panel::after {
  display: none;
}

.wizard.card-panel {
  padding-inline: clamp(10px, 2vw, 24px);
}

.step-panel {
  overflow: visible;
  padding: clamp(10px, 1.6vw, 20px);
  border: 0;
  background: transparent;
  box-shadow: none;
}

.wizard-steps {
  overflow: visible;
}

.wizard-rail-item,
.hero-stats .stat-card,
.hero-best-card {
  --header-frame: var(--frame-header-wide-a);
  position: relative;
  isolation: isolate;
  overflow: visible;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.wizard-rail-item::before,
.hero-stats .stat-card::before,
.hero-best-card::before {
  content: "";
  position: absolute;
  inset: -12px;
  z-index: 1;
  pointer-events: none;
  background-image: var(--header-frame);
  background-position: center;
  background-repeat: no-repeat;
  background-size: 100% 100%;
  filter: drop-shadow(0 12px 14px rgba(65, 42, 23, 0.13));
}

.wizard-rail-item::after,
.hero-stats .stat-card::after,
.hero-best-card::after {
  content: "";
  position: absolute;
  inset: 18px;
  z-index: 0;
  border-radius: 16px;
  background:
    radial-gradient(circle at top left, rgba(255, 250, 238, 0.74), transparent 52%),
    rgba(247, 234, 204, 0.46);
  pointer-events: none;
}

.wizard-rail-item > *,
.hero-stats .stat-card > *,
.hero-best-card > * {
  position: relative;
  z-index: 2;
}

.wizard-rail-item {
  min-width: 184px;
  min-height: 76px;
  padding: 20px 24px;
}

.wizard-rail-item:nth-child(1),
.hero-best-card:nth-child(1),
.hero-stats .stat-card:nth-child(1) {
  --header-frame: var(--frame-header-wide-a);
}

.wizard-rail-item:nth-child(2),
.hero-best-card:nth-child(2),
.hero-stats .stat-card:nth-child(2) {
  --header-frame: var(--frame-header-wide-b);
}

.wizard-rail-item:nth-child(3),
.hero-best-card:nth-child(3) {
  --header-frame: var(--frame-header-wide-c);
}

.wizard-rail-item:nth-child(4),
.hero-best-card:nth-child(4) {
  --header-frame: var(--frame-header-wide-d);
}

.hero-best-card:nth-child(5) {
  --header-frame: var(--frame-header-wide-e);
}

.choice-card,
.target-card,
.mode-card {
  --card-frame: var(--frame-card-wide-a);
  --card-tilt: 0deg;
  --card-x: 0;
  --card-y: 0;
  position: relative;
  isolation: isolate;
  overflow: visible;
  min-height: 170px;
  padding: clamp(26px, 3vw, 42px);
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.choice-card::before,
.target-card::before,
.mode-card::before {
  content: "";
  position: absolute;
  inset: -14px;
  z-index: 1;
  pointer-events: none;
  background-image: var(--card-frame);
  background-position: center;
  background-repeat: no-repeat;
  background-size: 100% 100%;
  filter: drop-shadow(0 16px 20px rgba(65, 42, 23, 0.14));
}

.choice-card::after,
.target-card::after,
.mode-card::after {
  content: "";
  position: absolute;
  inset: clamp(18px, 5%, 28px);
  z-index: 0;
  border-radius: 20px;
  background:
    radial-gradient(circle at top right, rgba(255, 250, 238, 0.64), transparent 52%),
    linear-gradient(180deg, rgba(247, 234, 204, 0.54), rgba(235, 211, 158, 0.36));
  pointer-events: none;
}

.choice-card > *,
.target-card > *,
.mode-card > * {
  position: relative;
  z-index: 2;
}

.choice-card.active,
.target-card.active,
.mode-card.active {
  box-shadow: none;
}

.choice-card.active::before,
.target-card.active::before,
.mode-card.active::before {
  filter:
    drop-shadow(0 18px 22px rgba(65, 42, 23, 0.18))
    saturate(1.16)
    brightness(1.04);
}

.choice-card:focus-visible,
.target-card:focus-visible,
.mode-card:focus-visible,
.wizard-rail-item:focus-visible {
  outline: 3px solid rgba(200, 156, 68, 0.56);
  outline-offset: 8px;
}

.wizard-choice-card:nth-child(1) {
  --card-frame: var(--frame-card-wide-a);
  --card-tilt: -1.4deg;
  --card-x: -1%;
  --card-y: 2%;
}

.wizard-choice-card:nth-child(2) {
  --card-frame: var(--frame-card-wide-b);
  --card-tilt: 1.8deg;
  --card-x: 2%;
  --card-y: -1%;
}

.wizard-choice-card:nth-child(3) {
  --card-frame: var(--frame-card-wide-c);
  --card-tilt: -0.8deg;
  --card-x: -2%;
  --card-y: 6%;
}

.wizard-choice-card:nth-child(4) {
  --card-frame: var(--frame-card-wide-d);
  --card-tilt: 1.2deg;
  --card-x: 3%;
  --card-y: -3%;
}

.wizard-choice-card:nth-child(5) {
  --card-frame: var(--frame-card-wide-e);
  --card-tilt: -1.1deg;
  --card-x: -3%;
  --card-y: 3%;
}

.wizard-choice-card:nth-child(6) {
  --card-frame: var(--frame-card-square-a);
  --card-tilt: 1.5deg;
  --card-x: 1%;
  --card-y: 4%;
}

@media (min-width: 861px) {
  .step-grid {
    grid-template-columns: repeat(12, minmax(0, 1fr));
    grid-auto-rows: clamp(20px, 1.75vw, 27px);
    grid-auto-flow: dense;
    gap: clamp(10px, 1.1vw, 18px);
    align-items: stretch;
    min-height: clamp(340px, 39vw, 540px);
    padding: clamp(10px, 1.2vw, 20px) clamp(6px, 1vw, 18px) clamp(28px, 3vw, 44px);
  }

  .step-grid.one,
  .step-grid.two,
  .step-grid.three,
  .step-grid.four,
  .step-grid.five {
    grid-template-columns: repeat(12, minmax(0, 1fr));
  }

  .step-grid > .wizard-choice-card {
    height: auto;
    min-height: 0;
    transform: translate(var(--card-x), var(--card-y)) rotate(var(--card-tilt));
    transform-origin: center;
  }

  .step-grid > .wizard-choice-card:hover {
    transform: translate(var(--card-x), calc(var(--card-y) - 4px)) rotate(var(--card-tilt));
  }

  .step-grid.one > .wizard-choice-card:nth-child(1) {
    grid-column: 4 / span 6;
    grid-row: 2 / span 9;
  }

  .step-grid.two > .wizard-choice-card:nth-child(1) {
    grid-column: 1 / span 5;
    grid-row: 3 / span 8;
  }

  .step-grid.two > .wizard-choice-card:nth-child(2) {
    grid-column: 7 / span 6;
    grid-row: 6 / span 9;
  }

  .step-grid.three > .wizard-choice-card:nth-child(1) {
    grid-column: 1 / span 4;
    grid-row: 5 / span 8;
  }

  .step-grid.three > .wizard-choice-card:nth-child(2) {
    grid-column: 5 / span 4;
    grid-row: 2 / span 8;
  }

  .step-grid.three > .wizard-choice-card:nth-child(3) {
    grid-column: 9 / span 4;
    grid-row: 6 / span 8;
  }

  .step-grid.four > .wizard-choice-card:nth-child(1) {
    grid-column: 1 / span 4;
    grid-row: 5 / span 8;
  }

  .step-grid.four > .wizard-choice-card:nth-child(2) {
    grid-column: 4 / span 4;
    grid-row: 1 / span 8;
  }

  .step-grid.four > .wizard-choice-card:nth-child(3) {
    grid-column: 8 / span 5;
    grid-row: 4 / span 8;
  }

  .step-grid.four > .wizard-choice-card:nth-child(4) {
    grid-column: 3 / span 6;
    grid-row: 13 / span 8;
  }

  .step-grid.five > .mode-card,
  .step-grid.five > .mode-card:nth-last-child(-n + 2) {
    grid-column: auto;
  }

  .step-grid.five > .wizard-choice-card:nth-child(1) {
    grid-column: 1 / span 4;
    grid-row: 4 / span 8;
  }

  .step-grid.five > .wizard-choice-card:nth-child(2) {
    grid-column: 5 / span 4;
    grid-row: 1 / span 8;
  }

  .step-grid.five > .wizard-choice-card:nth-child(3) {
    grid-column: 9 / span 4;
    grid-row: 5 / span 8;
  }

  .step-grid.five > .wizard-choice-card:nth-child(4) {
    grid-column: 2 / span 5;
    grid-row: 14 / span 8;
  }

  .step-grid.five > .wizard-choice-card:nth-child(5) {
    grid-column: 7 / span 5;
    grid-row: 12 / span 8;
  }
}

@media (max-width: 860px) {
  .wizard-rail-items {
    padding: 8px 4px;
  }

  .wizard-rail-item {
    min-width: 188px;
  }

  .choice-card,
  .target-card,
  .mode-card {
    min-height: 158px;
  }
}

/* Local May 9 refinement: sharp dark frames, grouped header stats, no overlapping card grid. */
:root {
  --frame-ink: #3d2113;
  --frame-ink-soft: rgba(61, 33, 19, 0.72);
  --frame-paper-line: rgba(236, 217, 176, 0.76);
  --frame-fill: rgba(250, 239, 210, 0.5);
}

.hero {
  padding: 28px;
  border-radius: 0;
  border: 1px solid rgba(107, 78, 22, 0.14);
  background:
    radial-gradient(circle at top center, rgba(255, 241, 208, 0.34), transparent 30%),
    linear-gradient(180deg, rgba(247, 236, 205, 0.92) 0%, rgba(229, 205, 153, 0.88) 54%, rgba(171, 126, 78, 0.82) 100%);
  box-shadow: 0 20px 42px rgba(65, 42, 23, 0.13);
  overflow: visible;
}

.hero-copy {
  text-align: center;
}

.hero h1 {
  color: var(--frame-ink);
}

.hero-progress-circles,
.hero-best-strip,
.wizard-rail-item,
.choice-card,
.target-card,
.mode-card {
  --frame-padding: 18px;
  --frame-line: 4px;
  position: relative;
  isolation: isolate;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.hero-progress-circles::before,
.hero-best-strip::before,
.wizard-rail-item::before,
.choice-card::before,
.target-card::before,
.mode-card::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  border: var(--frame-line) solid var(--frame-ink);
  background: transparent;
  box-shadow:
    inset 0 0 0 2px var(--frame-paper-line),
    inset 0 0 0 8px var(--frame-ink),
    inset 0 0 0 10px var(--frame-paper-line),
    0 12px 20px rgba(65, 42, 23, 0.13);
  filter: none;
}

.hero-progress-circles::after,
.hero-best-strip::after,
.wizard-rail-item::after,
.choice-card::after,
.target-card::after,
.mode-card::after {
  content: "";
  position: absolute;
  inset: var(--frame-padding);
  z-index: 0;
  border-radius: 0;
  background:
    radial-gradient(circle at top left, rgba(255, 250, 238, 0.52), transparent 48%),
    var(--frame-fill);
  box-shadow: inset 0 0 0 1px rgba(61, 33, 19, 0.08);
  pointer-events: none;
}

.hero-progress-circles > *,
.hero-best-strip > *,
.wizard-rail-item > *,
.choice-card > *,
.target-card > *,
.mode-card > * {
  position: relative;
  z-index: 2;
}

.hero-progress-circles {
  --frame-padding: 18px;
  width: min(100%, 360px);
  min-height: 190px;
  padding: 34px 34px 32px;
  gap: 12px;
  align-content: center;
}

.hero-stats .stat-card,
.hero-best-card {
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.hero-stats .stat-card::before,
.hero-stats .stat-card::after,
.hero-best-card::before,
.hero-best-card::after {
  display: none;
}

.progress-circle-card {
  width: 100%;
  padding: 6px 0;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 14px;
}

.stat-progress-ring {
  width: 74px;
  height: 74px;
}

.stat-progress-ring-inner {
  width: 54px;
  height: 54px;
}

.stat-progress-circle-copy span,
.hero-best-card span {
  color: rgba(61, 33, 19, 0.68);
}

.hero-best-strip {
  --frame-padding: 17px;
  width: min(100%, 980px);
  min-height: 108px;
  padding: 30px 34px;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  align-items: stretch;
  gap: 0;
}

.hero-best-card {
  min-height: 0;
  padding: 0 16px;
  align-content: center;
  border-left: 1px solid rgba(61, 33, 19, 0.18);
}

.hero-best-card:first-child {
  border-left: 0;
}

.wizard-rail-items {
  gap: 16px;
}

.wizard-rail-item {
  --frame-padding: 13px;
  --frame-line: 3px;
  min-width: 176px;
  min-height: 72px;
  padding: 21px 22px;
}

.wizard-rail-item.active {
  background: transparent;
}

.wizard-rail-item.upcoming {
  opacity: 0.58;
}

.wizard-rail-dot {
  background: rgba(61, 33, 19, 0.16);
  border-color: rgba(61, 33, 19, 0.26);
}

.wizard-rail-item.done .wizard-rail-dot,
.wizard-rail-item.active .wizard-rail-dot {
  background: var(--frame-ink);
  border-color: rgba(61, 33, 19, 0.28);
}

.wizard.card-panel,
.step-panel {
  background: transparent;
  border: 0;
  box-shadow: none;
}

.wizard.card-panel {
  padding-block: 18px 28px;
}

.section-heading {
  align-items: start;
}

.section-heading h2 {
  color: var(--frame-ink);
  line-height: 0.95;
}

.step-panel {
  padding: 0;
}

.step-top {
  justify-content: center;
  margin: 8px 0 20px;
}

.choice-card,
.target-card,
.mode-card {
  --frame-padding: clamp(17px, 2vw, 23px);
  --frame-line: 4px;
  min-height: 184px;
  padding: clamp(26px, 3.2vw, 44px);
}

.choice-card:hover,
.target-card:hover,
.mode-card:hover {
  transform: translateY(-3px) rotate(var(--card-tilt));
}

.choice-card.active::before,
.target-card.active::before,
.mode-card.active::before {
  box-shadow:
    inset 0 0 0 2px var(--frame-paper-line),
    inset 0 0 0 8px var(--frame-ink),
    inset 0 0 0 10px var(--frame-paper-line),
    0 16px 24px rgba(65, 42, 23, 0.18);
}

.wizard-choice-card .card-top {
  display: grid;
  height: 100%;
  min-height: 100%;
  gap: 12px;
  align-items: center;
  justify-items: center;
  padding: 0;
  text-align: center;
}

.wizard-choice-slot {
  position: static;
  width: clamp(72px, 8vw, 116px);
  height: clamp(64px, 7vw, 106px);
  min-height: 0;
  z-index: 2;
}

.wizard-choice-slot .asset-image,
.wizard-choice-slot .mascot-asset {
  width: 100%;
  height: 100%;
  max-width: 100%;
  max-height: 100%;
  min-width: 0;
  min-height: 0;
  object-fit: contain;
  object-position: center;
}

.wizard-choice-copy {
  width: 100%;
  max-width: 100%;
  min-height: 0;
  margin: 0;
  padding: 0;
  display: grid;
  align-items: center;
  justify-items: center;
  text-align: center;
}

.wizard-choice-copy h3,
.target-card .wizard-choice-copy h3,
.mode-card .wizard-choice-copy h3 {
  margin: 0;
  color: #6f4b28;
  font-size: clamp(1rem, 1.45vw, 1.5rem);
  line-height: 1.05;
  text-align: inherit;
}

.mode-card .wizard-choice-copy {
  align-items: center;
  justify-items: center;
}

.mode-card[data-pick-mode="run"] .wizard-choice-slot,
.mode-card[data-pick-mode="jump"] .wizard-choice-slot,
.mode-card[data-pick-mode="buildcase"] .wizard-choice-slot,
.mode-card[data-pick-mode="relay"] .wizard-choice-slot,
.mode-card[data-pick-mode="race"] .wizard-choice-slot {
  transform: none;
}

.wizard-choice-card:nth-child(3n + 1) .card-top {
  grid-template-columns: minmax(70px, 0.72fr) minmax(0, 1fr);
  justify-items: start;
  text-align: right;
}

.wizard-choice-card:nth-child(3n + 1) .wizard-choice-copy {
  justify-items: end;
  text-align: right;
}

.wizard-choice-card:nth-child(3n + 2) .card-top {
  grid-template-rows: auto auto;
  align-content: center;
}

.wizard-choice-card:nth-child(3n + 2) .wizard-choice-slot {
  width: clamp(82px, 9vw, 126px);
  height: clamp(76px, 8vw, 118px);
}

.wizard-choice-card:nth-child(3n) .card-top {
  grid-template-rows: auto auto;
  align-content: center;
}

.wizard-choice-card:nth-child(3n) .wizard-choice-copy {
  order: -1;
}

.wizard-choice-card:nth-child(4n) .card-top {
  grid-template-columns: minmax(0, 1fr) minmax(74px, 0.72fr);
  text-align: left;
}

.wizard-choice-card:nth-child(4n) .wizard-choice-slot {
  order: 2;
  justify-self: end;
}

.wizard-choice-card:nth-child(4n) .wizard-choice-copy {
  order: 1;
  justify-items: start;
  text-align: left;
}

@media (min-width: 861px) {
  .step-grid,
  .step-grid.one,
  .step-grid.two,
  .step-grid.three,
  .step-grid.four,
  .step-grid.five {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(clamp(210px, 22vw, 285px), 1fr));
    grid-auto-rows: auto;
    grid-auto-flow: row;
    gap: clamp(26px, 3vw, 42px) clamp(22px, 2.4vw, 36px);
    min-height: 0;
    padding: 14px clamp(6px, 1vw, 18px) 42px;
    align-items: stretch;
  }

  .step-grid.one {
    grid-template-columns: minmax(260px, 460px);
    justify-content: center;
  }

  .step-grid.two {
    grid-template-columns: repeat(2, minmax(260px, 420px));
    justify-content: center;
  }

  .step-grid.three {
    grid-template-columns: repeat(3, minmax(220px, 1fr));
  }

  .step-grid > .wizard-choice-card,
  .step-grid.five > .mode-card,
  .step-grid.five > .mode-card:nth-last-child(-n + 2),
  .step-grid.one > .wizard-choice-card:nth-child(1),
  .step-grid.two > .wizard-choice-card:nth-child(1),
  .step-grid.two > .wizard-choice-card:nth-child(2),
  .step-grid.three > .wizard-choice-card:nth-child(1),
  .step-grid.three > .wizard-choice-card:nth-child(2),
  .step-grid.three > .wizard-choice-card:nth-child(3),
  .step-grid.four > .wizard-choice-card:nth-child(1),
  .step-grid.four > .wizard-choice-card:nth-child(2),
  .step-grid.four > .wizard-choice-card:nth-child(3),
  .step-grid.four > .wizard-choice-card:nth-child(4),
  .step-grid.five > .wizard-choice-card:nth-child(1),
  .step-grid.five > .wizard-choice-card:nth-child(2),
  .step-grid.five > .wizard-choice-card:nth-child(3),
  .step-grid.five > .wizard-choice-card:nth-child(4),
  .step-grid.five > .wizard-choice-card:nth-child(5) {
    grid-column: auto;
    grid-row: auto;
    min-height: clamp(170px, 15vw, 216px);
  }

  .step-grid > .wizard-choice-card {
    transform: translateY(var(--card-y)) rotate(var(--card-tilt));
  }

  .wizard-choice-card:nth-child(6n + 1) {
    --card-tilt: -1.2deg;
    --card-y: 8px;
  }

  .wizard-choice-card:nth-child(6n + 2) {
    --card-tilt: 0.8deg;
    --card-y: -6px;
  }

  .wizard-choice-card:nth-child(6n + 3) {
    --card-tilt: -0.5deg;
    --card-y: 14px;
  }

  .wizard-choice-card:nth-child(6n + 4) {
    --card-tilt: 1.1deg;
    --card-y: 0px;
  }

  .wizard-choice-card:nth-child(6n + 5) {
    --card-tilt: -0.9deg;
    --card-y: 10px;
  }

  .wizard-choice-card:nth-child(6n) {
    --card-tilt: 0.6deg;
    --card-y: -2px;
  }
}

@media (max-width: 1120px) {
  .hero-progress-circles {
    width: min(100%, 660px);
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .hero {
    padding: 18px;
  }

  .hero-progress-circles {
    width: 100%;
    grid-template-columns: 1fr;
    padding: 30px 28px;
  }

  .hero-best-strip {
    width: 100%;
    display: grid;
    grid-template-columns: 1fr;
    overflow: visible;
    padding: 30px 28px;
  }

  .hero-best-card {
    border-left: 0;
    border-top: 1px solid rgba(61, 33, 19, 0.18);
    padding: 10px 0;
  }

  .hero-best-card:first-child {
    border-top: 0;
  }

  .section-heading {
    gap: 16px;
  }

  .section-heading h2 {
    text-align: left;
  }

  .wizard-rail-items {
    gap: 12px;
    padding: 10px 4px;
  }

  .wizard-rail-item {
    min-width: 196px;
  }

  .step-grid,
  .step-grid.one,
  .step-grid.two,
  .step-grid.three,
  .step-grid.four,
  .step-grid.five {
    gap: 24px;
  }

  .choice-card,
  .target-card,
  .mode-card {
    min-height: 164px;
  }
}

/* Local May 9 follow-up: softer browns, FrameScores header, chevrons, varied SVG card shapes. */
:root {
  --frame-ink: #6d4b2b;
  --frame-ink-soft: rgba(109, 75, 43, 0.66);
  --frame-paper-line: rgba(250, 237, 204, 0.86);
  --frame-fill: rgba(250, 239, 210, 0.54);
  --score-frame: url("./assets/mascot/library/final-pack/FrameScores.png");
  --wood-sign-long: url("./assets/boards/wood_sign_svgs/01_long_banner_01.svg");
  --wood-sign-soft-wide: url("./assets/boards/wood_sign_svgs/04_wide_soft_01.svg");
  --wood-sign-medium: url("./assets/boards/wood_sign_svgs/07_medium_rect_02.svg");
  --wood-sign-square: url("./assets/boards/wood_sign_svgs/10_square_02.svg");
  --wood-sign-portrait: url("./assets/boards/wood_sign_svgs/13_portrait_02.svg");
  --wood-sign-tall: url("./assets/boards/wood_sign_svgs/14_portrait_03.svg");
}

.hero {
  border-radius: 34px;
}

.hero h1 {
  color: #4f321d;
}

.hero-progress-circles::before,
.hero-best-strip::before {
  inset: 0;
  border: 0;
  background-image: var(--score-frame);
  background-position: center;
  background-repeat: no-repeat;
  background-size: 100% 100%;
  box-shadow: none;
  filter:
    drop-shadow(0 14px 18px rgba(65, 42, 23, 0.14))
    saturate(0.74)
    brightness(1.04);
}

.hero-progress-circles::after,
.hero-best-strip::after {
  inset: 28px 34px;
  background:
    radial-gradient(circle at top left, rgba(255, 250, 238, 0.46), transparent 46%),
    rgba(247, 234, 204, 0.42);
}

.hero-progress-circles {
  padding: 44px 46px;
}

.hero-best-strip {
  padding: 42px 76px;
}

.wizard-rail-items {
  gap: 4px;
  align-items: stretch;
}

.wizard-rail-item {
  min-width: 176px;
  min-height: 68px;
  padding: 13px 28px 13px 32px;
  border: 1px solid rgba(138, 99, 56, 0.22);
  background:
    linear-gradient(180deg, rgba(247, 234, 204, 0.78), rgba(235, 213, 170, 0.62));
  clip-path: polygon(0 0, calc(100% - 18px) 0, 100% 50%, calc(100% - 18px) 100%, 0 100%, 16px 50%);
  box-shadow: 0 10px 18px rgba(75, 47, 33, 0.07);
}

.wizard-rail-item:first-child {
  clip-path: polygon(0 0, calc(100% - 18px) 0, 100% 50%, calc(100% - 18px) 100%, 0 100%);
}

.wizard-rail-item::before,
.wizard-rail-item::after {
  display: none;
}

.wizard-rail-item.active {
  background:
    radial-gradient(circle at top right, rgba(200, 156, 68, 0.15), transparent 40%),
    linear-gradient(180deg, rgba(247, 234, 204, 0.96), rgba(236, 217, 170, 0.9));
  border-color: rgba(107, 78, 22, 0.2);
}

.wizard-rail-item.done {
  background:
    linear-gradient(180deg, rgba(245, 232, 199, 0.9), rgba(232, 207, 158, 0.78));
}

.wizard-rail-item.upcoming {
  opacity: 0.74;
}

.wizard-rail-dot {
  width: 14px;
  height: 14px;
  background: rgba(107, 78, 22, 0.18);
  border: 2px solid rgba(107, 78, 22, 0.22);
}

.wizard-rail-item.done .wizard-rail-dot {
  background: rgba(138, 99, 56, 0.82);
  border-color: rgba(138, 99, 56, 0.3);
}

.wizard-rail-item.active .wizard-rail-dot {
  background: var(--gold);
  border-color: rgba(107, 78, 22, 0.26);
}

.wizard-rail-title {
  color: #7c5632;
}

.wizard-rail-value {
  color: rgba(65, 42, 23, 0.68);
}

.step-top {
  display: none;
}

.choice-card,
.target-card,
.mode-card {
  --card-shape: var(--wood-sign-soft-wide);
  --card-inner-inset: 24px;
  --card-tilt: 0deg;
  --card-y: 0px;
  min-height: 0;
  padding: clamp(30px, 3.4vw, 46px);
  border: 0;
}

.choice-card::before,
.target-card::before,
.mode-card::before {
  inset: -2px;
  z-index: 0;
  border: 0;
  background-image: var(--card-shape);
  background-position: center;
  background-repeat: no-repeat;
  background-size: 100% 100%;
  box-shadow: none;
  opacity: 0.7;
  filter:
    sepia(0.12)
    saturate(0.64)
    hue-rotate(350deg)
    brightness(0.94)
    contrast(0.82)
    drop-shadow(0 10px 14px rgba(65, 42, 23, 0.1));
}

.choice-card::after,
.target-card::after,
.mode-card::after {
  display: none;
}

.choice-card.active::before,
.target-card.active::before,
.mode-card.active::before {
  filter:
    sepia(0.12)
    saturate(0.7)
    hue-rotate(350deg)
    brightness(0.98)
    contrast(0.86)
    drop-shadow(0 13px 16px rgba(65, 42, 23, 0.14));
}

.wizard-choice-card:nth-child(6n + 1) {
  --card-shape: var(--wood-sign-long);
  --card-inner-inset: 25px 38px;
}

.wizard-choice-card:nth-child(6n + 2) {
  --card-shape: var(--wood-sign-square);
  --card-inner-inset: 29px;
}

.wizard-choice-card:nth-child(6n + 3) {
  --card-shape: var(--wood-sign-medium);
  --card-inner-inset: 24px 30px;
}

.wizard-choice-card:nth-child(6n + 4) {
  --card-shape: var(--wood-sign-portrait);
  --card-inner-inset: 33px 27px;
}

.wizard-choice-card:nth-child(6n + 5) {
  --card-shape: var(--wood-sign-soft-wide);
  --card-inner-inset: 25px 34px;
}

.wizard-choice-card:nth-child(6n) {
  --card-shape: var(--wood-sign-tall);
  --card-inner-inset: 34px 26px;
}

@media (min-width: 861px) {
  .step-grid,
  .step-grid.one,
  .step-grid.two,
  .step-grid.three,
  .step-grid.four,
  .step-grid.five {
    display: grid;
    grid-template-columns: repeat(12, minmax(0, 1fr));
    grid-auto-rows: 19px;
    grid-auto-flow: dense;
    gap: clamp(18px, 2.1vw, 32px);
    align-items: stretch;
    padding: 18px clamp(6px, 1vw, 18px) 48px;
  }

  .step-grid > .wizard-choice-card,
  .step-grid.one > .wizard-choice-card:nth-child(1),
  .step-grid.two > .wizard-choice-card:nth-child(1),
  .step-grid.two > .wizard-choice-card:nth-child(2),
  .step-grid.three > .wizard-choice-card:nth-child(1),
  .step-grid.three > .wizard-choice-card:nth-child(2),
  .step-grid.three > .wizard-choice-card:nth-child(3),
  .step-grid.four > .wizard-choice-card:nth-child(1),
  .step-grid.four > .wizard-choice-card:nth-child(2),
  .step-grid.four > .wizard-choice-card:nth-child(3),
  .step-grid.four > .wizard-choice-card:nth-child(4),
  .step-grid.five > .wizard-choice-card:nth-child(1),
  .step-grid.five > .wizard-choice-card:nth-child(2),
  .step-grid.five > .wizard-choice-card:nth-child(3),
  .step-grid.five > .wizard-choice-card:nth-child(4),
  .step-grid.five > .wizard-choice-card:nth-child(5) {
    grid-column: span 4;
    grid-row: span 8;
    min-height: 0;
    transform: translateY(var(--card-y)) rotate(var(--card-tilt));
  }

  .step-grid.one > .wizard-choice-card {
    grid-column: 4 / span 6;
    grid-row: span 8;
  }

  .step-grid.two > .wizard-choice-card {
    grid-column: span 6;
    grid-row: span 8;
  }

  .step-grid.three > .wizard-choice-card {
    grid-column: span 4;
    grid-row: span 8;
  }

  .wizard-choice-card:nth-child(6n + 1) {
    grid-column: span 5;
    grid-row: span 6;
    --card-tilt: -1deg;
    --card-y: 8px;
  }

  .wizard-choice-card:nth-child(6n + 2) {
    grid-column: span 3;
    grid-row: span 8;
    --card-tilt: 0.7deg;
    --card-y: -4px;
  }

  .wizard-choice-card:nth-child(6n + 3) {
    grid-column: span 4;
    grid-row: span 6;
    --card-tilt: -0.5deg;
    --card-y: 14px;
  }

  .wizard-choice-card:nth-child(6n + 4) {
    grid-column: span 3;
    grid-row: span 9;
    --card-tilt: 1deg;
    --card-y: 3px;
  }

  .wizard-choice-card:nth-child(6n + 5) {
    grid-column: span 5;
    grid-row: span 6;
    --card-tilt: -0.8deg;
    --card-y: 10px;
  }

  .wizard-choice-card:nth-child(6n) {
    grid-column: span 3;
    grid-row: span 9;
    --card-tilt: 0.6deg;
    --card-y: -2px;
  }

  .wizard-choice-card:nth-child(10n + 7) {
    grid-column: span 4;
    grid-row: span 7;
  }

  .wizard-choice-card:nth-child(10n + 8) {
    grid-column: span 5;
    grid-row: span 6;
  }

  .wizard-choice-card:nth-child(10n + 9) {
    grid-column: span 3;
    grid-row: span 8;
  }

  .wizard-choice-card:nth-child(10n) {
    grid-column: span 4;
    grid-row: span 7;
  }
}

@media (max-width: 1120px) {
  .hero-progress-circles {
    min-height: 0;
  }
}

@media (max-width: 760px) {
  .wizard-rail-item {
    clip-path: none;
    min-width: 188px;
    padding: 13px 18px;
  }

  .hero-progress-circles {
    min-height: 280px;
    padding: 72px 48px 62px;
    gap: 24px;
  }

  .hero-best-strip {
    padding: 62px 42px 58px;
  }

  .choice-card,
  .target-card,
  .mode-card {
    min-height: 178px;
  }
}

/* Local May 9 card reset: use cropped FrameCard signs, not SVG boards. */
:root {
  --sign-long-a: url("./assets/mascot/library/final-pack/generated-frames/framecard-signs-hd/long-a.png");
  --sign-long-b: url("./assets/mascot/library/final-pack/generated-frames/framecard-signs-hd/long-b.png");
  --sign-long-c: url("./assets/mascot/library/final-pack/generated-frames/framecard-signs-hd/long-c.png");
  --sign-wide-a: url("./assets/mascot/library/final-pack/generated-frames/framecard-signs-hd/wide-a.png");
  --sign-wide-b: url("./assets/mascot/library/final-pack/generated-frames/framecard-signs-hd/wide-b.png");
  --sign-wide-c: url("./assets/mascot/library/final-pack/generated-frames/framecard-signs-hd/wide-c.png");
  --sign-wide-thin: url("./assets/mascot/library/final-pack/generated-frames/framecard-signs-hd/wide-thin.png");
  --sign-square-a: url("./assets/mascot/library/final-pack/generated-frames/framecard-signs-hd/square-a.png");
  --sign-square-b: url("./assets/mascot/library/final-pack/generated-frames/framecard-signs-hd/square-b.png");
}

.choice-card,
.target-card,
.mode-card {
  --sign-image: var(--sign-wide-a);
  --sign-aspect: 3.39 / 1;
  --sign-layout: image-left;
  --card-tilt: 0deg;
  --card-x: 0px;
  --card-y: 0px;
  justify-self: center;
  align-self: center;
  width: 100%;
  height: auto;
  aspect-ratio: var(--sign-aspect);
  min-height: 0;
  padding: clamp(22px, 3vw, 38px) clamp(30px, 4vw, 56px);
  border: 0;
  border-radius: 0;
  background-color: transparent;
  background-image: var(--sign-image);
  background-position: center;
  background-repeat: no-repeat;
  background-size: 100% 100%;
  box-shadow: none;
  box-sizing: border-box;
  clip-path: inset(2% 2.5% round 14px);
  overflow: hidden;
  transform: translate(var(--card-x), var(--card-y)) rotate(var(--card-tilt));
}

.choice-card::before,
.choice-card::after,
.target-card::before,
.target-card::after,
.mode-card::before,
.mode-card::after {
  display: none;
}

.choice-card:hover,
.target-card:hover,
.mode-card:hover {
  transform: translate(var(--card-x), calc(var(--card-y) - 3px)) rotate(var(--card-tilt));
  filter: drop-shadow(0 10px 14px rgba(65, 42, 23, 0.12));
}

.choice-card.active,
.target-card.active,
.mode-card.active {
  filter:
    saturate(1.06)
    brightness(1.02)
    drop-shadow(0 12px 16px rgba(65, 42, 23, 0.14));
}

.wizard-choice-card .card-top {
  display: grid;
  grid-template-columns: minmax(46px, 0.48fr) minmax(0, 1fr);
  grid-template-rows: 1fr;
  width: 100%;
  height: 100%;
  min-height: 0;
  gap: clamp(10px, 1.8vw, 22px);
  align-content: center;
  align-items: center;
  justify-items: center;
  padding: 0;
  overflow: hidden;
  text-align: right;
}

.wizard-choice-slot {
  position: static;
  order: 1;
  width: min(100%, clamp(54px, 6vw, 92px));
  height: min(100%, clamp(50px, 5.6vw, 86px));
  max-width: 100%;
  max-height: 100%;
  min-height: 0;
  display: grid;
  place-items: center;
  overflow: hidden;
}

.wizard-choice-slot .asset-image,
.wizard-choice-slot .mascot-asset {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
}

.wizard-choice-copy {
  order: 2;
  width: 100%;
  max-width: 100%;
  max-height: 100%;
  min-width: 0;
  min-height: 0;
  margin: 0;
  padding: 0;
  display: grid;
  align-items: center;
  justify-items: end;
  text-align: right;
}

.wizard-choice-copy h3,
.target-card .wizard-choice-copy h3,
.mode-card .wizard-choice-copy h3 {
  max-width: 100%;
  margin: 0;
  color: #6f4b28;
  font-size: clamp(0.92rem, 1.34vw, 1.38rem);
  line-height: 1.04;
  text-align: inherit;
  overflow-wrap: anywhere;
  text-wrap: balance;
}

.mode-card-thanks {
  max-width: 100%;
  text-align: inherit;
}

.mode-card .wizard-choice-copy {
  align-items: center;
  justify-items: inherit;
}

.mode-card[data-pick-mode="run"] .wizard-choice-slot,
.mode-card[data-pick-mode="jump"] .wizard-choice-slot,
.mode-card[data-pick-mode="buildcase"] .wizard-choice-slot,
.mode-card[data-pick-mode="relay"] .wizard-choice-slot,
.mode-card[data-pick-mode="race"] .wizard-choice-slot {
  transform: none;
}

.wizard-choice-card:nth-child(8n + 1) {
  --sign-image: var(--sign-long-a);
  --sign-aspect: 3.36 / 1;
  --card-tilt: -0.8deg;
  --card-x: -7px;
  --card-y: 8px;
}

.wizard-choice-card:nth-child(8n + 2) {
  --sign-image: var(--sign-square-a);
  --sign-aspect: 1.18 / 1;
  --card-tilt: 0.7deg;
  --card-x: 6px;
  --card-y: -6px;
}

.wizard-choice-card:nth-child(8n + 3) {
  --sign-image: var(--sign-wide-a);
  --sign-aspect: 3.39 / 1;
  --card-tilt: -0.4deg;
  --card-x: 10px;
  --card-y: 12px;
}

.wizard-choice-card:nth-child(8n + 4) {
  --sign-image: var(--sign-square-b);
  --sign-aspect: 1.08 / 1;
  --card-tilt: 0.9deg;
  --card-x: -4px;
  --card-y: 2px;
}

.wizard-choice-card:nth-child(8n + 5) {
  --sign-image: var(--sign-long-b);
  --sign-aspect: 4.38 / 1;
  --card-tilt: -0.6deg;
  --card-x: 5px;
  --card-y: 10px;
}

.wizard-choice-card:nth-child(8n + 6) {
  --sign-image: var(--sign-wide-c);
  --sign-aspect: 3.5 / 1;
  --card-tilt: 0.5deg;
  --card-x: -8px;
  --card-y: -2px;
}

.wizard-choice-card:nth-child(8n + 7) {
  --sign-image: var(--sign-long-c);
  --sign-aspect: 4.01 / 1;
  --card-tilt: 0.8deg;
  --card-x: 9px;
  --card-y: 7px;
}

.wizard-choice-card:nth-child(8n) {
  --sign-image: var(--sign-wide-b);
  --sign-aspect: 4.02 / 1;
  --card-tilt: -0.5deg;
  --card-x: -6px;
  --card-y: 4px;
}

.wizard-choice-card:nth-child(odd) .card-top {
  grid-template-columns: minmax(46px, 0.48fr) minmax(0, 1fr);
  grid-template-rows: 1fr;
  text-align: right;
}

.wizard-choice-card:nth-child(odd) .wizard-choice-slot {
  order: 1;
  width: min(100%, clamp(54px, 6vw, 92px));
  height: min(100%, clamp(50px, 5.6vw, 86px));
}

.wizard-choice-card:nth-child(odd) .wizard-choice-copy {
  order: 2;
  justify-items: end;
  text-align: right;
}

.wizard-choice-card:nth-child(even) .card-top {
  grid-template-columns: minmax(0, 1fr) minmax(46px, 0.48fr);
  grid-template-rows: 1fr;
  text-align: left;
}

.wizard-choice-card:nth-child(even) .wizard-choice-slot {
  order: 2;
  width: min(100%, clamp(54px, 6vw, 92px));
  height: min(100%, clamp(50px, 5.6vw, 86px));
}

.wizard-choice-card:nth-child(even) .wizard-choice-copy {
  order: 1;
  justify-items: start;
  text-align: left;
}

.wizard-choice-card:nth-child(8n + 2) .card-top,
.wizard-choice-card:nth-child(8n + 4) .card-top {
  grid-template-columns: 1fr;
  grid-template-rows: minmax(0, 1fr) auto;
  text-align: center;
  gap: clamp(8px, 1.5vw, 16px);
}

.wizard-choice-card:nth-child(8n + 2) .wizard-choice-slot,
.wizard-choice-card:nth-child(8n + 4) .wizard-choice-slot {
  order: 1;
  width: min(72%, clamp(70px, 8.6vw, 116px));
  height: min(72%, clamp(64px, 8vw, 108px));
}

.wizard-choice-card:nth-child(8n + 2) .wizard-choice-copy,
.wizard-choice-card:nth-child(8n + 4) .wizard-choice-copy {
  order: 2;
  justify-items: center;
  text-align: center;
}

.wizard-choice-card:nth-child(8n + 4) .wizard-choice-slot {
  order: 2;
}

.wizard-choice-card:nth-child(8n + 4) .card-top {
  grid-template-rows: auto minmax(0, 1fr);
}

.wizard-choice-card:nth-child(8n + 4) .wizard-choice-copy {
  order: 1;
}

@media (min-width: 861px) {
  .step-grid,
  .step-grid.one,
  .step-grid.two,
  .step-grid.three,
  .step-grid.four,
  .step-grid.five {
    display: grid;
    grid-template-columns: repeat(12, minmax(0, 1fr));
    grid-auto-rows: auto;
    gap: clamp(22px, 2.4vw, 38px);
    align-items: center;
    padding: 18px clamp(6px, 1vw, 18px) 52px;
  }

  .step-grid > .wizard-choice-card,
  .step-grid.one > .wizard-choice-card:nth-child(1),
  .step-grid.two > .wizard-choice-card:nth-child(1),
  .step-grid.two > .wizard-choice-card:nth-child(2),
  .step-grid.three > .wizard-choice-card:nth-child(1),
  .step-grid.three > .wizard-choice-card:nth-child(2),
  .step-grid.three > .wizard-choice-card:nth-child(3),
  .step-grid.four > .wizard-choice-card:nth-child(1),
  .step-grid.four > .wizard-choice-card:nth-child(2),
  .step-grid.four > .wizard-choice-card:nth-child(3),
  .step-grid.four > .wizard-choice-card:nth-child(4),
  .step-grid.five > .wizard-choice-card:nth-child(1),
  .step-grid.five > .wizard-choice-card:nth-child(2),
  .step-grid.five > .wizard-choice-card:nth-child(3),
  .step-grid.five > .wizard-choice-card:nth-child(4),
  .step-grid.five > .wizard-choice-card:nth-child(5) {
    grid-row: auto;
    min-height: 0;
  }

  .wizard-choice-card:nth-child(8n + 1),
  .wizard-choice-card:nth-child(8n + 5),
  .wizard-choice-card:nth-child(8n + 7) {
    grid-column: span 5;
  }

  .wizard-choice-card:nth-child(8n + 3),
  .wizard-choice-card:nth-child(8n + 6),
  .wizard-choice-card:nth-child(8n) {
    grid-column: span 4;
  }

  .wizard-choice-card:nth-child(8n + 2),
  .wizard-choice-card:nth-child(8n + 4) {
    grid-column: span 3;
  }

  .step-grid.one > .wizard-choice-card,
  .step-grid.two > .wizard-choice-card,
  .step-grid.three > .wizard-choice-card {
    grid-column: span 4;
  }

  .step-grid.one > .wizard-choice-card {
    grid-column: 4 / span 6;
  }

  .step-grid.two > .wizard-choice-card {
    grid-column: span 6;
  }
}

@media (max-width: 760px) {
  .choice-card,
  .target-card,
  .mode-card {
    width: min(100%, 360px);
    min-height: 0;
    padding: 28px 36px;
  }

  .wizard-choice-card:nth-child(8n + 2),
  .wizard-choice-card:nth-child(8n + 4) {
    width: min(100%, 286px);
  }
}

/* Local May 9 frame swap: header scores use FrameCard signs, route cards use score frames. */
:root {
  --score-card-square: url("./assets/mascot/library/final-pack/generated-frames/frame-score-cards/score-card-square-filled.png");
  --header-score-sign-wide: url("./assets/mascot/library/final-pack/generated-frames/framecard-signs-hd/long-b.png");
  --header-score-sign-small: url("./assets/mascot/library/final-pack/generated-frames/framecard-signs-hd/square-a.png");
}

.hero-progress-circles::before {
  background-image: var(--header-score-sign-small);
  filter:
    drop-shadow(0 12px 16px rgba(65, 42, 23, 0.12))
    saturate(0.82)
    brightness(1.05);
}

.hero-best-strip::before {
  background-image: var(--header-score-sign-wide);
  filter:
    drop-shadow(0 12px 16px rgba(65, 42, 23, 0.12))
    saturate(0.82)
    brightness(1.05);
}

.choice-card,
.target-card,
.mode-card,
.wizard-choice-card:nth-child(8n + 1),
.wizard-choice-card:nth-child(8n + 2),
.wizard-choice-card:nth-child(8n + 3),
.wizard-choice-card:nth-child(8n + 4),
.wizard-choice-card:nth-child(8n + 5),
.wizard-choice-card:nth-child(8n + 6),
.wizard-choice-card:nth-child(8n + 7),
.wizard-choice-card:nth-child(8n) {
  --sign-image: var(--score-card-square);
  --sign-aspect: 1 / 1;
  --card-x: 0px;
  --card-y: 0px;
  --card-tilt: 0deg;
  width: clamp(144px, 12.5vw, 180px);
  max-width: 100%;
  aspect-ratio: 1 / 1;
  padding: clamp(30px, 2.6vw, 38px) clamp(24px, 2.4vw, 34px) clamp(42px, 3.2vw, 52px);
  background-color: transparent;
  background-image: var(--score-card-square);
  background-position: center;
  background-repeat: no-repeat;
  background-size: 100% 100%;
  clip-path: inset(3% 3% round 12px);
}

.choice-card:hover,
.target-card:hover,
.mode-card:hover {
  transform: translateY(-3px);
}

.wizard-choice-card .card-top,
.wizard-choice-card:nth-child(odd) .card-top,
.wizard-choice-card:nth-child(even) .card-top,
.wizard-choice-card:nth-child(8n + 2) .card-top,
.wizard-choice-card:nth-child(8n + 4) .card-top {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: minmax(0, 1fr) auto;
  gap: clamp(8px, 1.2vw, 14px);
  align-content: center;
  align-items: center;
  justify-items: center;
  text-align: center;
}

.wizard-choice-card .wizard-choice-slot,
.wizard-choice-card:nth-child(odd) .wizard-choice-slot,
.wizard-choice-card:nth-child(even) .wizard-choice-slot,
.wizard-choice-card:nth-child(8n + 2) .wizard-choice-slot,
.wizard-choice-card:nth-child(8n + 4) .wizard-choice-slot {
  order: 1;
  width: min(82%, clamp(58px, 5.9vw, 86px));
  height: min(100%, clamp(56px, 5.8vw, 84px));
}

.wizard-choice-card .wizard-choice-copy,
.wizard-choice-card:nth-child(odd) .wizard-choice-copy,
.wizard-choice-card:nth-child(even) .wizard-choice-copy,
.wizard-choice-card:nth-child(8n + 2) .wizard-choice-copy,
.wizard-choice-card:nth-child(8n + 4) .wizard-choice-copy {
  order: 2;
  justify-items: center;
  text-align: center;
}

.wizard-choice-copy h3,
.target-card .wizard-choice-copy h3,
.mode-card .wizard-choice-copy h3 {
  color: #5f3d20;
  font-size: clamp(0.92rem, 1.18vw, 1.2rem);
  line-height: 1.04;
  text-shadow: 0 1px 0 rgba(255, 241, 205, 0.76);
}

@media (min-width: 861px) {
  .step-grid,
  .step-grid.one,
  .step-grid.two,
  .step-grid.three,
  .step-grid.four,
  .step-grid.five {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(144px, 180px));
    grid-auto-rows: auto;
    justify-content: center;
    align-items: center;
    gap: clamp(18px, 2vw, 30px);
    padding: 24px clamp(8px, 1vw, 18px) 52px;
  }

  .step-grid > .wizard-choice-card,
  .step-grid.one > .wizard-choice-card,
  .step-grid.two > .wizard-choice-card,
  .step-grid.three > .wizard-choice-card,
  .step-grid.four > .wizard-choice-card,
  .step-grid.five > .wizard-choice-card,
  .step-grid.one > .wizard-choice-card:nth-child(1),
  .step-grid.two > .wizard-choice-card:nth-child(1),
  .step-grid.two > .wizard-choice-card:nth-child(2),
  .step-grid.three > .wizard-choice-card:nth-child(1),
  .step-grid.three > .wizard-choice-card:nth-child(2),
  .step-grid.three > .wizard-choice-card:nth-child(3),
  .step-grid.four > .wizard-choice-card:nth-child(1),
  .step-grid.four > .wizard-choice-card:nth-child(2),
  .step-grid.four > .wizard-choice-card:nth-child(3),
  .step-grid.four > .wizard-choice-card:nth-child(4),
  .step-grid.five > .wizard-choice-card:nth-child(1),
  .step-grid.five > .wizard-choice-card:nth-child(2),
  .step-grid.five > .wizard-choice-card:nth-child(3),
  .step-grid.five > .wizard-choice-card:nth-child(4),
  .step-grid.five > .wizard-choice-card:nth-child(5),
  .wizard-choice-card:nth-child(8n + 1),
  .wizard-choice-card:nth-child(8n + 2),
  .wizard-choice-card:nth-child(8n + 3),
  .wizard-choice-card:nth-child(8n + 4),
  .wizard-choice-card:nth-child(8n + 5),
  .wizard-choice-card:nth-child(8n + 6),
  .wizard-choice-card:nth-child(8n + 7),
  .wizard-choice-card:nth-child(8n) {
    grid-column: auto;
    grid-row: auto;
    justify-self: center;
  }
}

@media (max-width: 760px) {
  .choice-card,
  .target-card,
  .mode-card,
  .wizard-choice-card:nth-child(8n + 2),
  .wizard-choice-card:nth-child(8n + 4) {
    width: min(44vw, 168px) !important;
    padding: 34px 28px 46px;
  }
}

/* Local May 9 header/card polish. */
.hero-best-card {
  transform: translateY(-5px);
}

.hero-best-card span {
  color: #5f3d20;
  font-size: clamp(12.8px, 0.9vw, 14px);
  font-weight: 1000;
}

.hero-best-card strong {
  transform: translateY(-1px);
}

.hero-progress-circles {
  padding: 44px 34px 44px 12px;
}

.progress-circle-card {
  gap: 8px;
}

.stat-progress-circle-copy span {
  color: #5f3d20;
  font-size: clamp(14px, 1.05vw, 15.5px) !important;
  font-weight: 1000;
}

.choice-card,
.target-card,
.mode-card,
.wizard-choice-card:nth-child(8n + 1),
.wizard-choice-card:nth-child(8n + 2),
.wizard-choice-card:nth-child(8n + 3),
.wizard-choice-card:nth-child(8n + 4),
.wizard-choice-card:nth-child(8n + 5),
.wizard-choice-card:nth-child(8n + 6),
.wizard-choice-card:nth-child(8n + 7),
.wizard-choice-card:nth-child(8n) {
  aspect-ratio: 1 / 1.12;
  padding: clamp(38px, 3vw, 46px) clamp(24px, 2.4vw, 34px) clamp(44px, 3.1vw, 52px);
}

.wizard-choice-card .card-top,
.wizard-choice-card:nth-child(odd) .card-top,
.wizard-choice-card:nth-child(even) .card-top,
.wizard-choice-card:nth-child(8n + 2) .card-top,
.wizard-choice-card:nth-child(8n + 4) .card-top {
  grid-template-rows: minmax(0, 1fr) minmax(30px, auto);
  gap: clamp(6px, 0.9vw, 10px);
}

.wizard-choice-card .wizard-choice-slot,
.wizard-choice-card:nth-child(odd) .wizard-choice-slot,
.wizard-choice-card:nth-child(even) .wizard-choice-slot,
.wizard-choice-card:nth-child(8n + 2) .wizard-choice-slot,
.wizard-choice-card:nth-child(8n + 4) .wizard-choice-slot {
  align-self: end;
  transform: translateY(5px);
  width: min(80%, clamp(54px, 5.3vw, 78px));
  height: min(100%, clamp(52px, 5.2vw, 76px));
}

.wizard-choice-card .wizard-choice-copy,
.wizard-choice-card:nth-child(odd) .wizard-choice-copy,
.wizard-choice-card:nth-child(even) .wizard-choice-copy,
.wizard-choice-card:nth-child(8n + 2) .wizard-choice-copy,
.wizard-choice-card:nth-child(8n + 4) .wizard-choice-copy {
  width: 100%;
  justify-content: center;
  justify-items: center;
  align-self: center;
  text-align: center;
}

.wizard-choice-copy h3,
.target-card .wizard-choice-copy h3,
.mode-card .wizard-choice-copy h3 {
  width: 100%;
  font-size: clamp(0.78rem, 0.96vw, 1rem);
  line-height: 1.02;
  text-align: center;
}

@media (max-width: 760px) {
  .hero-progress-circles {
    padding-left: 18px;
    padding-right: 34px;
  }

  .choice-card,
  .target-card,
  .mode-card,
  .wizard-choice-card:nth-child(8n + 2),
  .wizard-choice-card:nth-child(8n + 4) {
    width: min(44vw, 168px) !important;
    aspect-ratio: 1 / 1.12;
    padding: 40px 26px 46px;
  }
}

/* Local May 9 card icon nudge pass. Step 2 lens cards intentionally stay unchanged. */
[data-pick-path] .wizard-choice-slot {
  transform: translateY(11px) !important;
}

[data-pick-target] .wizard-choice-slot,
[data-pick-mode] .wizard-choice-slot {
  transform: translateY(10px) !important;
}

[data-pick-target="concluding-questions"] .wizard-choice-slot,
[data-pick-target="where-the-sidewalk-starts"] .wizard-choice-slot,
[data-pick-target="more-to-do"] .wizard-choice-slot,
[data-pick-target="more-to-do-than-can-ever-be-listed"] .wizard-choice-slot,
[data-pick-target="prediction"] .wizard-choice-slot,
[data-pick-target="transition"] .wizard-choice-slot,
[data-pick-target="journeys"] .wizard-choice-slot,
[data-pick-target="tourism"] .wizard-choice-slot,
[data-pick-target="sciences"] .wizard-choice-slot,
[data-pick-target="psychology"] .wizard-choice-slot,
[data-pick-target="language-literature"] .wizard-choice-slot,
[data-pick-mode="relay"] .wizard-choice-slot,
[data-pick-mode="alpacard"] .wizard-choice-slot {
  transform: translate(-18px, 10px) !important;
}

[data-pick-mode="alpacard"] .mode-card-thanks {
  display: block;
  width: 100%;
  margin-top: 2px;
  font-size: 0.56rem;
  font-style: italic;
  line-height: 1;
  white-space: nowrap;
}

@media (min-width: 861px) {
  .step-grid.target-grid {
    grid-template-columns: repeat(12, minmax(0, 76px));
    grid-auto-rows: auto;
    justify-content: center;
    align-items: start;
    gap: 28px 22px;
  }

  .step-grid.target-grid > .wizard-choice-card {
    grid-column: auto / span 2 !important;
    grid-row: auto !important;
    width: 180px;
    justify-self: center;
  }

  .step-grid.target-grid.lens-section > .wizard-choice-card:nth-child(1),
  .step-grid.target-grid.lens-section > .wizard-choice-card:nth-child(12),
  .step-grid.target-grid.lens-bigidea > .wizard-choice-card:nth-child(7),
  .step-grid.target-grid.lens-subject > .wizard-choice-card:nth-child(1),
  .step-grid.target-grid.lens-subject > .wizard-choice-card:nth-child(6),
  .step-grid.target-grid.lens-subject > .wizard-choice-card:nth-child(11) {
    grid-column: 2 / span 2 !important;
  }

  .step-grid.target-grid.lens-section > .wizard-choice-card:nth-child(6),
  .step-grid.target-grid.lens-bigidea > .wizard-choice-card:nth-child(1),
  .step-grid.target-grid.lens-bigidea > .wizard-choice-card:nth-child(12) {
    grid-column: 1 / span 2 !important;
  }
}

[data-pick-target="psychology"] .wizard-choice-slot {
  transform: translate(-15px, 10px) !important;
}

@media (max-width: 760px) {
  [data-pick-target="concluding-questions"] .wizard-choice-slot,
  [data-pick-target="where-the-sidewalk-starts"] .wizard-choice-slot,
  [data-pick-target="more-to-do"] .wizard-choice-slot,
  [data-pick-target="more-to-do-than-can-ever-be-listed"] .wizard-choice-slot,
  [data-pick-target="prediction"] .wizard-choice-slot,
  [data-pick-target="transition"] .wizard-choice-slot,
  [data-pick-target="journeys"] .wizard-choice-slot,
  [data-pick-target="tourism"] .wizard-choice-slot,
  [data-pick-target="sciences"] .wizard-choice-slot,
  [data-pick-target="psychology"] .wizard-choice-slot,
  [data-pick-target="language-literature"] .wizard-choice-slot,
  [data-pick-mode="relay"] .wizard-choice-slot,
  [data-pick-mode="alpacard"] .wizard-choice-slot {
    transform: translate(-16px, 10px) !important;
  }

  [data-pick-target="psychology"] .wizard-choice-slot {
    transform: translate(-14px, 10px) !important;
  }
}

[data-pick-mode="channel"] .wizard-choice-slot,
[data-pick-mode="alpacard"] .wizard-choice-slot,
[data-pick-mode="relay"] .wizard-choice-slot {
  justify-self: center !important;
  place-self: center !important;
  transform: translateY(10px) !important;
}

[data-pick-mode="channel"] .wizard-choice-slot .asset-image,
[data-pick-mode="channel"] .wizard-choice-slot .mascot-asset,
[data-pick-mode="alpacard"] .wizard-choice-slot .asset-image,
[data-pick-mode="alpacard"] .wizard-choice-slot .mascot-asset,
[data-pick-mode="relay"] .wizard-choice-slot .asset-image,
[data-pick-mode="relay"] .wizard-choice-slot .mascot-asset {
  object-position: center center !important;
}

/* May 14 route-builder simplification: guiding sections first, then Learn/Play choices. */
.step-grid.mode-landing-grid {
  display: block;
  padding: clamp(14px, 2vw, 24px);
}

.mode-choice-board {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(18px, 2.4vw, 30px);
  align-items: start;
}

.mode-choice-footer {
  display: flex;
  justify-content: center;
  margin-top: clamp(18px, 2.4vw, 28px);
}

.mode-choice-column {
  min-width: 0;
  padding: clamp(14px, 1.8vw, 22px);
  border: 1px solid rgba(107, 78, 22, 0.14);
  border-radius: 18px;
  background: rgba(255, 250, 242, 0.44);
  box-shadow: inset 0 1px 0 rgba(255, 248, 232, 0.5);
}

.mode-choice-heading {
  display: grid;
  grid-template-columns: 72px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  min-height: 82px;
  margin-bottom: 14px;
}

.mode-choice-heading h3 {
  margin: 0;
  color: var(--bg);
  font-size: clamp(1.55rem, 2.8vw, 2.3rem);
  line-height: 1;
}

.mode-choice-heading-slot {
  width: 72px;
  height: 72px;
}

.mode-choice-heading-image {
  object-fit: contain;
  object-position: center;
}

.mode-choice-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(136px, 1fr));
  gap: clamp(12px, 1.6vw, 18px);
  justify-items: center;
}

.mode-choice-card-grid .wizard-choice-card {
  width: min(100%, 168px) !important;
}

.mode-choice-column-play .mode-choice-card-grid {
  grid-template-columns: repeat(2, minmax(118px, 1fr));
  justify-content: center;
}

.mode-choice-column-play .mode-choice-card-grid .wizard-choice-card {
  grid-column: auto;
  width: min(100%, 156px) !important;
}

.mode-choice-column-play .mode-choice-card-grid .wizard-choice-card:nth-child(1) {
  grid-column: auto;
}

.mode-choice-column-play .mode-choice-card-grid .wizard-choice-card:nth-child(2) {
  grid-column: auto;
}

.mode-choice-column-play .mode-choice-card-grid .wizard-choice-card:nth-child(3) {
  grid-column: auto;
}

.mode-choice-column-play .mode-choice-card-grid .wizard-choice-card:nth-child(4) {
  grid-column: auto;
}

.mode-choice-column-play .mode-choice-card-grid .wizard-choice-card:nth-child(5) {
  grid-column: auto;
}

.mode-choice-column-train .mode-choice-card-grid {
  grid-template-columns: repeat(2, minmax(118px, 1fr));
  justify-content: center;
}

.mode-choice-column-train .mode-choice-card-grid .wizard-choice-card {
  width: min(100%, 156px) !important;
}

.step-grid.target-grid.lens-section {
  display: grid;
  grid-template-columns: repeat(5, minmax(144px, 180px));
  grid-auto-rows: auto;
  justify-content: center;
  align-items: start;
  gap: 28px 22px;
  padding: 24px clamp(8px, 1vw, 18px) 52px;
}

.step-grid.target-grid.lens-section > .wizard-choice-card {
  grid-column: auto !important;
  grid-row: auto !important;
  justify-self: center;
  width: clamp(144px, 12.5vw, 180px) !important;
}

.step-grid.target-grid.lens-section > .wizard-choice-card:nth-child(n) {
  grid-column: auto / span 1 !important;
  grid-row: auto !important;
}

.target-next-row {
  grid-column: 1 / -1 !important;
  display: flex;
  justify-content: center;
  margin-top: 4px;
}

.target-next-row .button {
  min-width: 160px;
}

.selectable-target-card {
  position: relative;
}

.target-select-dot {
  position: absolute;
  right: 20px;
  top: 18px;
  z-index: 3;
  width: 20px;
  height: 20px;
  border-radius: 999px;
  border: 2px solid rgba(95, 61, 32, 0.62);
  background: rgba(255, 250, 242, 0.86);
  box-shadow: 0 2px 5px rgba(75, 47, 33, 0.16);
}

.selectable-target-card.selected .target-select-dot {
  border-color: rgba(45, 103, 59, 0.82);
  background: #3fb35f;
}

.section-heading h2:empty {
  display: none;
}

.hero-progress-circles::before,
.hero-best-strip::before {
  filter:
    drop-shadow(0 12px 16px rgba(65, 42, 23, 0.1))
    saturate(0.68)
    brightness(1.18) !important;
}

.hero-progress-circles::after,
.hero-best-strip::after {
  background:
    radial-gradient(circle at top left, rgba(255, 250, 238, 0.62), transparent 48%),
    rgba(247, 234, 204, 0.58) !important;
}

.quiz-setup-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 16px;
}

.quiz-difficulty-grid {
  grid-template-columns: 1fr;
}

.raw-section-group-card {
  display: grid;
  gap: 14px;
}

.raw-section-group-top h3 {
  margin: 0;
}

.raw-section-entry-list {
  display: grid;
  gap: 14px;
}

.learn-card-footer-nav {
  display: flex;
  justify-content: center;
  align-items: stretch;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 18px;
  padding-top: 16px;
  border-top: 1px solid rgba(107, 78, 22, 0.12);
}

.learn-footer-card-button {
  display: grid;
  justify-items: center;
  align-content: center;
  gap: 6px;
  width: 104px;
  min-height: 112px;
  border: 1px solid rgba(107, 78, 22, 0.16);
  border-radius: 14px;
  background: rgba(255, 250, 242, 0.68);
  color: #5f3d20;
  cursor: pointer;
  font: inherit;
  font-size: 0.78rem;
  font-weight: 900;
  line-height: 1.05;
  text-align: center;
}

.learn-footer-card-button:hover,
.learn-footer-card-button:focus-visible {
  border-color: rgba(63, 135, 96, 0.45);
  background: rgba(255, 250, 242, 0.92);
  outline: none;
  transform: translateY(-1px);
}

.learn-footer-card-slot {
  width: 58px;
  height: 58px;
}

.learn-footer-card-image {
  object-fit: contain;
  object-position: center center;
}

[data-pick-mode="jump"] .wizard-choice-slot,
[data-pick-target="home-and-wandering"] .wizard-choice-slot {
  justify-self: center !important;
  place-self: center !important;
  transform: translateY(10px) !important;
}

[data-pick-mode="jump"] .wizard-choice-slot .asset-image,
[data-pick-mode="jump"] .wizard-choice-slot .mascot-asset,
[data-pick-target="home-and-wandering"] .wizard-choice-slot .asset-image,
[data-pick-target="home-and-wandering"] .wizard-choice-slot .mascot-asset {
  object-position: center center !important;
}

@media (max-width: 980px) {
  .step-grid.target-grid.lens-section {
    grid-template-columns: repeat(auto-fit, minmax(144px, 180px));
  }

  .mode-choice-board,
  .quiz-setup-layout {
    grid-template-columns: 1fr;
  }

  .mode-choice-column-play .mode-choice-card-grid,
  .mode-choice-column-train .mode-choice-card-grid {
    grid-template-columns: repeat(auto-fit, minmax(136px, 168px));
  }

  .mode-choice-column-play .mode-choice-card-grid .wizard-choice-card:nth-child(n),
  .mode-choice-column-train .mode-choice-card-grid .wizard-choice-card:nth-child(n) {
    grid-column: auto;
  }
}

@media (min-width: 701px) and (max-width: 980px) {
  .step-grid.target-grid.lens-section {
    grid-template-columns: repeat(5, minmax(112px, 136px));
    gap: 24px 14px;
  }

  .step-grid.target-grid.lens-section > .wizard-choice-card {
    width: min(100%, 136px) !important;
    padding: 32px 20px 42px;
  }

  .step-grid.target-grid.lens-section .wizard-choice-copy h3 {
    font-size: 0.78rem;
  }

  .mode-choice-column-play .mode-choice-card-grid {
    grid-template-columns: repeat(6, minmax(0, 74px));
  }

  .mode-choice-column-play .mode-choice-card-grid .wizard-choice-card {
    width: min(100%, 148px) !important;
  }

  .mode-choice-column-play .mode-choice-card-grid .wizard-choice-card:nth-child(1) {
    grid-column: 2 / span 2;
  }

  .mode-choice-column-play .mode-choice-card-grid .wizard-choice-card:nth-child(2) {
    grid-column: 4 / span 2;
  }

  .mode-choice-column-play .mode-choice-card-grid .wizard-choice-card:nth-child(3) {
    grid-column: 1 / span 2;
  }

  .mode-choice-column-play .mode-choice-card-grid .wizard-choice-card:nth-child(4) {
    grid-column: 3 / span 2;
  }

  .mode-choice-column-play .mode-choice-card-grid .wizard-choice-card:nth-child(5) {
    grid-column: 5 / span 2;
  }

  .mode-choice-column-train .mode-choice-card-grid {
    grid-template-columns: repeat(2, minmax(112px, 148px));
  }
}

@media (max-width: 700px) {
  .step-grid.target-grid.lens-section {
    grid-template-columns: repeat(auto-fit, minmax(138px, 1fr));
  }

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

/* Final online header override: older frame rules use display:contents/grid rows, so keep this last. */
body.is-online-mode .hero-layout {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: clamp(10px, 1.2vw, 20px) !important;
  min-height: 0 !important;
}

body.is-online-mode .hero-links {
  order: 1 !important;
  display: flex !important;
  width: 100% !important;
  justify-content: center !important;
  align-items: center !important;
  gap: clamp(8px, 1vw, 14px) !important;
}

body.is-online-mode .hero-copy {
  order: 2 !important;
  width: 100% !important;
  text-align: center !important;
  position: relative !important;
  z-index: 2 !important;
}

body.is-online-mode .hero-stats,
body.is-online-mode .stats-strip {
  order: 3 !important;
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  position: relative !important;
  z-index: 1 !important;
}

body.is-online-mode .hero-best-strip,
body.is-online-mode .hero-best-strip-online {
  display: grid !important;
  grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
  grid-column: auto !important;
  grid-row: auto !important;
  align-self: stretch !important;
  justify-self: stretch !important;
  width: 100% !important;
  max-width: 100% !important;
  margin: 4px 0 0 !important;
  transform: none !important;
}

body.is-online-mode .hero-best-card {
  transform: none !important;
}

/* Legacy guard for older online wizard-card markup, kept harmless if that structure is rendered elsewhere. */
body.is-online-mode .online-home-game-grid {
  grid-template-columns: repeat(5, minmax(150px, 1fr)) !important;
  align-items: stretch !important;
}

body.is-online-mode .online-mode-card {
  width: 100% !important;
  min-height: clamp(190px, 14vw, 250px) !important;
  overflow: hidden !important;
}

body.is-online-mode .online-mode-card .card-top {
  display: grid !important;
  grid-template-rows: minmax(86px, 1fr) auto !important;
  align-items: center !important;
  justify-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  height: 100% !important;
  min-height: 0 !important;
  padding: 18px 12px 16px !important;
  overflow: hidden !important;
  text-align: center !important;
}

body.is-online-mode .online-mode-card .wizard-choice-slot {
  position: relative !important;
  inset: auto !important;
  order: 1 !important;
  width: clamp(72px, 5.6vw, 112px) !important;
  height: clamp(72px, 5.6vw, 112px) !important;
  max-width: 112px !important;
  max-height: 112px !important;
  min-height: 0 !important;
  justify-self: center !important;
  place-self: center !important;
  overflow: hidden !important;
  transform: none !important;
}

body.is-online-mode .online-mode-card .wizard-choice-slot .asset-image,
body.is-online-mode .online-mode-card .wizard-choice-slot .mascot-asset,
body.is-online-mode .online-mode-card .wizard-choice-image {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  max-width: 100% !important;
  max-height: 100% !important;
  min-width: 0 !important;
  min-height: 0 !important;
  object-fit: contain !important;
  object-position: center !important;
  transform: none !important;
}

body.is-online-mode .online-mode-card .wizard-choice-copy {
  order: 2 !important;
  width: 100% !important;
  max-width: 100% !important;
  min-height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  display: grid !important;
  justify-items: center !important;
  align-items: center !important;
  gap: 4px !important;
  text-align: center !important;
  transform: none !important;
}

body.is-online-mode .online-mode-card .wizard-choice-copy h3,
body.is-online-mode .online-mode-card .mode-card-thanks {
  margin: 0 !important;
  max-width: 100% !important;
  text-align: center !important;
}

/* Online hub cards: Uiverse-inspired hover cards rebuilt in the WSC gold theme. */
body.is-online-mode .online-home-game-grid {
  grid-template-columns: repeat(5, minmax(178px, 1fr)) !important;
  gap: clamp(14px, 1.6vw, 22px) !important;
}

body.is-online-mode .online-glow-card {
  position: relative !important;
  display: block !important;
  min-height: clamp(292px, 22vw, 350px) !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 24px !important;
  background: transparent !important;
  color: #fff6df !important;
  font: inherit !important;
  cursor: pointer !important;
  overflow: visible !important;
  isolation: isolate;
}

body.is-online-mode .online-card-container,
body.is-online-mode .online-card-canvas,
body.is-online-mode .online-card-frame,
body.is-online-mode .online-glow-card .card-content {
  display: block;
  width: 100%;
  height: 100%;
}

body.is-online-mode .online-card-container {
  min-height: inherit;
  user-select: none;
}

body.is-online-mode .online-card-canvas {
  position: relative;
  min-height: inherit;
  perspective: 900px;
}

body.is-online-mode .online-card-canvas .tracker {
  position: absolute;
  z-index: 8;
  width: 33.333%;
  height: 33.333%;
}

body.is-online-mode .online-card-canvas .tr-1,
body.is-online-mode .online-card-canvas .tr-2,
body.is-online-mode .online-card-canvas .tr-3 {
  top: 0;
}

body.is-online-mode .online-card-canvas .tr-4,
body.is-online-mode .online-card-canvas .tr-5,
body.is-online-mode .online-card-canvas .tr-6 {
  top: 33.333%;
}

body.is-online-mode .online-card-canvas .tr-7,
body.is-online-mode .online-card-canvas .tr-8,
body.is-online-mode .online-card-canvas .tr-9 {
  top: 66.666%;
}

body.is-online-mode .online-card-canvas .tr-1,
body.is-online-mode .online-card-canvas .tr-4,
body.is-online-mode .online-card-canvas .tr-7 {
  left: 0;
}

body.is-online-mode .online-card-canvas .tr-2,
body.is-online-mode .online-card-canvas .tr-5,
body.is-online-mode .online-card-canvas .tr-8 {
  left: 33.333%;
}

body.is-online-mode .online-card-canvas .tr-3,
body.is-online-mode .online-card-canvas .tr-6,
body.is-online-mode .online-card-canvas .tr-9 {
  left: 66.666%;
}

body.is-online-mode .online-card-frame {
  position: relative;
  min-height: inherit;
  border-radius: 24px;
  transform-style: preserve-3d;
  transition:
    transform 260ms cubic-bezier(0.22, 1, 0.36, 1),
    filter 260ms ease,
    box-shadow 260ms ease;
}

body.is-online-mode .online-glow-card .card-content {
  position: relative;
  min-height: inherit;
  display: grid;
  grid-template-rows: auto minmax(92px, 1fr) auto auto;
  align-content: stretch;
  justify-items: center;
  gap: 9px;
  padding: clamp(16px, 1.7vw, 24px);
  border: 1px solid rgba(252, 209, 39, 0.46);
  border-radius: inherit;
  overflow: hidden;
  background:
    radial-gradient(circle at 18% 14%, rgba(255, 246, 210, 0.2), transparent 26%),
    radial-gradient(circle at 80% 28%, rgba(252, 209, 39, 0.2), transparent 28%),
    linear-gradient(145deg, rgba(95, 59, 35, 0.98), rgba(61, 37, 25, 0.98));
  box-shadow:
    inset 0 0 0 1px rgba(255, 246, 210, 0.16),
    inset 0 0 34px rgba(252, 209, 39, 0.08),
    0 18px 34px rgba(65, 42, 23, 0.24),
    0 0 22px rgba(252, 209, 39, 0.16);
  transform: translateZ(0);
}

body.is-online-mode .online-glow-card:hover .online-card-frame,
body.is-online-mode .online-glow-card:focus-visible .online-card-frame {
  filter: saturate(1.08) brightness(1.03);
  box-shadow: 0 0 34px rgba(252, 209, 39, 0.24);
}

body.is-online-mode .online-card-canvas .tr-1:hover ~ .online-card-frame { transform: rotateX(9deg) rotateY(-9deg) translateY(-4px); }
body.is-online-mode .online-card-canvas .tr-2:hover ~ .online-card-frame { transform: rotateX(9deg) rotateY(0deg) translateY(-5px); }
body.is-online-mode .online-card-canvas .tr-3:hover ~ .online-card-frame { transform: rotateX(9deg) rotateY(9deg) translateY(-4px); }
body.is-online-mode .online-card-canvas .tr-4:hover ~ .online-card-frame { transform: rotateX(0deg) rotateY(-9deg) translateY(-3px); }
body.is-online-mode .online-card-canvas .tr-5:hover ~ .online-card-frame { transform: rotateX(0deg) rotateY(0deg) translateY(-7px); }
body.is-online-mode .online-card-canvas .tr-6:hover ~ .online-card-frame { transform: rotateX(0deg) rotateY(9deg) translateY(-3px); }
body.is-online-mode .online-card-canvas .tr-7:hover ~ .online-card-frame { transform: rotateX(-9deg) rotateY(-9deg) translateY(-2px); }
body.is-online-mode .online-card-canvas .tr-8:hover ~ .online-card-frame { transform: rotateX(-9deg) rotateY(0deg) translateY(-3px); }
body.is-online-mode .online-card-canvas .tr-9:hover ~ .online-card-frame { transform: rotateX(-9deg) rotateY(9deg) translateY(-2px); }

body.is-online-mode .online-glow-card:focus-visible {
  outline: 3px solid rgba(252, 209, 39, 0.75);
  outline-offset: 5px;
}

body.is-online-mode .online-glow-card .card-glare {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  opacity: 0.48;
  background:
    linear-gradient(115deg, transparent 0 34%, rgba(255, 246, 210, 0.2) 43%, transparent 54%),
    radial-gradient(circle at 24% 12%, rgba(255, 255, 255, 0.24), transparent 20%);
  mix-blend-mode: screen;
  transform: translateX(-14%);
  transition: opacity 220ms ease, transform 320ms ease;
}

body.is-online-mode .online-glow-card:hover .card-glare,
body.is-online-mode .online-glow-card:focus-visible .card-glare {
  opacity: 0.82;
  transform: translateX(10%);
}

body.is-online-mode .online-card-prompt {
  position: relative;
  z-index: 3;
  justify-self: start;
  padding: 5px 9px;
  border: 1px solid rgba(252, 209, 39, 0.36);
  border-radius: 999px;
  color: #fcd127;
  font-size: clamp(0.78rem, 0.82vw, 0.95rem);
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

body.is-online-mode .online-card-art {
  position: relative;
  z-index: 3;
  display: grid;
  place-items: center;
  width: clamp(104px, 8.2vw, 136px);
  height: clamp(104px, 8.2vw, 136px);
  border-radius: 999px;
  background:
    radial-gradient(circle, rgba(255, 250, 238, 0.92), rgba(252, 209, 39, 0.2) 62%, transparent 63%);
  box-shadow:
    0 0 26px rgba(252, 209, 39, 0.32),
    inset 0 0 18px rgba(255, 246, 210, 0.35);
}

body.is-online-mode .online-card-image-slot,
body.is-online-mode .online-card-image-slot .asset-slot,
body.is-online-mode .online-card-image,
body.is-online-mode .online-card-image-slot .mascot-asset {
  display: block;
  width: 100%;
  height: 100%;
}

body.is-online-mode .online-card-image,
body.is-online-mode .online-card-image-slot .asset-image,
body.is-online-mode .online-card-image-slot .mascot-asset {
  object-fit: contain;
  filter: drop-shadow(0 10px 16px rgba(29, 18, 12, 0.28));
}

body.is-online-mode .online-glow-card .title {
  position: relative;
  z-index: 3;
  display: block;
  width: 100%;
  color: #fff6df;
  font-size: clamp(1.45rem, 2vw, 2.25rem);
  font-weight: 950;
  line-height: 0.9;
  text-align: center;
  text-shadow: 0 2px 12px rgba(0, 0, 0, 0.32);
}

body.is-online-mode .online-glow-card .subtitle {
  position: relative;
  z-index: 3;
  display: grid;
  justify-items: center;
  gap: 7px;
  width: 100%;
  color: rgba(255, 246, 223, 0.86);
  font-size: clamp(0.86rem, 1.08vw, 1.08rem);
  font-weight: 850;
  line-height: 1.04;
  text-align: center;
}

body.is-online-mode .online-glow-card .subtitle .highlight {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 28px;
  padding: 4px 10px;
  border: 1px solid rgba(252, 209, 39, 0.34);
  border-radius: 999px;
  color: #fcd127;
  background: rgba(252, 209, 39, 0.08);
}

body.is-online-mode .online-glow-card .cyber-lines,
body.is-online-mode .online-glow-card .glowing-elements,
body.is-online-mode .online-glow-card .card-particles,
body.is-online-mode .online-glow-card .corner-elements,
body.is-online-mode .online-glow-card .scan-line {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

body.is-online-mode .online-glow-card .cyber-lines {
  z-index: 2;
}

body.is-online-mode .online-glow-card .cyber-lines span {
  position: absolute;
  display: block;
  background: linear-gradient(90deg, transparent, rgba(252, 209, 39, 0.42), transparent);
  opacity: 0.42;
}

body.is-online-mode .online-glow-card .cyber-lines span:nth-child(1) {
  top: 18%;
  left: 10%;
  width: 58%;
  height: 1px;
}

body.is-online-mode .online-glow-card .cyber-lines span:nth-child(2) {
  top: 76%;
  right: 8%;
  width: 64%;
  height: 1px;
}

body.is-online-mode .online-glow-card .cyber-lines span:nth-child(3) {
  top: 9%;
  right: 18%;
  width: 1px;
  height: 52%;
  background: linear-gradient(180deg, transparent, rgba(252, 209, 39, 0.35), transparent);
}

body.is-online-mode .online-glow-card .cyber-lines span:nth-child(4) {
  bottom: 10%;
  left: 17%;
  width: 1px;
  height: 42%;
  background: linear-gradient(180deg, transparent, rgba(252, 209, 39, 0.28), transparent);
}

body.is-online-mode .online-glow-card .glowing-elements span,
body.is-online-mode .online-glow-card .card-particles span {
  position: absolute;
  display: block;
  border-radius: 999px;
  background: #fcd127;
  box-shadow: 0 0 12px rgba(252, 209, 39, 0.7);
}

body.is-online-mode .online-glow-card .glow-1 {
  top: 12%;
  right: 14%;
  width: 7px;
  height: 7px;
}

body.is-online-mode .online-glow-card .glow-2 {
  left: 12%;
  bottom: 22%;
  width: 5px;
  height: 5px;
}

body.is-online-mode .online-glow-card .glow-3 {
  right: 18%;
  bottom: 15%;
  width: 4px;
  height: 4px;
}

body.is-online-mode .online-glow-card .card-particles span {
  width: 3px;
  height: 3px;
  opacity: 0.55;
  animation: onlineCardParticleFloat 3.4s ease-in-out infinite;
}

body.is-online-mode .online-glow-card .card-particles span:nth-child(1) { left: 16%; top: 28%; animation-delay: -0.2s; }
body.is-online-mode .online-glow-card .card-particles span:nth-child(2) { left: 74%; top: 18%; animation-delay: -1.1s; }
body.is-online-mode .online-glow-card .card-particles span:nth-child(3) { left: 85%; top: 58%; animation-delay: -1.7s; }
body.is-online-mode .online-glow-card .card-particles span:nth-child(4) { left: 22%; top: 78%; animation-delay: -2.3s; }
body.is-online-mode .online-glow-card .card-particles span:nth-child(5) { left: 45%; top: 13%; animation-delay: -2.8s; }
body.is-online-mode .online-glow-card .card-particles span:nth-child(6) { left: 58%; top: 86%; animation-delay: -3.1s; }

body.is-online-mode .online-glow-card .corner-elements span {
  position: absolute;
  width: 22px;
  height: 22px;
  border-color: rgba(252, 209, 39, 0.55);
}

body.is-online-mode .online-glow-card .corner-elements span:nth-child(1) {
  top: 12px;
  left: 12px;
  border-top: 2px solid;
  border-left: 2px solid;
}

body.is-online-mode .online-glow-card .corner-elements span:nth-child(2) {
  top: 12px;
  right: 12px;
  border-top: 2px solid;
  border-right: 2px solid;
}

body.is-online-mode .online-glow-card .corner-elements span:nth-child(3) {
  right: 12px;
  bottom: 12px;
  border-right: 2px solid;
  border-bottom: 2px solid;
}

body.is-online-mode .online-glow-card .corner-elements span:nth-child(4) {
  bottom: 12px;
  left: 12px;
  border-left: 2px solid;
  border-bottom: 2px solid;
}

body.is-online-mode .online-glow-card .scan-line {
  z-index: 2;
  height: 42%;
  background: linear-gradient(180deg, transparent, rgba(252, 209, 39, 0.08), transparent);
  transform: translateY(-100%);
  animation: onlineCardScan 4.8s linear infinite;
}

@keyframes onlineCardParticleFloat {
  0%,
  100% {
    transform: translateY(0);
    opacity: 0.38;
  }

  50% {
    transform: translateY(-8px);
    opacity: 0.78;
  }
}

@keyframes onlineCardScan {
  0% {
    transform: translateY(-110%);
  }

  72%,
  100% {
    transform: translateY(240%);
  }
}

@media (prefers-reduced-motion: reduce) {
  body.is-online-mode .online-card-frame,
  body.is-online-mode .online-glow-card .card-glare,
  body.is-online-mode .online-glow-card .card-particles span,
  body.is-online-mode .online-glow-card .scan-line {
    animation: none !important;
    transition: none !important;
  }
}

@media (max-width: 980px) {
  body.is-online-mode .online-home-game-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 700px) {
  body.is-online-mode .online-home-game-grid {
    grid-template-columns: 1fr !important;
  }
}

/* Local header compaction: keep the icon rail, title, progress board, and records in one desktop band. */
@media (min-width: 1121px) {
  body.is-local-mode .hero {
    padding: clamp(14px, 1.3vw, 22px) clamp(18px, 1.7vw, 30px) clamp(10px, 1vw, 16px);
  }

  body.is-local-mode .hero-layout {
    grid-template-columns: 108px minmax(520px, 1fr) minmax(190px, 260px);
    grid-template-rows: minmax(0, auto);
    min-height: 0;
    gap: clamp(14px, 1.6vw, 28px);
    align-items: stretch;
  }

  body.is-local-mode .hero-links {
    grid-column: 1;
    grid-row: 1;
    align-self: start;
  }

  body.is-local-mode .hero-copy {
    grid-column: 2;
    grid-row: 1;
    min-height: 0;
    align-self: start;
    align-content: start;
    padding-top: clamp(42px, 6.4vw, 112px);
    pointer-events: none;
  }

  body.is-local-mode .hero h1 {
    font-size: clamp(3rem, 5.25vw, 6.2rem);
    line-height: 0.86;
  }

  body.is-local-mode .hero-progress-circles {
    grid-column: 3;
    grid-row: 1;
    width: min(100%, 260px);
    align-self: center;
    justify-self: end;
  }

body.is-local-mode .hero-best-strip {
    grid-column: 2;
    grid-row: 1;
    width: min(100%, 1000px);
    align-self: end;
    justify-self: center;
    margin-top: 0;
  }
}

/* Solo route selection preview + Learn column balance. */
.selected-section-chip-strip {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 8px 10px;
  max-width: min(100%, 1180px);
  margin: 0 auto clamp(14px, 1.8vw, 22px);
}

.mode-choice-picker-row {
  display: grid;
  grid-template-columns: clamp(132px, 14vw, 220px) minmax(0, 1fr);
  align-items: center;
  gap: clamp(12px, 1.4vw, 22px);
  max-width: min(100%, 1420px);
  margin: 0 auto clamp(14px, 1.8vw, 22px);
}

.mode-choice-picker-row .selected-section-chip-strip {
  margin: 0;
  max-width: 100%;
}

.hub-mode-switch {
  display: grid;
  justify-items: center;
  align-content: center;
  gap: 4px;
  width: min(100%, 190px);
  min-height: clamp(112px, 11vw, 164px);
  justify-self: center;
  border: 0;
  background: transparent;
  color: #5f3d20;
  cursor: pointer;
  font: inherit;
  font-size: clamp(0.78rem, 0.95vw, 0.95rem);
  font-weight: 950;
  line-height: 1;
  text-align: center;
}

.hub-mode-switch img {
  width: clamp(96px, 9vw, 150px);
  height: clamp(96px, 9vw, 150px);
  object-fit: contain;
  object-position: center;
  filter: drop-shadow(0 12px 16px rgba(65, 42, 23, 0.18));
}

.hub-mode-switch:hover,
.hub-mode-switch:focus-visible {
  color: #3f8760;
  outline: none;
  transform: translateY(-1px);
}

.selected-section-chip {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  min-height: 38px;
  padding: 4px 12px 4px 5px;
  border: 1px solid rgba(107, 78, 22, 0.18);
  border-radius: 999px;
  background: rgba(255, 250, 238, 0.72);
  color: #5f3d20;
  cursor: pointer;
  font: inherit;
  font-size: clamp(0.72rem, 0.82vw, 0.86rem);
  font-weight: 900;
  line-height: 1.05;
  box-shadow: 0 8px 18px rgba(75, 47, 33, 0.08);
}

.selected-section-chip.active {
  border-color: rgba(44, 145, 91, 0.82);
  border-width: 2px;
  background:
    radial-gradient(circle at top left, rgba(67, 186, 116, 0.28), transparent 46%),
    rgba(255, 250, 238, 0.94);
  box-shadow:
    0 0 0 3px rgba(44, 145, 91, 0.12),
    0 10px 20px rgba(63, 135, 96, 0.16);
}

.selected-section-chip:not(.active) {
  opacity: 0.72;
  filter: saturate(0.84);
}

.selected-section-chip:hover,
.selected-section-chip:focus-visible {
  background: rgba(255, 250, 238, 0.94);
  border-color: rgba(63, 135, 96, 0.42);
  outline: none;
  transform: translateY(-1px);
}

.selected-section-chip-slot {
  width: 32px;
  height: 32px;
  flex: 0 0 auto;
}

.selected-section-chip-image {
  object-fit: contain;
  object-position: center;
}

.mode-choice-card-grid .wizard-choice-card:disabled {
  cursor: not-allowed;
  opacity: 0.48;
  filter: saturate(0.65);
  transform: none !important;
}

.mode-choice-card-grid .wizard-choice-card:disabled::before {
  filter:
    sepia(0.12)
    saturate(0.42)
    hue-rotate(350deg)
    brightness(0.98)
    contrast(0.78)
    drop-shadow(0 8px 12px rgba(65, 42, 23, 0.08));
}

.train-practice-shell {
  display: grid;
  gap: clamp(16px, 2vw, 24px);
}

.train-practice-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(260px, 0.65fr);
  gap: clamp(16px, 2vw, 24px);
  align-items: start;
}

.train-practice-main,
.train-practice-side,
.train-side-section {
  border: 1px solid rgba(107, 78, 22, 0.14);
  border-radius: 8px;
  background: rgba(255, 250, 242, 0.7);
  box-shadow: 0 14px 30px rgba(57, 34, 14, 0.08);
}

.train-practice-main {
  padding: clamp(18px, 2.3vw, 28px);
}

.train-practice-side {
  display: grid;
  gap: 14px;
  padding: clamp(12px, 1.6vw, 18px);
}

.train-side-section {
  padding: clamp(14px, 1.8vw, 18px);
}

.train-side-section h3,
.train-practice-main h3 {
  margin: 0 0 12px;
  color: var(--bg);
}

.train-practice-main h3 {
  font-size: clamp(1.25rem, 2.1vw, 1.75rem);
  line-height: 1.18;
}

.train-writing-prompt p,
.train-bowl-question p,
.train-tip-intro {
  color: rgba(55, 37, 22, 0.82);
  line-height: 1.55;
}

.train-writing-checklist,
.train-criteria-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 14px 0;
}

.train-writing-checklist span,
.train-criteria-grid span {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 7px 10px;
  border: 1px solid rgba(107, 78, 22, 0.14);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.68);
  color: rgba(55, 37, 22, 0.84);
  font-size: 0.84rem;
  font-weight: 700;
}

.train-criteria-grid.compact {
  margin-top: 0;
}

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

.train-phase-button {
  display: grid;
  grid-template-columns: 62px minmax(0, 1fr);
  gap: 4px 10px;
  width: 100%;
  padding: 12px;
  border: 1px solid rgba(107, 78, 22, 0.14);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.74);
  color: rgba(55, 37, 22, 0.86);
  text-align: left;
  cursor: pointer;
}

.train-phase-button span {
  grid-row: span 2;
  align-self: start;
  justify-self: start;
  padding: 5px 7px;
  border-radius: 999px;
  background: rgba(177, 31, 31, 0.12);
  color: var(--accent-strong);
  font-size: 0.75rem;
  font-weight: 800;
}

.train-phase-button strong {
  font-size: 0.94rem;
}

.train-phase-button em {
  font-size: 0.78rem;
  font-style: normal;
  line-height: 1.35;
  opacity: 0.76;
}

.train-phase-button.active {
  border-color: rgba(177, 31, 31, 0.42);
  box-shadow: 0 0 0 3px rgba(177, 31, 31, 0.12);
}

.train-tip-window {
  max-width: min(720px, calc(100vw - 28px));
}

.train-tip-card .setup-card-header {
  align-items: center;
}

.train-tip-rule-list {
  margin-top: 12px;
}

.train-bowl-setup {
  max-width: 760px;
  margin: 0 auto;
}

.train-bowl-question .raw-quiz-options {
  margin-top: 18px;
}

.bowl-option-button:disabled {
  cursor: default;
}

.scholars-bowl-setup {
  max-width: 880px;
}

.bowl-produced-count {
  align-self: center;
  color: rgba(55, 37, 22, 0.72);
  font-size: 0.9rem;
  font-weight: 800;
}

.bowl-flow-bar {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 8px;
  margin: 16px 0;
}

.bowl-flow-bar span {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 42px;
  padding: 8px 10px;
  border: 1px solid rgba(107, 78, 22, 0.16);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.62);
  color: rgba(55, 37, 22, 0.84);
  font-size: 0.78rem;
  font-weight: 800;
  line-height: 1.15;
}

.bowl-flow-bar strong {
  display: inline-grid;
  width: 22px;
  height: 22px;
  flex: 0 0 auto;
  place-items: center;
  border-radius: 999px;
  background: rgba(177, 31, 31, 0.12);
  color: var(--accent-strong);
  font-size: 0.76rem;
}

.bowl-stimulus-card {
  display: grid;
  gap: 10px;
  margin-bottom: 16px;
  padding: clamp(16px, 2vw, 22px);
  border: 1px solid rgba(177, 31, 31, 0.2);
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.82), rgba(255, 246, 230, 0.72)),
    rgba(255, 250, 242, 0.9);
}

.bowl-stimulus-head,
.bowl-hook-row,
.bowl-target-chip-row,
.bowl-resource-row,
.bowl-source-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.bowl-media-kind,
.bowl-media-role,
.bowl-hook-row span,
.bowl-target-chip-row span,
.bowl-resource-row span,
.bowl-source-row a {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 5px 9px;
  border-radius: 999px;
  border: 1px solid rgba(107, 78, 22, 0.14);
  background: rgba(255, 255, 255, 0.72);
  color: rgba(55, 37, 22, 0.76);
  font-size: 0.76rem;
  font-weight: 800;
}

.bowl-source-row a {
  max-width: 100%;
  color: var(--accent-strong);
  line-height: 1.2;
  text-decoration: none;
  white-space: normal;
}

.bowl-resource-row span {
  max-width: 100%;
  border-radius: 8px;
  line-height: 1.2;
  white-space: normal;
}

.bowl-source-row a:hover,
.bowl-source-row a:focus-visible {
  text-decoration: underline;
}

.bowl-media-kind {
  color: var(--accent-strong);
  background: rgba(177, 31, 31, 0.1);
}

.bowl-stimulus-media-frame {
  position: relative;
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  margin: 2px 0 4px;
  overflow: hidden;
  border: 1px solid rgba(107, 78, 22, 0.18);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 14px 34px rgba(55, 37, 22, 0.12);
}

.bowl-stimulus-media-frame img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.bowl-stimulus-card h3 {
  margin: 0;
  color: var(--bg);
  font-size: clamp(1.25rem, 2vw, 1.65rem);
}

.bowl-stimulus-card p {
  margin: 0;
}

.bowl-stimulus-cue {
  padding-left: 12px;
  border-left: 3px solid rgba(177, 31, 31, 0.36);
  color: rgba(55, 37, 22, 0.82);
  font-weight: 700;
  line-height: 1.45;
}

.scholars-bowl-card > h3 {
  margin-top: 12px;
}

.scholars-bowl-side {
  gap: 14px;
}

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

.bowl-target-card {
  display: grid;
  gap: 8px;
  padding: 12px;
  border: 1px solid rgba(107, 78, 22, 0.13);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.64);
}

.bowl-target-card strong {
  color: var(--bg);
  line-height: 1.25;
}

.bowl-target-card p {
  margin: 0;
  color: rgba(55, 37, 22, 0.76);
  font-size: 0.86rem;
  line-height: 1.42;
}

.bowl-target-chip-row {
  gap: 6px;
}

.bowl-target-chip-row span {
  min-height: 24px;
  padding: 4px 7px;
  font-size: 0.68rem;
}

.bowl-reveal {
  display: grid;
  gap: 10px;
  margin-top: 16px;
  padding: 14px;
  border-radius: 8px;
  border: 1px solid rgba(107, 78, 22, 0.16);
  background: rgba(255, 255, 255, 0.74);
}

.bowl-reveal.correct {
  border-color: rgba(63, 135, 96, 0.28);
  background: rgba(239, 250, 242, 0.84);
}

.bowl-reveal.wrong {
  border-color: rgba(177, 31, 31, 0.22);
  background: rgba(255, 242, 238, 0.78);
}

.bowl-reveal strong {
  color: var(--bg);
}

.bowl-reveal p {
  margin: 0;
}

.result-metrics.compact {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin: 0;
}

@media (max-width: 860px) {
  .train-practice-layout {
    grid-template-columns: 1fr;
  }

  .bowl-flow-bar {
    grid-template-columns: 1fr;
  }
}

@media (min-width: 981px) {
  .mode-choice-column-learn .mode-choice-card-grid {
    grid-template-columns: repeat(2, minmax(118px, 1fr));
    justify-content: center;
  }

  .mode-choice-column-learn .mode-choice-card-grid .wizard-choice-card {
    grid-column: auto;
    width: min(100%, 156px) !important;
  }
}

/* Experimental local header: same icon-row rhythm as online, with local records below the title. */
@media (min-width: 1121px) {
  body.is-local-mode .hero {
    padding: clamp(12px, 1vw, 18px) clamp(18px, 1.7vw, 30px) clamp(10px, 1vw, 16px);
  }

  body.is-local-mode .hero-layout {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: flex-start !important;
    min-height: 0 !important;
    gap: clamp(4px, 0.55vw, 9px) !important;
  }

  body.is-local-mode .hero-links {
    order: 1 !important;
    display: flex !important;
    width: 100% !important;
    justify-content: center !important;
    align-items: center !important;
    gap: clamp(8px, 1vw, 14px) !important;
    padding: 0 !important;
  }

  body.is-local-mode .hero-discord-link,
  body.is-local-mode .hero-link-icon,
  body.is-local-mode .session-signout-button {
    width: 58px !important;
  }

  body.is-local-mode .session-controls {
    width: auto !important;
  }

  body.is-local-mode .session-control-stack {
    display: flex !important;
    align-items: center !important;
    gap: clamp(8px, 1vw, 14px) !important;
  }

  body.is-local-mode .session-mode-icon-button {
    width: 86px !important;
  }

  body.is-local-mode .session-mode-icon-button.switch-online img {
    width: 84px !important;
    height: 84px !important;
  }

  body.is-local-mode .session-mode-icon-button.switch-local img {
    width: 66px !important;
    height: 66px !important;
  }

  body.is-local-mode .hero-copy {
    order: 2 !important;
    width: 100% !important;
    min-height: 0 !important;
    padding: 0 !important;
    text-align: center !important;
    align-content: center !important;
    pointer-events: none;
  }

  body.is-local-mode .hero h1 {
    font-size: clamp(2.7rem, 4.7vw, 5rem);
    line-height: 0.88;
  }

  body.is-local-mode .hero-stats,
  body.is-local-mode .stats-strip {
    order: 3 !important;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    grid-template-rows: auto auto !important;
    align-items: center !important;
    gap: clamp(5px, 0.7vw, 10px) !important;
    width: 100% !important;
    max-width: 1420px !important;
    margin-top: clamp(-52px, -3.2vw, -28px) !important;
  }

  body.is-local-mode .hero-best-strip {
    grid-column: 1 !important;
    grid-row: 2 !important;
    width: 100% !important;
    max-width: 100% !important;
    align-self: center !important;
    justify-self: stretch !important;
    margin: 0 !important;
    padding: 28px clamp(42px, 5vw, 76px) !important;
  }

  body.is-local-mode .hero-progress-circles {
    grid-column: 1 !important;
    grid-row: 1 !important;
    width: min(100%, 196px) !important;
    min-height: 196px !important;
    align-self: center !important;
    justify-self: end !important;
    padding: 25px 24px !important;
  }

  body.is-local-mode .progress-circle-card {
    gap: 7px !important;
    padding: 2px 0 !important;
  }

  body.is-local-mode .stat-progress-ring {
    width: 56px !important;
    height: 56px !important;
  }

  body.is-local-mode .stat-progress-ring-inner {
    width: 42px !important;
    height: 42px !important;
  }

  body.is-local-mode .stat-progress-ring-inner strong {
    font-size: 0.78rem !important;
  }

  body.is-local-mode .stat-progress-circle-copy strong {
    font-size: 0.78rem !important;
  }

  body.is-local-mode .stat-progress-circle-copy em {
    font-size: 0.6rem !important;
  }
}

/* Final local header mosaic: keep this after earlier local header experiments. */
@media (min-width: 1121px) {
  body.is-local-mode .hero {
    position: relative !important;
    min-height: clamp(410px, 31vw, 520px) !important;
    padding: 0 clamp(18px, 1.7vw, 30px) clamp(8px, 0.8vw, 14px) !important;
    overflow: hidden !important;
  }

  body.is-local-mode .hero-layout {
    display: block !important;
    position: relative !important;
    width: 100% !important;
    min-height: clamp(398px, 30vw, 504px) !important;
  }

  body.is-local-mode .hero-links {
    display: contents !important;
    width: auto !important;
    padding: 0 !important;
  }

  body.is-local-mode .hero-discord-link,
  body.is-local-mode .hero-link-icon,
  body.is-local-mode .session-controls {
    position: absolute !important;
    z-index: 4 !important;
  }

  body.is-local-mode .hero-discord-link {
    left: calc(50% - 110px) !important;
    top: clamp(36px, 3.4vw, 58px) !important;
    width: clamp(58px, 4.2vw, 76px) !important;
  }

  body.is-local-mode .hero-link-icon {
    width: clamp(62px, 4.4vw, 84px) !important;
  }

  body.is-local-mode .hero-link-icon:nth-of-type(1) {
    left: clamp(82px, 9vw, 155px) !important;
    top: clamp(56px, 5.5vw, 94px) !important;
  }

  body.is-local-mode .hero-link-icon:nth-of-type(2) {
    left: clamp(88px, 9.4vw, 166px) !important;
    top: clamp(160px, 12vw, 220px) !important;
  }

  body.is-local-mode .session-controls {
    left: calc(50% + 34px) !important;
    top: clamp(32px, 3.2vw, 55px) !important;
    width: auto !important;
  }

  body.is-local-mode .session-control-stack {
    display: flex !important;
    align-items: center !important;
    gap: clamp(16px, 2vw, 34px) !important;
  }

  body.is-local-mode .session-signout-button {
    width: clamp(58px, 4.3vw, 78px) !important;
  }

  body.is-local-mode .session-mode-icon-button {
    width: clamp(82px, 5.8vw, 112px) !important;
  }

  body.is-local-mode .session-mode-icon-button.switch-online img {
    width: clamp(82px, 5.8vw, 112px) !important;
    height: clamp(82px, 5.8vw, 112px) !important;
  }

  body.is-local-mode .session-mode-icon-button.switch-local img {
    width: clamp(68px, 4.8vw, 90px) !important;
    height: clamp(68px, 4.8vw, 90px) !important;
  }

  body.is-local-mode .hero-copy {
    position: absolute !important;
    left: 50% !important;
    top: clamp(150px, 13.3vw, 220px) !important;
    width: min(56vw, 760px) !important;
    min-height: 0 !important;
    padding: 0 !important;
    text-align: center !important;
    transform: translateX(-50%) !important;
    z-index: 2 !important;
    pointer-events: none;
  }

  body.is-local-mode .hero h1 {
    font-size: clamp(3.05rem, 5.05vw, 6.15rem) !important;
    line-height: 0.86 !important;
  }

  body.is-local-mode .hero-stats,
  body.is-local-mode .stats-strip {
    display: contents !important;
    margin: 0 !important;
    width: auto !important;
    max-width: none !important;
  }

  body.is-local-mode .hero-progress-circles {
    position: absolute !important;
    right: clamp(98px, 9.6vw, 180px) !important;
    top: clamp(64px, 5.2vw, 92px) !important;
    width: clamp(196px, 14vw, 264px) !important;
    min-height: clamp(196px, 14vw, 264px) !important;
    padding: clamp(24px, 2vw, 36px) clamp(22px, 1.9vw, 34px) !important;
    z-index: 3 !important;
  }

  body.is-local-mode .hero-best-strip {
    position: absolute !important;
    left: 50% !important;
    right: auto !important;
    bottom: clamp(10px, 1vw, 18px) !important;
    width: min(88vw, 1420px) !important;
    max-width: min(88vw, 1420px) !important;
    margin: 0 !important;
    padding: clamp(28px, 2.3vw, 38px) clamp(42px, 5vw, 76px) !important;
    transform: translateX(-50%) !important;
    z-index: 2 !important;
  }
}

/* Final hub-mode location: the local/online switch lives beside guiding sections, not in the solo header. */
@media (min-width: 1121px) {
  body.is-local-mode .session-controls .session-mode-icon-button {
    display: none !important;
  }
}

/* App cursor: local transparent alpaca pointer. */
:root {
  --wsc-app-cursor: url("./assets/icons/ui/alpaca-pointer-cursor.png?v=20260523pathstage36") 13 1, auto;
  --wsc-click-cursor: url("./assets/icons/ui/alpaca-pointer-cursor.png?v=20260523pathstage36") 13 1, pointer;
}

html,
body,
#app {
  cursor: var(--wsc-app-cursor) !important;
}

a,
button,
summary,
select,
label,
[role="button"],
[tabindex]:not([tabindex="-1"]),
input[type="button"],
input[type="checkbox"],
input[type="radio"],
input[type="reset"],
input[type="submit"],
.choice-card,
.mode-card,
.target-card,
.wizard-rail-item,
.route-button,
.hero-link-icon,
.session-signout-button,
.session-mode-icon-button,
.raw-entry-back-to-top {
  cursor: var(--wsc-click-cursor) !important;
}

input:not([type="button"]):not([type="checkbox"]):not([type="radio"]):not([type="reset"]):not([type="submit"]),
textarea,
[contenteditable="true"] {
  cursor: text !important;
}

button:disabled,
[disabled],
[aria-disabled="true"],
.is-disabled {
  cursor: not-allowed !important;
}

/* Final route chooser cleanup: transparent section chips and no category boxes. */
.selected-section-chip {
  min-height: 40px !important;
  padding: 4px 14px 4px 7px !important;
  border: 1px solid rgba(107, 78, 22, 0.2) !important;
  border-radius: 12px !important;
  background: transparent !important;
  box-shadow: none !important;
}

.selected-section-chip.active,
.selected-section-chip[aria-pressed="true"],
.selected-section-chip:active,
.selected-section-chip:focus {
  border-color: rgba(44, 145, 91, 0.82) !important;
  border-width: 2px !important;
  background:
    radial-gradient(circle at top left, rgba(67, 186, 116, 0.28), transparent 46%),
    rgba(255, 250, 238, 0.94) !important;
  box-shadow:
    0 0 0 3px rgba(44, 145, 91, 0.12),
    0 10px 20px rgba(63, 135, 96, 0.16) !important;
}

.selected-section-chip:not(.active) {
  opacity: 0.78 !important;
  filter: none !important;
}

.selected-section-chip:hover:not(.active):not([aria-pressed="true"]) {
  border-color: rgba(107, 78, 22, 0.42) !important;
  background: transparent !important;
  box-shadow: none !important;
}

.mode-choice-column {
  border-color: transparent !important;
  background: transparent !important;
  box-shadow: none !important;
}

/* Final route chooser experiment: section dock + radial Learn / Play / Train hubs. */
.step-grid.mode-landing-grid {
  padding-top: clamp(6px, 0.8vw, 12px) !important;
}

.mode-choice-picker-row {
  position: relative !important;
  display: block !important;
  max-width: min(100%, 1840px) !important;
  margin: 0 auto clamp(14px, 1.4vw, 22px) !important;
  overflow: visible !important;
}

.mode-choice-picker-row .hub-mode-switch {
  position: absolute !important;
  left: 0 !important;
  top: -12px !important;
  width: 104px !important;
  min-height: 84px !important;
  opacity: 0.74 !important;
  transform: scale(0.72) !important;
  transform-origin: left top !important;
  z-index: 6 !important;
}

.mode-choice-picker-row .hub-mode-switch img {
  width: 88px !important;
  height: 88px !important;
}

.selected-section-chip-strip {
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: end !important;
  justify-content: center !important;
  gap: clamp(2px, 0.28vw, 6px) !important;
  width: 100% !important;
  max-width: none !important;
  min-height: clamp(58px, 5vw, 82px) !important;
  margin: 0 auto !important;
  padding: clamp(16px, 1.6vw, 26px) clamp(4px, 1vw, 18px) clamp(3px, 0.5vw, 8px) clamp(90px, 8vw, 132px) !important;
  overflow: visible !important;
}

.selected-section-chip {
  position: relative !important;
  z-index: 1 !important;
  flex: 0 0 auto !important;
  min-height: clamp(27px, 2.2vw, 34px) !important;
  gap: 4px !important;
  padding: 2px clamp(5px, 0.54vw, 8px) 2px 3px !important;
  border-radius: 8px !important;
  font-size: clamp(0.48rem, 0.58vw, 0.66rem) !important;
  line-height: 1 !important;
  white-space: nowrap !important;
  transform-origin: center bottom !important;
  transition:
    transform 190ms cubic-bezier(0.2, 0.9, 0.2, 1),
    opacity 160ms ease,
    border-color 160ms ease,
    background 160ms ease,
    box-shadow 160ms ease !important;
  will-change: transform !important;
}

.selected-section-chip-slot {
  width: clamp(19px, 1.75vw, 27px) !important;
  height: clamp(19px, 1.75vw, 27px) !important;
}

.selected-section-chip-strip:hover .selected-section-chip {
  opacity: 0.54 !important;
  transform: translateY(0) scale(0.88) !important;
}

.selected-section-chip-strip .selected-section-chip:hover,
.selected-section-chip-strip .selected-section-chip:focus-visible {
  opacity: 1 !important;
  z-index: 12 !important;
  transform: translateY(-14px) scale(1.52) !important;
}

.selected-section-chip-strip .selected-section-chip:has(+ .selected-section-chip:hover),
.selected-section-chip-strip .selected-section-chip:hover + .selected-section-chip,
.selected-section-chip-strip .selected-section-chip:has(+ .selected-section-chip:focus-visible),
.selected-section-chip-strip .selected-section-chip:focus-visible + .selected-section-chip {
  opacity: 0.92 !important;
  z-index: 8 !important;
  transform: translateY(-8px) scale(1.24) !important;
}

.selected-section-chip-strip .selected-section-chip:has(+ .selected-section-chip + .selected-section-chip:hover),
.selected-section-chip-strip .selected-section-chip:hover + .selected-section-chip + .selected-section-chip,
.selected-section-chip-strip .selected-section-chip:has(+ .selected-section-chip + .selected-section-chip:focus-visible),
.selected-section-chip-strip .selected-section-chip:focus-visible + .selected-section-chip + .selected-section-chip {
  opacity: 0.74 !important;
  z-index: 5 !important;
  transform: translateY(-4px) scale(1.09) !important;
}

.selected-section-chip.active,
.selected-section-chip[aria-pressed="true"] {
  opacity: 1 !important;
}

.mode-choice-board {
  display: flex !important;
  align-items: flex-start !important;
  justify-content: center !important;
  gap: clamp(24px, 4vw, 76px) !important;
  max-width: min(100%, 1360px) !important;
  margin: clamp(8px, 1vw, 18px) auto 0 !important;
  padding: 0 clamp(8px, 1vw, 18px) clamp(18px, 1.8vw, 30px) !important;
  overflow: visible !important;
}

.mode-choice-column {
  --hub-size: clamp(88px, 7.2vw, 116px);
  --tile-size: clamp(76px, 6.3vw, 102px);
  --ring-radius: clamp(82px, 7.1vw, 112px);
  position: relative !important;
  flex: 0 1 clamp(270px, 27vw, 360px) !important;
  width: clamp(270px, 27vw, 360px) !important;
  height: clamp(296px, 28vw, 382px) !important;
  min-width: 0 !important;
  padding: 0 !important;
  overflow: visible !important;
}

.mode-choice-heading {
  position: absolute !important;
  left: 50% !important;
  top: 50% !important;
  z-index: 7 !important;
  display: grid !important;
  grid-template-columns: 1fr !important;
  grid-template-rows: minmax(0, 1fr) auto !important;
  place-items: center !important;
  align-content: center !important;
  width: var(--hub-size) !important;
  height: var(--hub-size) !important;
  min-height: 0 !important;
  margin: 0 !important;
  padding: clamp(8px, 0.8vw, 12px) !important;
  border: 1px solid rgba(107, 78, 22, 0.22) !important;
  border-radius: 999px !important;
  background: rgba(255, 250, 238, 0.68) !important;
  box-shadow: 0 12px 24px rgba(75, 47, 33, 0.12) !important;
  transform: translate(-50%, -50%) scale(1) !important;
  transition: transform 190ms cubic-bezier(0.2, 0.9, 0.2, 1), box-shadow 160ms ease !important;
  pointer-events: none !important;
}

.mode-choice-column.is-open .mode-choice-heading {
  pointer-events: none !important;
}

.mode-choice-heading-slot {
  width: clamp(44px, 3.7vw, 62px) !important;
  height: clamp(44px, 3.7vw, 62px) !important;
}

.mode-choice-heading h3 {
  font-size: clamp(1rem, 1.35vw, 1.38rem) !important;
  text-align: center !important;
}

.mode-choice-column:hover .mode-choice-heading {
  transform: translate(-50%, -50%) scale(1.08) !important;
  box-shadow: 0 16px 30px rgba(75, 47, 33, 0.16) !important;
}

.mode-choice-card-grid {
  position: absolute !important;
  inset: 0 !important;
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  overflow: visible !important;
}

.mode-choice-card-grid .wizard-choice-card {
  --tile-scale: 1;
  --tile-x: 50%;
  --tile-y: 50%;
  --tile-translate: translate(-50%, -50%);
  position: absolute !important;
  left: var(--tile-x) !important;
  top: var(--tile-y) !important;
  z-index: 4 !important;
  width: var(--tile-size) !important;
  height: var(--tile-size) !important;
  aspect-ratio: 1 / 1 !important;
  padding: clamp(10px, 1.1vw, 15px) !important;
  border-radius: 16px !important;
  clip-path: inset(2% round 14px) !important;
  --sign-image: var(--sign-square-a) !important;
  --sign-aspect: 1 / 1 !important;
  transform: var(--tile-translate) scale(var(--tile-scale)) !important;
  transition:
    transform 190ms cubic-bezier(0.2, 0.9, 0.2, 1),
    filter 160ms ease,
    opacity 160ms ease !important;
}

.mode-choice-card-grid .wizard-choice-card:nth-child(even) {
  --sign-image: var(--sign-square-b) !important;
}

.mode-choice-card-grid .wizard-choice-card .card-top {
  grid-template-columns: 1fr !important;
  grid-template-rows: minmax(0, 1fr) auto !important;
  gap: 3px !important;
  text-align: center !important;
}

.mode-choice-card-grid .wizard-choice-card .wizard-choice-slot {
  order: 1 !important;
  width: min(72%, 58px) !important;
  height: min(72%, 58px) !important;
  justify-self: center !important;
}

.mode-choice-card-grid .wizard-choice-card .wizard-choice-copy {
  order: 2 !important;
  justify-items: center !important;
  text-align: center !important;
}

.mode-choice-card-grid .wizard-choice-card .wizard-choice-copy h3 {
  font-size: clamp(0.58rem, 0.68vw, 0.78rem) !important;
  line-height: 0.98 !important;
  text-align: center !important;
}

.mode-choice-column-learn .mode-choice-card-grid .wizard-choice-card:nth-child(1),
.mode-choice-column-train .mode-choice-card-grid .wizard-choice-card:nth-child(1) {
  --tile-x: 50%;
  --tile-y: calc(50% - var(--ring-radius));
}

.mode-choice-column-learn .mode-choice-card-grid .wizard-choice-card:nth-child(2),
.mode-choice-column-train .mode-choice-card-grid .wizard-choice-card:nth-child(2) {
  --tile-x: calc(50% + var(--ring-radius));
  --tile-y: 50%;
}

.mode-choice-column-learn .mode-choice-card-grid .wizard-choice-card:nth-child(3),
.mode-choice-column-train .mode-choice-card-grid .wizard-choice-card:nth-child(3) {
  --tile-x: 50%;
  --tile-y: calc(50% + var(--ring-radius));
}

.mode-choice-column-learn .mode-choice-card-grid .wizard-choice-card:nth-child(4),
.mode-choice-column-train .mode-choice-card-grid .wizard-choice-card:nth-child(4) {
  --tile-x: calc(50% - var(--ring-radius));
  --tile-y: 50%;
}

.mode-choice-column-play .mode-choice-card-grid .wizard-choice-card:nth-child(1) {
  --tile-x: 50%;
  --tile-y: calc(50% - var(--ring-radius));
}

.mode-choice-column-play .mode-choice-card-grid .wizard-choice-card:nth-child(2) {
  --tile-x: calc(50% + (var(--ring-radius) * 0.95));
  --tile-y: calc(50% - (var(--ring-radius) * 0.3));
}

.mode-choice-column-play .mode-choice-card-grid .wizard-choice-card:nth-child(3) {
  --tile-x: calc(50% + (var(--ring-radius) * 0.58));
  --tile-y: calc(50% + (var(--ring-radius) * 0.82));
}

.mode-choice-column-play .mode-choice-card-grid .wizard-choice-card:nth-child(4) {
  --tile-x: calc(50% - (var(--ring-radius) * 0.58));
  --tile-y: calc(50% + (var(--ring-radius) * 0.82));
}

.mode-choice-column-play .mode-choice-card-grid .wizard-choice-card:nth-child(5) {
  --tile-x: calc(50% - (var(--ring-radius) * 0.95));
  --tile-y: calc(50% - (var(--ring-radius) * 0.3));
}

.mode-choice-card-grid .wizard-choice-card:hover,
.mode-choice-card-grid .wizard-choice-card:focus-visible {
  --tile-scale: 1.24;
  z-index: 10 !important;
  filter: drop-shadow(0 14px 18px rgba(65, 42, 23, 0.18)) !important;
}

.mode-choice-card-grid:hover .wizard-choice-card:not(:hover):not(:focus-visible) {
  --tile-scale: 0.96;
  opacity: 0.84 !important;
}

.mode-choice-card-grid .wizard-choice-card:disabled {
  opacity: 0.42 !important;
}

@media (max-width: 980px) {
  .selected-section-chip-strip {
    justify-content: flex-start !important;
    overflow-x: auto !important;
    overflow-y: visible !important;
    padding-left: 12px !important;
    scrollbar-width: none;
  }

  .selected-section-chip-strip::-webkit-scrollbar {
    display: none;
  }

  .mode-choice-picker-row .hub-mode-switch {
    position: relative !important;
    left: auto !important;
    top: auto !important;
    margin: 0 auto 6px !important;
  }

  .mode-choice-board {
    flex-wrap: wrap !important;
  }
}

.mode-choice-column .mode-choice-card-grid .wizard-choice-card,
.mode-choice-column-play .mode-choice-card-grid .wizard-choice-card,
.mode-choice-column-train .mode-choice-card-grid .wizard-choice-card,
.mode-choice-column-learn .mode-choice-card-grid .wizard-choice-card {
  width: var(--tile-size) !important;
  height: var(--tile-size) !important;
  min-width: var(--tile-size) !important;
  max-width: var(--tile-size) !important;
  min-height: var(--tile-size) !important;
  max-height: var(--tile-size) !important;
}

.mode-choice-shell {
  width: calc(100vw - 88px) !important;
  max-width: calc(100vw - 88px) !important;
  min-width: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  overflow: visible !important;
  box-sizing: border-box !important;
}

.mode-choice-picker-row {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
}

.selected-section-chip-strip {
  box-sizing: border-box !important;
  max-width: 100% !important;
  overflow-x: auto !important;
  overflow-y: visible !important;
  scrollbar-width: none !important;
}

.selected-section-chip-strip::-webkit-scrollbar {
  display: none !important;
}

.mode-choice-board {
  width: min(100%, 1040px) !important;
  max-width: min(100%, 1040px) !important;
  box-sizing: border-box !important;
  gap: clamp(18px, 2.4vw, 34px) !important;
}

.mode-choice-column {
  flex: 0 1 clamp(264px, 27vw, 308px) !important;
  width: clamp(264px, 27vw, 308px) !important;
}

@media (max-width: 1280px) {
  .selected-section-chip-strip {
    justify-content: flex-start !important;
    padding-left: 104px !important;
  }
}

@media (max-width: 760px) {
  .mode-choice-shell {
    width: calc(100vw - 28px) !important;
    max-width: calc(100vw - 28px) !important;
  }
}

/* May 23 final compact shell: small header, rolling stage, icon-only guiding-section dock. */
html,
body {
  max-width: 100% !important;
  overflow-x: hidden !important;
}

.page-shell,
.layout,
.wizard.card-panel {
  max-width: 100% !important;
  box-sizing: border-box !important;
}

body.is-local-mode .hero {
  min-height: 0 !important;
  height: auto !important;
  max-height: none !important;
  padding: clamp(8px, 0.8vw, 12px) clamp(12px, 1.4vw, 22px) clamp(9px, 0.9vw, 14px) !important;
  overflow: visible !important;
}

body.is-local-mode .hero-layout {
  display: grid !important;
  grid-template-columns: auto minmax(220px, 0.82fr) minmax(210px, 0.62fr) !important;
  grid-template-rows: auto auto !important;
  align-items: center !important;
  gap: clamp(6px, 0.8vw, 12px) clamp(12px, 1.4vw, 22px) !important;
  width: 100% !important;
  min-height: 0 !important;
  max-height: none !important;
}

body.is-local-mode .hero-links {
  grid-column: 1 !important;
  grid-row: 1 !important;
  position: static !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: clamp(6px, 0.7vw, 10px) !important;
  width: auto !important;
  padding: 0 !important;
}

body.is-local-mode .hero-discord-link,
body.is-local-mode .hero-link-icon,
body.is-local-mode .session-controls,
body.is-local-mode .session-signout-button {
  position: static !important;
  inset: auto !important;
  width: clamp(42px, 3.6vw, 54px) !important;
  min-width: 0 !important;
  transform: none !important;
}

body.is-local-mode .hero-link-icon img,
body.is-local-mode .hero-discord-link img,
body.is-local-mode .session-signout-button img {
  width: 100% !important;
  height: auto !important;
  object-fit: contain !important;
}

body.is-local-mode .hero-copy {
  grid-column: 2 !important;
  grid-row: 1 !important;
  position: static !important;
  width: auto !important;
  min-height: 0 !important;
  padding: 0 !important;
  text-align: left !important;
  transform: none !important;
  pointer-events: none !important;
}

body.is-local-mode .hero h1 {
  margin: 0 !important;
  font-size: clamp(1.72rem, 2.65vw, 3.05rem) !important;
  line-height: 0.9 !important;
  letter-spacing: 0 !important;
}

body.is-local-mode .hero-stats,
body.is-local-mode .stats-strip {
  display: contents !important;
}

body.is-local-mode .hero-progress-circles {
  grid-column: 3 !important;
  grid-row: 1 !important;
  position: static !important;
  justify-self: end !important;
  align-self: center !important;
  width: min(100%, 238px) !important;
  min-height: 0 !important;
  padding: 12px 16px !important;
  transform: none !important;
}

body.is-local-mode .progress-circle-card {
  gap: 5px !important;
}

body.is-local-mode .stat-progress-ring {
  width: 46px !important;
  height: 46px !important;
}

body.is-local-mode .stat-progress-ring-inner {
  width: 34px !important;
  height: 34px !important;
}

body.is-local-mode .stat-progress-ring-inner strong,
body.is-local-mode .stat-progress-circle-copy strong {
  font-size: 0.72rem !important;
}

body.is-local-mode .stat-progress-circle-copy em {
  font-size: 0.56rem !important;
}

body.is-local-mode .hero-best-strip {
  grid-column: 1 / -1 !important;
  grid-row: 2 !important;
  position: static !important;
  justify-self: center !important;
  align-self: center !important;
  width: min(100%, 900px) !important;
  max-width: min(100%, 900px) !important;
  margin: 0 !important;
  padding: 11px clamp(18px, 2.8vw, 34px) !important;
  transform: none !important;
  display: grid !important;
  grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
  gap: 7px !important;
}

body.is-local-mode .hero-best-card {
  min-height: 48px !important;
  padding: 3px 7px !important;
}

body.is-local-mode .hero-best-card span {
  font-size: clamp(0.48rem, 0.58vw, 0.64rem) !important;
}

body.is-local-mode .hero-best-card strong {
  font-size: clamp(0.72rem, 0.86vw, 0.96rem) !important;
}

body.is-local-mode .layout {
  position: relative !important;
  perspective: 1200px !important;
  margin-top: clamp(-2px, -0.2vw, 0px) !important;
  padding-top: clamp(8px, 1vw, 14px) !important;
  overflow: visible !important;
}

body.is-local-mode .layout::before {
  content: "" !important;
  position: absolute !important;
  left: 50% !important;
  top: 0 !important;
  width: min(92vw, 1180px) !important;
  height: 34px !important;
  border-radius: 999px 999px 0 0 !important;
  background: linear-gradient(180deg, rgba(255, 250, 238, 0.44), rgba(255, 250, 238, 0)) !important;
  transform: translateX(-50%) rotateX(58deg) !important;
  transform-origin: center top !important;
  pointer-events: none !important;
}

body.is-local-mode .wizard.card-panel {
  border-radius: clamp(34px, 4vw, 58px) clamp(34px, 4vw, 58px) 26px 26px !important;
  transform: perspective(1200px) rotateX(1.6deg) !important;
  transform-origin: top center !important;
  transition: transform 260ms ease, border-radius 260ms ease !important;
}

body.is-local-mode .wizard.card-panel:focus-within,
body.is-local-mode .wizard.card-panel:hover {
  transform: perspective(1200px) rotateX(0deg) !important;
}

.selected-section-chip-strip {
  justify-content: center !important;
  align-items: center !important;
  gap: clamp(8px, 1vw, 14px) !important;
  min-height: 86px !important;
  padding: 18px clamp(14px, 2vw, 26px) 22px !important;
  border: 1px solid rgba(107, 78, 22, 0.12) !important;
  border-radius: 22px !important;
  background: rgba(255, 250, 238, 0.34) !important;
  backdrop-filter: blur(6px) !important;
  overflow-x: auto !important;
  overflow-y: visible !important;
}

.selected-section-chip {
  width: clamp(42px, 4vw, 56px) !important;
  height: clamp(42px, 4vw, 56px) !important;
  min-width: clamp(42px, 4vw, 56px) !important;
  min-height: clamp(42px, 4vw, 56px) !important;
  padding: 5px !important;
  display: grid !important;
  place-items: center !important;
  gap: 0 !important;
  border-radius: 999px !important;
  border: 1px solid rgba(107, 78, 22, 0.18) !important;
  background: rgba(255, 250, 238, 0.36) !important;
  box-shadow: 0 8px 14px rgba(75, 47, 33, 0.08) !important;
  overflow: visible !important;
}

.selected-section-chip > span:not(.selected-section-chip-slot) {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
  clip: rect(0 0 0 0) !important;
  clip-path: inset(50%) !important;
  white-space: nowrap !important;
}

.selected-section-chip-slot {
  width: 100% !important;
  height: 100% !important;
  display: grid !important;
  place-items: center !important;
}

.selected-section-chip-image {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
}

.selected-section-chip::after {
  content: attr(data-section-title) !important;
  position: absolute !important;
  left: 50% !important;
  bottom: calc(100% + 9px) !important;
  z-index: 50 !important;
  max-width: 260px !important;
  padding: 6px 9px !important;
  border: 1px solid rgba(107, 78, 22, 0.2) !important;
  border-radius: 8px !important;
  background: rgba(65, 42, 23, 0.94) !important;
  color: #fff8e9 !important;
  box-shadow: 0 10px 22px rgba(57, 34, 14, 0.18) !important;
  font-size: 0.72rem !important;
  font-weight: 850 !important;
  line-height: 1.1 !important;
  opacity: 0 !important;
  pointer-events: none !important;
  text-align: center !important;
  transform: translate(-50%, 8px) scale(0.96) !important;
  transition: opacity 150ms ease, transform 170ms cubic-bezier(0.2, 0.9, 0.2, 1) !important;
  white-space: nowrap !important;
}

.selected-section-chip:hover::after,
.selected-section-chip:focus-visible::after {
  opacity: 1 !important;
  transform: translate(-50%, 0) scale(1) !important;
}

.selected-section-chip.active,
.selected-section-chip[aria-pressed="true"],
.selected-section-chip:active,
.selected-section-chip:focus {
  border-color: rgba(44, 145, 91, 0.88) !important;
  background:
    radial-gradient(circle at 30% 20%, rgba(67, 186, 116, 0.42), rgba(255, 250, 238, 0.44) 56%),
    rgba(255, 250, 238, 0.58) !important;
  box-shadow:
    0 0 0 3px rgba(44, 145, 91, 0.14),
    0 12px 20px rgba(63, 135, 96, 0.18) !important;
}

.selected-section-chip-strip:hover .selected-section-chip {
  opacity: 0.64 !important;
  transform: translateY(0) scale(0.9) !important;
}

.selected-section-chip-strip .selected-section-chip:hover,
.selected-section-chip-strip .selected-section-chip:focus-visible {
  opacity: 1 !important;
  transform: translateY(-12px) scale(1.34) !important;
}

.selected-section-chip-strip .selected-section-chip:has(+ .selected-section-chip:hover),
.selected-section-chip-strip .selected-section-chip:hover + .selected-section-chip,
.selected-section-chip-strip .selected-section-chip:has(+ .selected-section-chip:focus-visible),
.selected-section-chip-strip .selected-section-chip:focus-visible + .selected-section-chip {
  opacity: 0.9 !important;
  transform: translateY(-7px) scale(1.15) !important;
}

.selected-section-chip-strip .selected-section-chip:has(+ .selected-section-chip + .selected-section-chip:hover),
.selected-section-chip-strip .selected-section-chip:hover + .selected-section-chip + .selected-section-chip,
.selected-section-chip-strip .selected-section-chip:has(+ .selected-section-chip + .selected-section-chip:focus-visible),
.selected-section-chip-strip .selected-section-chip:focus-visible + .selected-section-chip + .selected-section-chip {
  opacity: 0.78 !important;
  transform: translateY(-3px) scale(1.05) !important;
}

@media (max-width: 980px) {
  body.is-local-mode .hero-layout {
    grid-template-columns: 1fr !important;
  }

  body.is-local-mode .hero-links,
  body.is-local-mode .hero-copy,
  body.is-local-mode .hero-progress-circles,
  body.is-local-mode .hero-best-strip {
    grid-column: 1 !important;
  }

  body.is-local-mode .hero-copy {
    text-align: center !important;
  }

  body.is-local-mode .hero-best-strip {
    grid-template-columns: repeat(5, minmax(88px, 1fr)) !important;
    overflow-x: auto !important;
  }
}

/* Header compaction must apply before the app has decided local/online state. */
.hero {
  min-height: 0 !important;
  height: auto !important;
  max-height: none !important;
  padding: clamp(8px, 0.8vw, 12px) clamp(12px, 1.4vw, 22px) clamp(9px, 0.9vw, 14px) !important;
  overflow: visible !important;
}

.hero-layout {
  display: grid !important;
  grid-template-columns: auto minmax(220px, 0.82fr) minmax(210px, 0.62fr) !important;
  grid-template-rows: auto auto !important;
  align-items: center !important;
  gap: clamp(6px, 0.8vw, 12px) clamp(12px, 1.4vw, 22px) !important;
  width: 100% !important;
  min-height: 0 !important;
  max-height: none !important;
}

.hero-links {
  grid-column: 1 !important;
  grid-row: 1 !important;
  position: static !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: clamp(6px, 0.7vw, 10px) !important;
  width: auto !important;
  padding: 0 !important;
}

.hero-discord-link,
.hero-link-icon,
.session-controls,
.session-signout-button {
  position: static !important;
  inset: auto !important;
  width: clamp(42px, 3.6vw, 54px) !important;
  min-width: 0 !important;
  transform: none !important;
}

.hero-link-icon img,
.hero-discord-link img,
.session-signout-button img {
  width: 100% !important;
  height: auto !important;
  object-fit: contain !important;
}

.hero-copy {
  grid-column: 2 !important;
  grid-row: 1 !important;
  position: static !important;
  width: auto !important;
  min-height: 0 !important;
  padding: 0 !important;
  text-align: left !important;
  transform: none !important;
  pointer-events: none !important;
}

.hero h1 {
  margin: 0 !important;
  font-size: clamp(1.72rem, 2.65vw, 3.05rem) !important;
  line-height: 0.9 !important;
  letter-spacing: 0 !important;
}

.hero-stats,
.stats-strip {
  display: contents !important;
}

.hero-progress-circles {
  grid-column: 3 !important;
  grid-row: 1 !important;
  position: static !important;
  justify-self: end !important;
  align-self: center !important;
  width: min(100%, 214px) !important;
  height: 78px !important;
  min-height: 0 !important;
  padding: 7px 12px !important;
  transform: none !important;
  align-content: center !important;
}

.progress-circle-card {
  gap: 5px !important;
}

.stat-progress-ring {
  width: 36px !important;
  height: 36px !important;
}

.stat-progress-ring-inner {
  width: 27px !important;
  height: 27px !important;
}

.stat-progress-ring-inner strong,
.stat-progress-circle-copy strong {
  font-size: 0.62rem !important;
}

.stat-progress-circle-copy em {
  font-size: 0.5rem !important;
}

.hero-best-strip {
  grid-column: 1 / -1 !important;
  grid-row: 2 !important;
  position: static !important;
  justify-self: center !important;
  align-self: center !important;
  width: min(100%, 900px) !important;
  max-width: min(100%, 900px) !important;
  margin: 0 !important;
  height: 64px !important;
  min-height: 0 !important;
  padding: 6px clamp(14px, 2.2vw, 28px) !important;
  transform: none !important;
  display: grid !important;
  grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
  gap: 7px !important;
}

.hero-best-card {
  min-height: 32px !important;
  padding: 1px 6px !important;
}

.hero-best-card span {
  font-size: clamp(0.42rem, 0.5vw, 0.56rem) !important;
}

.hero-best-card strong {
  font-size: clamp(0.62rem, 0.72vw, 0.82rem) !important;
}

.layout {
  position: relative !important;
  perspective: 1200px !important;
  padding-top: clamp(8px, 1vw, 14px) !important;
  overflow: visible !important;
}

.layout::before {
  content: "" !important;
  position: absolute !important;
  left: 50% !important;
  top: 0 !important;
  width: min(92vw, 1180px) !important;
  height: 34px !important;
  border-radius: 999px 999px 0 0 !important;
  background: linear-gradient(180deg, rgba(255, 250, 238, 0.44), rgba(255, 250, 238, 0)) !important;
  transform: translateX(-50%) rotateX(58deg) !important;
  transform-origin: center top !important;
  pointer-events: none !important;
}

.wizard.card-panel {
  border-radius: clamp(34px, 4vw, 58px) clamp(34px, 4vw, 58px) 26px 26px !important;
  transform: perspective(1200px) rotateX(1.6deg) !important;
  transform-origin: top center !important;
  transition: transform 260ms ease, border-radius 260ms ease !important;
}

.wizard.card-panel:focus-within,
.wizard.card-panel:hover {
  transform: perspective(1200px) rotateX(0deg) !important;
}

/* Keep the hub mascot visually central while letting the surrounding mode cards receive clicks. */
.mode-choice-heading,
.mode-choice-heading * {
  pointer-events: none !important;
}

/* May 23: scoreless compact header, split section dock, and circle mode menus. */
.hero {
  padding-block: clamp(6px, 0.7vw, 10px) !important;
}

.hero-layout {
  grid-template-columns: auto minmax(190px, 1fr) minmax(160px, auto) !important;
  grid-template-rows: auto !important;
}

.hero-best-strip,
.hero-best-strip-online,
body.is-local-mode .hero-best-strip,
body.is-online-mode .hero-best-strip,
body.is-online-mode .hero-best-strip-online {
  display: none !important;
}

.hero-progress-circles,
body.is-local-mode .hero-progress-circles,
body.is-online-mode .hero-progress-circles {
  width: auto !important;
  min-width: 0 !important;
  height: auto !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  gap: clamp(6px, 0.9vw, 12px) !important;
}

.hero-progress-circles::before,
.hero-progress-circles::after,
.progress-circle-card::before,
.progress-circle-card::after {
  display: none !important;
}

.progress-circle-card,
body.is-local-mode .progress-circle-card,
body.is-online-mode .progress-circle-card {
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.mode-choice-shell,
.mode-choice-picker-row,
.mode-landing-grid,
.step-grid,
.step-panel,
.wizard.card-panel,
.selected-section-chip-strip,
.selected-section-selected-row {
  overflow: visible !important;
}

.mode-choice-picker-row {
  align-items: center !important;
  gap: clamp(8px, 1.2vw, 16px) !important;
  flex-wrap: wrap !important;
}

.selected-section-chip-strip {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-wrap: nowrap !important;
  gap: 0 !important;
  padding: clamp(12px, 1.2vw, 18px) clamp(10px, 1vw, 16px) !important;
}

.selected-section-chip-strip .selected-section-chip {
  width: clamp(42px, 4.2vw, 58px) !important;
  height: clamp(42px, 4.2vw, 58px) !important;
  min-width: clamp(42px, 4.2vw, 58px) !important;
  min-height: clamp(42px, 4.2vw, 58px) !important;
  margin: 0 !important;
  padding: 4px !important;
  border: 0 !important;
  border-radius: 10px !important;
  background: transparent !important;
  box-shadow: none !important;
}

.selected-section-chip-strip .selected-section-chip::after {
  z-index: 999 !important;
  bottom: calc(100% + 12px) !important;
}

.selected-section-chip-strip:hover .selected-section-chip {
  opacity: 0.58 !important;
  transform: translateY(0) scale(0.86) !important;
}

.selected-section-chip-strip .selected-section-chip:hover,
.selected-section-chip-strip .selected-section-chip:focus-visible {
  opacity: 1 !important;
  transform: translateY(-12px) scale(1.36) !important;
}

.selected-section-selected-row {
  display: flex !important;
  order: 3 !important;
  flex: 0 0 100% !important;
  justify-content: center !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  width: 100% !important;
  padding: 7px 10px 2px !important;
  z-index: 4 !important;
}

.selected-section-selected-row .selected-section-chip {
  width: auto !important;
  min-width: 0 !important;
  height: 38px !important;
  min-height: 38px !important;
  padding: 4px 12px 4px 7px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  border-radius: 12px !important;
  border: 1px solid rgba(36, 132, 77, 0.66) !important;
  background:
    linear-gradient(180deg, rgba(239, 255, 244, 0.92), rgba(197, 237, 208, 0.82)) !important;
  color: #28573b !important;
  box-shadow: 0 10px 18px rgba(54, 122, 80, 0.16) !important;
  animation: selected-section-slide-in 280ms cubic-bezier(0.18, 0.92, 0.22, 1) both !important;
}

.selected-section-selected-row .selected-section-chip-slot {
  width: 30px !important;
  height: 30px !important;
  flex: 0 0 30px !important;
}

.selected-section-selected-row .selected-section-chip > span:not(.selected-section-chip-slot) {
  position: static !important;
  width: auto !important;
  height: auto !important;
  overflow: visible !important;
  clip: auto !important;
  clip-path: none !important;
  white-space: nowrap !important;
  font-size: clamp(0.68rem, 0.88vw, 0.86rem) !important;
  font-weight: 850 !important;
  line-height: 1 !important;
}

.selected-section-selected-row .selected-section-chip::after {
  display: none !important;
}

@keyframes selected-section-slide-in {
  from {
    opacity: 0;
    transform: translateY(-18px) scale(0.82);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

.mode-choice-board {
  display: flex !important;
  justify-content: center !important;
  align-items: flex-start !important;
  gap: clamp(10px, 3vw, 48px) !important;
  min-height: 330px !important;
  padding-top: clamp(10px, 1vw, 18px) !important;
  overflow: visible !important;
}

.mode-choice-column,
.mode-choice-column-learn,
.mode-choice-column-play,
.mode-choice-column-train {
  position: relative !important;
  width: clamp(205px, 23vw, 270px) !important;
  height: clamp(205px, 23vw, 270px) !important;
  min-width: clamp(205px, 23vw, 270px) !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  overflow: visible !important;
  isolation: isolate !important;
  pointer-events: auto !important;
}

.mode-choice-column.is-open {
  z-index: 8 !important;
}

.mode-choice-heading {
  position: absolute !important;
  left: 50% !important;
  top: 50% !important;
  z-index: 20 !important;
  width: clamp(88px, 9vw, 112px) !important;
  height: clamp(88px, 9vw, 112px) !important;
  min-width: 0 !important;
  min-height: 0 !important;
  padding: 8px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 2px !important;
  border: 1px solid rgba(123, 87, 42, 0.28) !important;
  border-radius: 999px !important;
  background:
    radial-gradient(circle at 35% 20%, rgba(255, 250, 238, 0.96), rgba(232, 202, 131, 0.76)) !important;
  box-shadow: 0 16px 28px rgba(72, 48, 25, 0.16) !important;
  transform: translate(-50%, -50%) !important;
  cursor: var(--wsc-click-cursor) !important;
  pointer-events: auto !important;
  transition: filter 140ms ease, transform 180ms cubic-bezier(0.18, 0.92, 0.22, 1), box-shadow 180ms ease !important;
}

.mode-choice-heading:hover,
.mode-choice-heading:focus-visible,
.mode-choice-column.is-open .mode-choice-heading {
  filter: brightness(1.05) !important;
  transform: translate(-50%, -50%) scale(1.08) !important;
  box-shadow: 0 18px 34px rgba(72, 48, 25, 0.22) !important;
}

.mode-choice-column.is-closing .mode-choice-heading {
  animation: mode-menu-close-wiggle 320ms linear !important;
}

.mode-choice-heading-slot {
  width: 42px !important;
  height: 42px !important;
}

.mode-choice-heading h3 {
  margin: 0 !important;
  font-size: clamp(0.8rem, 1vw, 1rem) !important;
  line-height: 1 !important;
  color: #775528 !important;
}

.mode-choice-card-grid,
.mode-choice-column-play .mode-choice-card-grid,
.mode-choice-column-train .mode-choice-card-grid,
.mode-choice-column-learn .mode-choice-card-grid {
  position: absolute !important;
  inset: 0 !important;
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
  overflow: visible !important;
  pointer-events: none !important;
}

.mode-choice-card-grid .wizard-choice-card,
.mode-choice-column-play .mode-choice-card-grid .wizard-choice-card,
.mode-choice-column-train .mode-choice-card-grid .wizard-choice-card,
.mode-choice-column-learn .mode-choice-card-grid .wizard-choice-card {
  position: absolute !important;
  left: 50% !important;
  top: 50% !important;
  width: clamp(74px, 7.2vw, 92px) !important;
  height: clamp(74px, 7.2vw, 92px) !important;
  min-width: 0 !important;
  min-height: 0 !important;
  padding: 6px !important;
  border-radius: 18px !important;
  border: 1px solid rgba(123, 87, 42, 0.2) !important;
  background:
    linear-gradient(180deg, rgba(255, 249, 232, 0.94), rgba(236, 213, 154, 0.82)) !important;
  box-shadow: 0 12px 22px rgba(76, 51, 24, 0.14) !important;
  opacity: 0 !important;
  filter: blur(2px) !important;
  pointer-events: none !important;
  transform: translate(-50%, -50%) scale(0.2) !important;
  transition:
    transform 340ms cubic-bezier(0.18, 0.92, 0.22, 1),
    opacity 180ms ease,
    filter 180ms ease,
    box-shadow 180ms ease !important;
}

.mode-choice-column.is-open .mode-choice-card-grid {
  pointer-events: auto !important;
}

.mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card {
  opacity: 1 !important;
  filter: blur(0) !important;
  pointer-events: auto !important;
}

.mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:hover,
.mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:focus-visible {
  box-shadow: 0 18px 28px rgba(76, 51, 24, 0.2) !important;
  transform: translate(var(--menu-x), var(--menu-y)) scale(1.09) !important;
}

.mode-choice-card-grid .wizard-choice-card:nth-child(1) {
  --menu-x: -50%;
  --menu-y: -168%;
  transition-delay: 20ms !important;
}

.mode-choice-card-grid .wizard-choice-card:nth-child(2) {
  --menu-x: 60%;
  --menu-y: -86%;
  transition-delay: 50ms !important;
}

.mode-choice-card-grid .wizard-choice-card:nth-child(3) {
  --menu-x: 22%;
  --menu-y: 52%;
  transition-delay: 80ms !important;
}

.mode-choice-card-grid .wizard-choice-card:nth-child(4) {
  --menu-x: -122%;
  --menu-y: 52%;
  transition-delay: 110ms !important;
}

.mode-choice-card-grid .wizard-choice-card:nth-child(5) {
  --menu-x: -158%;
  --menu-y: -86%;
  transition-delay: 140ms !important;
}

.mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(1),
.mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(2),
.mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(3),
.mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(4),
.mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(5) {
  transform: translate(var(--menu-x), var(--menu-y)) scale(1) !important;
}

.mode-choice-card-grid .wizard-choice-card .card-top {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 3px !important;
  height: 100% !important;
}

.mode-choice-card-grid .wizard-choice-card .wizard-choice-slot {
  width: clamp(34px, 3.8vw, 46px) !important;
  height: clamp(34px, 3.8vw, 46px) !important;
}

.mode-choice-card-grid .wizard-choice-card .wizard-choice-copy h3 {
  font-size: clamp(0.48rem, 0.68vw, 0.68rem) !important;
  line-height: 1.02 !important;
  max-width: 72px !important;
}

.mode-choice-card-grid .wizard-choice-card .mode-card-thanks {
  font-size: 0.42rem !important;
  line-height: 1 !important;
}

.mode-choice-card-grid .wizard-choice-card:disabled {
  opacity: 0.34 !important;
  pointer-events: none !important;
}

@keyframes mode-menu-close-wiggle {
  0%, 100% { transform: translate(-50%, -50%); }
  25% { transform: translate(calc(-50% + 2px), -50%) scale(1.08); }
  50% { transform: translate(calc(-50% - 2px), -50%) scale(1.08); }
  75% { transform: translate(calc(-50% + 1px), -50%) scale(1.04); }
}

@media (max-width: 900px) {
  .hero-layout {
    grid-template-columns: auto 1fr !important;
  }

  .hero-progress-circles {
    grid-column: 1 / -1 !important;
    justify-self: center !important;
  }

  .mode-choice-board {
    flex-direction: column !important;
    align-items: center !important;
    min-height: 780px !important;
  }
}

/* May 23 refinement: curved header menu, strict icon sizing, and active path staging. */
.hero {
  position: relative !important;
  min-height: clamp(138px, 13vw, 166px) !important;
  padding: 0 !important;
}

.hero-layout {
  position: relative !important;
  display: block !important;
  min-height: clamp(138px, 13vw, 166px) !important;
}

.hero-copy {
  position: absolute !important;
  left: 50% !important;
  top: 50% !important;
  z-index: 4 !important;
  width: min(42vw, 520px) !important;
  min-height: 0 !important;
  display: grid !important;
  place-items: center !important;
  gap: 4px !important;
  text-align: center !important;
  transform: translate(-50%, -50%) !important;
  pointer-events: auto !important;
}

.hero h1 {
  font-size: clamp(1.82rem, 2.85vw, 3.25rem) !important;
  line-height: 0.92 !important;
  text-align: center !important;
}

.hero-online-mount {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  min-height: 34px !important;
}

.hero-online-button {
  width: auto !important;
  min-width: 0 !important;
  height: 32px !important;
  padding: 2px 10px 2px 5px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 6px !important;
  border: 1px solid rgba(110, 78, 43, 0.2) !important;
  border-radius: 11px !important;
  background: rgba(255, 250, 238, 0.2) !important;
  color: #76592f !important;
  box-shadow: none !important;
  font-size: 0.64rem !important;
  font-weight: 850 !important;
  line-height: 1 !important;
}

.hero-online-button img {
  width: 27px !important;
  height: 27px !important;
  object-fit: contain !important;
}

.hero-progress-circles,
body.is-local-mode .hero-progress-circles,
body.is-online-mode .hero-progress-circles {
  position: absolute !important;
  right: clamp(16px, 2vw, 28px) !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  z-index: 3 !important;
  width: clamp(190px, 17vw, 260px) !important;
}

.hero-links {
  position: absolute !important;
  left: 0 !important;
  top: 0 !important;
  z-index: 40 !important;
  width: 230px !important;
  height: 230px !important;
  display: block !important;
  padding: 0 !important;
  pointer-events: none !important;
  overflow: visible !important;
}

.hero-links::before {
  content: "" !important;
  position: absolute !important;
  left: 0 !important;
  top: 0 !important;
  width: 230px !important;
  height: 230px !important;
  border-radius: 0 0 230px 0 !important;
  background:
    radial-gradient(circle at 0 0, rgba(255, 246, 222, 0.98), rgba(196, 154, 85, 0.96) 72%, rgba(111, 75, 40, 0.96) 100%) !important;
  border-right: 1px solid rgba(83, 54, 27, 0.24) !important;
  border-bottom: 1px solid rgba(83, 54, 27, 0.24) !important;
  box-shadow: 18px 24px 42px rgba(73, 47, 23, 0.22) !important;
  opacity: 0 !important;
  transform: translate(-42px, -42px) scale(0.18) !important;
  transform-origin: left top !important;
  transition: opacity 260ms ease, transform 800ms cubic-bezier(0.76, 0, 0.24, 1) !important;
  pointer-events: none !important;
}

.hero-links.is-open::before {
  opacity: 1 !important;
  transform: translate(0, 0) scale(1) !important;
}

.hero-menu-trigger {
  position: absolute !important;
  left: 15px !important;
  top: 14px !important;
  z-index: 8 !important;
  width: 48px !important;
  height: 48px !important;
  padding: 10px !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: space-between !important;
  border: 1px solid rgba(83, 54, 27, 0.22) !important;
  border-radius: 12px !important;
  background: rgba(83, 54, 27, 0.92) !important;
  box-shadow: 0 12px 22px rgba(58, 35, 17, 0.18) !important;
  pointer-events: auto !important;
}

.hero-menu-trigger span {
  display: block !important;
  width: 100% !important;
  height: 3px !important;
  border-radius: 3px !important;
  background: #fff1cf !important;
  transform-origin: center !important;
  transition: opacity 220ms ease, transform 260ms ease !important;
}

.hero-links.is-open .hero-menu-trigger span:nth-child(1) {
  transform: translateY(12px) rotate(45deg) !important;
}

.hero-links.is-open .hero-menu-trigger span:nth-child(2) {
  opacity: 0 !important;
}

.hero-links.is-open .hero-menu-trigger span:nth-child(3) {
  transform: translateY(-12px) rotate(-45deg) !important;
}

.hero-links > :not(.hero-menu-trigger) {
  position: absolute !important;
  left: 18px !important;
  top: 17px !important;
  z-index: 7 !important;
  width: 52px !important;
  height: 52px !important;
  min-width: 52px !important;
  min-height: 52px !important;
  display: grid !important;
  place-items: center !important;
  padding: 5px !important;
  border: 1px solid rgba(255, 241, 207, 0.26) !important;
  border-radius: 16px !important;
  background: rgba(255, 241, 207, 0.22) !important;
  box-shadow: 0 12px 22px rgba(58, 35, 17, 0.16) !important;
  opacity: 0 !important;
  pointer-events: none !important;
  transform: translate(0, 0) scale(0.2) !important;
  transition:
    opacity 260ms ease,
    transform 800ms cubic-bezier(0.76, 0, 0.24, 1),
    filter 160ms ease !important;
}

.hero-links.is-open > :not(.hero-menu-trigger) {
  opacity: 1 !important;
  pointer-events: auto !important;
}

.hero-links.is-open > .hero-discord-link {
  transform: translate(76px, 4px) scale(1) !important;
}

.hero-links.is-open > button.hero-link-icon {
  transform: translate(128px, 55px) scale(1) !important;
}

.hero-links.is-open > a.hero-link-icon {
  transform: translate(92px, 123px) scale(1) !important;
}

.hero-links.is-open > .session-controls {
  transform: translate(22px, 144px) scale(1) !important;
}

.hero-links > :not(.hero-menu-trigger):hover,
.hero-links > :not(.hero-menu-trigger):focus-visible {
  filter: brightness(1.08) !important;
}

.hero-links img,
.hero-links .session-controls img,
.hero-links .session-signout-button img,
.hero-links .hero-link-icon img,
.hero-links .hero-discord-link img {
  width: 40px !important;
  height: 40px !important;
  max-width: 40px !important;
  max-height: 40px !important;
  object-fit: contain !important;
}

.hero-links .session-control-stack,
.hero-links .session-controls {
  display: grid !important;
  place-items: center !important;
}

.hero-links .session-controls .hero-link-icon,
.hero-links .session-controls .session-signout-button {
  width: 52px !important;
  height: 52px !important;
  min-width: 52px !important;
  min-height: 52px !important;
  padding: 5px !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.mode-choice-picker-row .hub-mode-switch {
  display: none !important;
}

.selected-section-chip::after,
.selected-section-chip-strip .selected-section-chip::after {
  border-color: rgba(255, 241, 207, 0.28) !important;
  background: rgba(83, 54, 27, 0.96) !important;
  color: #fff1cf !important;
}

.selected-section-chip-strip .selected-section-chip-slot {
  width: 38px !important;
  height: 38px !important;
  max-width: 38px !important;
  max-height: 38px !important;
  overflow: hidden !important;
}

.selected-section-chip-strip .selected-section-chip-image {
  width: 34px !important;
  height: 34px !important;
  max-width: 34px !important;
  max-height: 34px !important;
  object-fit: contain !important;
}

.selected-section-selected-row .selected-section-chip {
  position: relative !important;
  overflow: visible !important;
}

.selected-section-selected-row .selected-section-chip-slot {
  width: 27px !important;
  height: 27px !important;
  flex: 0 0 27px !important;
  overflow: hidden !important;
}

.selected-section-selected-row .selected-section-chip-image {
  width: 25px !important;
  height: 25px !important;
  max-width: 25px !important;
  max-height: 25px !important;
  object-fit: contain !important;
}

.selected-section-selected-row .selected-section-chip::before {
  content: "×" !important;
  position: absolute !important;
  left: 50% !important;
  top: -18px !important;
  z-index: 12 !important;
  width: 18px !important;
  height: 18px !important;
  display: grid !important;
  place-items: center !important;
  border-radius: 999px !important;
  background: rgba(148, 17, 24, 0.94) !important;
  color: #fff2dc !important;
  box-shadow:
    0 0 0 2px rgba(255, 215, 190, 0.26),
    0 0 18px rgba(190, 22, 32, 0.72) !important;
  font-size: 1rem !important;
  font-weight: 950 !important;
  line-height: 1 !important;
  opacity: 0 !important;
  pointer-events: none !important;
  transform: translate(-50%, -7px) scale(0.72) !important;
  transition: opacity 180ms ease, transform 260ms cubic-bezier(0.18, 0.92, 0.22, 1) !important;
}

.selected-section-selected-row .selected-section-chip:hover::before,
.selected-section-selected-row .selected-section-chip:focus-visible::before {
  opacity: 1 !important;
  transform: translate(-50%, 8px) scale(1) !important;
}

.mode-choice-board {
  position: relative !important;
  min-height: clamp(410px, 45vw, 520px) !important;
}

.mode-choice-column,
.mode-choice-column-learn,
.mode-choice-column-play,
.mode-choice-column-train {
  width: clamp(260px, 25vw, 330px) !important;
  height: clamp(260px, 25vw, 330px) !important;
  min-width: clamp(260px, 25vw, 330px) !important;
  transition:
    left 1s cubic-bezier(0.76, 0, 0.24, 1),
    top 1s cubic-bezier(0.76, 0, 0.24, 1),
    width 1s cubic-bezier(0.76, 0, 0.24, 1),
    height 1s cubic-bezier(0.76, 0, 0.24, 1),
    transform 1s cubic-bezier(0.76, 0, 0.24, 1),
    opacity 320ms ease !important;
}

.mode-choice-heading {
  width: clamp(138px, 13vw, 174px) !important;
  height: clamp(138px, 13vw, 174px) !important;
}

.mode-choice-heading-slot {
  width: clamp(58px, 6vw, 76px) !important;
  height: clamp(58px, 6vw, 76px) !important;
  overflow: hidden !important;
}

.mode-choice-heading-image {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
}

.mode-choice-heading h3 {
  font-size: clamp(1rem, 1.35vw, 1.35rem) !important;
}

.mode-choice-board:has(.mode-choice-column.is-open) {
  min-height: clamp(500px, 49vw, 610px) !important;
}

.mode-choice-board:has(.mode-choice-column.is-open) .mode-choice-column {
  position: absolute !important;
  left: clamp(12px, 5vw, 72px) !important;
  width: 116px !important;
  height: 116px !important;
  min-width: 116px !important;
  transform: none !important;
  opacity: 0.72 !important;
}

.mode-choice-board:has(.mode-choice-column.is-open) .mode-choice-column:nth-child(1) {
  top: 42px !important;
}

.mode-choice-board:has(.mode-choice-column.is-open) .mode-choice-column:nth-child(2) {
  top: 178px !important;
}

.mode-choice-board:has(.mode-choice-column.is-open) .mode-choice-column:nth-child(3) {
  top: 314px !important;
}

.mode-choice-board:has(.mode-choice-column.is-open) .mode-choice-column.is-open {
  left: 50% !important;
  top: 50px !important;
  width: clamp(300px, 32vw, 390px) !important;
  height: clamp(300px, 32vw, 390px) !important;
  min-width: clamp(300px, 32vw, 390px) !important;
  transform: translateX(-50%) !important;
  opacity: 1 !important;
}

.mode-choice-board:has(.mode-choice-column.is-open) .mode-choice-column:not(.is-open) .mode-choice-heading {
  width: 82px !important;
  height: 82px !important;
  opacity: 0.86 !important;
}

.mode-choice-board:has(.mode-choice-column.is-open) .mode-choice-column:not(.is-open) .mode-choice-heading-slot {
  width: 38px !important;
  height: 38px !important;
}

.mode-choice-board:has(.mode-choice-column.is-open) .mode-choice-column:not(.is-open) .mode-choice-heading h3 {
  font-size: 0.72rem !important;
}

.mode-choice-board:has(.mode-choice-column.is-open) .mode-choice-column:not(.is-open) .mode-choice-card-grid {
  display: none !important;
}

.mode-choice-board:has(.mode-choice-column.is-open) .mode-choice-column.is-open .mode-choice-heading {
  width: clamp(132px, 12vw, 164px) !important;
  height: clamp(132px, 12vw, 164px) !important;
}

@media (max-width: 900px) {
  .hero {
    min-height: 190px !important;
  }

  .hero-copy {
    width: min(70vw, 520px) !important;
    top: 42% !important;
  }

  .hero-progress-circles,
  body.is-local-mode .hero-progress-circles,
  body.is-online-mode .hero-progress-circles {
    right: 50% !important;
    top: auto !important;
    bottom: 8px !important;
    transform: translateX(50%) !important;
  }

  .mode-choice-board:has(.mode-choice-column.is-open) .mode-choice-column {
    left: 8px !important;
  }

  .mode-choice-board:has(.mode-choice-column.is-open) .mode-choice-column.is-open {
    left: 58% !important;
  }
}

/* Final specificity guard: keep the header menu over the header, never in the layout flow. */
body.is-local-mode .hero,
body.is-online-mode .hero {
  min-height: clamp(138px, 13vw, 166px) !important;
  padding: 0 !important;
}

body.is-local-mode .hero-layout,
body.is-online-mode .hero-layout {
  position: relative !important;
  display: block !important;
  min-height: clamp(138px, 13vw, 166px) !important;
}

body.is-local-mode .hero-copy,
body.is-online-mode .hero-copy {
  position: absolute !important;
  left: 50% !important;
  top: 50% !important;
  width: min(42vw, 520px) !important;
  display: grid !important;
  text-align: center !important;
  transform: translate(-50%, -50%) !important;
  pointer-events: auto !important;
}

body.is-local-mode .hero-links,
body.is-online-mode .hero-links {
  position: absolute !important;
  left: 0 !important;
  top: 0 !important;
  display: block !important;
  width: 230px !important;
  height: 230px !important;
  padding: 0 !important;
  pointer-events: none !important;
  overflow: visible !important;
}

body.is-local-mode .hero-links > :not(.hero-menu-trigger),
body.is-online-mode .hero-links > :not(.hero-menu-trigger) {
  position: absolute !important;
  width: 52px !important;
  height: 52px !important;
  min-width: 52px !important;
  min-height: 52px !important;
}

body.is-local-mode .hero-links img,
body.is-online-mode .hero-links img,
body.is-local-mode .hero-links .session-controls img,
body.is-online-mode .hero-links .session-controls img,
body.is-local-mode .hero-links .session-signout-button img,
body.is-online-mode .hero-links .session-signout-button img,
body.is-local-mode .hero-links .hero-link-icon img,
body.is-online-mode .hero-links .hero-link-icon img,
body.is-local-mode .hero-links .hero-discord-link img,
body.is-online-mode .hero-links .hero-discord-link img {
  width: 40px !important;
  height: 40px !important;
  max-width: 40px !important;
  max-height: 40px !important;
  object-fit: contain !important;
}

.hero-menu-trigger.final-anchor {
  display: contents;
}

/* Absolute last overrides for May 23 path staging. */
body.is-local-mode .hero,
body.is-online-mode .hero,
.hero {
  background: linear-gradient(180deg, rgba(96, 62, 33, 0.98), rgba(75, 48, 27, 0.98)) !important;
  border: 0 !important;
  border-radius: 0 !important;
  color: #fff1cf !important;
  min-height: 150px !important;
  padding: 0 !important;
}

.hero h1,
.hero-progress-circles .stat-progress-circle-copy span,
.hero-progress-circles .stat-progress-circle-copy strong,
.hero-progress-circles .stat-progress-circle-copy em {
  color: #fff1cf !important;
}

.hero-online-mount {
  position: absolute !important;
  left: clamp(-150px, -12vw, -70px) !important;
  top: 50% !important;
  transform: translate(-50%, -50%) !important;
}

.hero-online-button {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  color: #fff1cf !important;
  flex-direction: column !important;
  height: auto !important;
  padding: 0 !important;
}

.hero-online-button img {
  height: 38px !important;
  width: 38px !important;
}

.hero-online-button span {
  color: #fff1cf !important;
  max-height: none !important;
  opacity: 1 !important;
  overflow: visible !important;
}

.hero-links,
body.is-local-mode .hero-links,
body.is-online-mode .hero-links {
  height: 150px !important;
  width: 430px !important;
}

.hero-menu-trigger {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  height: 58px !important;
  left: 22px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 58px !important;
}

.hero-menu-trigger span {
  background: #fff1cf !important;
  height: 4px !important;
}

.hero-links.is-open .hero-menu-trigger span {
  background: #5a391f !important;
}

.hero-links::before {
  background: #fff1cf !important;
  border-radius: 50% !important;
  height: 430px !important;
  left: -276px !important;
  opacity: 0 !important;
  top: 50% !important;
  transform: translate(-22%, -50%) scale(0.16) !important;
  transform-origin: left center !important;
  width: 430px !important;
}

.hero-links.is-open::before {
  opacity: 1 !important;
  transform: translate(0, -50%) scale(1) !important;
}

.hero-links > :not(.hero-menu-trigger),
body.is-local-mode .hero-links > :not(.hero-menu-trigger),
body.is-online-mode .hero-links > :not(.hero-menu-trigger) {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  color: #5a391f !important;
  flex-direction: column !important;
  gap: 3px !important;
  height: 58px !important;
  min-height: 58px !important;
  min-width: 82px !important;
  width: 82px !important;
}

.hero-links.is-open > .hero-discord-link {
  transform: translate(122px, -106px) scale(1) !important;
}

.hero-links.is-open > .session-controls {
  transform: translate(104px, -32px) scale(1) !important;
}

.hero-links.is-open > button.hero-link-icon {
  transform: translate(126px, 42px) scale(1) !important;
}

.hero-links.is-open > a.hero-link-icon {
  transform: translate(168px, 104px) scale(1) !important;
}

.hero-discord-link::after {
  content: "Discord" !important;
}

.hero-links > button.hero-link-icon::after {
  content: "Links" !important;
}

.hero-links > a.hero-link-icon::after {
  content: "Contact" !important;
}

.hero-links > .session-controls::after {
  content: "Log in" !important;
}

.hero-discord-link::after,
.hero-links > button.hero-link-icon::after,
.hero-links > a.hero-link-icon::after,
.hero-links > .session-controls::after {
  color: #5a391f !important;
  display: block !important;
  font-size: 0.64rem !important;
  font-weight: 900 !important;
}

.mode-choice-board {
  display: block !important;
  margin: 0 auto !important;
  min-height: clamp(520px, 50vw, 640px) !important;
  position: relative !important;
  width: min(100%, 1120px) !important;
}

.mode-choice-board.no-section-selection .mode-choice-column {
  opacity: 0.48 !important;
}

.mode-choice-board.no-section-selection .mode-choice-heading,
.mode-choice-board.no-section-selection .mode-choice-heading * {
  cursor: not-allowed !important;
  pointer-events: none !important;
}

.mode-choice-column,
.mode-choice-column-learn,
.mode-choice-column-play,
.mode-choice-column-train {
  height: clamp(250px, 24vw, 315px) !important;
  min-width: 0 !important;
  position: absolute !important;
  top: clamp(76px, 7vw, 100px) !important;
  width: clamp(250px, 24vw, 315px) !important;
}

.mode-choice-column-learn {
  left: 20% !important;
  transform: translateX(-50%) !important;
}

.mode-choice-column-play {
  left: 50% !important;
  transform: translateX(-50%) !important;
}

.mode-choice-column-train {
  left: 80% !important;
  transform: translateX(-50%) !important;
}

.mode-choice-heading {
  height: clamp(148px, 14vw, 186px) !important;
  width: clamp(148px, 14vw, 186px) !important;
}

.mode-choice-board[data-active-path] .mode-choice-column,
.mode-choice-board:has(.mode-choice-column.is-open) .mode-choice-column {
  height: 112px !important;
  left: clamp(4px, 1vw, 14px) !important;
  opacity: 0.68 !important;
  transform: none !important;
  width: 112px !important;
}

.mode-choice-board[data-active-path] .mode-choice-column-learn,
.mode-choice-board:has(.mode-choice-column.is-open) .mode-choice-column-learn {
  top: 44px !important;
}

.mode-choice-board[data-active-path] .mode-choice-column-play,
.mode-choice-board:has(.mode-choice-column.is-open) .mode-choice-column-play {
  top: 172px !important;
}

.mode-choice-board[data-active-path] .mode-choice-column-train,
.mode-choice-board:has(.mode-choice-column.is-open) .mode-choice-column-train {
  top: 300px !important;
}

.mode-choice-board[data-active-path="learn"] .mode-choice-column-learn,
.mode-choice-board[data-active-path="play"] .mode-choice-column-play,
.mode-choice-board[data-active-path="train"] .mode-choice-column-train,
.mode-choice-board:has(.mode-choice-column-learn.is-open) .mode-choice-column-learn,
.mode-choice-board:has(.mode-choice-column-play.is-open) .mode-choice-column-play,
.mode-choice-board:has(.mode-choice-column-train.is-open) .mode-choice-column-train {
  height: clamp(390px, 41vw, 520px) !important;
  left: 46% !important;
  opacity: 1 !important;
  top: clamp(44px, 4vw, 68px) !important;
  transform: translateX(-50%) !important;
  width: clamp(370px, 38vw, 460px) !important;
}

.mode-choice-board[data-active-path] .mode-choice-column:not(.is-open) .mode-choice-heading {
  height: 84px !important;
  opacity: 0.82 !important;
  width: 84px !important;
}

.mode-choice-board[data-active-path] .mode-choice-column.is-targeting .mode-choice-heading,
.mode-choice-board[data-active-path] .mode-choice-column.is-open .mode-choice-heading {
  height: clamp(104px, 10vw, 128px) !important;
  left: 30% !important;
  top: 50% !important;
  width: clamp(104px, 10vw, 128px) !important;
}

.mode-choice-card-grid .wizard-choice-card,
.mode-choice-column-play .mode-choice-card-grid .wizard-choice-card,
.mode-choice-column-train .mode-choice-card-grid .wizard-choice-card,
.mode-choice-column-learn .mode-choice-card-grid .wizard-choice-card {
  height: clamp(118px, 13vw, 150px) !important;
  width: clamp(118px, 13vw, 150px) !important;
}

.mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(1) {
  --menu-x: 12%;
  --menu-y: -206%;
}

.mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(2) {
  --menu-x: 92%;
  --menu-y: -132%;
}

.mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(3) {
  --menu-x: 126%;
  --menu-y: -26%;
}

.mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(4) {
  --menu-x: 92%;
  --menu-y: 82%;
}

.mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(5) {
  --menu-x: 12%;
  --menu-y: 160%;
}

/* May 23 final pass: dark full header, left arc menu, gated route path menus. */
body .hero,
body.is-local-mode .hero,
body.is-online-mode .hero {
  min-height: 148px !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: linear-gradient(180deg, #684222 0%, #4f311d 100%) !important;
  color: #fff1cf !important;
  box-shadow: 0 2px 0 rgba(38, 22, 12, 0.28) !important;
}

body .hero-layout,
body.is-local-mode .hero-layout,
body.is-online-mode .hero-layout {
  position: relative !important;
  display: block !important;
  min-height: 148px !important;
  padding: 0 !important;
}

body .hero-copy {
  position: absolute !important;
  left: 50% !important;
  top: 50% !important;
  z-index: 5 !important;
  width: min(42vw, 520px) !important;
  transform: translate(-50%, -50%) !important;
  display: grid !important;
  place-items: center !important;
  gap: 4px !important;
  text-align: center !important;
}

body .hero h1 {
  margin: 0 !important;
  color: #fff1cf !important;
  font-size: clamp(1.85rem, 2.7vw, 3rem) !important;
  line-height: 0.92 !important;
}

body .hero-online-mount {
  position: absolute !important;
  left: clamp(-180px, calc(-25vw + 260px), -12px) !important;
  top: 50% !important;
  transform: translate(-50%, -50%) !important;
  z-index: 6 !important;
  display: grid !important;
  place-items: center !important;
}

body .hero-online-button {
  display: grid !important;
  place-items: center !important;
  gap: 2px !important;
  width: 72px !important;
  min-width: 72px !important;
  height: auto !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  color: #fff1cf !important;
}

body .hero-online-button img {
  width: 42px !important;
  height: 42px !important;
  object-fit: contain !important;
}

body .hero-online-button span {
  color: #fff1cf !important;
  font-size: 0.66rem !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  max-height: none !important;
  opacity: 1 !important;
}

body .hero-best-strip,
body .hero-best-strip-online,
body.is-local-mode .hero-best-strip,
body.is-online-mode .hero-best-strip,
body.is-online-mode .hero-best-strip-online {
  display: none !important;
}

body .hero-progress-circles,
body.is-local-mode .hero-progress-circles,
body.is-online-mode .hero-progress-circles {
  position: absolute !important;
  right: clamp(18px, 2.1vw, 34px) !important;
  top: 50% !important;
  z-index: 4 !important;
  width: clamp(210px, 19vw, 285px) !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  transform: translateY(-50%) !important;
  display: grid !important;
  gap: 8px !important;
}

body .progress-circle-card {
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  grid-template-columns: auto minmax(0, 1fr) !important;
  gap: 9px !important;
}

body .stat-progress-ring {
  width: 42px !important;
  height: 42px !important;
  background:
    conic-gradient(#f3c65d calc(var(--percent) * 1%), rgba(255, 241, 207, 0.22) 0),
    rgba(255, 241, 207, 0.15) !important;
}

body .stat-progress-ring-inner {
  width: 30px !important;
  height: 30px !important;
  background: #fff1cf !important;
}

body .stat-progress-ring-inner strong {
  color: #4f311d !important;
  font-size: 0.58rem !important;
}

body .hero-progress-circles .stat-progress-circle-copy span,
body .hero-progress-circles .stat-progress-circle-copy strong,
body .hero-progress-circles .stat-progress-circle-copy em {
  color: #fff1cf !important;
}

body .hero-progress-circles .stat-progress-circle-copy span {
  font-size: 0.74rem !important;
  font-weight: 950 !important;
  letter-spacing: 0.04em !important;
}

body .hero-progress-circles .stat-progress-circle-copy strong {
  font-size: 0.68rem !important;
  font-weight: 900 !important;
}

body .hero-progress-circles .stat-progress-circle-copy em {
  font-size: 0.58rem !important;
  font-weight: 850 !important;
}

body .hero-links,
body.is-local-mode .hero-links,
body.is-online-mode .hero-links {
  position: absolute !important;
  left: 0 !important;
  top: 0 !important;
  z-index: 60 !important;
  width: 360px !important;
  height: 360px !important;
  padding: 0 !important;
  display: block !important;
  overflow: visible !important;
  pointer-events: none !important;
}

body .hero-links::before {
  content: "" !important;
  position: absolute !important;
  left: -36px !important;
  top: -164px !important;
  width: 390px !important;
  height: 390px !important;
  border-radius: 50% !important;
  background: radial-gradient(circle at 23% 30%, #fff1cf 0%, #f5d997 64%, #c2944f 100%) !important;
  border: 1px solid rgba(78, 49, 29, 0.18) !important;
  box-shadow: 24px 28px 46px rgba(54, 33, 18, 0.28) !important;
  opacity: 0 !important;
  transform: translate(-80px, -18px) scale(0.18) !important;
  transform-origin: 44px 224px !important;
  transition: opacity 260ms ease, transform 780ms cubic-bezier(0.76, 0, 0.24, 1) !important;
  pointer-events: none !important;
}

body .hero-links.is-open::before {
  opacity: 1 !important;
  transform: translate(0, 0) scale(1) !important;
}

body .hero-menu-trigger {
  position: absolute !important;
  left: 22px !important;
  top: 74px !important;
  z-index: 10 !important;
  width: 58px !important;
  height: 58px !important;
  padding: 12px !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: space-between !important;
  border: 0 !important;
  border-radius: 14px !important;
  background: transparent !important;
  box-shadow: none !important;
  pointer-events: auto !important;
  transform: translateY(-50%) !important;
}

body .hero-menu-trigger span {
  display: block !important;
  width: 100% !important;
  height: 4px !important;
  border-radius: 4px !important;
  background: #fff1cf !important;
  transform-origin: center !important;
}

body .hero-links.is-open .hero-menu-trigger {
  background: rgba(79, 49, 29, 0.94) !important;
}

body .hero-links.is-open .hero-menu-trigger span {
  background: #fff1cf !important;
}

body .hero-links.is-open .hero-menu-trigger span:nth-child(1) {
  transform: translateY(15px) rotate(45deg) !important;
}

body .hero-links.is-open .hero-menu-trigger span:nth-child(2) {
  opacity: 0 !important;
}

body .hero-links.is-open .hero-menu-trigger span:nth-child(3) {
  transform: translateY(-15px) rotate(-45deg) !important;
}

body .hero-links > :not(.hero-menu-trigger),
body.is-local-mode .hero-links > :not(.hero-menu-trigger),
body.is-online-mode .hero-links > :not(.hero-menu-trigger) {
  position: absolute !important;
  left: 24px !important;
  top: 74px !important;
  z-index: 9 !important;
  width: 82px !important;
  height: 72px !important;
  min-width: 82px !important;
  min-height: 72px !important;
  padding: 4px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 2px !important;
  border: 1px solid rgba(255, 241, 207, 0.28) !important;
  border-radius: 18px !important;
  background: transparent !important;
  box-shadow: none !important;
  color: #4f311d !important;
  opacity: 0 !important;
  pointer-events: none !important;
  transform: translate(0, 0) scale(0.22) !important;
  transition: opacity 250ms ease, transform 780ms cubic-bezier(0.76, 0, 0.24, 1) !important;
}

body .hero-links.is-open > :not(.hero-menu-trigger) {
  opacity: 1 !important;
  pointer-events: auto !important;
}

body .hero-links.is-open > .hero-discord-link {
  transform: translate(86px, -30px) scale(1) !important;
}

body .hero-links.is-open > .session-controls {
  transform: translate(48px, 84px) scale(1) !important;
}

body .hero-links.is-open > button.hero-link-icon {
  transform: translate(158px, 116px) scale(1) !important;
}

body .hero-links.is-open > a.hero-link-icon {
  transform: translate(238px, 164px) scale(1) !important;
}

body .hero-links img,
body .hero-links .session-controls img,
body .hero-links .session-signout-button img,
body .hero-links .hero-link-icon img,
body .hero-links .hero-discord-link img {
  width: 38px !important;
  height: 38px !important;
  max-width: 38px !important;
  max-height: 38px !important;
  object-fit: contain !important;
}

body .hero-links .session-controls,
body .hero-links .session-control-stack,
body .hero-links .session-controls .hero-link-icon,
body .hero-links .session-controls .session-signout-button {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

body .hero-links .session-controls .hero-link-icon,
body .hero-links .session-controls .session-signout-button {
  width: 42px !important;
  height: 42px !important;
  min-width: 42px !important;
  min-height: 42px !important;
  padding: 0 !important;
}

body .hero-discord-link::after { content: "Discord" !important; }
body .hero-links > .session-controls::after { content: "Log in" !important; }
body .hero-links > button.hero-link-icon::after { content: "Links" !important; }
body .hero-links > a.hero-link-icon::after { content: "Contact" !important; }

body .hero-discord-link::after,
body .hero-links > .session-controls::after,
body .hero-links > button.hero-link-icon::after,
body .hero-links > a.hero-link-icon::after {
  display: block !important;
  color: #4f311d !important;
  font-size: 0.66rem !important;
  font-weight: 950 !important;
  line-height: 1 !important;
}

body .selected-section-chip-strip {
  overflow: visible !important;
  padding-block: 10px !important;
}

body .selected-section-chip-strip .selected-section-chip {
  width: 54px !important;
  height: 54px !important;
  min-width: 54px !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 10px !important;
  background: transparent !important;
  box-shadow: none !important;
}

body .selected-section-chip-strip .selected-section-chip::before {
  display: none !important;
}

body .selected-section-chip-strip .selected-section-chip::after {
  bottom: calc(100% + 10px) !important;
  z-index: 999 !important;
  border: 1px solid rgba(255, 241, 207, 0.38) !important;
  border-radius: 12px !important;
  background: #4f311d !important;
  color: #fff1cf !important;
  box-shadow: 0 12px 24px rgba(48, 29, 15, 0.22) !important;
}

body .selected-section-chip-strip .selected-section-chip-slot,
body .selected-section-chip-strip .selected-section-chip-image {
  width: 42px !important;
  height: 42px !important;
  max-width: 42px !important;
  max-height: 42px !important;
  object-fit: contain !important;
}

body .mode-choice-board {
  display: block !important;
  position: relative !important;
  width: min(100%, 1120px) !important;
  min-height: clamp(560px, 52vw, 680px) !important;
  margin: 0 auto !important;
}

body .mode-choice-board.no-section-selection .mode-choice-column {
  opacity: 0.45 !important;
}

body .mode-choice-board.no-section-selection .mode-choice-heading,
body .mode-choice-board.no-section-selection .mode-choice-heading * {
  cursor: not-allowed !important;
  pointer-events: none !important;
}

body .mode-choice-column,
body .mode-choice-column-learn,
body .mode-choice-column-play,
body .mode-choice-column-train {
  position: absolute !important;
  top: clamp(86px, 8vw, 112px) !important;
  width: clamp(250px, 23vw, 310px) !important;
  height: clamp(250px, 23vw, 310px) !important;
  min-width: 0 !important;
  transform: translateX(-50%) !important;
  transition:
    left 1s cubic-bezier(0.76, 0, 0.24, 1),
    top 1s cubic-bezier(0.76, 0, 0.24, 1),
    width 1s cubic-bezier(0.76, 0, 0.24, 1),
    height 1s cubic-bezier(0.76, 0, 0.24, 1),
    transform 1s cubic-bezier(0.76, 0, 0.24, 1),
    opacity 320ms ease !important;
}

body .mode-choice-column-learn { left: 22% !important; }
body .mode-choice-column-play { left: 50% !important; }
body .mode-choice-column-train { left: 78% !important; }

body .mode-choice-heading {
  width: clamp(150px, 14vw, 186px) !important;
  height: clamp(150px, 14vw, 186px) !important;
}

body .mode-choice-board[data-active-path] .mode-choice-column {
  left: clamp(4px, 1.1vw, 16px) !important;
  width: 112px !important;
  height: 112px !important;
  opacity: 0.68 !important;
  transform: none !important;
}

body .mode-choice-board[data-active-path] .mode-choice-column-learn { top: 40px !important; }
body .mode-choice-board[data-active-path] .mode-choice-column-play { top: 174px !important; }
body .mode-choice-board[data-active-path] .mode-choice-column-train { top: 308px !important; }

body .mode-choice-board[data-active-path="learn"] .mode-choice-column-learn,
body .mode-choice-board[data-active-path="play"] .mode-choice-column-play,
body .mode-choice-board[data-active-path="train"] .mode-choice-column-train {
  left: 43% !important;
  top: clamp(42px, 4.6vw, 70px) !important;
  width: clamp(420px, 40vw, 520px) !important;
  height: clamp(420px, 40vw, 520px) !important;
  opacity: 1 !important;
  transform: translateX(-50%) !important;
}

body .mode-choice-board[data-active-path] .mode-choice-column:not(.is-open):not(.is-targeting) .mode-choice-heading {
  width: 82px !important;
  height: 82px !important;
}

body .mode-choice-board[data-active-path] .mode-choice-column.is-targeting .mode-choice-heading,
body .mode-choice-board[data-active-path] .mode-choice-column.is-open .mode-choice-heading {
  width: clamp(112px, 10vw, 136px) !important;
  height: clamp(112px, 10vw, 136px) !important;
  left: 22% !important;
}

body .mode-choice-board[data-active-path] .mode-choice-column:not(.is-open):not(.is-targeting) .mode-choice-card-grid {
  display: none !important;
}

body .mode-choice-board[data-active-path] .mode-choice-column.is-closing .mode-choice-card-grid .wizard-choice-card {
  opacity: 0 !important;
  filter: blur(2px) !important;
  transform: translate(0, 0) scale(0.18) !important;
}

body .mode-choice-card-grid .wizard-choice-card,
body .mode-choice-column-play .mode-choice-card-grid .wizard-choice-card,
body .mode-choice-column-train .mode-choice-card-grid .wizard-choice-card,
body .mode-choice-column-learn .mode-choice-card-grid .wizard-choice-card {
  width: clamp(132px, 12vw, 164px) !important;
  height: clamp(132px, 12vw, 164px) !important;
  max-width: clamp(132px, 12vw, 164px) !important;
  max-height: clamp(132px, 12vw, 164px) !important;
  min-width: clamp(132px, 12vw, 164px) !important;
  min-height: clamp(132px, 12vw, 164px) !important;
  border-radius: 20px !important;
}

body .mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(1) {
  --menu-x: 28%;
  --menu-y: -196%;
}

body .mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(2) {
  --menu-x: 104%;
  --menu-y: -118%;
}

body .mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(3) {
  --menu-x: 136%;
  --menu-y: -16%;
}

body .mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(4) {
  --menu-x: 104%;
  --menu-y: 88%;
}

body .mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(5) {
  --menu-x: 28%;
  --menu-y: 166%;
}

body .mode-choice-card-grid .wizard-choice-card .wizard-choice-slot {
  width: clamp(58px, 5.4vw, 72px) !important;
  height: clamp(58px, 5.4vw, 72px) !important;
}

body .mode-choice-card-grid .wizard-choice-card .wizard-choice-copy h3 {
  max-width: 132px !important;
  font-size: clamp(0.74rem, 0.92vw, 0.96rem) !important;
  line-height: 1.03 !important;
}

@media (max-width: 900px) {
  body .hero,
  body.is-local-mode .hero,
  body.is-online-mode .hero {
    min-height: 190px !important;
  }

  body .hero-copy {
    top: 42% !important;
    width: min(66vw, 420px) !important;
  }

  body .hero-online-mount {
    left: clamp(-84px, calc(-18vw + 90px), -10px) !important;
  }

  body .hero-progress-circles,
  body.is-local-mode .hero-progress-circles,
  body.is-online-mode .hero-progress-circles {
    left: 50% !important;
    right: auto !important;
    top: auto !important;
    bottom: 8px !important;
    width: min(92vw, 360px) !important;
    transform: translateX(-50%) !important;
  }

  body .mode-choice-board[data-active-path="learn"] .mode-choice-column-learn,
  body .mode-choice-board[data-active-path="play"] .mode-choice-column-play,
  body .mode-choice-board[data-active-path="train"] .mode-choice-column-train {
    left: 58% !important;
    width: clamp(300px, 74vw, 390px) !important;
    height: clamp(300px, 74vw, 390px) !important;
  }
}

body .layout {
  padding-top: clamp(22px, 2vw, 34px) !important;
}

/* May 23 pathstage9: oval header menu and simultaneous horizontal path cards. */
body .hero-online-button img {
  width: 50px !important;
  height: 50px !important;
}

body .hero-online-button {
  width: 86px !important;
  min-width: 86px !important;
}

body .hero-links,
body.is-local-mode .hero-links,
body.is-online-mode .hero-links {
  width: 510px !important;
  height: 560px !important;
}

body .hero-links::before {
  left: -236px !important;
  top: -210px !important;
  width: 560px !important;
  height: 640px !important;
  border-radius: 56% 44% 52% 48% / 45% 54% 46% 55% !important;
  background:
    radial-gradient(ellipse at 36% 35%, #fff1cf 0%, #f3d99f 54%, #d0a15b 100%) !important;
  border: 0 !important;
  box-shadow: 28px 30px 54px rgba(54, 33, 18, 0.24) !important;
  opacity: 0 !important;
  transform: translate(-145px, -20px) scale(0.08, 0.18) rotate(-8deg) !important;
  transform-origin: 260px 290px !important;
  transition:
    opacity 260ms ease,
    transform 880ms cubic-bezier(0.76, 0, 0.24, 1),
    border-radius 880ms cubic-bezier(0.76, 0, 0.24, 1) !important;
}

body .hero-links.is-open::before {
  opacity: 1 !important;
  transform: translate(0, 0) scale(1) rotate(0deg) !important;
}

body .hero-links > :not(.hero-menu-trigger),
body.is-local-mode .hero-links > :not(.hero-menu-trigger),
body.is-online-mode .hero-links > :not(.hero-menu-trigger) {
  left: 24px !important;
  top: 74px !important;
  width: 150px !important;
  height: 58px !important;
  min-width: 150px !important;
  min-height: 58px !important;
  padding: 4px 8px !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 8px !important;
  border: 1px solid transparent !important;
  border-radius: 14px !important;
  background: transparent !important;
  box-shadow: none !important;
  transform: translate(0, 0) scale(0.18) rotate(-8deg) !important;
  transform-origin: 20px 50% !important;
  transition:
    opacity 260ms ease,
    transform 880ms cubic-bezier(0.76, 0, 0.24, 1),
    filter 160ms ease !important;
}

body .hero-links.is-open > .hero-discord-link {
  transform: translate(114px, -36px) scale(1) rotate(0deg) !important;
}

body .hero-links.is-open > .session-controls {
  transform: translate(66px, 86px) scale(1) rotate(0deg) !important;
}

body .hero-links.is-open > button.hero-link-icon {
  transform: translate(178px, 154px) scale(1) rotate(0deg) !important;
}

body .hero-links.is-open > a.hero-link-icon {
  transform: translate(304px, 246px) scale(1) rotate(0deg) !important;
}

body .hero-links img,
body .hero-links .session-controls img,
body .hero-links .session-signout-button img,
body .hero-links .hero-link-icon img,
body .hero-links .hero-discord-link img {
  width: 40px !important;
  height: 40px !important;
  max-width: 40px !important;
  max-height: 40px !important;
  flex: 0 0 40px !important;
}

body .hero-links .session-controls,
body .hero-links .session-control-stack {
  flex-direction: row !important;
  gap: 8px !important;
}

body .hero-links .session-controls .hero-link-icon,
body .hero-links .session-controls .session-signout-button {
  width: 40px !important;
  height: 40px !important;
  min-width: 40px !important;
  min-height: 40px !important;
  flex: 0 0 40px !important;
}

body .hero-discord-link::after,
body .hero-links > .session-controls::after,
body .hero-links > button.hero-link-icon::after,
body .hero-links > a.hero-link-icon::after {
  display: inline-block !important;
  min-width: 0 !important;
  color: #4f311d !important;
  font-size: 0.82rem !important;
  font-weight: 950 !important;
  line-height: 1 !important;
  text-align: left !important;
  white-space: nowrap !important;
}

body .mode-choice-column,
body .mode-choice-column-learn,
body .mode-choice-column-play,
body .mode-choice-column-train {
  transition:
    left 880ms cubic-bezier(0.76, 0, 0.24, 1),
    top 880ms cubic-bezier(0.76, 0, 0.24, 1),
    width 880ms cubic-bezier(0.76, 0, 0.24, 1),
    height 880ms cubic-bezier(0.76, 0, 0.24, 1),
    transform 880ms cubic-bezier(0.76, 0, 0.24, 1),
    opacity 260ms ease !important;
}

body .mode-choice-board[data-active-path="learn"] .mode-choice-column-learn,
body .mode-choice-board[data-active-path="play"] .mode-choice-column-play,
body .mode-choice-board[data-active-path="train"] .mode-choice-column-train {
  left: 41% !important;
  width: clamp(420px, 38vw, 500px) !important;
  height: clamp(360px, 34vw, 440px) !important;
}

body .mode-choice-board[data-active-path] .mode-choice-column.is-targeting .mode-choice-heading,
body .mode-choice-board[data-active-path] .mode-choice-column.is-open .mode-choice-heading {
  left: 27% !important;
  width: clamp(112px, 10vw, 136px) !important;
  height: clamp(112px, 10vw, 136px) !important;
}

body .mode-choice-card-grid .wizard-choice-card,
body .mode-choice-column-play .mode-choice-card-grid .wizard-choice-card,
body .mode-choice-column-train .mode-choice-card-grid .wizard-choice-card,
body .mode-choice-column-learn .mode-choice-card-grid .wizard-choice-card {
  width: clamp(174px, 16vw, 220px) !important;
  height: clamp(68px, 6.6vw, 86px) !important;
  max-width: clamp(174px, 16vw, 220px) !important;
  max-height: clamp(68px, 6.6vw, 86px) !important;
  min-width: clamp(174px, 16vw, 220px) !important;
  min-height: clamp(68px, 6.6vw, 86px) !important;
  padding: 6px 10px !important;
  border: 1px solid transparent !important;
  border-radius: 15px !important;
  background: transparent !important;
  box-shadow: none !important;
}

body .mode-choice-card-grid .wizard-choice-card .card-top {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 9px !important;
  width: 100% !important;
  height: 100% !important;
}

body .mode-choice-card-grid .wizard-choice-card .wizard-choice-slot {
  width: clamp(44px, 4.2vw, 56px) !important;
  height: clamp(44px, 4.2vw, 56px) !important;
  flex: 0 0 clamp(44px, 4.2vw, 56px) !important;
}

body .mode-choice-card-grid .wizard-choice-card .wizard-choice-copy {
  min-width: 0 !important;
  text-align: left !important;
}

body .mode-choice-card-grid .wizard-choice-card .wizard-choice-copy h3 {
  max-width: 140px !important;
  margin: 0 !important;
  font-size: clamp(0.72rem, 0.85vw, 0.92rem) !important;
  line-height: 1.02 !important;
  text-align: left !important;
}

body .mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(1) {
  --menu-x: 56%;
  --menu-y: -142%;
}

body .mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(2) {
  --menu-x: 78%;
  --menu-y: -72%;
}

body .mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(3) {
  --menu-x: 86%;
  --menu-y: -2%;
}

body .mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(4) {
  --menu-x: 78%;
  --menu-y: 68%;
}

body .mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(5) {
  --menu-x: 56%;
  --menu-y: 138%;
}

body .mode-choice-column.is-closing .mode-choice-card-grid .wizard-choice-card,
body .mode-choice-board[data-active-path] .mode-choice-column.is-closing .mode-choice-card-grid .wizard-choice-card {
  opacity: 0 !important;
  filter: blur(2px) !important;
  pointer-events: none !important;
  transform: translate(-50%, -50%) scale(0.18) !important;
}

body .mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card {
  transition:
    transform 780ms cubic-bezier(0.76, 0, 0.24, 1),
    opacity 260ms ease,
    filter 260ms ease !important;
}

/* May 23 pathstage10: refine egg menu placement and simultaneous column swapping. */
body .hero-links a,
body .hero-links button,
body .hero-links > :not(.hero-menu-trigger),
body .hero-discord-link::after,
body .hero-links > .session-controls::after,
body .hero-links > button.hero-link-icon::after,
body .hero-links > a.hero-link-icon::after {
  text-decoration: none !important;
  text-decoration-line: none !important;
}

body .hero-links.is-open > .hero-discord-link {
  transform: translate(140px, -28px) scale(1) rotate(0deg) !important;
}

body .hero-links.is-open > .session-controls {
  transform: translate(164px, 92px) scale(1) rotate(0deg) !important;
}

body .hero-links.is-open > button.hero-link-icon {
  transform: translate(92px, 170px) scale(1) rotate(0deg) !important;
}

body .hero-links.is-open > a.hero-link-icon {
  transform: translate(126px, 254px) scale(1) rotate(0deg) !important;
}

body .mode-choice-board[data-active-path] .mode-choice-column.is-open.is-closing {
  left: clamp(4px, 1.1vw, 16px) !important;
  width: 112px !important;
  height: 112px !important;
  opacity: 0.68 !important;
  transform: none !important;
}

body .mode-choice-board[data-active-path] .mode-choice-column-learn.is-open.is-closing {
  top: 40px !important;
}

body .mode-choice-board[data-active-path] .mode-choice-column-play.is-open.is-closing {
  top: 174px !important;
}

body .mode-choice-board[data-active-path] .mode-choice-column-train.is-open.is-closing {
  top: 308px !important;
}

body .mode-choice-board[data-active-path] .mode-choice-column.is-open.is-closing .mode-choice-heading {
  left: 50% !important;
  width: 82px !important;
  height: 82px !important;
  opacity: 0.86 !important;
}

body .mode-choice-board[data-active-path] .mode-choice-column.is-open.is-closing .mode-choice-heading-slot {
  width: 38px !important;
  height: 38px !important;
}

body .mode-choice-board[data-active-path] .mode-choice-column.is-open.is-closing .mode-choice-heading h3 {
  font-size: 0.72rem !important;
}

body .mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(1) {
  --menu-x: 50%;
  --menu-y: -110%;
}

body .mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(2) {
  --menu-x: 66%;
  --menu-y: 5%;
}

body .mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(3) {
  --menu-x: 72%;
  --menu-y: 120%;
}

body .mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(4) {
  --menu-x: 66%;
  --menu-y: 235%;
}

body .mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(5) {
  --menu-x: 50%;
  --menu-y: 350%;
}

body .mode-choice-board.has-section-selection .mode-choice-heading,
body .mode-choice-board[data-active-path] .mode-choice-heading {
  pointer-events: auto !important;
}

body .mode-choice-heading * {
  pointer-events: none !important;
}

body .mode-choice-board.no-section-selection .mode-choice-heading {
  pointer-events: none !important;
}

/* May 23 pathstage13: keep header menu items inside the egg and make staged card opening visible. */
body .hero-links::before {
  left: -252px !important;
  top: -214px !important;
  width: 620px !important;
  height: 660px !important;
  border-radius: 58% 42% 54% 46% / 46% 55% 45% 54% !important;
}

body .hero-links.is-open > .hero-discord-link {
  transform: translate(118px, -30px) scale(1) rotate(0deg) !important;
}

body .hero-links.is-open > .session-controls {
  transform: translate(150px, 92px) scale(1) rotate(0deg) !important;
}

body .hero-links.is-open > button.hero-link-icon {
  transform: translate(86px, 176px) scale(1) rotate(0deg) !important;
}

body .hero-links.is-open > a.hero-link-icon {
  transform: translate(70px, 254px) scale(1) rotate(0deg) !important;
}

body .hero-discord-link::after,
body .hero-links > .session-controls::after,
body .hero-links > button.hero-link-icon::after,
body .hero-links > a.hero-link-icon::after {
  font-size: 1rem !important;
  letter-spacing: 0 !important;
}

body .mode-choice-column.is-opening:not(.is-open) .mode-choice-card-grid .wizard-choice-card {
  opacity: 0 !important;
  filter: blur(2px) !important;
  pointer-events: none !important;
  transform: translate(-50%, -50%) scale(0.18) !important;
}

body .mode-choice-column.is-opening.is-open .mode-choice-card-grid .wizard-choice-card {
  opacity: 1 !important;
  filter: blur(0) !important;
}

/* May 23 pathstage14: keep menu motion reversible and center path cards against the open circle. */
body .hero-online-button {
  width: 132px !important;
  min-width: 132px !important;
  height: 122px !important;
  min-height: 122px !important;
}

body .hero-online-button img {
  width: 100px !important;
  height: 100px !important;
  min-width: 100px !important;
  min-height: 100px !important;
  max-width: 100px !important;
  max-height: 100px !important;
  flex: 0 0 100px !important;
}

body .hero-links::before {
  transition:
    opacity 360ms ease,
    transform 1180ms cubic-bezier(0.76, 0, 0.24, 1),
    border-radius 1180ms cubic-bezier(0.76, 0, 0.24, 1) !important;
}

body .hero-links > :not(.hero-menu-trigger),
body.is-local-mode .hero-links > :not(.hero-menu-trigger),
body.is-online-mode .hero-links > :not(.hero-menu-trigger) {
  width: 190px !important;
  min-width: 190px !important;
  height: 66px !important;
  min-height: 66px !important;
  transition:
    opacity 360ms ease,
    transform 1180ms cubic-bezier(0.76, 0, 0.24, 1),
    filter 260ms ease !important;
}

body .hero-links.is-open > .hero-discord-link {
  transform: translate(126px, -30px) scale(1) rotate(0deg) !important;
}

body .hero-links.is-open > .session-controls {
  transform: translate(104px, 92px) scale(1) rotate(0deg) !important;
}

body .hero-links.is-open > button.hero-link-icon {
  transform: translate(72px, 176px) scale(1) rotate(0deg) !important;
}

body .hero-links.is-open > a.hero-link-icon {
  transform: translate(48px, 254px) scale(1) rotate(0deg) !important;
}

body .hero-discord-link::after,
body .hero-links > .session-controls::after,
body .hero-links > button.hero-link-icon::after,
body .hero-links > a.hero-link-icon::after {
  font-size: 1.18rem !important;
  line-height: 1.05 !important;
}

body .mode-choice-column,
body .mode-choice-column-learn,
body .mode-choice-column-play,
body .mode-choice-column-train,
body .mode-choice-board[data-active-path] .mode-choice-column.is-open.is-closing {
  transition:
    left 880ms cubic-bezier(0.76, 0, 0.24, 1),
    top 880ms cubic-bezier(0.76, 0, 0.24, 1),
    width 880ms cubic-bezier(0.76, 0, 0.24, 1),
    height 880ms cubic-bezier(0.76, 0, 0.24, 1),
    transform 880ms cubic-bezier(0.76, 0, 0.24, 1),
    opacity 320ms ease !important;
  will-change: left, top, width, height, transform, opacity;
}

body .mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(1) {
  --menu-x: 50%;
  --menu-y: -230%;
}

body .mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(2) {
  --menu-x: 66%;
  --menu-y: -100%;
}

body .mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(3) {
  --menu-x: 72%;
  --menu-y: 30%;
}

body .mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(4) {
  --menu-x: 66%;
  --menu-y: 160%;
}

body .mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(5) {
  --menu-x: 50%;
  --menu-y: 290%;
}

body .mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card,
body .mode-choice-column.is-opening.is-open .mode-choice-card-grid .wizard-choice-card,
body .mode-choice-column.is-closing .mode-choice-card-grid .wizard-choice-card {
  transition:
    transform 980ms cubic-bezier(0.76, 0, 0.24, 1),
    opacity 520ms ease,
    filter 520ms ease !important;
}

body .mode-choice-column.is-opening:not(.is-open) .mode-choice-card-grid .wizard-choice-card,
body .mode-choice-column.is-closing .mode-choice-card-grid .wizard-choice-card,
body .mode-choice-board[data-active-path] .mode-choice-column.is-closing .mode-choice-card-grid .wizard-choice-card {
  opacity: 0 !important;
  filter: blur(2px) !important;
  pointer-events: none !important;
  transform: translate(-50%, -50%) scale(0.18) !important;
}

/* May 23 pathstage20: make path switching one continuous move plus a real card spread. */
body .mode-choice-board[data-active-path] .mode-choice-column.is-closing {
  left: clamp(4px, 1.1vw, 16px) !important;
  width: 112px !important;
  height: 112px !important;
  opacity: 0.68 !important;
  transform: none !important;
  z-index: 4 !important;
}

body .mode-choice-board[data-active-path] .mode-choice-column-learn.is-closing {
  top: 40px !important;
}

body .mode-choice-board[data-active-path] .mode-choice-column-play.is-closing {
  top: 174px !important;
}

body .mode-choice-board[data-active-path] .mode-choice-column-train.is-closing {
  top: 308px !important;
}

body .mode-choice-board[data-active-path] .mode-choice-column.is-closing .mode-choice-heading,
body .mode-choice-board[data-active-path] .mode-choice-column:not(.is-open):not(.is-targeting) .mode-choice-heading {
  left: 50% !important;
  width: 82px !important;
  height: 82px !important;
  opacity: 0.86 !important;
}

body .mode-choice-column.is-opening.is-open .mode-choice-card-grid .wizard-choice-card {
  animation: mode-choice-card-spread-from-circle 980ms cubic-bezier(0.76, 0, 0.24, 1) both !important;
}

body .mode-choice-column.is-opening.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(1) {
  animation-delay: 0ms !important;
}

body .mode-choice-column.is-opening.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(2) {
  animation-delay: 36ms !important;
}

body .mode-choice-column.is-opening.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(3) {
  animation-delay: 72ms !important;
}

body .mode-choice-column.is-opening.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(4) {
  animation-delay: 108ms !important;
}

body .mode-choice-column.is-opening.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(5) {
  animation-delay: 144ms !important;
}

@keyframes mode-choice-card-spread-from-circle {
  from {
    opacity: 0;
    filter: blur(2px);
    transform: translate(-50%, -50%) scale(0.18);
  }
  to {
    opacity: 1;
    filter: blur(0);
    transform: translate(var(--menu-x), var(--menu-y)) scale(1);
  }
}

/* May 23 pathstage29: keep Train intro tips visible instead of leaving only a blurred page. */
body .question-popup-overlay.train-tip {
  position: fixed !important;
  inset: 0 !important;
  width: 100vw !important;
  height: 100dvh !important;
  min-height: 100dvh !important;
  max-height: 100dvh !important;
  display: grid !important;
  align-items: center !important;
  justify-items: center !important;
  overflow-y: auto !important;
  padding: 24px !important;
  z-index: 30000 !important;
}

body .question-popup-overlay.train-tip .question-popup-window {
  width: min(720px, calc(100vw - 28px)) !important;
  max-height: calc(100dvh - 28px) !important;
  margin: auto !important;
}

/* May 23 pathstage31: compact active path buttons, double-size aligned subcards. */
body .mode-choice-board.has-section-selection[data-active-path="learn"] .mode-choice-column.mode-choice-column-learn.is-targeting .mode-choice-heading,
body .mode-choice-board.has-section-selection[data-active-path="learn"] .mode-choice-column.mode-choice-column-learn.is-open .mode-choice-heading,
body .mode-choice-board.has-section-selection[data-active-path="play"] .mode-choice-column.mode-choice-column-play.is-targeting .mode-choice-heading,
body .mode-choice-board.has-section-selection[data-active-path="play"] .mode-choice-column.mode-choice-column-play.is-open .mode-choice-heading,
body .mode-choice-board.has-section-selection[data-active-path="train"] .mode-choice-column.mode-choice-column-train.is-targeting .mode-choice-heading,
body .mode-choice-board.has-section-selection[data-active-path="train"] .mode-choice-column.mode-choice-column-train.is-open .mode-choice-heading,
body .mode-choice-board.has-section-selection:has(.mode-choice-column.is-open) .mode-choice-column.is-open .mode-choice-heading {
  left: 27% !important;
  width: 82px !important;
  height: 82px !important;
  min-width: 82px !important;
  min-height: 82px !important;
  padding: 6px !important;
  gap: 1px !important;
}

body .mode-choice-board.has-section-selection[data-active-path] .mode-choice-column.is-targeting .mode-choice-heading-slot,
body .mode-choice-board.has-section-selection[data-active-path] .mode-choice-column.is-open .mode-choice-heading-slot,
body .mode-choice-board.has-section-selection:has(.mode-choice-column.is-open) .mode-choice-column.is-open .mode-choice-heading-slot {
  width: 36px !important;
  height: 36px !important;
  min-width: 36px !important;
  min-height: 36px !important;
  max-width: 36px !important;
  max-height: 36px !important;
}

body .mode-choice-board.has-section-selection[data-active-path] .mode-choice-column.is-targeting .mode-choice-heading h3,
body .mode-choice-board.has-section-selection[data-active-path] .mode-choice-column.is-open .mode-choice-heading h3,
body .mode-choice-board.has-section-selection:has(.mode-choice-column.is-open) .mode-choice-column.is-open .mode-choice-heading h3 {
  max-width: 66px !important;
  font-size: 0.68rem !important;
  line-height: 0.95 !important;
  text-align: center !important;
}

body .mode-choice-board.has-section-selection[data-active-path] .mode-choice-column .mode-choice-card-grid .wizard-choice-card,
body .mode-choice-board.has-section-selection[data-active-path] .mode-choice-column-play .mode-choice-card-grid .wizard-choice-card,
body .mode-choice-board.has-section-selection[data-active-path] .mode-choice-column-train .mode-choice-card-grid .wizard-choice-card,
body .mode-choice-board.has-section-selection[data-active-path] .mode-choice-column-learn .mode-choice-card-grid .wizard-choice-card,
body .mode-choice-board.has-section-selection:has(.mode-choice-column.is-open) .mode-choice-column .mode-choice-card-grid .wizard-choice-card {
  width: clamp(300px, 28vw, 360px) !important;
  height: clamp(104px, 10vw, 126px) !important;
  max-width: clamp(300px, 28vw, 360px) !important;
  max-height: clamp(104px, 10vw, 126px) !important;
  min-width: clamp(300px, 28vw, 360px) !important;
  min-height: clamp(104px, 10vw, 126px) !important;
  padding: 8px 18px !important;
  aspect-ratio: auto !important;
  border-radius: 15px !important;
  opacity: 0 !important;
  filter: blur(2px) !important;
}

body .mode-choice-board.has-section-selection[data-active-path] .mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card,
body .mode-choice-board.has-section-selection:has(.mode-choice-column.is-open) .mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card {
  opacity: 1 !important;
  filter: blur(0) !important;
  pointer-events: auto !important;
}

body .mode-choice-board.has-section-selection[data-active-path] .mode-choice-column.is-open:not(.is-opening) .mode-choice-card-grid .wizard-choice-card {
  transform: translate(var(--menu-x), var(--menu-y)) scale(1) !important;
}

body .mode-choice-board.has-section-selection[data-active-path] .mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:hover,
body .mode-choice-board.has-section-selection[data-active-path] .mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:focus-visible {
  transform: translate(var(--menu-x), var(--menu-y)) scale(1.04) !important;
}

body .mode-choice-board.has-section-selection[data-active-path] .mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(1) {
  --menu-x: 52%;
  --menu-y: -172%;
}

body .mode-choice-board.has-section-selection[data-active-path] .mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(2) {
  --menu-x: 64%;
  --menu-y: -82%;
}

body .mode-choice-board.has-section-selection[data-active-path] .mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(3) {
  --menu-x: 70%;
  --menu-y: 8%;
}

body .mode-choice-board.has-section-selection[data-active-path] .mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(4) {
  --menu-x: 64%;
  --menu-y: 98%;
}

body .mode-choice-board.has-section-selection[data-active-path] .mode-choice-column.is-open .mode-choice-card-grid .wizard-choice-card:nth-child(5) {
  --menu-x: 52%;
  --menu-y: 188%;
}

body .mode-choice-board.has-section-selection[data-active-path] .mode-choice-card-grid .wizard-choice-card .card-top,
body .mode-choice-board.has-section-selection:has(.mode-choice-column.is-open) .mode-choice-card-grid .wizard-choice-card .card-top {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: clamp(14px, 1.6vw, 22px) !important;
  width: 100% !important;
  height: 100% !important;
}

body .mode-choice-board.has-section-selection[data-active-path] .mode-choice-card-grid .wizard-choice-card .wizard-choice-slot,
body .mode-choice-board.has-section-selection:has(.mode-choice-column.is-open) .mode-choice-card-grid .wizard-choice-card .wizard-choice-slot {
  width: clamp(86px, 8vw, 104px) !important;
  height: clamp(86px, 8vw, 104px) !important;
  flex: 0 0 clamp(86px, 8vw, 104px) !important;
  min-width: clamp(86px, 8vw, 104px) !important;
  min-height: clamp(86px, 8vw, 104px) !important;
  max-width: clamp(86px, 8vw, 104px) !important;
  max-height: clamp(86px, 8vw, 104px) !important;
}

body .mode-choice-board.has-section-selection[data-active-path] .mode-choice-card-grid .wizard-choice-card .wizard-choice-copy,
body .mode-choice-board.has-section-selection:has(.mode-choice-column.is-open) .mode-choice-card-grid .wizard-choice-card .wizard-choice-copy {
  display: flex !important;
  min-width: 0 !important;
  height: 100% !important;
  align-items: center !important;
  justify-items: start !important;
  text-align: left !important;
}

body .mode-choice-board.has-section-selection[data-active-path] .mode-choice-card-grid .wizard-choice-card .wizard-choice-copy h3,
body .mode-choice-board.has-section-selection:has(.mode-choice-column.is-open) .mode-choice-card-grid .wizard-choice-card .wizard-choice-copy h3 {
  max-width: clamp(170px, 17vw, 230px) !important;
  margin: 0 !important;
  font-size: clamp(1.06rem, 1.45vw, 1.48rem) !important;
  line-height: 1.02 !important;
  text-align: left !important;
}

body .mode-choice-board.has-section-selection[data-active-path] .mode-choice-card-grid .wizard-choice-card .mode-card-thanks,
body .mode-choice-board.has-section-selection:has(.mode-choice-column.is-open) .mode-choice-card-grid .wizard-choice-card .mode-card-thanks {
  display: block !important;
  margin-top: 3px !important;
  font-size: clamp(0.62rem, 0.78vw, 0.82rem) !important;
  line-height: 1 !important;
}

/* Orbit mind map: adapted from the online orbit template into the WSC warm theme. */
.experience-panel.experience-panel--mindmap {
  padding: 0 !important;
  background: transparent !important;
  border-color: transparent !important;
  box-shadow: none !important;
}

.experience-panel--mindmap .panel-title,
.experience-panel--mindmap .mindmap-shell,
.experience-panel--mindmap .mindmap-radial-set,
.experience-panel--mindmap .mindmap-radial-map,
.experience-panel--mindmap .learn-card-footer-nav {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

.experience-panel--mindmap .panel-title {
  margin-bottom: 14px !important;
}

.experience-panel--mindmap .mindmap-shell {
  padding: 0 !important;
  gap: 14px !important;
}

.experience-panel--mindmap .mindmap-radial-set,
.experience-panel--mindmap .mindmap-radial-map {
  gap: 14px !important;
}

.experience-panel--mindmap .learn-card-footer-nav {
  margin-top: 14px !important;
  padding-top: 0 !important;
}

.mindmap-gallery {
  position: relative;
  display: grid;
  gap: 12px;
}

.mindmap-gallery-track {
  display: flex !important;
  grid-auto-flow: column;
  grid-auto-columns: minmax(0, 100%);
  gap: clamp(18px, 4vw, 42px) !important;
  overflow-x: auto;
  overflow-y: visible;
  padding: 2px clamp(8px, 7vw, 86px) 16px;
  scroll-behavior: smooth;
  scroll-padding-inline: clamp(8px, 7vw, 86px);
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
}

.mindmap-gallery-track::-webkit-scrollbar {
  display: none;
}

.mindmap-gallery-slide {
  flex: 0 0 min(100%, 1080px);
  min-width: 0;
  scroll-snap-align: center;
  scroll-snap-stop: always;
}

.mindmap-gallery.has-multiple .mindmap-gallery-slide {
  filter: drop-shadow(0 18px 34px rgba(65, 42, 23, 0.08));
}

.mindmap-gallery.has-multiple .mindmap-radial-scroll {
  cursor: default;
}

.mindmap-gallery.has-multiple .mindmap-radial-scroll:active {
  cursor: default;
}

.mindmap-gallery-nav {
  position: absolute;
  top: 50%;
  z-index: 8;
  width: 48px;
  height: 48px;
  display: grid;
  place-items: center;
  padding: 0;
  border: 1px solid rgba(107, 78, 22, 0.18);
  border-radius: 999px;
  background: rgba(255, 250, 238, 0.84);
  color: #4b2f21;
  box-shadow: 0 16px 30px rgba(65, 42, 23, 0.16);
  cursor: pointer;
  font: inherit;
  transform: translateY(-50%);
  transition: transform 180ms ease, background 180ms ease, box-shadow 180ms ease;
}

.mindmap-gallery-nav:hover,
.mindmap-gallery-nav:focus-visible {
  background: rgba(255, 250, 238, 0.98);
  box-shadow: 0 20px 36px rgba(65, 42, 23, 0.2);
  outline: none;
  transform: translateY(-50%) scale(1.05);
}

.mindmap-gallery-nav span {
  display: block;
  margin-top: -3px;
  font-size: 2.25rem;
  font-weight: 900;
  line-height: 1;
}

.mindmap-gallery-nav--previous {
  left: 10px;
}

.mindmap-gallery-nav--next {
  right: 10px;
}

.experience-panel--mindmap .mindmap-radial-scroll {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 640px;
  overflow: hidden !important;
  overflow: clip !important;
  border-radius: 42px;
  border: 1px solid rgba(107, 78, 22, 0.18);
  background:
    radial-gradient(circle at 50% 48%, rgba(255, 249, 232, 0.92) 0 16%, transparent 17%),
    radial-gradient(circle at 18% 16%, rgba(255, 250, 238, 0.82), transparent 34%),
    radial-gradient(circle at 84% 82%, rgba(200, 156, 68, 0.28), transparent 36%),
    linear-gradient(135deg, rgba(248, 233, 193, 0.9), rgba(221, 190, 124, 0.72));
  box-shadow:
    inset 0 0 0 1px rgba(255, 250, 238, 0.5),
    inset 0 0 64px rgba(138, 99, 56, 0.08),
    0 24px 48px rgba(65, 42, 23, 0.12);
  scrollbar-width: none;
  -webkit-overflow-scrolling: auto;
}

.experience-panel--mindmap .mindmap-radial-scroll::-webkit-scrollbar {
  display: none;
}

.experience-panel--mindmap .mindmap-radial-stage {
  flex: 0 0 auto;
  isolation: isolate;
  overflow: visible;
  margin: 0;
  transform: none;
  background:
    radial-gradient(circle at center, rgba(255, 250, 238, 0.9) 0 9%, rgba(255, 250, 238, 0.36) 9.2% 13%, transparent 13.4%),
    radial-gradient(circle at center, rgba(252, 209, 39, 0.14), transparent 52%),
    radial-gradient(circle at center, transparent 0 64%, rgba(107, 78, 22, 0.07) 64.3% 64.7%, transparent 65%);
}

.mindmap-orbit-path {
  position: absolute;
  z-index: 0;
  top: 50%;
  left: 50%;
  width: calc(var(--orbit-radius) * 2);
  height: calc(var(--orbit-radius) * 2);
  border-radius: 50%;
  pointer-events: none;
  transform: translate(-50%, -50%);
}

.mindmap-orbit-path::before,
.mindmap-orbit-path::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
}

.mindmap-orbit-path::before {
  background: radial-gradient(circle, transparent 56%, rgba(252, 209, 39, 0.14) 72%, rgba(138, 99, 56, 0.18) 100%);
  box-shadow:
    0 0 46px rgba(200, 156, 68, 0.22),
    inset 0 0 34px rgba(255, 250, 238, 0.34);
  animation: mindmapOrbitPulse 5.2s ease-in-out infinite;
  animation-delay: var(--orbit-delay);
}

.mindmap-orbit-path::after {
  border: 1px solid rgba(138, 99, 56, 0.22);
  box-shadow: inset 0 0 22px rgba(107, 78, 22, 0.1);
}

.mindmap-orbit-path.orbit-tone-1::before {
  display: none;
  animation: none;
  box-shadow: none;
}

.mindmap-orbit-path.orbit-tone-1::after {
  border-color: rgba(138, 99, 56, 0.18);
  box-shadow: none;
}

.mindmap-orbit-path.orbit-tone-2::before {
  background: radial-gradient(circle, transparent 56%, rgba(185, 137, 83, 0.15) 72%, rgba(75, 47, 33, 0.16) 100%);
}

.experience-panel--mindmap .mindmap-radial-center {
  z-index: 3;
  width: 190px;
  min-height: 190px;
  padding: 28px;
  border: 1px solid rgba(255, 250, 238, 0.28);
  background:
    radial-gradient(circle at 30% 20%, rgba(255, 250, 238, 0.22), transparent 34%),
    linear-gradient(145deg, rgba(126, 81, 39, 0.98), rgba(75, 47, 33, 0.98));
  box-shadow:
    0 0 34px rgba(200, 156, 68, 0.34),
    0 0 78px rgba(75, 47, 33, 0.16),
    0 24px 42px rgba(65, 42, 23, 0.24);
}

.experience-panel--mindmap .mindmap-radial-center::before {
  content: "";
  position: absolute;
  inset: -18px;
  z-index: -1;
  border-radius: inherit;
  background: radial-gradient(circle, rgba(252, 209, 39, 0.2), transparent 68%);
  filter: blur(4px);
  animation: mindmapOrbitPulse 4.6s ease-in-out infinite;
}

.experience-panel--mindmap .mindmap-radial-center strong {
  max-width: 145px;
  color: #fff6df;
  font-size: clamp(1.05rem, 2vw, 1.28rem);
  text-shadow: 0 2px 14px rgba(0, 0, 0, 0.24);
}

.experience-panel--mindmap .mindmap-radial-entry {
  z-index: 2;
  width: var(--bubble-width);
  min-height: var(--bubble-height);
  border-color: rgba(138, 99, 56, 0.34);
  background:
    radial-gradient(circle at 28% 20%, rgba(255, 255, 255, 0.8), transparent 38%),
    linear-gradient(145deg, rgba(255, 250, 238, 0.96), rgba(244, 222, 170, 0.94));
  color: #4b2f21;
  box-shadow:
    0 0 18px rgba(200, 156, 68, 0.18),
    0 16px 28px rgba(65, 42, 23, 0.11);
  will-change: left, top, transform;
}

.experience-panel--mindmap .mindmap-radial-entry.orbit-tone-1 {
  border-color: rgba(138, 99, 56, 0.34);
  background:
    radial-gradient(circle at 28% 20%, rgba(255, 255, 255, 0.8), transparent 38%),
    linear-gradient(145deg, rgba(255, 250, 238, 0.96), rgba(244, 222, 170, 0.94));
  box-shadow: 0 14px 24px rgba(65, 42, 23, 0.1);
}

.experience-panel--mindmap .mindmap-radial-entry.orbit-tone-2 {
  border-color: rgba(185, 137, 83, 0.42);
  background:
    radial-gradient(circle at 28% 20%, rgba(255, 255, 255, 0.78), transparent 38%),
    linear-gradient(145deg, rgba(255, 250, 238, 0.96), rgba(232, 203, 139, 0.9));
}

.experience-panel--mindmap .mindmap-radial-entry:hover,
.experience-panel--mindmap .mindmap-radial-entry:focus-visible {
  border-color: rgba(75, 47, 33, 0.76);
  background:
    radial-gradient(circle at 28% 20%, rgba(255, 255, 255, 0.9), transparent 38%),
    linear-gradient(145deg, rgba(255, 250, 238, 1), rgba(252, 231, 175, 0.98));
  box-shadow:
    0 0 28px rgba(252, 209, 39, 0.34),
    0 0 52px rgba(200, 156, 68, 0.18),
    0 22px 34px rgba(65, 42, 23, 0.18);
}

.experience-panel--mindmap .mindmap-radial-entry.orbit-tone-1:hover,
.experience-panel--mindmap .mindmap-radial-entry.orbit-tone-1:focus-visible {
  box-shadow: 0 18px 28px rgba(65, 42, 23, 0.14);
}

@keyframes mindmapOrbitPulse {
  0%,
  100% {
    opacity: 0.7;
    transform: scale(0.985);
  }

  50% {
    opacity: 1;
    transform: scale(1.015);
  }
}

@media (prefers-reduced-motion: reduce) {
  .mindmap-orbit-path::before,
  .experience-panel--mindmap .mindmap-radial-center::before {
    animation: none;
  }
}

@media (max-width: 760px) {
  .mindmap-gallery-track {
    padding-inline: 0;
    scroll-padding-inline: 0;
  }

  .mindmap-gallery-nav {
    width: 40px;
    height: 40px;
  }

  .mindmap-gallery-nav--previous {
    left: 6px;
  }

  .mindmap-gallery-nav--next {
    right: 6px;
  }

  .experience-panel--mindmap .mindmap-radial-scroll {
    min-height: 500px;
    border-radius: 30px;
  }

  .experience-panel--mindmap .mindmap-radial-center {
    width: 154px;
    min-height: 154px;
    padding: 22px;
  }
}

/* May 23 pathstage34: app-wide Google font requested by the user. */
:root {
  --wsc-app-font: "Shadows Into Light Two", "Inter Tight", system-ui, sans-serif;
}

body,
body *:not(svg):not(path) {
  font-family: var(--wsc-app-font) !important;
  letter-spacing: 0 !important;
}

/* May 23 pathstage36: Raw Content and Guide questions use the Mind Map slideshow pattern. */
.raw-question-gallery {
  margin-top: 10px;
  overflow: visible;
}

.raw-question-gallery-track {
  align-items: stretch !important;
  gap: clamp(16px, 3vw, 34px) !important;
  padding: 4px clamp(14px, 7vw, 86px) 18px !important;
}

.raw-question-gallery-slide {
  display: flex;
  align-items: stretch;
  flex: 0 0 min(100%, 920px);
  min-width: 0;
  transition: opacity 220ms ease, filter 220ms ease, transform 220ms ease;
}

.raw-question-gallery-slide:not(.active) {
  opacity: 0.54;
  filter: saturate(0.9);
  transform: scale(0.985);
}

.raw-question-gallery-slide > .raw-quiz-card {
  width: 100%;
  min-height: clamp(280px, 26vw, 420px);
}

.raw-question-gallery-nav {
  top: calc(50% + 10px);
}

.raw-question-gallery-nav:disabled {
  opacity: 0.24;
  cursor: default;
  pointer-events: none;
}

/* May 23 pathstage36: online setup/lobby cleanup requested by the user. */
.online-create-heading {
  align-items: start;
  flex-wrap: nowrap;
}

.online-create-title-copy {
  display: grid;
  gap: 3px;
  min-width: 0;
}

.online-create-title-copy > p,
.online-create-title-copy > h2 {
  width: auto;
  margin: 0;
}

.online-return-hub-button {
  margin-left: auto;
  flex: 0 0 auto;
}

.live-run-setup-color-picker {
  width: min(100%, 760px);
}

.live-run-setup-color-picker > strong {
  color: var(--bg);
}

.live-run-setup-color-picker .live-color-chip {
  min-height: 86px;
}
