:root {
      --ink: #102033;
      --muted: #5b6775;
      --blue: #2e74b5;
      --blue-dark: #1f4d78;
      --line: #d8e1ea;
      --paper: #ffffff;
      --soft: #f4f7fb;
      --warm: #c97b42;
      --green: #5d8f75;
      --shadow: 0 18px 50px rgba(16, 32, 51, .10);
    }

    * {
      box-sizing: border-box;
    }

    html {
      scroll-behavior: smooth;
    }

    [id] {
      scroll-margin-top: 132px;
    }

    body {
      margin: 0;
      font-family: Arial, Helvetica, sans-serif;
      color: var(--ink);
      background:
        linear-gradient(180deg, #ffffff 0%, #fbfcfd 38%, #f5f8fb 100%);
    }

    body.modal-open {
      overflow: hidden;
    }

    a {
      color: inherit;
    }

    .sr-only {
      position: absolute;
      width: 1px;
      height: 1px;
      padding: 0;
      margin: -1px;
      overflow: hidden;
      clip: rect(0, 0, 0, 0);
      white-space: nowrap;
      border: 0;
    }

    .site-shell {
      min-height: 100vh;
    }

    .hero {
      position: relative;
      display: grid;
      grid-template-columns: minmax(0, 1fr) minmax(340px, .9fr);
      gap: clamp(28px, 5vw, 64px);
      align-items: center;
      max-width: 1180px;
      margin: 0 auto;
      padding: clamp(88px, 9vw, 118px) 20px 28px;
    }

    .email-dock {
      position: absolute;
      top: 18px;
      left: 50%;
      z-index: 5;
      width: min(360px, calc(100vw - 40px));
      text-align: center;
      transform: translateX(-50%);
    }

    .email-dock a {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 38px;
      padding: 8px 11px;
      border: 1px solid var(--line);
      border-radius: 8px;
      background: rgba(255, 255, 255, .96);
      box-shadow: 0 12px 30px rgba(16, 32, 51, .08);
      color: var(--blue-dark);
      font-size: 13px;
      font-weight: 800;
      text-decoration: none;
    }

    .game-promo-banner {
      position: relative;
      display: grid;
      grid-template-columns: auto minmax(0, 1fr) auto;
      align-items: center;
      gap: 10px;
      max-width: 710px;
      min-height: 46px;
      margin: 0 0 18px;
      padding: 6px 9px;
      border: 4px solid #10203b;
      border-radius: 0;
      background:
        linear-gradient(90deg, rgba(255,255,255,.18) 2px, transparent 2px) 0 0 / 16px 16px,
        linear-gradient(rgba(255,255,255,.14) 2px, transparent 2px) 0 0 / 16px 16px,
        linear-gradient(90deg, #17377d 0%, #2457ad 44%, #10203b 100%);
      color: #fff;
      font-family: "Courier New", ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
      font-smooth: never;
      -webkit-font-smoothing: none;
      text-decoration: none;
      image-rendering: pixelated;
      box-shadow: inset 0 0 0 2px rgba(255,255,255,.22), 7px 7px 0 rgba(16, 32, 51, .18);
      overflow: hidden;
    }

    .game-promo-banner::before {
      content: "";
      position: absolute;
      inset: auto 0 0;
      height: 6px;
      background: repeating-linear-gradient(90deg, #f0a637 0 14px, #d7b46a 14px 28px);
    }

    .game-promo-banner:hover {
      transform: translateY(-1px);
      box-shadow: inset 0 0 0 2px rgba(255,255,255,.28), 9px 9px 0 rgba(16, 32, 51, .22);
    }

    .game-promo-sprite {
      position: relative;
      width: 32px;
      height: 36px;
      flex: 0 0 auto;
      filter: drop-shadow(3px 4px 0 rgba(0,0,0,.28));
    }

    .game-promo-sprite::before {
      content: "";
      position: absolute;
      left: 9px;
      top: 3px;
      width: 14px;
      height: 14px;
      background: #f2c38f;
      box-shadow:
        0 15px 0 5px #2d7d44,
        -5px 20px 0 0 #f2c38f,
        20px 20px 0 0 #f2c38f,
        0 32px 0 3px #10203b,
        13px 32px 0 3px #10203b;
    }

    .game-promo-sprite::after {
      content: "";
      position: absolute;
      left: 6px;
      top: 0;
      width: 20px;
      height: 7px;
      background: #24334d;
      box-shadow: 5px 6px 0 #24334d;
    }

    .game-promo-copy {
      min-width: 0;
      display: grid;
      gap: 2px;
    }

    .game-promo-kicker {
      color: #f1cf8b;
      font-size: 10px;
      font-weight: 900;
      letter-spacing: .14em;
      line-height: 1;
      text-transform: uppercase;
    }

    .game-promo-title {
      color: #fff;
      font-size: clamp(14px, 1.7vw, 17px);
      font-weight: 900;
      line-height: 1.08;
      letter-spacing: .04em;
      text-transform: uppercase;
      text-shadow: 3px 3px 0 #0b1426;
    }

    .game-promo-line {
      color: #dbe8ff;
      font-size: 10px;
      font-weight: 800;
      line-height: 1.25;
      letter-spacing: .02em;
    }

    .game-promo-cta {
      display: inline-grid;
      place-items: center;
      min-height: 27px;
      padding: 4px 7px;
      border: 3px solid #fff;
      background: #f0a637;
      color: #10203b;
      font-size: 11px;
      font-weight: 900;
      letter-spacing: .08em;
      line-height: 1;
      text-transform: uppercase;
      box-shadow: 4px 4px 0 #0b1426;
      white-space: nowrap;
    }

    .eyebrow {
      margin: 0 0 12px;
      color: var(--blue);
      font-size: 13px;
      font-weight: 800;
      letter-spacing: .08em;
      text-transform: uppercase;
    }

    .brand-lockup {
      display: flex;
      align-items: center;
      gap: 12px;
      margin-bottom: 16px;
    }

    .logo-mark {
      display: grid;
      place-items: center;
      width: 58px;
      height: 58px;
      border: 1px solid var(--line);
      border-radius: 10px;
      background: #fff;
      color: var(--blue-dark);
      box-shadow: 0 12px 32px rgba(16, 32, 51, .08);
    }

    .logo-mark img {
      width: 42px;
      height: 42px;
      object-fit: cover;
      display: block;
    }

    h1 {
      margin: 0 0 16px;
      max-width: 760px;
      font-size: clamp(44px, 8vw, 92px);
      line-height: .94;
      letter-spacing: 0;
    }

    .hero-title-wrap {
      position: relative;
      display: inline-grid;
      max-width: 760px;
      margin-bottom: 16px;
      padding-right: clamp(55px, 10.8vw, 114px);
      isolation: isolate;
    }

    .hero-title-wrap h1 {
      position: relative;
      z-index: 2;
      margin-bottom: 0;
    }

    .title-trap-mark {
      position: absolute;
      right: 0;
      top: 50%;
      z-index: 1;
      width: clamp(58px, 10.8vw, 114px);
      color: rgba(16, 32, 51, .20);
      transform: translateY(-50%);
      pointer-events: none;
    }

    .title-trap-mark img {
      width: 100%;
      height: auto;
      object-fit: contain;
      display: block;
    }

    .lede {
      max-width: 680px;
      margin: 0;
      color: var(--muted);
      font-size: clamp(18px, 2.1vw, 22px);
      line-height: 1.55;
    }

    .hero-actions {
      display: flex;
      flex-wrap: wrap;
      gap: 10px;
      margin-top: 26px;
    }

    .hero-search {
      max-width: 560px;
      margin-top: 18px;
    }

    .hero-search input {
      width: 100%;
      min-height: 48px;
      padding: 12px 14px;
      border: 1px solid var(--line);
      border-radius: 8px;
      background: #fff;
      color: var(--ink);
      font: inherit;
      font-size: 16px;
      box-shadow: 0 10px 26px rgba(16, 32, 51, .06);
    }

    .button {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 44px;
      padding: 10px 16px;
      border: 1px solid var(--blue);
      border-radius: 6px;
      background: var(--blue);
      color: #fff;
      font: inherit;
      font-size: 15px;
      font-weight: 700;
      text-decoration: none;
      cursor: pointer;
    }

    .button.secondary {
      background: #fff;
      color: var(--blue-dark);
      border-color: var(--line);
    }

    .button.tertiary {
      background: #fffaf2;
      color: #8b561f;
      border-color: #ead1ae;
    }

    .button:hover {
      transform: translateY(-1px);
      box-shadow: 0 8px 18px rgba(46, 116, 181, .18);
    }

    .field-visual {
      min-height: 420px;
      border: 1px solid var(--line);
      border-radius: 8px;
      background:
        linear-gradient(140deg, rgba(255,255,255,.96) 0%, rgba(237,244,251,.96) 100%);
      box-shadow: var(--shadow);
      padding: 24px;
      overflow: hidden;
    }

    .visual-board {
      position: relative;
      height: 100%;
      min-height: 370px;
      border-radius: 6px;
      background:
        linear-gradient(90deg, rgba(46,116,181,.08) 1px, transparent 1px),
        linear-gradient(rgba(46,116,181,.08) 1px, transparent 1px),
        #fff;
      background-size: 34px 34px;
      overflow: hidden;
    }

    .visual-board::before {
      content: "";
      position: absolute;
      inset: 26px;
      border: 1px dashed rgba(31, 77, 120, .22);
      border-radius: 8px;
    }

    .note {
      position: absolute;
      z-index: 1;
      width: 142px;
      min-height: 86px;
      padding: 12px;
      border: 1px solid var(--line);
      border-radius: 6px;
      background: #fff;
      box-shadow: 0 10px 26px rgba(16,32,51,.10);
    }

    .note strong {
      display: block;
      margin-bottom: 8px;
      color: var(--blue-dark);
      font-size: 13px;
    }

    .note span {
      display: block;
      height: 7px;
      margin: 7px 0;
      border-radius: 999px;
      background: #dfe8f0;
    }

    .note.one { left: 24px; top: 28px; transform: rotate(-4deg); }
    .note.two { right: 30px; top: 58px; transform: rotate(5deg); }
    .note.three { left: 46px; bottom: 52px; transform: rotate(3deg); }
    .note.four { right: 66px; bottom: 38px; transform: rotate(-3deg); }

    .thought-line {
      position: absolute;
      left: 28%;
      top: 45%;
      width: 44%;
      height: 2px;
      background: var(--warm);
      transform: rotate(-10deg);
      opacity: .75;
    }

    .thought-line::before,
    .thought-line::after {
      content: "";
      position: absolute;
      top: 50%;
      width: 9px;
      height: 9px;
      border-radius: 999px;
      background: var(--warm);
      transform: translateY(-50%);
    }

    .thought-line::before { left: 0; }
    .thought-line::after { right: 0; }

    .marker-cloud {
      position: absolute;
      left: 50%;
      top: 50%;
      z-index: 2;
      display: grid;
      grid-template-columns: repeat(3, 44px);
      gap: 8px;
      transform: translate(-50%, -50%);
    }

    .mini-mark {
      display: grid;
      place-items: center;
      width: 44px;
      height: 44px;
      border-radius: 6px;
      background: var(--accent-soft);
      color: var(--accent);
      font-weight: 800;
      box-shadow: inset 0 0 0 1px #d4e0ec;
    }

    .mini-mark svg {
      width: 24px;
      height: 24px;
      fill: none;
      stroke: currentColor;
      stroke-width: 2.4;
      stroke-linecap: round;
      stroke-linejoin: round;
    }

    .stats {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 8px;
      max-width: 1180px;
      margin: 0 auto;
      padding: 0 20px 16px;
    }

    .stat {
      position: relative;
      display: flex;
      align-items: baseline;
      gap: 8px;
      min-height: 48px;
      padding: 10px 12px;
      border: 1px solid var(--line);
      border-radius: 8px;
      background: #fff;
      overflow: hidden;
    }

    .stat::before {
      content: "";
      position: absolute;
      inset: 0 0 auto;
      height: 3px;
      background: linear-gradient(90deg, var(--blue), var(--green), var(--warm));
    }

    .stat strong {
      display: inline-block;
      margin-bottom: 0;
      color: var(--blue-dark);
      font-size: 21px;
      line-height: 1;
    }

    .stat span {
      color: var(--muted);
      font-size: 12px;
      font-weight: 800;
      line-height: 1.2;
    }

    .onboarding-strip {
      max-width: 1180px;
      margin: 0 auto;
      padding: 0 20px 28px;
    }

    .onboarding-inner {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 10px;
      padding: 14px;
      border: 1px solid var(--line);
      border-radius: 10px;
      background: #fff;
      box-shadow: 0 10px 26px rgba(16, 32, 51, .05);
    }

    .onboarding-step {
      display: grid;
      grid-template-columns: 34px minmax(0, 1fr);
      gap: 10px;
      align-items: center;
      padding: 10px;
      border-radius: 8px;
      background: var(--soft);
    }

    a.onboarding-step {
      color: inherit;
      text-decoration: none;
    }

    .onboarding-step strong {
      display: grid;
      place-items: center;
      width: 34px;
      height: 34px;
      border-radius: 999px;
      background: var(--blue);
      color: #fff;
      font-size: 14px;
    }

    .onboarding-step span {
      color: var(--ink);
      font-size: 14px;
      font-weight: 800;
      line-height: 1.25;
    }

    .prompt-check,
    .trap-check {
      max-width: 1180px;
      margin: 0 auto;
      padding: 0 20px 28px;
    }

    .prompt-check:not(.active),
    .trap-check:not(.active) {
      display: none;
    }

    .prompt-check-card,
    .trap-check-card {
      display: grid;
      grid-template-columns: minmax(0, .95fr) minmax(320px, 1.05fr);
      gap: 18px;
      padding: 20px;
      border: 1px solid var(--line);
      border-radius: 10px;
      background:
        linear-gradient(135deg, #ffffff 0%, #f4f7fb 100%);
      box-shadow: 0 12px 34px rgba(16, 32, 51, .07);
    }

    .prompt-check-copy h2,
    .trap-check-copy h2 {
      margin: 0 0 8px;
      color: var(--blue-dark);
      font-size: clamp(26px, 3.6vw, 40px);
      line-height: 1.05;
      letter-spacing: 0;
    }

    .prompt-check-copy p,
    .trap-check-copy p {
      margin: 0 0 14px;
      color: var(--muted);
      line-height: 1.55;
    }

    .prompt-samples,
    .trap-samples {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      margin-top: 12px;
    }

    .prompt-sample,
    .trap-sample {
      min-height: 34px;
      padding: 7px 10px;
      border: 1px solid var(--line);
      border-radius: 999px;
      background: #fff;
      color: var(--blue-dark);
      font: inherit;
      font-size: 12px;
      font-weight: 900;
      cursor: pointer;
    }

    .prompt-tool,
    .trap-tool {
      display: grid;
      gap: 10px;
    }

    .prompt-tool textarea,
    .trap-tool textarea {
      width: 100%;
      min-height: 158px;
      resize: vertical;
      padding: 13px;
      border: 1px solid var(--line);
      border-radius: 8px;
      background: #fff;
      color: var(--ink);
      font: inherit;
      font-size: 15px;
      line-height: 1.45;
      box-shadow: inset 0 1px 0 rgba(16, 32, 51, .03);
    }

    .prompt-tool-actions,
    .trap-tool-actions {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
    }

    .prompt-results,
    .trap-results {
      display: none;
      gap: 10px;
      padding: 14px;
      border: 1px solid var(--line);
      border-radius: 8px;
      background: #fff;
    }

    .trap-results {
      grid-column: 1 / -1;
    }

    .prompt-results {
      grid-column: 1 / -1;
    }

    .prompt-results.active,
    .trap-results.active {
      display: grid;
    }

    .prompt-result-item,
    .trap-result-item {
      padding: 12px;
      border: 1px solid var(--line);
      border-left: 5px solid var(--item-accent, var(--blue));
      border-radius: 8px;
      background: var(--item-soft, #f4f7fb);
    }

    .prompt-result-item h3,
    .trap-result-item h3 {
      margin: 0 0 5px;
      color: var(--ink);
      font-size: 16px;
      letter-spacing: 0;
    }

    .trap-confidence {
      display: inline-flex;
      align-items: center;
      min-height: 24px;
      margin: 0 0 8px;
      padding: 3px 8px;
      border-radius: 999px;
      background: rgba(255, 255, 255, .82);
      color: var(--item-accent, var(--blue-dark));
      font-size: 11px;
      font-weight: 900;
      text-transform: uppercase;
    }

    .prompt-result-item p,
    .trap-result-item p {
      margin: 0 0 8px;
      color: var(--muted);
      line-height: 1.45;
      font-size: 14px;
    }

    .trap-result-actions {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      margin-top: 8px;
    }

    .prompt-rewrite,
    .trap-rewrite {
      padding: 12px;
      border-radius: 8px;
      background: #fffaf2;
      color: var(--ink);
      line-height: 1.5;
    }

    .daily-trap {
      max-width: 1180px;
      margin: 0 auto;
      padding: 0 20px 28px;
    }

    .daily-card {
      display: grid;
      grid-template-columns: 78px minmax(0, 1fr) auto;
      gap: 18px;
      align-items: center;
      padding: 20px;
      border: 1px solid var(--line);
      border-radius: 10px;
      background: linear-gradient(135deg, #fff 0%, var(--daily-soft, #f4f7fb) 100%);
      box-shadow: 0 12px 34px rgba(16, 32, 51, .07);
    }

    .daily-icon {
      display: grid;
      place-items: center;
      width: 78px;
      height: 78px;
      border-radius: 10px;
      background: var(--daily-soft, #e8eef5);
      color: var(--daily-accent, var(--blue-dark));
    }

    .daily-icon svg {
      width: 42px;
      height: 42px;
      fill: none;
      stroke: currentColor;
      stroke-width: 2.4;
      stroke-linecap: round;
      stroke-linejoin: round;
    }

    .daily-copy p {
      margin: 0;
      color: var(--muted);
      line-height: 1.45;
    }

    .daily-label {
      margin: 0 0 5px;
      color: var(--warm);
      font-size: 12px;
      font-weight: 800;
      letter-spacing: .08em;
      text-transform: uppercase;
    }

    .daily-copy h2 {
      margin: 0 0 7px;
      color: var(--daily-accent, var(--blue));
      font-size: clamp(24px, 3vw, 34px);
      line-height: 1.1;
      letter-spacing: 0;
    }

    .daily-example {
      margin-top: 8px !important;
      color: var(--ink) !important;
    }

    .daily-link {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 42px;
      padding: 9px 13px;
      border: 1px solid var(--daily-accent, var(--blue));
      border-radius: 6px;
      background: #fff;
      color: var(--daily-accent, var(--blue-dark));
      font: inherit;
      font-size: 14px;
      font-weight: 800;
      text-decoration: none;
      white-space: nowrap;
      cursor: pointer;
    }

    .daily-actions {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      justify-content: flex-end;
    }

    .daily-link.secondary {
      border-color: var(--line);
      background: var(--daily-soft, #f4f7fb);
    }

    .mobile-quick-nav {
      display: none;
    }

    .category-sheet {
      display: none;
    }

    .sticky-tools {
      position: sticky;
      top: 0;
      z-index: 20;
      background: rgba(251, 252, 253, .96);
      border-top: 1px solid var(--line);
      border-bottom: 1px solid var(--line);
      backdrop-filter: blur(10px);
    }

    .tools-inner {
      display: grid;
      grid-template-columns: 1fr;
      gap: 14px;
      align-items: center;
      max-width: 1180px;
      margin: 0 auto;
      padding: 12px 20px;
    }

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

    .nav-pill {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      min-height: 38px;
      padding: 7px 10px;
      border: 1px solid var(--line);
      border-radius: 6px;
      background: #fff;
      color: var(--ink);
      font-size: 13px;
      line-height: 1.15;
      text-decoration: none;
      transition: border-color .18s ease, background .18s ease, color .18s ease;
    }

    .nav-pill:hover {
      border-color: var(--accent);
      background: var(--accent-soft);
      color: var(--accent);
    }

    .nav-mark,
    .section-mark,
    .card-mark {
      display: inline-grid;
      place-items: center;
      border-radius: 5px;
      background: var(--accent-soft, #e8eef5);
      color: var(--accent, var(--blue-dark));
      font-weight: 800;
    }

    .nav-mark svg,
    .section-mark svg,
    .card-mark svg {
      fill: none;
      stroke: currentColor;
      stroke-width: 2.4;
      stroke-linecap: round;
      stroke-linejoin: round;
    }

    .nav-mark {
      width: 24px;
      height: 24px;
    }

    .nav-mark svg {
      width: 16px;
      height: 16px;
    }

    .category-sheet-link span svg {
      width: 22px;
      height: 22px;
      fill: none;
      stroke: currentColor;
      stroke-width: 2.4;
      stroke-linecap: round;
      stroke-linejoin: round;
    }

    .filter-panel {
      grid-column: 1 / -1;
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      align-items: center;
      padding-top: 2px;
    }

    .filter-panel > span {
      color: var(--muted);
      font-size: 12px;
      font-weight: 800;
      letter-spacing: .06em;
      text-transform: uppercase;
    }

    .filter-chip {
      min-height: 32px;
      padding: 6px 10px;
      border: 1px solid var(--line);
      border-radius: 999px;
      background: #fff;
      color: var(--ink);
      font: inherit;
      font-size: 13px;
      font-weight: 700;
      cursor: pointer;
    }

    .filter-chip:hover,
    .filter-chip.active {
      border-color: var(--blue);
      background: var(--soft);
      color: var(--blue-dark);
    }

    .content {
      max-width: 1180px;
      margin: 0 auto;
      padding: 30px 20px 72px;
    }

    .situation-section {
      max-width: 1180px;
      margin: 0 auto;
      padding: 0 20px 18px;
    }

    .situation-top {
      display: flex;
      justify-content: space-between;
      gap: 18px;
      align-items: end;
      margin-bottom: 12px;
    }

    .situation-top h2 {
      margin: 0 0 6px;
      color: var(--blue-dark);
      font-size: clamp(24px, 3vw, 34px);
      line-height: 1.08;
    }

    .situation-top p {
      margin: 0;
      max-width: 680px;
      color: var(--muted);
      line-height: 1.45;
    }

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

    .situation-card {
      display: grid;
      gap: 6px;
      min-height: 132px;
      padding: 14px;
      border: 1px solid var(--line);
      border-radius: 8px;
      background: #fff;
      color: var(--ink);
      text-decoration: none;
      transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
    }

    .situation-card:hover {
      transform: translateY(-2px);
      border-color: var(--blue);
      box-shadow: 0 14px 34px rgba(16, 32, 51, .08);
    }

    .situation-card span {
      color: var(--warm);
      font-size: 12px;
      font-weight: 900;
    }

    .situation-card strong {
      color: var(--blue-dark);
      font-size: 18px;
      line-height: 1.15;
    }

    .situation-card small {
      color: var(--muted);
      font-size: 13px;
      line-height: 1.35;
    }

    .bias-section {
      scroll-margin-top: 190px;
      margin-bottom: 64px;
      padding-top: 6px;
    }

    .section-heading {
      display: grid;
      grid-template-columns: 64px minmax(0, 1fr);
      gap: 16px;
      align-items: start;
      margin-bottom: 16px;
      padding-bottom: 14px;
      border-bottom: 1px solid var(--line);
    }

    .section-mark {
      width: 64px;
      height: 64px;
      font-size: 26px;
    }

    .section-mark svg {
      width: 34px;
      height: 34px;
    }

    .section-heading p {
      margin: 0 0 6px;
      color: var(--warm);
      font-size: 13px;
      font-weight: 800;
      letter-spacing: .06em;
      text-transform: uppercase;
    }

    .section-heading h2 {
      margin: 0 0 8px;
      color: var(--accent, var(--blue));
      font-size: clamp(28px, 4.2vw, 44px);
      line-height: 1.05;
      letter-spacing: 0;
    }

    .section-intro {
      max-width: 820px;
      color: var(--muted);
      font-size: 17px;
      line-height: 1.5;
    }

    .section-meta {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      margin-top: 12px;
    }

    .section-meta span {
      display: inline-flex;
      align-items: center;
      min-height: 28px;
      padding: 5px 9px;
      border: 1px solid var(--line);
      border-radius: 999px;
      background: var(--accent-soft);
      color: var(--accent);
      font-size: 12px;
      font-weight: 800;
      text-transform: uppercase;
      letter-spacing: .04em;
    }

    .pause-box {
      margin-bottom: 18px;
      padding: 16px 18px;
      border: 1px solid var(--line);
      border-left: 5px solid var(--accent);
      border-radius: 8px;
      background: linear-gradient(90deg, var(--accent-soft), #fff);
    }

    .pause-box h3 {
      margin: 0 0 8px;
      color: var(--blue-dark);
      font-size: 16px;
      letter-spacing: 0;
    }

    .pause-box ul {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 6px 20px;
      margin: 0;
      padding-left: 20px;
      color: var(--ink);
      line-height: 1.45;
    }

    .card-grid {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(310px, 1fr));
      gap: 14px;
    }

    .expand-category,
    .back-to-categories {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 40px;
      margin-top: 14px;
      padding: 9px 13px;
      border: 1px solid var(--accent, var(--blue));
      border-radius: 6px;
      background: #fff;
      color: var(--accent, var(--blue-dark));
      font: inherit;
      font-size: 13px;
      font-weight: 900;
      text-decoration: none;
      cursor: pointer;
    }

    .back-to-categories {
      margin-left: 8px;
      border-color: var(--line);
      color: var(--blue-dark);
    }

    .expand-category:hover,
    .back-to-categories:hover {
      background: var(--accent-soft, var(--soft));
    }

    .bias-card {
      position: relative;
      display: flex;
      flex-direction: column;
      gap: 12px;
      min-height: 176px;
      padding: 15px;
      border: 1px solid var(--line);
      border-radius: 8px;
      background: var(--paper);
      box-shadow: 0 8px 22px rgba(16, 32, 51, .04);
      transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
      overflow: hidden;
      cursor: pointer;
    }

    .bias-card:focus-within {
      border-color: var(--accent);
      box-shadow: 0 0 0 3px var(--accent-soft), 0 14px 32px rgba(16, 32, 51, .09);
    }

    .bias-card::before {
      content: "";
      position: absolute;
      inset: 0 0 auto;
      height: 4px;
      background: var(--accent);
      opacity: .9;
    }

    .bias-card:hover {
      transform: translateY(-2px);
      border-color: var(--accent);
      box-shadow: 0 14px 32px rgba(16, 32, 51, .09);
    }

    .bias-card.is-hidden {
      display: none;
    }

    .card-mark {
      width: 42px;
      height: 42px;
      font-size: 18px;
    }

    .card-mark svg {
      width: 23px;
      height: 23px;
    }

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

    .card-number {
      color: var(--accent);
      font-size: 12px;
      font-weight: 800;
      letter-spacing: .08em;
    }

    .card-copy h3 {
      margin: 0 0 6px;
      color: var(--ink);
      font-size: 17px;
      line-height: 1.24;
      letter-spacing: 0;
    }

    .card-copy p {
      margin: 0 0 8px;
      color: var(--muted);
      font-size: 14px;
      line-height: 1.45;
    }

    .card-copy .example {
      color: var(--ink);
    }

    .example strong {
      color: var(--accent, var(--blue-dark));
    }

    .card-copy .check {
      margin-bottom: 0;
      color: var(--ink);
      padding-top: 8px;
      border-top: 1px solid var(--line);
    }

    .check strong {
      color: var(--accent, var(--blue-dark));
    }

    .card-actions {
      display: flex;
      justify-content: space-between;
      align-items: center;
      gap: 10px;
      margin-top: auto;
      padding-top: 10px;
    }

    .deep-button,
    .share-button,
    .share-menu-trigger {
      border: 1px solid var(--line);
      border-radius: 6px;
      background: #fff;
      color: var(--ink);
      font: inherit;
      font-size: 12px;
      font-weight: 800;
      cursor: pointer;
    }

    .deep-button {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 32px;
      padding: 6px 10px;
      color: var(--accent, var(--blue-dark));
      text-decoration: none;
    }

    .share-row {
      display: flex;
      flex-wrap: wrap;
      justify-content: flex-end;
      gap: 5px;
    }

    .share-menu-wrap {
      position: relative;
      display: inline-flex;
      justify-content: flex-end;
    }

    .share-menu-trigger {
      min-height: 32px;
      padding: 6px 10px;
      color: var(--blue-dark);
    }

    .share-menu {
      position: absolute;
      right: 0;
      bottom: calc(100% + 6px);
      z-index: 3;
      min-width: 132px;
      padding: 6px;
      border: 1px solid var(--line);
      border-radius: 8px;
      background: #fff;
      box-shadow: 0 16px 34px rgba(16, 32, 51, .12);
    }

    .share-menu[hidden] {
      display: none;
    }

    .share-button {
      min-width: 34px;
      min-height: 34px;
      padding: 5px 7px;
    }

    .result-summary {
      display: none;
      margin: 0 0 18px;
      color: var(--muted);
      font-weight: 800;
    }

    .result-summary.active {
      display: block;
    }

    .share-x svg,
    .share-copy svg {
      display: block;
      width: 15px;
      height: 15px;
      fill: none;
      stroke: currentColor;
      stroke-width: 2.2;
      stroke-linecap: round;
      stroke-linejoin: round;
    }

    .share-x svg path:first-child {
      fill: currentColor;
      stroke: none;
    }

    .deep-button:hover,
    .share-button:hover,
    .share-menu-trigger:hover {
      border-color: var(--accent, var(--blue));
      background: var(--accent-soft, var(--soft));
    }

    .no-results {
      display: none;
      padding: 28px;
      border: 1px solid var(--line);
      border-radius: 8px;
      background: #fff;
      color: var(--muted);
      text-align: center;
    }

    .no-results.active {
      display: block;
    }

    .closing {
      padding: 24px;
      border: 1px solid var(--line);
      border-radius: 8px;
      background: #fff;
    }

    .faq-section {
      margin: 0 0 28px;
      padding: 24px;
      border: 1px solid var(--line);
      border-radius: 8px;
      background: #fff;
    }

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

    .faq-item {
      padding: 14px;
      border: 1px solid var(--line);
      border-radius: 8px;
      background: var(--soft);
    }

    .faq-item h3 {
      margin: 0 0 7px;
      color: var(--blue-dark);
      font-size: 17px;
    }

    .faq-item p {
      margin: 0;
      color: var(--muted);
      line-height: 1.5;
    }

    .blog-section {
      margin: 0 0 54px;
      padding: 24px;
      border: 1px solid var(--line);
      border-radius: 10px;
      background: #fff;
      box-shadow: 0 12px 34px rgba(16, 32, 51, .06);
    }

    .blog-header {
      display: flex;
      justify-content: space-between;
      gap: 18px;
      align-items: end;
      margin-bottom: 16px;
    }

    .blog-header h2 {
      margin: 0 0 7px;
      color: var(--blue-dark);
      font-size: clamp(28px, 4vw, 42px);
      line-height: 1.05;
    }

    .blog-header p {
      max-width: 680px;
      margin: 0;
      color: var(--muted);
      line-height: 1.5;
    }

    .blog-preview-grid {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 12px;
    }

    .blog-preview-card {
      display: grid;
      gap: 8px;
      padding: 16px;
      border: 1px solid var(--line);
      border-radius: 8px;
      background: var(--soft);
    }

    .blog-preview-card h3 {
      margin: 0;
      color: var(--blue-dark);
      font-size: 20px;
      line-height: 1.15;
    }

    .blog-preview-card h3 a {
      color: inherit;
      text-decoration: none;
    }

    .blog-preview-card p {
      margin: 0;
      color: var(--muted);
      line-height: 1.45;
    }

    .quiz-section {
      margin: 0 0 54px;
      padding: 24px;
      border: 1px solid var(--line);
      border-radius: 10px;
      background: #fff;
      box-shadow: 0 12px 34px rgba(16, 32, 51, .06);
    }

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

    .quiz-header h2 {
      margin: 0 0 7px;
      color: var(--blue);
      font-size: clamp(28px, 4vw, 42px);
      line-height: 1.05;
    }

    .quiz-header p {
      max-width: 680px;
      margin: 0;
      color: var(--muted);
      line-height: 1.5;
    }

    .quiz-modes {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      margin-bottom: 14px;
    }

    .quiz-mode {
      min-height: 34px;
      padding: 7px 10px;
      border: 1px solid var(--line);
      border-radius: 6px;
      background: #fff;
      color: var(--ink);
      font: inherit;
      font-size: 13px;
      font-weight: 800;
      cursor: pointer;
    }

    .quiz-mode.active,
    .quiz-mode:hover {
      border-color: var(--blue);
      background: #e8f1fb;
      color: var(--blue-dark);
    }

    .quiz-shell {
      border: 1px solid var(--line);
      border-radius: 8px;
      overflow: hidden;
      background: #fbfcfd;
    }

    .quiz-bar {
      height: 10px;
      background: #e7edf4;
    }

    .quiz-progress {
      width: 0%;
      height: 100%;
      background: linear-gradient(90deg, var(--blue), var(--green));
      transition: width .2s ease;
    }

    .quiz-body {
      padding: 20px;
    }

    .quiz-meta {
      display: flex;
      justify-content: space-between;
      gap: 12px;
      margin-bottom: 14px;
      color: var(--muted);
      font-size: 13px;
      font-weight: 800;
      letter-spacing: .04em;
      text-transform: uppercase;
    }

    .quiz-timer {
      color: var(--warm);
    }

    .quiz-scenario {
      margin: 0 0 16px;
      color: var(--ink);
      font-size: 18px;
      line-height: 1.5;
    }

    .quiz-options {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 10px;
      margin-bottom: 14px;
    }

    .quiz-option {
      min-height: 48px;
      padding: 12px 14px;
      border: 1px solid var(--line);
      border-radius: 6px;
      background: #fff;
      color: var(--ink);
      font: inherit;
      font-weight: 700;
      text-align: left;
      cursor: pointer;
    }

    .quiz-option:hover:not(:disabled) {
      border-color: var(--blue);
      background: var(--soft);
    }

    .quiz-option.correct {
      border-color: var(--green);
      background: #eaf4ef;
    }

    .quiz-option.incorrect {
      border-color: #bd6b6b;
      background: #f8eeee;
    }

    .quiz-option:disabled {
      cursor: default;
    }

    .quiz-feedback {
      min-height: 50px;
      padding: 12px 14px;
      border: 1px solid var(--line);
      border-radius: 6px;
      background: #fff;
      color: var(--muted);
      line-height: 1.45;
    }

    .quiz-feedback strong {
      color: var(--ink);
    }

    .quiz-actions {
      display: flex;
      gap: 10px;
      margin-top: 14px;
    }

    .quiz-results {
      display: none;
      padding: 20px;
      border-top: 1px solid var(--line);
      background: #fff;
    }

    .quiz-results.active {
      display: block;
    }

    .quiz-results h3 {
      margin: 0 0 8px;
      color: var(--blue-dark);
      font-size: 24px;
    }

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

    .result-score {
      display: grid;
      place-items: center;
      width: 112px;
      height: 112px;
      border-radius: 999px;
      background: var(--soft);
      color: var(--blue-dark);
      font-size: 30px;
      font-weight: 900;
    }

    .missed-list {
      margin: 12px 0 0;
      padding-left: 20px;
      line-height: 1.5;
    }

    .quiz-focus {
      margin: 14px 0;
      padding: 14px;
      border: 1px solid var(--line);
      border-radius: 8px;
      background: var(--soft);
    }

    .quiz-focus h4 {
      margin: 0 0 5px;
      color: var(--blue-dark);
    }

    .quiz-focus p {
      margin: 0;
      line-height: 1.45;
    }

    .quest-section {
      --quest-font: "Courier New", ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
      position: relative;
      z-index: 25;
      margin: 0 0 54px;
      padding: 24px;
      border: 1px solid #172f5b;
      border-radius: 10px;
      background:
        linear-gradient(180deg, rgba(19, 54, 93, .08), rgba(19, 54, 93, 0) 34%),
        #fff;
      box-shadow: 0 16px 36px rgba(16, 32, 51, .08);
    }

    body:not(.quest-page) .quest-section {
      display: none;
    }

    body.quest-page .hero,
    body.quest-page .mobile-quick-nav,
    body.quest-page .category-strip,
    body.quest-page .prompt-check-section,
    body.quest-page .trap-check-section,
    body.quest-page .bias-section,
    body.quest-page .quiz-section,
    body.quest-page .signup-section,
    body.quest-page .blog-section,
    body.quest-page .merch-section,
    body.quest-page .faq-section,
    body.quest-page .closing {
      display: none;
    }

    body.quest-page .content {
      padding-top: 34px;
    }

    body.quest-page .quest-section {
      display: block;
      margin-top: 0;
    }

    .quest-section,
    .quest-section button,
    .quest-section input,
    .quest-section textarea {
      font-family: var(--quest-font);
      font-smooth: never;
      -webkit-font-smoothing: none;
      text-rendering: geometricPrecision;
    }

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

    .quest-header .eyebrow {
      color: #17377d;
      font-family: var(--quest-font);
      font-size: 12px;
      font-weight: 900;
      letter-spacing: .12em;
      text-transform: uppercase;
    }

    .quest-header h2 {
      margin: 0 0 7px;
      color: var(--blue-dark);
      font-size: clamp(28px, 4vw, 42px);
      line-height: 1.05;
      letter-spacing: .03em;
      text-transform: uppercase;
      text-shadow: 3px 3px 0 rgba(240, 166, 55, .24);
    }

    .quest-header p {
      max-width: 720px;
      margin: 0;
      color: var(--muted);
      font-size: 14px;
      font-weight: 700;
      line-height: 1.6;
      letter-spacing: .02em;
    }

    .quest-header .button,
    .quest-actions .button,
    .quest-start-actions .button {
      border-radius: 0;
      border-width: 3px;
      font-size: 12px;
      font-weight: 900;
      letter-spacing: .08em;
      text-transform: uppercase;
      box-shadow: 4px 4px 0 #10203b;
    }

    .quest-shell {
      border: 6px solid #f0a637;
      border-radius: 0;
      background: #08172f;
      box-shadow:
        0 0 0 4px #10203b,
        inset 0 0 0 2px #fff3bf,
        0 18px 34px rgba(16, 32, 51, .24);
    }

    .quest-stage {
      position: relative;
      overflow: hidden;
      border: 3px solid #10203b;
      background: #08172f;
    }

    .quest-start-screen {
      position: relative;
      z-index: 8;
      display: grid;
      gap: 18px;
      min-height: 520px;
      padding: 22px;
      border: 6px solid #10203b;
      background:
        linear-gradient(90deg, rgba(255,255,255,.12) 2px, transparent 2px) 0 0 / 16px 16px,
        linear-gradient(rgba(255,255,255,.10) 2px, transparent 2px) 0 0 / 16px 16px,
        linear-gradient(135deg, #183c7a, #10203b 62%, #0b1426);
      color: #fff;
      image-rendering: pixelated;
      font-family: var(--quest-font);
      letter-spacing: .02em;
    }

    .quest-start-screen.hidden {
      display: none;
    }

    .quest-start-panel {
      align-self: center;
      width: min(900px, 100%);
      margin: 0 auto;
      padding: 22px;
      border: 4px solid #fff;
      background: #17377d;
      box-shadow: inset 0 0 0 3px rgba(255,255,255,.18), 10px 10px 0 rgba(0,0,0,.22);
    }

    .quest-start-panel .eyebrow {
      color: #f1cf8b;
      font-family: inherit;
      letter-spacing: .12em;
    }

    .quest-start-panel h3 {
      margin: 0 0 8px;
      color: #fff;
      font-size: clamp(28px, 5vw, 48px);
      line-height: 1;
      text-transform: uppercase;
      letter-spacing: .04em;
      text-shadow: 4px 4px 0 #0b1426;
    }

    .quest-start-panel p {
      margin: 0;
      color: #dbe8ff;
      line-height: 1.45;
    }

    .quest-choice-group {
      margin-top: 18px;
    }

    .quest-choice-group strong {
      display: block;
      margin-bottom: 9px;
      color: #f1cf8b;
      font-size: 13px;
      letter-spacing: .08em;
      text-transform: uppercase;
    }

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

    .quest-choice {
      min-height: 154px;
      padding: 12px;
      border: 3px solid #fff;
      background: #0d285f;
      color: #fff;
      font: inherit;
      font-weight: 900;
      text-align: center;
      text-transform: uppercase;
      cursor: pointer;
      box-shadow: inset 0 0 0 2px rgba(255,255,255,.12);
    }

    .quest-choice:hover,
    .quest-choice.active {
      background: #1f4c9b;
      outline: 3px solid #f0a637;
      outline-offset: -7px;
    }

    .quest-choice span {
      display: block;
      margin-top: 9px;
      color: #f1cf8b;
      font-size: 14px;
      letter-spacing: .1em;
      text-transform: uppercase;
    }

    .quest-choice small {
      display: block;
      margin-top: 5px;
      color: #dbe8ff;
      font-weight: 700;
      line-height: 1.35;
      text-transform: uppercase;
      letter-spacing: .06em;
    }

    .quest-choice-sprite + span {
      margin-top: 24px;
    }

    .quest-map-preview + span {
      margin-top: 10px;
    }

    .quest-choice-sprite {
      position: relative;
      display: block;
      width: 52px;
      height: 66px;
      margin: 0 auto;
      image-rendering: pixelated;
      filter: drop-shadow(5px 6px 0 rgba(0,0,0,.22));
    }

    .quest-choice-sprite::before {
      content: "";
      position: absolute;
      left: 13px;
      top: 3px;
      width: 26px;
      height: 26px;
      background: #f2c38f;
      box-shadow:
        0 26px 0 6px var(--sprite-shirt, #234b7c),
        -9px 33px 0 0 #f2c38f,
        35px 33px 0 0 #f2c38f,
        -1px 60px 0 4px #10203b,
        22px 60px 0 4px #10203b;
    }

    .quest-choice-sprite::after {
      content: "";
      position: absolute;
      left: 8px;
      top: 0;
      width: 36px;
      height: 14px;
      background: var(--sprite-hair, #24334d);
      box-shadow:
        9px 8px 0 var(--sprite-hair, #24334d),
        13px 18px 0 -7px #10203b,
        28px 18px 0 -7px #10203b;
    }

    .quest-choice-sprite.scout {
      --sprite-shirt: #234b7c;
      --sprite-hair: #24334d;
    }

    .quest-choice-sprite.angler {
      --sprite-shirt: #2d7d44;
      --sprite-hair: #6c4a2d;
    }

    .quest-choice-sprite.analyst {
      --sprite-shirt: #6f5aa8;
      --sprite-hair: #6c2f2f;
    }

    .quest-map-preview {
      position: relative;
      display: block;
      width: 100%;
      aspect-ratio: 16 / 9;
      overflow: hidden;
      border: 3px solid #fff;
      background:
        linear-gradient(90deg, rgba(255,255,255,.16) 2px, transparent 2px) 0 0 / 16px 16px,
        linear-gradient(rgba(255,255,255,.13) 2px, transparent 2px) 0 0 / 16px 16px,
        #6fbf73;
      box-shadow: inset 0 0 0 2px rgba(255,255,255,.12);
    }

    .quest-map-preview::before {
      content: "";
      position: absolute;
      inset: 0;
      background:
        linear-gradient(90deg, transparent 0 28%, #d7b46a 28% 42%, transparent 42%),
        linear-gradient(0deg, transparent 0 38%, #d7b46a 38% 54%, transparent 54%);
    }

    .quest-map-preview::after {
      content: "";
      position: absolute;
      right: 0;
      top: 0;
      width: 34%;
      height: 62%;
      background:
        linear-gradient(90deg, rgba(255,255,255,.24) 2px, transparent 2px) 0 0 / 11px 11px,
        #79b8d8;
      border-left: 3px solid #3d7aa5;
      border-bottom: 3px solid #3d7aa5;
    }

    .quest-map-preview.mountain {
      background:
        linear-gradient(90deg, rgba(255,255,255,.16) 2px, transparent 2px) 0 0 / 16px 16px,
        linear-gradient(rgba(255,255,255,.13) 2px, transparent 2px) 0 0 / 16px 16px,
        linear-gradient(135deg, #4f8e60 0 36%, #6d8e73 36% 52%, #88b86f 52%);
    }

    .quest-map-preview.mountain::after {
      right: 28%;
      width: 14%;
      height: 100%;
      transform: skewX(-12deg);
    }

    .quest-map-preview.beach {
      background:
        linear-gradient(90deg, rgba(255,255,255,.16) 2px, transparent 2px) 0 0 / 16px 16px,
        linear-gradient(rgba(255,255,255,.13) 2px, transparent 2px) 0 0 / 16px 16px,
        #e4c981;
    }

    .quest-map-preview.beach::after {
      width: 42%;
      height: 100%;
      border-bottom: 0;
    }

    .quest-map-preview.lake {
      background:
        linear-gradient(90deg, rgba(255,255,255,.16) 2px, transparent 2px) 0 0 / 16px 16px,
        linear-gradient(rgba(255,255,255,.13) 2px, transparent 2px) 0 0 / 16px 16px,
        #6fbf73;
    }

    .quest-start-actions {
      display: flex;
      justify-content: flex-end;
      margin-top: 18px;
    }

    .quest-play[hidden] {
      display: none;
    }

    .quest-map {
      position: relative;
      height: 500px;
      overflow: hidden;
      isolation: isolate;
      image-rendering: pixelated;
      background: #08172f;
    }

    .quest-world {
      position: absolute;
      left: 0;
      top: 0;
      width: 2200px;
      height: 980px;
      transform: translate(var(--camera-x, 0), var(--camera-y, 0));
      transform-origin: 0 0;
      transition: transform .08s linear;
      background:
        radial-gradient(circle at 24px 18px, rgba(255,255,255,.16) 0 2px, transparent 3px) 0 0 / 96px 82px,
        radial-gradient(circle at 78px 58px, rgba(22, 90, 48, .42) 0 7px, transparent 8px) 0 0 / 112px 96px,
        linear-gradient(90deg, rgba(255,255,255,.08) 1px, transparent 1px) 0 0 / 24px 24px,
        linear-gradient(rgba(255,255,255,.07) 1px, transparent 1px) 0 0 / 24px 24px,
        linear-gradient(135deg, #73c76e 0 42%, #4e9a59 42% 54%, #84ce73 54% 100%);
    }

    .quest-world.map-mountain {
      background:
        radial-gradient(circle at 24px 18px, rgba(255,255,255,.14) 0 2px, transparent 3px) 0 0 / 96px 82px,
        radial-gradient(circle at 78px 58px, rgba(30, 83, 45, .46) 0 7px, transparent 8px) 0 0 / 112px 96px,
        linear-gradient(90deg, rgba(255,255,255,.08) 1px, transparent 1px) 0 0 / 24px 24px,
        linear-gradient(rgba(255,255,255,.07) 1px, transparent 1px) 0 0 / 24px 24px,
        linear-gradient(135deg, #4f8e60 0 34%, #70896d 34% 52%, #93c874 52% 100%);
    }

    .quest-world.map-beach {
      background:
        radial-gradient(circle at 28px 18px, rgba(255,255,255,.20) 0 2px, transparent 3px) 0 0 / 88px 76px,
        radial-gradient(circle at 78px 52px, rgba(181, 138, 68, .24) 0 8px, transparent 9px) 0 0 / 108px 92px,
        linear-gradient(90deg, rgba(255,255,255,.12) 1px, transparent 1px) 0 0 / 24px 24px,
        linear-gradient(rgba(255,255,255,.10) 1px, transparent 1px) 0 0 / 24px 24px,
        linear-gradient(135deg, #e8cc84 0 56%, #d3ad61 56% 100%);
    }

    .quest-world.map-lake {
      background:
        radial-gradient(circle at 24px 18px, rgba(255,255,255,.15) 0 2px, transparent 3px) 0 0 / 96px 82px,
        radial-gradient(circle at 78px 58px, rgba(22, 90, 48, .42) 0 7px, transparent 8px) 0 0 / 112px 96px,
        linear-gradient(90deg, rgba(255,255,255,.08) 1px, transparent 1px) 0 0 / 24px 24px,
        linear-gradient(rgba(255,255,255,.07) 1px, transparent 1px) 0 0 / 24px 24px,
        linear-gradient(135deg, #6fc375 0 48%, #529f59 48% 52%, #82cc73 52% 100%);
    }

    .quest-map.is-active {
      outline: 3px solid #f0a637;
      outline-offset: -9px;
    }

    .quest-world::before {
      content: "";
      position: absolute;
      inset: 0;
      background:
        linear-gradient(90deg, transparent 0 246px, rgba(125,78,40,.25) 246px 252px, #d7b46a 252px 372px, rgba(125,78,40,.20) 372px 378px, transparent 378px 100%),
        linear-gradient(0deg, transparent 0 368px, rgba(125,78,40,.22) 368px 374px, #d7b46a 374px 498px, rgba(125,78,40,.20) 498px 504px, transparent 504px 100%),
        linear-gradient(90deg, transparent 0 1116px, rgba(125,78,40,.22) 1116px 1122px, #d7b46a 1122px 1238px, rgba(125,78,40,.20) 1238px 1244px, transparent 1244px 100%),
        linear-gradient(0deg, transparent 0 711px, rgba(125,78,40,.20) 711px 717px, #d7b46a 717px 828px, rgba(125,78,40,.20) 828px 834px, transparent 834px 100%);
      opacity: .95;
    }

    .quest-world::after {
      content: "";
      position: absolute;
      right: 0;
      top: 0;
      width: 520px;
      height: 420px;
      border: 4px solid #3d7aa5;
      background:
        linear-gradient(90deg, rgba(255,255,255,.18) 2px, transparent 2px) 0 0 / 18px 18px,
        linear-gradient(rgba(255,255,255,.12) 2px, transparent 2px) 0 0 / 18px 18px,
        linear-gradient(135deg, #6db6d9, #2f7fb0);
      box-shadow: -10px 10px 0 rgba(16, 32, 51, .12), inset 0 0 0 6px rgba(255,255,255,.12);
    }

    .quest-world.map-mountain .quest-water {
      right: 280px;
      top: 0;
      width: 240px;
      height: 980px;
      transform: skewX(-14deg);
      border-left: 6px solid #3d7aa5;
      border-right: 6px solid #3d7aa5;
    }

    .quest-world.map-beach .quest-water {
      right: 0;
      top: 0;
      width: 720px;
      height: 980px;
      border-left: 8px solid #3d7aa5;
      border-bottom: 0;
    }

    .quest-world.map-lake .quest-water {
      right: 0;
      top: 0;
      width: 620px;
      height: 520px;
    }

    .quest-trees,
    .quest-houses,
    .quest-water,
    .quest-fish,
    .quest-rod,
    .quest-boat,
    .quest-hook,
    .quest-fishing-score,
    .quest-path-label {
      position: absolute;
      z-index: 1;
    }

    .quest-trees {
      left: 58px;
      top: 44px;
      width: 1380px;
      height: 860px;
      pointer-events: none;
      background:
        radial-gradient(circle at 18px 22px, #22683a 0 17px, transparent 18px),
        radial-gradient(circle at 54px 18px, #2d7d44 0 18px, transparent 19px),
        radial-gradient(circle at 92px 24px, #22683a 0 17px, transparent 18px),
        radial-gradient(circle at 134px 18px, #2d7d44 0 18px, transparent 19px),
        radial-gradient(circle at 170px 26px, #22683a 0 17px, transparent 18px),
        linear-gradient(#7d4e28, #7d4e28) 17px 36px / 8px 34px no-repeat,
        linear-gradient(#7d4e28, #7d4e28) 53px 34px / 8px 36px no-repeat,
        linear-gradient(#7d4e28, #7d4e28) 91px 38px / 8px 32px no-repeat,
        linear-gradient(#7d4e28, #7d4e28) 133px 34px / 8px 36px no-repeat,
        linear-gradient(#7d4e28, #7d4e28) 169px 40px / 8px 30px no-repeat,
        radial-gradient(circle at 520px 112px, #2d7d44 0 22px, transparent 23px),
        radial-gradient(circle at 566px 105px, #22683a 0 20px, transparent 21px),
        radial-gradient(circle at 610px 120px, #2d7d44 0 22px, transparent 23px),
        linear-gradient(#7d4e28, #7d4e28) 517px 132px / 9px 42px no-repeat,
        linear-gradient(#7d4e28, #7d4e28) 563px 126px / 9px 48px no-repeat,
        linear-gradient(#7d4e28, #7d4e28) 607px 140px / 9px 34px no-repeat,
        radial-gradient(circle at 250px 660px, #22683a 0 19px, transparent 20px),
        radial-gradient(circle at 296px 654px, #2d7d44 0 22px, transparent 23px),
        linear-gradient(#7d4e28, #7d4e28) 247px 680px / 8px 40px no-repeat,
        linear-gradient(#7d4e28, #7d4e28) 293px 676px / 9px 43px no-repeat,
        radial-gradient(circle at 1000px 650px, #2d7d44 0 21px, transparent 22px),
        radial-gradient(circle at 1044px 642px, #22683a 0 18px, transparent 19px),
        linear-gradient(#7d4e28, #7d4e28) 997px 671px / 9px 40px no-repeat,
        linear-gradient(#7d4e28, #7d4e28) 1041px 660px / 8px 50px no-repeat;
      filter: drop-shadow(6px 8px 0 rgba(16, 32, 51, .14));
    }

    .quest-houses {
      left: 760px;
      top: 88px;
      width: 142px;
      height: 104px;
      pointer-events: none;
      background:
        linear-gradient(135deg, transparent 0 48%, #10203b 48% 52%, transparent 52%) 0 0 / 100% 48px no-repeat,
        linear-gradient(45deg, transparent 0 48%, #10203b 48% 52%, transparent 52%) 0 0 / 100% 48px no-repeat,
        linear-gradient(135deg, transparent 0 49%, #2f64ad 49% 51%, transparent 51%) 0 4px / 100% 44px no-repeat,
        linear-gradient(45deg, transparent 0 49%, #2f64ad 49% 51%, transparent 51%) 0 4px / 100% 44px no-repeat,
        linear-gradient(#f3dfad, #d9bd79) 16px 42px / 110px 58px no-repeat,
        linear-gradient(#10203b, #10203b) 58px 70px / 22px 30px no-repeat,
        linear-gradient(#8fd0f0, #375f9b) 26px 54px / 22px 16px no-repeat,
        linear-gradient(#8fd0f0, #375f9b) 94px 54px / 22px 16px no-repeat,
        linear-gradient(#f0a637, #f0a637) 14px 98px / 116px 6px no-repeat;
      filter: drop-shadow(8px 8px 0 rgba(16, 32, 51, .14));
    }

    .quest-water {
      right: 0;
      top: 0;
      width: 620px;
      height: 520px;
      border-left: 6px solid #3d7aa5;
      border-bottom: 6px solid #3d7aa5;
      background:
        radial-gradient(ellipse at 20px 12px, rgba(255,255,255,.36) 0 8px, transparent 9px) 0 0 / 78px 54px,
        linear-gradient(90deg, rgba(255,255,255,.18) 2px, transparent 2px) 0 0 / 18px 18px,
        linear-gradient(rgba(255,255,255,.12) 2px, transparent 2px) 0 0 / 18px 18px,
        linear-gradient(135deg, #76c4e5, #2d7fad 54%, #196396);
      z-index: 1;
      pointer-events: none;
      box-shadow: inset 0 0 0 6px rgba(255,255,255,.12), inset 12px 0 0 rgba(16, 32, 51, .12);
      animation: quest-water-shimmer 2.4s steps(4, end) infinite;
    }

    .quest-fish {
      width: 28px;
      height: 14px;
      border-radius: 999px 60% 60% 999px;
      background: #f0a637;
      z-index: 2;
      transform: translate(var(--fish-x), var(--fish-y));
      animation: fish-swim 1.5s steps(2, end) infinite;
      pointer-events: none;
    }

    .quest-fish::after {
      content: "";
      position: absolute;
      right: -8px;
      top: 2px;
      width: 10px;
      height: 10px;
      background: #c97b42;
      clip-path: polygon(0 50%, 100% 0, 100% 100%);
    }

    .quest-fish.caught {
      display: none;
    }

    .quest-rod {
      width: 88px;
      height: 52px;
      transform: translate(1510px, 520px);
      z-index: 4;
      border: 0;
      background: transparent;
      cursor: pointer;
    }

    .quest-rod::before {
      content: "";
      position: absolute;
      left: 8px;
      top: 34px;
      width: 82px;
      height: 5px;
      background: #7d4e28;
      transform: rotate(-28deg);
      transform-origin: 0 50%;
      box-shadow: 0 0 0 2px rgba(16, 32, 51, .14);
    }

    .quest-rod::after {
      content: "ROD";
      position: absolute;
      left: 0;
      top: 0;
      padding: 4px 6px;
      border: 2px solid #10203b;
      background: #fff;
      color: #10203b;
      font-size: 10px;
      font-weight: 900;
      font-family: var(--quest-font);
      letter-spacing: .08em;
    }

    .quest-boat {
      width: 92px;
      height: 48px;
      z-index: 2;
      transform: translate(var(--boat-x, 1500px), var(--boat-y, 480px));
      border: 0;
      background: transparent;
      cursor: pointer;
      transition: transform .08s linear;
    }

    .quest-boat::before {
      content: "";
      position: absolute;
      left: 6px;
      top: 18px;
      width: 78px;
      height: 22px;
      border: 3px solid #10203b;
      border-radius: 6px 6px 18px 18px;
      background: #8b4b38;
      box-shadow: inset 0 -6px 0 #633124, 4px 5px 0 rgba(16, 32, 51, .22);
    }

    .quest-boat::after {
      content: "BOAT";
      position: absolute;
      left: 13px;
      top: 0;
      padding: 3px 5px;
      border: 2px solid #10203b;
      background: #fff;
      color: #10203b;
      font-size: 10px;
      font-weight: 900;
      font-family: var(--quest-font);
      letter-spacing: .08em;
    }

    .quest-boat.boarded {
      pointer-events: none;
      cursor: default;
      z-index: 3;
    }

    .quest-boat.boarded::after {
      display: none;
    }

    .quest-hook {
      display: none;
      width: 18px;
      height: 18px;
      z-index: 5;
      transform: translate(var(--hook-x, 0), var(--hook-y, 0));
      pointer-events: none;
    }

    .quest-hook.active {
      display: block;
    }

    .quest-hook::before {
      content: "";
      position: absolute;
      left: 6px;
      top: 0;
      width: 7px;
      height: 15px;
      border: 3px solid #10203b;
      border-left: 0;
      border-top: 0;
      border-radius: 0 0 10px 0;
    }

    .quest-fishing-score {
      right: 22px;
      top: 22px;
      z-index: 4;
      padding: 5px 7px;
      border: 2px solid #10203b;
      background: #fff;
      color: #10203b;
      font-size: 11px;
      font-weight: 900;
      font-family: var(--quest-font);
      letter-spacing: .08em;
      text-transform: uppercase;
      pointer-events: none;
    }

    .quest-path-label {
      left: 18px;
      bottom: 18px;
      padding: 5px 7px;
      border: 2px solid #10203b;
      background: #fff;
      color: #10203b;
      font-size: 11px;
      font-weight: 900;
      font-family: var(--quest-font);
      letter-spacing: .08em;
      text-transform: uppercase;
      pointer-events: none;
    }

    .quest-control-hint {
      position: absolute;
      right: 76px;
      bottom: 22px;
      z-index: 3;
      padding: 5px 7px;
      border: 2px solid #10203b;
      background: #fff;
      color: #10203b;
      font-size: 11px;
      font-weight: 900;
      font-family: var(--quest-font);
      letter-spacing: .08em;
      text-transform: uppercase;
      pointer-events: none;
    }

    .quest-sprite {
      position: absolute;
      z-index: 4;
      width: 58px;
      height: 74px;
      --sprite-shirt: #234b7c;
      --sprite-hair: #24334d;
      --sprite-pants: #10203b;
      --sprite-skin: #f2c38f;
      image-rendering: pixelated;
      background:
        radial-gradient(ellipse at 50% 92%, rgba(16, 32, 51, .30) 0 24px, transparent 25px);
      filter: drop-shadow(5px 7px 0 rgba(16, 32, 51, .20));
    }

    .quest-player {
      left: 0;
      top: 0;
      transform: translate(var(--player-x, 43%), var(--player-y, 50%));
      transition: transform .08s linear;
    }

    .quest-player.walking::before {
      animation: quest-walk-body .18s steps(2, end) infinite;
    }

    .quest-player.walking::after {
      animation: quest-walk-head .18s steps(2, end) infinite;
    }

    .quest-player.in-boat::before {
      top: 0;
    }

    .quest-player.in-boat::after {
      top: 0;
    }

    .quest-npc {
      left: 0;
      top: 0;
      transform: translate(var(--npc-x, 53vw), var(--npc-y, 36px));
      transition: opacity .16s ease, filter .16s ease;
    }

    .quest-npc.can-talk {
      filter: drop-shadow(0 0 0 #fff) drop-shadow(0 0 10px #f0a637);
    }

    .quest-npc.completed {
      opacity: .48;
    }

    .quest-npc.in-boat::before {
      left: 29px;
    }

    .quest-npc.in-boat::after {
      left: 26px;
    }

    .quest-npc.in-boat {
      width: 86px;
      height: 74px;
      background:
        linear-gradient(90deg, transparent 0 6px, #10203b 6px 80px, transparent 80px 100%) 0 51px / 86px 4px no-repeat,
        linear-gradient(#8b4b38, #633124) 8px 46px / 70px 21px no-repeat;
      border-radius: 0 0 18px 18px;
    }

    .quest-sprite::before {
      content: "";
      position: absolute;
      left: 15px;
      top: 3px;
      width: 30px;
      height: 62px;
      background:
        linear-gradient(var(--sprite-pants), var(--sprite-pants)) 7px 50px / 7px 13px no-repeat,
        linear-gradient(var(--sprite-pants), var(--sprite-pants)) 18px 50px / 7px 13px no-repeat,
        linear-gradient(#071226, #071226) 5px 61px / 11px 5px no-repeat,
        linear-gradient(#071226, #071226) 18px 61px / 11px 5px no-repeat,
        linear-gradient(var(--sprite-skin), var(--sprite-skin)) 2px 29px / 6px 17px no-repeat,
        linear-gradient(var(--sprite-skin), var(--sprite-skin)) 24px 29px / 6px 17px no-repeat,
        linear-gradient(#10203b, #10203b) 5px 27px / 22px 27px no-repeat,
        linear-gradient(var(--sprite-shirt), var(--sprite-shirt)) 7px 28px / 18px 24px no-repeat,
        linear-gradient(#f6d2a5, #d99968) 4px 5px / 24px 23px no-repeat !important;
      background-repeat: no-repeat;
      background-color: transparent;
      background-blend-mode: normal;
      background-clip: border-box;
      box-shadow: none !important;
    }

    .quest-player.character-scout {
      --sprite-shirt: #234b7c;
      --sprite-hair: #24334d;
      --sprite-pants: #0b1831;
    }

    .quest-player.character-angler {
      --sprite-shirt: #2d7d44;
      --sprite-hair: #6c4a2d;
      --sprite-pants: #10203b;
    }

    .quest-player.character-analyst {
      --sprite-shirt: #6f5aa8;
      --sprite-hair: #6c2f2f;
      --sprite-pants: #151832;
    }

    .quest-player.character-scout::before {
      --sprite-shirt: #234b7c;
      --sprite-hair: #24334d;
      --sprite-pants: #0b1831;
    }

    .quest-player.character-angler::before {
      --sprite-shirt: #2d7d44;
      --sprite-hair: #6c4a2d;
      --sprite-pants: #10203b;
    }

    .quest-player.character-analyst::before {
      --sprite-shirt: #6f5aa8;
      --sprite-hair: #6c2f2f;
      --sprite-pants: #151832;
    }

    .quest-sprite::after {
      content: "";
      position: absolute;
      left: 12px;
      top: 0;
      width: 36px;
      height: 38px;
      background:
        linear-gradient(#10203b, #10203b) 12px 18px / 4px 4px no-repeat,
        linear-gradient(#10203b, #10203b) 24px 18px / 4px 4px no-repeat,
        linear-gradient(#8a5636, #8a5636) 18px 27px / 9px 3px no-repeat,
        linear-gradient(var(--sprite-hair), var(--sprite-hair)) 4px 0 / 28px 10px no-repeat,
        linear-gradient(var(--sprite-hair), var(--sprite-hair)) 0 7px / 10px 15px no-repeat,
        linear-gradient(var(--sprite-hair), var(--sprite-hair)) 27px 7px / 9px 14px no-repeat !important;
      box-shadow: none !important;
    }

    .quest-npc {
      --sprite-shirt: #f0a637;
      --sprite-hair: #6c2f2f;
      --sprite-pants: #10203b;
      --sprite-skin: #f0b887;
    }

    .quest-npc::before {
      box-shadow: none !important;
    }

    .quest-npc[data-npc-index="1"] { --sprite-shirt: #3d7aa5; --sprite-hair: #d8d3c7; }
    .quest-npc[data-npc-index="2"] { --sprite-shirt: #6f5aa8; --sprite-hair: #2e2038; }
    .quest-npc[data-npc-index="3"] { --sprite-shirt: #2d7d44; --sprite-hair: #6c4a2d; }
    .quest-npc[data-npc-index="4"] { --sprite-shirt: #bd6b6b; --sprite-hair: #693333; }
    .quest-npc[data-npc-index="5"] { --sprite-shirt: #d78a38; --sprite-hair: #40251c; }
    .quest-npc[data-npc-index="6"] { --sprite-shirt: #8a5fbf; --sprite-hair: #514071; }
    .quest-npc[data-npc-index="7"] { --sprite-shirt: #237a68; --sprite-hair: #6c2f2f; }
    .quest-npc[data-npc-index="8"] { --sprite-shirt: #91495a; --sprite-hair: #2f2033; }
    .quest-npc[data-npc-index="9"] { --sprite-shirt: #255f9b; --sprite-hair: #d8d3c7; }
    .quest-npc[data-npc-index="10"] { --sprite-shirt: #5d6d35; --sprite-hair: #2f2f23; }
    .quest-npc[data-npc-index="11"] { --sprite-shirt: #7d4e28; --sprite-hair: #2b1a14; }

    .quest-npc[data-npc-index="1"]::before {
      box-shadow:
        0 24px 0 5px #3d7aa5,
        -8px 30px 0 0 #f0b887,
        32px 30px 0 0 #f0b887,
        -1px 54px 0 3px #10203b,
        19px 54px 0 3px #10203b;
    }

    .quest-npc[data-npc-index="2"]::before {
      box-shadow:
        0 24px 0 5px #6f5aa8,
        -8px 30px 0 0 #f0b887,
        32px 30px 0 0 #f0b887,
        -1px 54px 0 3px #10203b,
        19px 54px 0 3px #10203b;
    }

    .quest-npc[data-npc-index="3"]::before {
      box-shadow:
        0 24px 0 5px #2d7d44,
        -8px 30px 0 0 #f0b887,
        32px 30px 0 0 #f0b887,
        -1px 54px 0 3px #10203b,
        19px 54px 0 3px #10203b;
    }

    .quest-npc[data-npc-index="4"]::before {
      box-shadow:
        0 24px 0 5px #bd6b6b,
        -8px 30px 0 0 #f0b887,
        32px 30px 0 0 #f0b887,
        -1px 54px 0 3px #10203b,
        19px 54px 0 3px #10203b;
    }

    .quest-npc[data-npc-index="5"]::before {
      box-shadow:
        0 24px 0 5px #d78a38,
        -8px 30px 0 0 #f0b887,
        32px 30px 0 0 #f0b887,
        -1px 54px 0 3px #10203b,
        19px 54px 0 3px #10203b;
    }

    .quest-npc[data-npc-index="6"]::before {
      box-shadow:
        0 24px 0 5px #8a5fbf,
        -8px 30px 0 0 #f0b887,
        32px 30px 0 0 #f0b887,
        -1px 54px 0 3px #10203b,
        19px 54px 0 3px #10203b;
    }

    .quest-npc[data-npc-index="7"]::before {
      box-shadow:
        0 24px 0 5px #237a68,
        -8px 30px 0 0 #f0b887,
        32px 30px 0 0 #f0b887,
        -1px 54px 0 3px #10203b,
        19px 54px 0 3px #10203b;
    }

    .quest-npc[data-npc-index="8"]::before {
      box-shadow:
        0 24px 0 5px #91495a,
        -8px 30px 0 0 #f0b887,
        32px 30px 0 0 #f0b887,
        -1px 54px 0 3px #10203b,
        19px 54px 0 3px #10203b;
    }

    .quest-npc[data-npc-index="9"]::before {
      box-shadow:
        0 24px 0 5px #255f9b,
        -8px 30px 0 0 #f0b887,
        32px 30px 0 0 #f0b887,
        -1px 54px 0 3px #10203b,
        19px 54px 0 3px #10203b;
    }

    .quest-npc[data-npc-index="10"]::before {
      box-shadow:
        0 24px 0 5px #5d6d35,
        -8px 30px 0 0 #f0b887,
        32px 30px 0 0 #f0b887,
        -1px 54px 0 3px #10203b,
        19px 54px 0 3px #10203b;
    }

    .quest-npc[data-npc-index="11"]::before {
      box-shadow:
        0 24px 0 5px #7d4e28,
        -8px 30px 0 0 #f0b887,
        32px 30px 0 0 #f0b887,
        -1px 54px 0 3px #10203b,
        19px 54px 0 3px #10203b;
    }

    .quest-npc::after {
      background: #6c2f2f;
      box-shadow:
        8px 7px 0 #6c2f2f,
        11px 16px 0 -7px #10203b,
        25px 16px 0 -7px #10203b;
    }

    .quest-avatar {
      position: absolute;
      right: 18px;
      bottom: 18px;
      z-index: 3;
      display: grid;
      place-items: center;
      width: 52px;
      height: 52px;
      border: 4px solid #fff;
      background: #10203b;
      color: #fff;
      font-size: 17px;
      font-weight: 900;
      font-family: var(--quest-font);
      letter-spacing: .04em;
      box-shadow: 0 0 0 2px #10203b;
    }

    @keyframes quest-walk-body {
      0% { transform: translateY(0); }
      100% { transform: translateY(3px); }
    }

    @keyframes quest-walk-head {
      0% { transform: translateY(0); }
      100% { transform: translateY(-2px); }
    }

    @keyframes fish-swim {
      0% { margin-left: 0; }
      100% { margin-left: 10px; }
    }

    @keyframes quest-water-shimmer {
      0% { background-position: 0 0, 0 0, 0 0, 0 0; }
      100% { background-position: 18px 12px, 18px 0, 0 18px, 0 0; }
    }

    .quest-hud {
      position: absolute;
      top: 14px;
      left: 14px;
      z-index: 4;
      width: min(360px, calc(100% - 28px));
      display: grid;
      gap: 8px;
      padding: 10px;
      border: 4px solid #f0d77e;
      background:
        linear-gradient(90deg, rgba(255,255,255,.08) 1px, transparent 1px) 0 0 / 10px 10px,
        #102d67;
      color: #fff;
      box-shadow: 0 0 0 3px #10203b, 6px 6px 0 rgba(16, 32, 51, .30);
    }

    .quest-stat-row {
      display: grid;
      grid-template-columns: 72px minmax(0, 1fr) 34px;
      gap: 8px;
      align-items: center;
      font-size: 12px;
      font-weight: 900;
      font-family: var(--quest-font);
      text-transform: uppercase;
      letter-spacing: .05em;
    }

    .quest-meter {
      height: 10px;
      overflow: hidden;
      border: 2px solid #fff;
      background: #091735;
    }

    .quest-meter span {
      display: block;
      width: 0%;
      height: 100%;
      background: linear-gradient(90deg, #f0a637, #75c878);
      transition: width .2s ease;
    }

    .energy-physical .quest-meter span {
      background: linear-gradient(90deg, #75c878, #2f9e57);
    }

    .energy-mental .quest-meter span {
      background: linear-gradient(90deg, #61b8ff, #2e74b5);
    }

    .quest-map.low-physical .quest-hud {
      box-shadow: 0 0 0 3px #10203b, 0 0 0 7px rgba(117, 200, 120, .34), 6px 6px 0 rgba(16, 32, 51, .30);
    }

    .quest-map.low-mental .quest-hud {
      box-shadow: 0 0 0 3px #10203b, 0 0 0 7px rgba(97, 184, 255, .34), 6px 6px 0 rgba(16, 32, 51, .30);
    }

    .quest-play {
      display: grid;
      gap: 12px;
      padding: 14px;
      background: #10203b;
    }

    .quest-dialogue {
      display: grid;
      grid-template-columns: minmax(150px, 210px) minmax(0, 1fr);
      gap: 14px;
      padding: 16px;
      border: 4px solid #f0d77e;
      background:
        linear-gradient(90deg, rgba(255,255,255,.08) 1px, transparent 1px) 0 0 / 10px 10px,
        linear-gradient(180deg, #17377d, #102d67);
      color: #fff;
      font-family: var(--quest-font);
      box-shadow: 0 0 0 3px #10203b, inset 0 0 0 2px rgba(255,255,255,.18);
    }

    .quest-character h3 {
      margin: 0 0 4px;
      color: #fff;
      font-size: 22px;
      line-height: 1.1;
      letter-spacing: .05em;
      text-transform: uppercase;
      text-shadow: 3px 3px 0 #0b1426;
    }

    .quest-character p {
      margin: 0;
      color: #dbe8ff;
      font-size: 12px;
      font-weight: 800;
      line-height: 1.45;
      letter-spacing: .03em;
    }

    .quest-meta {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      margin-bottom: 8px;
      color: #f1cf8b;
      font-size: 12px;
      font-weight: 900;
      font-family: var(--quest-font);
      letter-spacing: .06em;
      text-transform: uppercase;
    }

    .quest-line {
      min-height: 82px;
      margin: 0;
      color: #fff;
      font-size: 18px;
      font-weight: 800;
      line-height: 1.55;
      letter-spacing: .02em;
    }

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

    .quest-response {
      position: relative;
      min-height: 78px;
      padding: 13px 14px 13px 32px;
      border: 3px solid #f0d77e;
      background:
        linear-gradient(90deg, rgba(255,255,255,.07) 1px, transparent 1px) 0 0 / 10px 10px,
        #0d285f;
      color: #fff;
      font: inherit;
      font-size: 15px;
      font-family: var(--quest-font);
      font-weight: 900;
      line-height: 1.38;
      letter-spacing: .02em;
      text-align: left;
      cursor: pointer;
      box-shadow: 0 0 0 2px #10203b, inset 0 0 0 2px rgba(255,255,255,.14);
    }

    .quest-response::before {
      content: ">";
      position: absolute;
      margin-left: -22px;
      color: #f0a637;
      opacity: 0;
    }

    .quest-response:hover:not(:disabled) {
      background: #17377d;
      transform: translateY(-1px);
    }

    .quest-response:hover:not(:disabled)::before {
      opacity: 1;
    }

    .quest-response.best {
      border-color: #78cf8a;
      background: #174e47;
    }

    .quest-response.missed {
      border-color: #e09b9b;
      background: #613044;
    }

    .quest-response:disabled {
      cursor: default;
    }

    .quest-feedback {
      display: none;
      padding: 14px 16px;
      border: 4px solid #f0d77e;
      background:
        linear-gradient(90deg, rgba(16,32,51,.04) 1px, transparent 1px) 0 0 / 10px 10px,
        #f8f3e7;
      color: var(--ink);
      font-family: var(--quest-font);
      font-size: 14px;
      font-weight: 800;
      line-height: 1.55;
      letter-spacing: .01em;
      box-shadow: 0 0 0 3px #10203b;
    }

    .quest-feedback.active {
      display: block;
    }

    .quest-feedback p {
      margin: 0 0 7px;
    }

    .quest-feedback p:last-child {
      margin-bottom: 0;
    }

    .quest-feedback strong {
      color: var(--blue-dark);
    }

    .quest-feedback a {
      color: var(--blue-dark);
      font-weight: 900;
    }

    .quest-actions {
      display: flex;
      flex-wrap: wrap;
      gap: 10px;
      justify-content: flex-end;
    }

    .quest-actions .button:disabled {
      opacity: .55;
      cursor: not-allowed;
    }

    .quest-map-preview,
    .quest-world,
    .quest-sprite,
    .quest-portrait,
    .quest-boat,
    .quest-rod,
    .quest-fish {
      background-repeat: no-repeat;
      image-rendering: pixelated;
    }

    .quest-map-preview.mountain {
      background: url("cq-map-mountain.jpg") center / cover no-repeat;
    }

    .quest-map-preview.beach {
      background: url("cq-map-beach.jpg") center / cover no-repeat;
    }

    .quest-map-preview.lake {
      background: url("cq-map-lake.jpg") center / cover no-repeat;
    }

    .quest-map-preview::before,
    .quest-map-preview::after,
    .quest-map-preview.mountain::after,
    .quest-map-preview.beach::after {
      display: none;
    }

    .quest-world {
      width: 2688px;
      height: 1520px;
      background-size: 100% 100%;
      background-position: 0 0;
    }

    .quest-world.map-mountain {
      background: url("cq-map-mountain.jpg") 0 0 / 100% 100% no-repeat;
    }

    .quest-world.map-beach {
      background: url("cq-map-beach.jpg") 0 0 / 100% 100% no-repeat;
    }

    .quest-world.map-lake {
      background: url("cq-map-lake.jpg") 0 0 / 100% 100% no-repeat;
    }

    .quest-world::before,
    .quest-world::after,
    .quest-water,
    .quest-trees,
    .quest-houses {
      display: none;
    }

    .quest-sprite {
      width: 76px;
      height: 98px;
      background-image: var(--sprite-image);
      background-size: contain;
      background-position: center bottom;
      filter: drop-shadow(4px 6px 0 rgba(16, 32, 51, .32));
    }

    .quest-sprite::before,
    .quest-sprite::after {
      display: none;
    }

    .quest-player.character-scout {
      --sprite-image: url("cq-player-scout.png");
    }

    .quest-player.character-angler {
      --sprite-image: url("cq-player-angler.png");
    }

    .quest-player.character-analyst {
      --sprite-image: url("cq-player-analyst.png");
    }

    .quest-npc[data-npc-index="0"] { --sprite-image: url("cq-npc-0.png"); }
    .quest-npc[data-npc-index="1"] { --sprite-image: url("cq-npc-1.png"); }
    .quest-npc[data-npc-index="2"] { --sprite-image: url("cq-npc-2.png"); }
    .quest-npc[data-npc-index="3"] { --sprite-image: url("cq-npc-3.png"); }
    .quest-npc[data-npc-index="4"] { --sprite-image: url("cq-npc-4.png"); }
    .quest-npc[data-npc-index="5"] { --sprite-image: url("cq-npc-5.png"); }
    .quest-npc[data-npc-index="6"] { --sprite-image: url("cq-npc-6.png"); }
    .quest-npc[data-npc-index="7"] { --sprite-image: url("cq-npc-7.png"); }
    .quest-npc[data-npc-index="8"] { --sprite-image: url("cq-npc-8.png"); }
    .quest-npc[data-npc-index="9"] { --sprite-image: url("cq-npc-9.png"); }
    .quest-npc[data-npc-index="10"] { --sprite-image: url("cq-npc-10.png"); }
    .quest-npc[data-npc-index="11"] { --sprite-image: url("cq-npc-11.png"); }

    .quest-npc.in-boat {
      width: 116px;
      height: 110px;
      background:
        var(--sprite-image) center 4px / 58px auto no-repeat,
        url("cq-boat-top.png") center bottom / 112px auto no-repeat;
      border-radius: 0;
    }

    .quest-choice-sprite {
      width: 76px;
      height: 96px;
      background-size: contain;
      background-position: center bottom;
      background-repeat: no-repeat;
      filter: drop-shadow(4px 6px 0 rgba(0,0,0,.26));
    }

    .quest-choice-sprite::before,
    .quest-choice-sprite::after {
      display: none;
    }

    .quest-choice-sprite.scout { background-image: url("cq-player-scout.png"); }
    .quest-choice-sprite.angler { background-image: url("cq-player-angler.png"); }
    .quest-choice-sprite.analyst { background-image: url("cq-player-analyst.png"); }

    .quest-boat {
      width: 118px;
      height: 88px;
      background: url("cq-boat-top.png") center / contain no-repeat;
      filter: drop-shadow(5px 7px 0 rgba(16, 32, 51, .26));
    }

    .quest-boat::before,
    .quest-boat::after {
      display: none;
    }

    .quest-rod {
      width: 112px;
      height: 70px;
      background: url("cq-rod.png") center / contain no-repeat;
      filter: drop-shadow(4px 5px 0 rgba(16, 32, 51, .24));
    }

    .quest-rod::before,
    .quest-rod::after {
      display: none;
    }

    .quest-fish {
      width: 46px;
      height: 28px;
      border-radius: 0;
      background-color: transparent;
      background-size: contain;
      background-position: center;
    }

    .quest-fish::after {
      display: none;
    }

    .quest-fish[data-fish-index="0"] { background-image: url("cq-fish-blue.png"); }
    .quest-fish[data-fish-index="1"] { background-image: url("cq-fish-green.png"); }
    .quest-fish[data-fish-index="2"] { background-image: url("cq-fish-orange.png"); }

    .quest-hook {
      width: 42px;
      height: 34px;
      background: url("cq-ripple.png") center / contain no-repeat;
    }

    .quest-hook::before {
      display: none;
    }

    .quest-portrait {
      width: 100%;
      aspect-ratio: 6 / 5;
      margin-bottom: 10px;
      border: 3px solid #f0d77e;
      background: #071735 center / cover no-repeat;
      box-shadow: 0 0 0 2px #10203b, inset 0 0 0 2px rgba(255,255,255,.12);
    }

    .quest-character {
      min-width: 0;
    }

    .signup-section {
      margin: 0 0 54px;
      display: grid;
      grid-template-columns: minmax(0, 1fr) minmax(300px, 430px);
      gap: 22px;
      align-items: center;
      padding: 24px;
      border: 1px solid var(--line);
      border-radius: 10px;
      background: linear-gradient(135deg, #fff 0%, #f7f1df 100%);
    }

    .signup-section h2 {
      margin: 0 0 8px;
      color: var(--blue-dark);
      font-size: clamp(26px, 4vw, 40px);
      line-height: 1.05;
    }

    .signup-section p {
      margin: 0;
      color: var(--muted);
      line-height: 1.5;
    }

    .email-preview {
      margin-top: 16px;
      padding: 14px;
      border: 1px solid #ead1ae;
      border-radius: 8px;
      background: rgba(255, 255, 255, .72);
    }

    .email-preview strong {
      display: block;
      margin-bottom: 6px;
      color: var(--warm);
      font-size: 13px;
      text-transform: uppercase;
      letter-spacing: .06em;
    }

    .email-preview p {
      color: var(--ink);
      font-size: 14px;
    }

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

    .signup-form input {
      min-height: 44px;
      padding: 10px 12px;
      border: 1px solid var(--line);
      border-radius: 6px;
      font: inherit;
    }

    .signup-note {
      margin-top: 8px !important;
      font-size: 12px;
    }

    .merch-section {
      margin: 0 0 42px;
      padding: 22px;
      border: 1px solid var(--line);
      border-radius: 10px;
      background: #fff;
    }

    .merch-header {
      display: grid;
      grid-template-columns: minmax(0, 1fr) auto;
      gap: 18px;
      align-items: end;
      margin-bottom: 16px;
    }

    .merch-header h2 {
      margin: 0 0 7px;
      color: var(--blue-dark);
      font-size: clamp(26px, 4vw, 40px);
      line-height: 1.05;
    }

    .merch-header p {
      margin: 0;
      max-width: 680px;
      color: var(--muted);
      line-height: 1.5;
    }

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

    .merch-card {
      min-height: 0;
      display: grid;
      grid-template-rows: auto auto;
      gap: 14px;
      padding: 16px;
      border: 1px solid var(--line);
      border-radius: 8px;
      background: var(--soft);
    }

    .merch-visual {
      position: relative;
      display: grid;
      place-items: center;
      aspect-ratio: 1 / 1;
      min-height: 0;
      border: 1px solid rgba(16, 32, 51, .08);
      border-radius: 8px;
      background: #fff;
      overflow: hidden;
    }

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

    .merch-visual a {
      position: absolute;
      inset: 0;
      display: block;
      border-radius: inherit;
    }

    .merch-visual a:focus-visible {
      outline: 3px solid var(--blue);
      outline-offset: 3px;
    }

    .merch-image.deck-image {
      object-position: center;
    }

    .mug-shape {
      position: relative;
      width: 88px;
      height: 82px;
      border: 5px solid var(--blue-dark);
      border-radius: 8px 8px 18px 18px;
      background: linear-gradient(180deg, #fff 0%, #f7f1df 100%);
    }

    .mug-shape::after {
      content: "";
      position: absolute;
      right: -31px;
      top: 16px;
      width: 30px;
      height: 38px;
      border: 5px solid var(--blue-dark);
      border-left: 0;
      border-radius: 0 18px 18px 0;
    }

    .mug-copy {
      position: absolute;
      left: 9px;
      right: 9px;
      top: 19px;
      min-height: 38px;
      display: grid;
      place-items: center;
      color: var(--warm);
      font-size: 8.5px;
      font-weight: 900;
      line-height: 1.08;
      text-align: center;
      text-transform: uppercase;
      overflow-wrap: anywhere;
    }

    .deck-shape {
      width: 92px;
      height: 112px;
      border: 5px solid var(--blue-dark);
      border-radius: 8px;
      background: linear-gradient(135deg, #fff 0%, #f7f1df 100%);
      box-shadow: 13px 10px 0 rgba(19, 54, 93, .16);
    }

    .deck-shape::before {
      content: "?";
      display: grid;
      place-items: center;
      width: 100%;
      height: 100%;
      color: var(--warm);
      font-size: 42px;
      font-weight: 900;
    }

    .merch-card h3 {
      margin: 0 0 7px;
      color: var(--blue-dark);
      font-size: 18px;
      line-height: 1.15;
    }

    .merch-card h3 a {
      color: inherit;
      text-decoration: none;
    }

    .merch-card h3 a:hover,
    .merch-bias-link:hover {
      color: var(--warm);
    }

    .merch-card p {
      margin: 0 0 10px;
      color: var(--ink);
      font-size: 14px;
      line-height: 1.42;
    }

    .merch-tag {
      display: inline-flex;
      align-items: center;
      width: fit-content;
      min-height: 28px;
      padding: 5px 9px;
      border: 1px solid #ead1ae;
      border-radius: 999px;
      background: #fff;
      color: var(--warm);
      font-size: 12px;
      font-weight: 900;
      text-transform: uppercase;
      letter-spacing: .04em;
    }

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

    .merch-bias-link {
      color: var(--blue-dark);
      font-size: 13px;
      font-weight: 900;
      text-decoration: none;
    }

    .modal-backdrop {
      position: fixed;
      inset: 0;
      z-index: 80;
      display: none;
      align-items: center;
      justify-content: center;
      padding: 18px;
      background: rgba(16, 32, 51, .46);
    }

    .modal-backdrop.active {
      display: flex;
    }

    .deep-modal {
      width: min(720px, 100%);
      max-height: min(760px, 88vh);
      display: flex;
      flex-direction: column;
      overflow: hidden;
      border-radius: 10px;
      border: 1px solid var(--line);
      background: #fff;
      box-shadow: 0 22px 70px rgba(16, 32, 51, .26);
    }

    .modal-top {
      display: flex;
      justify-content: space-between;
      gap: 12px;
      align-items: start;
      padding: 18px 20px;
      border-bottom: 1px solid var(--line);
      background: var(--modal-soft, var(--soft));
    }

    .modal-top h2 {
      margin: 0;
      color: var(--modal-accent, var(--blue));
      font-size: 28px;
      line-height: 1.12;
    }

    .modal-category {
      margin: 0 0 5px;
      color: var(--warm);
      font-size: 12px;
      font-weight: 900;
      text-transform: uppercase;
      letter-spacing: .07em;
    }

    .modal-close {
      min-width: 36px;
      min-height: 36px;
      border: 1px solid var(--line);
      border-radius: 6px;
      background: #fff;
      cursor: pointer;
      font-size: 20px;
    }

    .modal-body {
      padding: 20px;
      overflow: auto;
    }

    .modal-body h3 {
      margin: 18px 0 6px;
      color: var(--blue-dark);
    }

    .modal-body p {
      margin: 0 0 10px;
      color: var(--ink);
      line-height: 1.55;
    }

    .modal-share-row {
      justify-content: flex-end;
    }

    .modal-actions {
      position: sticky;
      bottom: 0;
      display: flex;
      flex-wrap: wrap;
      justify-content: flex-end;
      align-items: center;
      gap: 8px;
      margin: 18px -20px -20px;
      padding: 12px 20px;
      border-top: 1px solid var(--line);
      background: #fff;
    }

    .closing h2 {
      margin: 0 0 8px;
      color: var(--blue);
      font-size: 28px;
    }

    .closing ul {
      margin: 12px 0 0;
      padding-left: 20px;
      line-height: 1.55;
    }

    .site-footer {
      max-width: 1180px;
      margin: 0 auto;
      padding: 0 20px 44px;
    }

    .footer-inner {
      display: flex;
      flex-wrap: wrap;
      justify-content: space-between;
      gap: 14px;
      padding-top: 18px;
      border-top: 1px solid var(--line);
      color: var(--muted);
      font-size: 14px;
    }

    .footer-links {
      display: flex;
      flex-wrap: wrap;
      gap: 12px;
    }

    .footer-links a {
      color: var(--blue-dark);
      font-weight: 800;
      text-decoration: none;
    }

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

      .game-promo-banner {
        max-width: none;
      }

      .field-visual {
        min-height: 330px;
      }

      .visual-board {
        min-height: 280px;
      }

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

      .tools-inner {
        grid-template-columns: 1fr;
      }

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

      .prompt-check-card,
      .trap-check-card {
        grid-template-columns: 1fr;
      }
    }

    @media (max-width: 680px) {
      .mobile-quick-nav {
        position: sticky;
        top: 0;
        z-index: 45;
        display: grid;
        grid-template-columns: repeat(5, minmax(0, 1fr));
        gap: 4px;
        padding: 8px;
        border-top: 1px solid var(--line);
        border-bottom: 1px solid var(--line);
        background: rgba(251, 252, 253, .97);
        backdrop-filter: blur(10px);
      }

      .mobile-quick-nav a,
      .mobile-quick-nav button {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        min-height: 38px;
        padding: 6px 5px;
        border: 1px solid var(--line);
        border-radius: 6px;
        background: #fff;
        color: var(--blue-dark);
        font: inherit;
        font-size: 11px;
        font-weight: 900;
        text-decoration: none;
        white-space: nowrap;
        cursor: pointer;
      }

      .game-promo-banner {
        grid-template-columns: auto minmax(0, 1fr) auto;
        gap: 7px;
        min-height: 50px;
        padding: 7px 8px 8px;
      }

      .game-promo-sprite {
        width: 30px;
        height: 38px;
      }

      .game-promo-title {
        font-size: 14px;
      }

      .game-promo-line {
        display: none;
      }

      .game-promo-cta {
        min-height: 26px;
        padding-inline: 6px;
        font-size: 10px;
      }

      .category-sheet {
        position: fixed;
        inset: 0;
        z-index: 80;
        display: none;
        align-items: flex-end;
        background: rgba(16, 32, 51, .36);
      }

      .category-sheet.active {
        display: flex;
      }

      .category-sheet-panel {
        width: 100%;
        max-height: min(76vh, 720px);
        overflow: auto;
        padding: 18px;
        border-radius: 16px 16px 0 0;
        background: #fff;
        box-shadow: 0 -20px 50px rgba(16, 32, 51, .20);
      }

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

      .category-sheet-top h2 {
        margin: 0;
        color: var(--ink);
        font-size: 22px;
        letter-spacing: 0;
      }

      .category-sheet-top button {
        width: 44px;
        height: 44px;
        border: 1px solid var(--line);
        border-radius: 8px;
        background: #fff;
        color: var(--ink);
        font: inherit;
        font-size: 24px;
        cursor: pointer;
      }

      .category-sheet-list {
        display: grid;
        gap: 8px;
      }

      .category-sheet-link {
        display: grid;
        grid-template-columns: 42px 1fr auto;
        gap: 10px;
        align-items: center;
        min-height: 56px;
        padding: 9px;
        border: 1px solid var(--line);
        border-radius: 8px;
        background: #fff;
        color: var(--ink);
        text-decoration: none;
      }

      .category-sheet-link span {
        display: inline-grid;
        place-items: center;
        width: 42px;
        height: 42px;
        border-radius: 7px;
        background: var(--soft);
        color: var(--blue-dark);
      }

      .category-sheet-link strong {
        font-size: 14px;
        line-height: 1.15;
      }

      .category-sheet-link small {
        color: var(--muted);
        font-size: 11px;
        font-weight: 800;
        white-space: nowrap;
      }

      .hero {
        padding-top: 28px;
      }

      .email-dock {
        position: relative;
        top: auto;
        left: auto;
        right: auto;
        width: auto;
        grid-column: 1 / -1;
        margin-bottom: 8px;
        transform: none;
      }

      .hero-title-wrap {
        display: block;
        padding-right: 0;
      }

      .title-trap-mark {
        position: relative;
        right: auto;
        top: auto;
        display: block;
        width: 55px;
        margin: 10px 0 0;
        color: rgba(16, 32, 51, .28);
        transform: none;
      }

      .stats,
      .onboarding-inner,
      .prompt-check-card,
      .trap-check-card,
      .quest-shell,
      .card-grid,
      .faq-grid,
      .blog-preview-grid,
      .merch-header,
      .merch-grid,
      .situation-grid,
      .quiz-options,
      .signup-section,
      .signup-form,
      .pause-box ul {
        grid-template-columns: 1fr;
      }

      .stat {
        min-height: 40px;
        padding: 8px 10px;
      }

      .daily-card {
        grid-template-columns: 1fr;
      }

      .situation-top {
        display: block;
      }

      .situation-card {
        min-height: 0;
      }

      .prompt-check-card,
      .trap-check-card {
        padding: 16px;
      }

      .prompt-tool textarea,
      .trap-tool textarea {
        min-height: 132px;
      }

      .daily-icon {
        width: 62px;
        height: 62px;
      }

      .quiz-header {
        display: block;
      }

      .quest-header {
        display: block;
      }

      .quest-section {
        padding: 14px;
      }

      .quest-header {
        margin-bottom: 12px;
      }

      .quest-header p {
        display: none;
      }

      .quest-map {
        height: 360px;
      }

      .quest-start-screen {
        min-height: 0;
        padding: 12px;
      }

      .quest-start-panel {
        padding: 14px;
      }

      .quest-choice-grid {
        grid-template-columns: 1fr;
      }

      .quest-choice {
        min-height: 0;
      }

      .quest-choice-sprite {
        width: 44px;
        height: 58px;
      }

      .quest-map-preview {
        aspect-ratio: 18 / 7;
      }

      .quest-world {
        width: 2688px;
        height: 1520px;
      }

      .quest-dialogue,
      .quest-responses {
        grid-template-columns: 1fr;
      }

      .quest-dialogue {
        gap: 8px;
        padding: 12px;
      }

      .quest-line {
        min-height: 0;
        font-size: 16px;
      }

      .quest-response {
        min-height: 0;
        padding-top: 10px;
        padding-bottom: 10px;
        font-size: 14px;
      }

      .quest-hud {
        top: 10px;
        left: 10px;
        width: calc(100% - 20px);
      }

      .quest-houses {
        left: 650px;
      }

      .quest-player {
        transform: translate(var(--player-x, 38%), var(--player-y, 55%));
      }

      .quest-npc {
        transform: translate(var(--npc-x, 55vw), var(--npc-y, 40px));
      }

      .quest-control-hint {
        right: 72px;
        bottom: 18px;
        max-width: 112px;
      }

      .blog-header {
        display: block;
      }

      .tools-inner {
        padding: 8px 14px;
      }

      .category-grid {
        display: none;
      }

      .filter-panel {
        flex-wrap: nowrap;
        overflow-x: auto;
        padding: 0 0 2px;
        scrollbar-width: none;
      }

      .filter-panel::-webkit-scrollbar {
        display: none;
      }

      .filter-chip {
        white-space: nowrap;
      }

      .card-actions {
        display: grid;
        grid-template-columns: 1fr;
      }

      .deep-button,
      .share-button,
      .share-menu-trigger {
        min-height: 44px;
      }

      .share-button,
      .share-menu-trigger {
        min-width: 44px;
      }

      .share-row {
        justify-content: start;
      }

      .result-score-card {
        grid-template-columns: 1fr;
      }

      .section-heading {
        grid-template-columns: 52px minmax(0, 1fr);
      }

      .section-mark {
        width: 52px;
        height: 52px;
        font-size: 22px;
      }

      .bias-card {
        min-height: 0;
      }

      .merch-section {
        padding: 16px;
      }

      .merch-header {
        align-items: start;
      }

      .merch-header .button {
        width: 100%;
        justify-content: center;
      }

      .merch-card {
        min-height: 0;
        grid-template-columns: 1fr;
        grid-template-rows: auto;
        align-items: center;
        padding: 12px;
      }

      .merch-visual {
        width: 100%;
        aspect-ratio: 1 / 1;
        min-height: 0;
      }

      .merch-image {
        object-position: center;
      }

      .merch-image.deck-image {
        object-position: center;
      }

      .mug-shape {
        width: 62px;
        height: 58px;
        border-width: 4px;
      }

      .mug-shape::after {
        right: -23px;
        top: 11px;
        width: 22px;
        height: 29px;
        border-width: 4px;
      }

      .mug-copy {
        left: 6px;
        right: 6px;
        top: 13px;
        min-height: 28px;
        font-size: 5.8px;
        line-height: 1.06;
      }

      .deck-shape {
        width: 62px;
        height: 78px;
        border-width: 4px;
        box-shadow: 9px 7px 0 rgba(19, 54, 93, .16);
      }

      .modal-backdrop {
        align-items: flex-start;
        padding: 8px;
      }

      .deep-modal {
        width: 100%;
        max-height: calc(100dvh - 16px);
        border-radius: 9px;
      }

      .modal-top {
        padding: 12px 12px 10px;
      }

      .modal-top h2 {
        font-size: 22px;
      }

      .modal-body {
        padding: 12px;
      }

      .modal-body h3 {
        margin: 12px 0 4px;
        font-size: 13px;
      }

      .modal-body p,
      .modal-body li {
        font-size: 13px;
        line-height: 1.38;
      }

      .modal-body ul {
        margin: 0 0 8px;
        padding-left: 18px;
      }

      .modal-actions {
        margin: 12px -12px -12px;
        padding: 10px 12px;
        justify-content: space-between;
        box-shadow: 0 -10px 22px rgba(16, 32, 51, .08);
      }

      .modal-actions .full-page-link {
        flex: 1 1 auto;
        justify-content: center;
      }

      .modal-share-row {
        margin-left: auto;
        justify-content: flex-end;
      }

      .note {
        width: 120px;
      }

      .note.two {
        right: 14px;
      }

      .note.four {
        right: 20px;
      }
    }

    @media print {
      .field-visual,
      .sticky-tools,
      .hero-actions {
        display: none;
      }

      body {
        background: #fff;
      }

      .hero,
      .content,
      .stats {
        max-width: none;
        padding-left: 0;
        padding-right: 0;
      }

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

      .bias-card {
        break-inside: avoid;
        box-shadow: none;
      }

      .bias-section {
        break-before: page;
      }
    }
