:root {
  /* Typography compliance terms: Mono** from sparingly exhibit numbers authority against acid pop-art Display** elegant headline face. major titles Black ExtraBold Grotesk** captions */
  --ink: #05040A;
  --violet: #3B0B6D;
  --magenta: #FF2DAA;
  --cyan: #00F0FF;
  --yellow: #FFE83D;
  --paper: #F7F1E3;
  --red: #FF3B30;
  --playfair: 'Playfair Display', Georgia, 'Times New Roman', serif;
  --space: 'Space Grotesk', Inter, system-ui, sans-serif;
  --mono: 'IBM Plex Mono', 'SFMono-Regular', Consolas, monospace;
}

* { box-sizing: border-box; }

body {
  margin: 0;
  background: var(--ink);
  color: var(--paper);
  font-family: var(--space);
  overflow-x: hidden;
}

.grid-field {
  position: fixed;
  inset: 0;
  z-index: -2;
  background:
    radial-gradient(circle at 25% 12%, rgba(255,45,170,.18), transparent 28%),
    radial-gradient(circle at 76% 78%, rgba(59,11,109,.8), transparent 34%),
    linear-gradient(rgba(0,240,255,.13) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,240,255,.13) 1px, transparent 1px),
    var(--ink);
  background-size: auto, auto, 44px 44px, 44px 44px, auto;
  transition: filter .28s ease, opacity .28s ease;
}

.grid-field.pulse {
  filter: drop-shadow(0 0 16px var(--cyan));
  opacity: .95;
}

.grid-field::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle, rgba(0,240,255,.55) 0 2px, transparent 2.5px);
  background-size: 88px 88px;
  opacity: .25;
}

.case-strip {
  position: fixed;
  top: 0;
  bottom: 0;
  left: 0;
  width: 42px;
  z-index: 8;
  display: flex;
  align-items: center;
  justify-content: space-around;
  writing-mode: vertical-rl;
  text-orientation: mixed;
  background: var(--ink);
  border-right: 2px solid var(--cyan);
  box-shadow: 6px 0 0 var(--magenta), 14px 0 32px rgba(0,240,255,.2);
  color: var(--cyan);
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .18em;
}

.proof-wall {
  width: min(1480px, calc(100vw - 64px));
  margin-left: 58px;
  padding: 22px 18px 80px;
}

.panel,
.opening-panel,
.final-verdict,
.lock-piece {
  position: relative;
  border: 3px solid var(--paper);
  background: var(--ink);
  box-shadow: 8px 8px 0 var(--cyan), -5px -5px 0 rgba(255,45,170,.75);
  overflow: hidden;
}

.snap-panel {
  transform: translate(var(--sx, 0), var(--sy, 0)) rotate(var(--sr, 0deg)) scale(.94);
  opacity: 0;
}

.snap-panel.locked {
  animation: tribunalSnap .78s cubic-bezier(.2, 1.55, .22, 1) forwards;
}

@keyframes tribunalSnap {
  0% { transform: translate(var(--sx), var(--sy)) rotate(var(--sr)) scale(.94); opacity: 0; }
  68% { transform: translate(calc(var(--sx) * -.045), calc(var(--sy) * -.045)) rotate(calc(var(--sr) * -.2)) scale(1.035); opacity: 1; }
  84% { transform: translate(5px, -4px) rotate(.35deg) scale(.992); }
  100% { transform: translate(0,0) rotate(0deg) scale(1); opacity: 1; }
}

.opening-panel {
  min-height: 92vh;
  margin-bottom: 30px;
  padding: clamp(34px, 7vw, 86px);
  display: grid;
  align-content: center;
  background:
    linear-gradient(90deg, rgba(0,240,255,.14) 1px, transparent 1px),
    linear-gradient(rgba(0,240,255,.14) 1px, transparent 1px),
    radial-gradient(circle at 88% 22%, rgba(255,232,61,.95) 0 10%, transparent 10.4%),
    var(--ink);
  background-size: 36px 36px, 36px 36px, auto, auto;
}

.case-stamp,
.chapter-label,
.mono-tag {
  font-family: var(--mono);
  color: var(--cyan);
  letter-spacing: .16em;
  font-size: 12px;
  text-transform: uppercase;
}

