:root {
  /* compliance tokens: Mono* KR* */
  --night: #10131A;
  --curfew: #A9D8FF;
  --cyan: #4DB7E8;
  --clay: #7B5E3B;
  --paper: #F2EAD7;
  --vermillion: #E5533D;
  --fog: #D8E9F2;
  --border: 3px solid #10131A;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  min-height: 100vh;
  background: var(--night);
  color: var(--night);
  font-family: "IBM Plex Sans KR", Inter, sans-serif;
  overflow-x: hidden;
}

.fog-field {
  position: fixed;
  inset: -20vh -25vw;
  z-index: -3;
  background:
    radial-gradient(circle at 20% 30%, rgba(169,216,255,.9), transparent 26%),
    radial-gradient(circle at 72% 18%, rgba(77,183,232,.6), transparent 24%),
    radial-gradient(circle at 56% 78%, rgba(216,233,242,.7), transparent 31%),
    linear-gradient(135deg, #10131A 0%, #18202b 46%, #7B5E3B 140%);
  filter: blur(16px) saturate(1.04);
  animation: fogDrift 28s ease-in-out infinite alternate;
}

.scanline {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 10;
  background: repeating-linear-gradient(to bottom, rgba(242,234,215,.05) 0 1px, transparent 1px 7px);
  mix-blend-mode: overlay;
}

.field-log {
  position: fixed;
  left: 18px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 12;
  display: grid;
  gap: 10px;
}

.field-log a {
  font-family: "IBM Plex Mono", monospace;
  color: var(--paper);
  background: var(--night);
  border: 2px solid var(--paper);
  box-shadow: 5px 5px 0 var(--clay);
  padding: 9px 8px;
  text-decoration: none;
  font-size: 12px;
  letter-spacing: .08em;
  transition: transform .2s ease, background .2s ease, color .2s ease;
}

.field-log a.active,
.field-log a:hover {
  background: var(--cyan);
  color: var(--night);
  transform: translateX(5px) rotate(-2deg);
}

.curfew-route {
  position: relative;
  width: min(1480px, 100%);
  margin: 0 auto;
  padding: 0 clamp(18px, 4vw, 70px);
}

.checkpoint {
  min-height: 100vh;
  position: relative;
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: clamp(14px, 2vw, 28px);
  align-items: center;
  padding: clamp(72px, 9vh, 120px) 0;
}

.evidence-panel {
  position: relative;
  border: var(--border);
  box-shadow: 12px 12px 0 var(--clay);
}

.evidence-panel::before,
.evidence-panel::after {
  content: "";
  position: absolute;
  width: 24px;
  height: 24px;
  border-color: var(--cyan);
  pointer-events: none;
}

.evidence-panel::before {
  top: 10px;
  left: 10px;
  border-left: 3px solid;
  border-top: 3px solid;
}

.evidence-panel::after {
  right: 10px;
  bottom: 10px;
  border-right: 3px solid;
  border-bottom: 3px solid;
}

.timestamp-box {
  position: absolute;
  right: clamp(12px, 5vw, 90px);
  top: 28px;
  font-family: "IBM Plex Mono", monospace;
  color: var(--curfew);
  background: rgba(16,19,26,.86);
  border: 2px solid var(--cyan);
  padding: 11px 14px;
  letter-spacing: .08em;
  animation: flicker 1.8s steps(2, end) infinite;
}

.alarm-panel {
  grid-column: 1 / 10;
  background: var(--paper);
  padding: clamp(24px, 5vw, 70px);
  transform: rotate(-1.5deg) translateX(-6vw);
  clip-path: polygon(0 4%, 96% 0, 100% 88%, 88% 100%, 3% 96%);
  min-height: 48vh;
  display: grid;
  align-content: center;
}

.alarm-panel h1 {
  margin: 0;
  font-family: "Black Han Sans", sans-serif;
  font-size: clamp(68px, 15vw, 228px);
  line-height: .82;
  letter-spacing: -.06em;
  text-shadow: 5px 5px 0 var(--curfew);
  word-break: keep-all;
}

.stamp-label,
.chapter-kicker,
.mono {
  font-family: "IBM Plex Mono", monospace;
  letter-spacing: .1em;
}

.stamp-label {
  display: inline-block;
  width: max-content;
  margin: 0 0 12px;
  padding: 8px 12px;
  background: var(--vermillion);
  border: 3px solid var(--night);
  transform: rotate(2deg);
  font-weight: 700;
}

.slash-mark {
  position: absolute;
  right: 7%;
  top: 14%;
  width: 34px;
  height: 72%;
  background: var(--vermillion);
  border: 3px solid var(--night);
  transform: rotate(18deg);
  opacity: .9;
}

.signal-arcs {
  grid-column: 6 / 13;
  grid-row: 1;
  width: 100%;
  align-self: end;
  overflow: visible;
}

.signal-arcs path {
  fill: none;
  stroke: var(--cyan);
  stroke-width: 8;
  stroke-linecap: round;
  stroke-dasharray: 30 18;
  filter: drop-shadow(4px 4px 0 #10131A);
  animation: signalDash 6s linear infinite reverse;
}

.signal-arcs .arc-two { stroke: var(--curfew); animation-duration: 8s; }
.signal-arcs .arc-three { stroke-width: 5; opacity: .8; animation-direction: normal; }
.node { fill: var(--paper); stroke: var(--night); stroke-width: 5; animation: pulseNode 2.8s ease-in-out infinite; }
.node-b { animation-delay: .6s; }
.node-c { animation-delay: 1.1s; }

.note-card {
  grid-column: 8 / 12;
  grid-row: 1;
  align-self: end;
  background: var(--fog);
  padding: 22px;
  transform: rotate(1.8deg) translateY(34px);
  font-size: clamp(16px, 1.5vw, 21px);
}

.note-card b { display: block; font-family: "Black Han Sans", sans-serif; font-size: 34px; margin-bottom: 8px; }

.path-divider {
  height: 160px;
  margin: -70px 0;
  position: relative;
  z-index: 1;
}

.path-divider svg { width: 100%; height: 100%; overflow: visible; }
.path-divider path { fill: none; stroke: var(--paper); stroke-width: 8; stroke-linecap: round; stroke-dasharray: 18 26; filter: drop-shadow(6px 6px 0 var(--clay)); }

.order h2,
.street h2,
.afterimage h2 {
  font-family: "Black Han Sans", sans-serif;
  font-size: clamp(42px, 8vw, 118px);
  line-height: .95;
  letter-spacing: -.04em;
  margin: 0;
}

.order > .chapter-kicker {
  grid-column: 2 / 5;
  color: var(--cyan);
  align-self: end;
  background: var(--night);
  border: 2px solid var(--cyan);
  padding: 12px;
  width: max-content;
}

.order > h2 {
  grid-column: 3 / 11;
  color: var(--paper);
  text-shadow: 6px 6px 0 var(--clay);
  transform: rotate(1deg);
}

.proclamation-stack {
  grid-column: 2 / 12;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  align-items: stretch;
}

.proclamation {
  background: var(--paper);
  padding: 28px;
  min-height: 330px;
}

.proclamation h3 {
  font-family: "Black Han Sans", sans-serif;
  font-size: clamp(30px, 4vw, 56px);
  line-height: .95;
  margin: 12px 0 18px;
}

.proclamation p:not(.mono) { font-size: 18px; line-height: 1.65; }
.card-one { transform: rotate(-2deg); }
.card-two { transform: rotate(1.4deg) translateY(26px); background: var(--fog); }
.card-three { transform: rotate(-.6deg) translateY(-16px); }

.timing-bars { display: grid; gap: 8px; margin: 22px 0; }
.timing-bars span { height: 18px; background: var(--cyan); border: 2px solid var(--night); box-shadow: 5px 5px 0 var(--clay); }
.timing-bars span:nth-child(2) { width: 72%; background: var(--vermillion); }
.timing-bars span:nth-child(3) { width: 88%; }
.timing-bars span:nth-child(4) { width: 54%; background: var(--curfew); }

.node-chain { display: flex; align-items: center; gap: 16px; margin: 32px 0; }
.node-chain i { width: 34px; height: 34px; background: var(--paper); border: var(--border); border-radius: 50%; box-shadow: 4px 4px 0 var(--clay); }
.node-chain i:nth-child(2) { background: var(--vermillion); transform: translateY(-14px); }
.node-chain i:nth-child(3) { background: var(--cyan); }

.counter-strip {
  grid-column: 4 / 10;
  background: var(--night);
  color: var(--paper);
  display: grid;
  grid-template-columns: auto 1fr auto 1fr;
  gap: 14px;
  align-items: center;
  padding: 18px 24px;
  font-family: "IBM Plex Mono", monospace;
  transform: rotate(-1deg);
}

.counter-strip strong,
.ledger-grid strong { color: var(--cyan); font-size: clamp(32px, 5vw, 72px); font-family: "IBM Plex Mono", monospace; }

.street { align-items: stretch; }
.map-stage { grid-column: 1 / 9; position: relative; align-self: center; min-height: 680px; }
.curfew-map { width: 100%; height: 100%; overflow: visible; }
.map-blob { fill: rgba(169,216,255,.78); stroke: var(--night); stroke-width: 8; filter: drop-shadow(16px 16px 0 var(--clay)); }
.contour { fill: none; stroke: var(--cyan); stroke-width: 5; stroke-dasharray: 14 14; animation: signalDash 13s linear infinite; }
.contour-b { stroke: var(--paper); animation-direction: reverse; }
.route { fill: none; stroke: var(--night); stroke-width: 9; stroke-linecap: round; stroke-dasharray: 2 22; animation: signalDash 10s linear infinite reverse; }
.route-ghost { stroke: var(--vermillion); stroke-width: 6; opacity: .9; }
.bar { fill: var(--vermillion); stroke: var(--night); stroke-width: 4; }
.pulse-dot { fill: var(--paper); stroke: var(--night); stroke-width: 5; animation: pulseNode 2.5s ease-in-out infinite; }
.pulse-dot.delay { animation-delay: 1s; }

.map-label {
  position: absolute;
  font-family: "IBM Plex Mono", monospace;
  font-weight: 700;
  background: var(--paper);
  border: var(--border);
  padding: 8px 10px;
  box-shadow: 6px 6px 0 var(--clay);
}
.label-lost { left: 13%; top: 19%; transform: rotate(-4deg); }
.label-street { right: 7%; top: 44%; transform: rotate(3deg); }
.label-disputed { left: 34%; bottom: 12%; transform: rotate(-2deg); background: var(--vermillion); }

.street-copy {
  grid-column: 7 / 13;
  align-self: center;
  background: var(--paper);
  padding: clamp(26px, 4vw, 56px);
  transform: rotate(1.2deg);
  z-index: 2;
}

.street-copy p:not(.chapter-kicker), .ledger-text { font-size: clamp(17px, 1.55vw, 22px); line-height: 1.75; }
.chapter-kicker { color: var(--vermillion); font-weight: 700; }
.moving-pip { width: 18px; height: 18px; background: var(--cyan); border: var(--border); border-radius: 50%; offset-path: path("M 0 0 C 90 -80, 150 80, 260 -30"); animation: pipRoute 5s ease-in-out infinite alternate; }

.afterimage { padding-bottom: 15vh; }
.ledger {
  grid-column: 2 / 11;
  background: var(--fog);
  padding: clamp(28px, 5vw, 70px);
  background-image: linear-gradient(rgba(77,183,232,.24) 2px, transparent 2px), linear-gradient(90deg, rgba(77,183,232,.24) 2px, transparent 2px);
  background-size: 42px 42px;
  transform: rotate(-.8deg);
}

.ledger-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin: 34px 0;
}

.ledger-grid div {
  background: var(--night);
  color: var(--paper);
  border: var(--border);
  padding: 20px;
  box-shadow: 8px 8px 0 var(--clay);
}

.ledger-grid span { display: block; font-family: "IBM Plex Mono", monospace; margin-bottom: 10px; }
.earth-notes { grid-column: 8 / 13; display: grid; gap: 12px; align-self: end; transform: translateY(-40px) rotate(2deg); }
.tag { width: max-content; background: var(--paper); border: var(--border); padding: 12px 14px; box-shadow: 6px 6px 0 var(--clay); font-family: "IBM Plex Mono", monospace; font-weight: 700; }
.tag.warning { background: var(--vermillion); }

.stamp-ready { opacity: 0; transform: translateY(34px) rotate(var(--r, 0deg)) scale(.98); }
.stamp-live { opacity: 1; transform: translateY(0) rotate(var(--r, 0deg)) scale(1); transition: transform .46s cubic-bezier(.2,1.4,.3,1), opacity .18s linear; }

@keyframes fogDrift { from { transform: translateX(-4vw) scale(1); } to { transform: translateX(5vw) scale(1.05); } }
@keyframes flicker { 0%, 100% { opacity: 1; } 52% { opacity: .62; } 54% { opacity: 1; } 68% { opacity: .8; } }
@keyframes signalDash { to { stroke-dashoffset: -240; } }
@keyframes pulseNode { 0%, 100% { transform: scale(1); opacity: .82; } 50% { transform: scale(1.45); opacity: 1; } }
@keyframes pipRoute { from { offset-distance: 0%; } to { offset-distance: 100%; } }

@media (max-width: 900px) {
  .field-log { left: 8px; transform: none; top: auto; bottom: 10px; grid-auto-flow: column; }
  .field-log a { font-size: 10px; padding: 7px 6px; }
  .checkpoint, .proclamation-stack, .ledger-grid { display: block; }
  .alarm-panel, .note-card, .street-copy, .ledger, .map-stage { margin: 24px 0; transform: none; }
  .signal-arcs { position: absolute; inset: 30% 0 auto; opacity: .55; }
  .proclamation { margin: 20px 0; }
  .counter-strip { grid-template-columns: 1fr 1fr; margin: 30px 0; }
  .map-stage { min-height: 430px; }
  .earth-notes { transform: none; }
}