h1,
h2 {
  font-family: var(--playfair);
  margin: 0;
  font-weight: 900;
  line-height: .84;
}

h1 {
  font-size: clamp(72px, 17vw, 252px);
  letter-spacing: -.08em;
  color: var(--paper);
  text-shadow: 5px 0 0 var(--red), -5px 0 0 var(--cyan), 0 10px 0 var(--violet);
  margin-left: -3vw;
}

h2 { font-size: clamp(32px, 4.4vw, 72px); }

p {
  font-size: clamp(16px, 1.7vw, 24px);
  line-height: 1.18;
  margin: 18px 0 0;
}

.opening-decree {
  max-width: 720px;
  border-left: 10px solid var(--yellow);
  padding-left: 18px;
  color: var(--paper);
}

.giant-piece {
  position: absolute;
  right: 7%;
  bottom: 7%;
  width: 220px;
  height: 220px;
  background: var(--paper);
  clip-path: polygon(0 0, 38% 0, 38% 18%, 62% 18%, 62% 0, 100% 0, 100% 38%, 82% 38%, 82% 62%, 100% 62%, 100% 100%, 0 100%);
  opacity: .14;
}

.comic-fragment {
  position: absolute;
  right: 4%;
  top: 10%;
  transform: rotate(-10deg);
  font-family: var(--space);
  font-size: clamp(44px, 8vw, 132px);
  font-weight: 700;
  color: var(--yellow);
  -webkit-text-stroke: 3px var(--ink);
  text-shadow: 7px 7px 0 var(--magenta);
}

.chapter {
  min-height: 86vh;
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  grid-auto-rows: 58px;
  gap: 16px;
  margin: 28px 0 70px;
}

.chapter-label {
  grid-column: 1 / -1;
  align-self: end;
  color: var(--yellow);
  border-bottom: 2px solid var(--cyan);
  padding-bottom: 8px;
}

.panel { padding: 24px; }
.tall { grid-column: 1 / span 4; grid-row: 2 / span 8; }
.short { grid-column: 5 / span 3; grid-row: 3 / span 3; }
.wide { grid-column: 6 / span 7; grid-row: 6 / span 5; }
.mini { grid-column: 9 / span 2; grid-row: 2 / span 2; }
.path-panel { grid-column: 2 / span 6; grid-row: 2 / span 6; }
.narrow { grid-column: 8 / span 2; grid-row: 4 / span 7; }
.burst { grid-column: 10 / span 3; grid-row: 2 / span 5; }
.verdict-caption { grid-column: 1 / span 6; grid-row: 2 / span 6; }
.maze { grid-column: 7 / span 3; grid-row: 3 / span 5; }
.speech { grid-column: 9 / span 4; grid-row: 7 / span 4; }

.violet { background: var(--violet); }
.ink { background: var(--ink); }
.cyan-outline { border-color: var(--cyan); box-shadow: 10px 10px 0 var(--magenta); }

.halftone {
  background-image: radial-gradient(circle, var(--magenta) 0 3px, transparent 3.5px);
  background-size: 16px 16px;
}

.warning {
  display: inline-block;
  background: var(--red);
  color: var(--paper);
  border: 3px solid var(--ink);
  padding: 8px 14px;
  font-family: var(--mono);
  transform: rotate(-7deg);
}

.yellow-burst {
  display: grid;
  place-items: center;
  background: var(--yellow);
  color: var(--ink);
  clip-path: polygon(50% 0, 61% 30%, 96% 18%, 74% 48%, 100% 70%, 65% 68%, 58% 100%, 42% 70%, 8% 96%, 26% 58%, 0 38%, 36% 36%);
  font-weight: 700;
  font-size: 36px;
}

.jigsaw-tab {
  position: absolute;
  right: -38px;
  top: 42%;
  width: 82px;
  height: 82px;
  border-radius: 50%;
  background: var(--paper);
  border: 3px solid var(--ink);
}

.spring-wire {
  width: 100%;
  height: 180px;
  margin-top: 20px;
}

.spring-wire path {
  fill: none;
  stroke: var(--magenta);
  stroke-width: 9;
  stroke-linecap: round;
  filter: drop-shadow(0 0 10px var(--magenta));
  stroke-dasharray: 24 13;
  animation: wireRun 1.6s linear infinite;
}

@keyframes wireRun { to { stroke-dashoffset: -74; } }

.paper-cut { background: var(--paper); color: var(--ink); }
.tab-shape {
  width: 100%;
  aspect-ratio: 1;
  margin-bottom: 20px;
  background: var(--violet);
  clip-path: polygon(0 0, 100% 0, 100% 35%, 82% 35%, 82% 65%, 100% 65%, 100% 100%, 0 100%, 0 65%, 18% 65%, 18% 35%, 0 35%);
}

.red-mark::after {
  content: '';
  position: absolute;
  inset: 16px;
  background: linear-gradient(45deg, transparent 45%, var(--red) 45% 55%, transparent 55%), linear-gradient(-45deg, transparent 45%, var(--red) 45% 55%, transparent 55%);
  opacity: .85;
}

.label-box {
  display: inline-block;
  margin-bottom: 18px;
  background: var(--paper);
  color: var(--ink);
  border: 4px solid var(--ink);
  box-shadow: 5px 5px 0 var(--cyan);
  padding: 10px 16px;
  font-weight: 700;
}

.maze-bars { position: absolute; inset: 28px; }
.maze-bars i { position: absolute; display: block; background: var(--cyan); box-shadow: 0 0 12px var(--cyan); }
.maze-bars i:nth-child(1) { left: 0; top: 0; width: 80%; height: 10px; }
.maze-bars i:nth-child(2) { right: 0; top: 0; width: 10px; height: 76%; }
.maze-bars i:nth-child(3) { left: 12%; top: 38%; width: 70%; height: 10px; }
.maze-bars i:nth-child(4) { left: 12%; top: 38%; width: 10px; height: 48%; }
.maze-bars i:nth-child(5) { left: 12%; bottom: 0; width: 72%; height: 10px; }

.bubble {
  width: 76%;
  aspect-ratio: 2.2;
  background: var(--paper);
  border: 4px solid var(--ink);
  border-radius: 50%;
  box-shadow: 8px 8px 0 var(--red);
}

.bubble::after {
  content: '';
  position: absolute;
  left: 60px;
  top: 92px;
  border: 24px solid transparent;
  border-top-color: var(--paper);
  transform: rotate(22deg);
}

.chapter-ruling { grid-auto-rows: 72px; }
.puzzle-lockup {
  grid-column: 1 / span 6;
  grid-row: 2 / span 6;
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: 0;
  filter: drop-shadow(0 0 22px rgba(0,240,255,.55));
}

.lock-piece {
  display: grid;
  place-items: center;
  min-height: 190px;
  font-family: var(--mono);
  font-weight: 700;
  color: var(--cyan);
  background: var(--ink);
  box-shadow: none;
}

.p1 { border-radius: 0 55px 0 0; }
.p2 { background: var(--violet); border-radius: 55px 0 0 0; }
.p3 { background: var(--violet); border-radius: 0 0 55px 0; }
.p4 { border-radius: 0 0 0 55px; }

.final-verdict {
  grid-column: 7 / span 6;
  grid-row: 3 / span 5;
  padding: 34px;
  background:
    radial-gradient(circle, rgba(5,4,10,.9) 0 3px, transparent 3.5px) 0 0 / 18px 18px,
    var(--yellow);
  color: var(--ink);
  border-color: var(--cyan);
  box-shadow: 12px 12px 0 var(--magenta), -8px -8px 0 var(--cyan);
}

.final-verdict .mono-tag { color: var(--red); }

[data-coord]::before {
  content: attr(data-coord);
  position: absolute;
  top: 8px;
  right: 10px;
  font-family: var(--mono);
  font-size: 11px;
  color: var(--red);
  letter-spacing: .12em;
}

[data-coord].resolved::before { color: var(--cyan); }

@media (max-width: 860px) {
  .case-strip { width: 30px; font-size: 8px; }
  .proof-wall { width: calc(100vw - 42px); margin-left: 38px; padding: 12px; }
  .chapter { display: block; min-height: auto; }
  .panel, .final-verdict, .puzzle-lockup { margin: 16px 0; min-height: 220px; }
  .puzzle-lockup { display: grid; }
  .giant-piece { width: 120px; height: 120px; }
}
