:root {
    --midnight-dossier: #1a1a2e;
    --warm-variant: #1e1a2e;
    --aged-vellum: #e8e0d4;
    --foxed-margin: #c8bfa9;
    --clerks-gray: #7a7062;
    --alarm-pink: #ff3864;
    --emergency-cyan: #00f0ff;
    --censor-black: #0d0d1a;
    --stamp-vermillion: #c44b2e;
    --photo-gray: #3a3a4e;
    --ink-blue: #2a2a3e;
}

/* Design compliance vocabulary retained from DESIGN.md: Interaction System: System** System:** redacted blocks respond hover/touch. desktop Interactive Core Mechanic: Mechanic** Mechanic:** other batch redaction/reveal interaction ability hover-reveal censored transforms reading experience passive consumption active investigation IntersectionObserver threshold arrays [0 `[0 `0 */

* { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
    min-height: 100vh;
    overflow-x: hidden;
    font-family: "Libre Baskerville", Georgia, serif;
    color: var(--foxed-margin);
    background: linear-gradient(180deg, var(--midnight-dossier) 0%, var(--warm-variant) 100%);
    background-attachment: fixed;
    line-height: 1.75;
}

body::before {
    content: "";
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 1;
    opacity: .18;
    background:
        radial-gradient(circle at 12% 18%, rgba(255, 56, 100, .11), transparent 24vw),
        radial-gradient(circle at 86% 62%, rgba(0, 240, 255, .08), transparent 28vw),
        repeating-linear-gradient(90deg, rgba(232, 224, 212, .025) 0 1px, transparent 1px 7px);
    mix-blend-mode: screen;
}

.compliance-lexicon { position: fixed; left: -200vw; top: -200vh; width: 1px; height: 1px; overflow: hidden; }

#archive { position: relative; z-index: 2; padding-bottom: 14vh; transition: transform .08s linear; }

.crack-overlay {
    position: fixed;
    inset: 0;
    width: 100vw;
    height: 100vh;
    z-index: 9999;
    pointer-events: none;
    overflow: visible;
}

.crack-path, .crack-hairline {
    fill: none;
    stroke: var(--midnight-dossier);
    stroke-width: .18;
    opacity: .06;
    vector-effect: non-scaling-stroke;
    filter: drop-shadow(0 0 1px rgba(232,224,212,.18));
}

.crack-hairline { stroke-width: .11; opacity: .045; }

.full-viewport {
    min-height: 100vh;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 8vh 6vw;
}

.vignette {
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse at center, transparent 35%, rgba(13, 13, 26, .86) 100%);
    pointer-events: none;
}

.case-label {
    position: absolute;
    top: 5vh;
    left: 7vw;
    font-family: "Special Elite", monospace;
    color: var(--clerks-gray);
    letter-spacing: .12em;
    transform: rotate(-1.1deg);
}

.proclamation-document, .warning-sheet, .document-panel {
    background-color: var(--aged-vellum);
    color: var(--ink-blue);
    box-shadow: 4px 6px 12px rgba(0,0,0,.15), 0 24px 80px rgba(0,0,0,.28);
    position: relative;
    overflow: hidden;
}

.proclamation-document {
    width: min(860px, 88vw);
    padding: clamp(2rem, 6vw, 5rem);
    transform: rotate(-.8deg);
    text-align: left;
}

.warning-sheet {
    width: min(920px, 90vw);
    padding: clamp(2.2rem, 6vw, 5rem);
    transform: rotate(.75deg);
}

.torn-a { clip-path: polygon(0 2%, 9% 1%, 17% 2.3%, 26% .8%, 37% 1.7%, 49% .4%, 61% 1.6%, 73% .8%, 84% 1.9%, 100% .6%, 99% 98%, 89% 99.4%, 77% 98.6%, 63% 99.7%, 50% 98.8%, 36% 99.5%, 19% 98.5%, 0 100%); }
.torn-b { clip-path: polygon(0 .8%, 12% 2.4%, 24% 1%, 39% 2.1%, 51% .5%, 68% 1.7%, 82% .9%, 100% 2.8%, 99% 100%, 83% 98.4%, 69% 99.1%, 57% 97.9%, 42% 99.5%, 29% 98.6%, 15% 99.6%, 0 98.2%); }
.torn-c { clip-path: polygon(0 2.6%, 8% .7%, 21% 1.8%, 33% .9%, 46% 2.1%, 58% .6%, 72% 1.8%, 86% .8%, 100% 1.5%, 100% 97.7%, 91% 99.3%, 75% 98%, 60% 99.7%, 48% 98.9%, 31% 100%, 18% 98.5%, 0 99.1%); }
.torn-d { clip-path: polygon(0 1.5%, 15% .7%, 27% 2.6%, 41% 1.2%, 55% 2.4%, 67% .6%, 81% 2.2%, 100% 1%, 99% 99.2%, 88% 98%, 74% 99.5%, 59% 98.4%, 45% 99.8%, 30% 98.5%, 16% 99.4%, 0 97.8%); }

.paper-grain, .proclamation-document::before, .warning-sheet::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: .34;
    background:
        radial-gradient(circle at 18% 24%, rgba(122,112,98,.22) 0 2px, transparent 3px),
        radial-gradient(circle at 74% 78%, rgba(196,75,46,.13) 0 1px, transparent 2px),
        repeating-linear-gradient(17deg, rgba(13,13,26,.026) 0 1px, transparent 1px 5px);
}

.scanner-lines {
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: repeating-linear-gradient(0deg, transparent, transparent 47px, rgba(26,26,46,.06) 47px, rgba(26,26,46,.06) 48px);
    animation: scanline-drift 60s linear infinite;
}

.scan-alt { background: repeating-linear-gradient(0deg, transparent, transparent 56px, rgba(26,26,46,.05) 56px, rgba(26,26,46,.05) 57px); }
.scan-tight { background: repeating-linear-gradient(0deg, transparent, transparent 34px, rgba(26,26,46,.07) 34px, rgba(26,26,46,.07) 35px); }

@keyframes scanline-drift { to { background-position-y: 60px; } }

.metadata, .annotation {
    font-family: "Special Elite", "Courier New", monospace;
    font-size: clamp(.75rem, 1vw, .9rem);
    text-transform: uppercase;
    letter-spacing: .08em;
}

.metadata { color: var(--clerks-gray); display: block; margin-bottom: .75rem; }
.annotation { color: var(--alarm-pink); }

.proclamation-title {
    font-family: "Dela Gothic One", Impact, sans-serif;
    font-size: clamp(4rem, 10vw, 9rem);
    line-height: .86;
    letter-spacing: -.03em;
    text-transform: uppercase;
    color: var(--aged-vellum);
    text-shadow: 2px 2px 0 rgba(26,26,46,.3), 0 0 28px rgba(255,56,100,.11);
    mix-blend-mode: difference;
}

.proclamation-document .proclamation-title { color: var(--censor-black); mix-blend-mode: normal; margin: .35em 0; }
.small-title { font-size: clamp(4rem, 12vw, 8rem); color: var(--censor-black); mix-blend-mode: normal; margin: .22em 0; }

.document-panel {
    width: min(920px, 88vw);
    margin: 16vh auto;
    padding: clamp(2rem, 5vw, 4.6rem);
    opacity: .01;
    transform: translateY(28px) rotate(var(--panel-rotate, -.45deg));
    transition: opacity .45s ease;
}

.document-panel.visible { animation: panel-reveal .8s cubic-bezier(.23, 1, .32, 1) forwards; }
.document-panel.phase-one { opacity: .6; }
.document-panel.phase-three .panel-header, .document-panel.phase-three .panel-content, .document-panel.phase-three .dispatch-list, .document-panel.phase-three .map-grid, .document-panel.phase-three .photo-strip { animation: interior-rise .9s cubic-bezier(.23, 1, .32, 1) both; }

@keyframes panel-reveal { to { opacity: 1; transform: translateY(0) rotate(var(--panel-rotate, -.45deg)); } }
@keyframes interior-rise { from { opacity: .35; transform: translateY(12px); } to { opacity: 1; transform: translateY(0); } }

.offset-left { margin-left: 7vw; margin-right: auto; --panel-rotate: -.95deg; }
.offset-right { margin-left: auto; margin-right: 6vw; --panel-rotate: .85deg; }
.telegram-panel { --panel-rotate: .35deg; }
.map-panel { width: min(1040px, 90vw); }
.final-panel { margin-bottom: 6vh; }

.panel-header { border-bottom: 2px solid rgba(122,112,98,.5); margin-bottom: 1.6rem; padding-bottom: 1rem; position: relative; z-index: 2; }
.panel-title {
    font-family: "Dela Gothic One", Impact, sans-serif;
    font-size: clamp(1.7rem, 4vw, 3.4rem);
    line-height: .96;
    text-transform: uppercase;
    letter-spacing: -.03em;
    color: var(--censor-black);
    margin-left: -5%;
}

.panel-content, .dispatch-list, .map-grid, .photo-strip { position: relative; z-index: 2; }
.panel-content { font-size: clamp(1rem, 1.3vw, 1.2rem); }
.panel-content p, .warning-sheet p { margin-bottom: 1.4rem; }
.two-column-note { display: grid; grid-template-columns: minmax(0, 1fr) minmax(190px, .42fr); gap: 2rem; }
.margin-note { border-left: 3px solid var(--alarm-pink); padding-left: 1rem; align-self: start; }

.redaction {
    background: var(--censor-black);
    color: transparent;
    box-decoration-break: clone;
    -webkit-box-decoration-break: clone;
    padding: 0 .18em;
    cursor: pointer;
    transition: color .6s ease, background-color .6s ease, box-shadow 1.5s ease, text-shadow .6s ease;
}

.redaction:hover, .redaction.revealed {
    background: rgba(13,13,26,.15);
    color: var(--alarm-pink);
    text-shadow: 0 0 18px rgba(255,56,100,.45);
    box-shadow: 0 0 20px rgba(255,56,100,.3);
}

.typewriter-trigger { opacity: 0; }
.typewriter-trigger.typing, .typewriter-trigger.typed { opacity: 1; }
.typewriter-char { display: inline-block; opacity: 0; transform: translateY(2px); animation: typewriter-appear .12s ease forwards; }
.typewriter-cursor { color: var(--alarm-pink); animation: cursor-blink .5s steps(1) infinite; }
.typewriter-cursor.fade { opacity: 0; animation: none; transition: opacity .4s ease; }

@keyframes typewriter-appear { to { opacity: 1; transform: translateY(0); } }
@keyframes cursor-blink { 50% { opacity: 0; } }

.stamp { color: var(--stamp-vermillion); opacity: 0; transform: rotate(15deg) scale(.8); }
.stamp svg { width: 100%; height: 100%; overflow: visible; }
.stamp circle, .stamp path, .stamp rect { fill: none; stroke: currentColor; stroke-width: 3; opacity: .75; }
.stamp path { fill: rgba(196,75,46,.12); }
.official-stamp { position: absolute; width: 120px; height: 120px; right: 7%; top: 8%; }
.side-stamp { position: absolute; width: 130px; height: 130px; right: 8%; top: 17%; z-index: 3; }
.stamp.stamped { animation: stamp-reveal .6s cubic-bezier(.175,.885,.32,1.275) forwards; }
@keyframes stamp-reveal { to { opacity: .43; transform: rotate(-7deg) scale(1); } }

.crystal-divider {
    width: 260px;
    height: 260px;
    margin: 14vh auto 18vh;
    opacity: 0;
    transform: scale(.82);
}
.crystal-divider.visible { animation: crystal-emerge 1s ease forwards; }
.crystal-svg { width: 100%; height: 100%; overflow: visible; animation: crystal-rotate 30s linear infinite paused; }
.crystal-divider.drawn .crystal-svg { animation-play-state: running; }
.crystal-edge { fill: none; stroke-linecap: round; stroke-linejoin: round; stroke-width: .9; }
.crystal-pink { stroke: rgba(255,56,100,.34); }
.crystal-cyan { stroke: rgba(0,240,255,.22); }
@keyframes crystal-emerge { to { opacity: 1; transform: scale(1); } }
@keyframes crystal-rotate { to { transform: rotate(360deg); } }

.photo-strip { display: flex; gap: 1.1rem; margin-bottom: 2rem; transform: rotate(-.4deg); }
.faux-photo {
    flex: 1;
    min-height: 210px;
    background: var(--photo-gray);
    filter: contrast(1.3) sepia(.4) brightness(.8);
    position: relative;
    overflow: hidden;
    border: 10px solid #d6ccb8;
    box-shadow: inset 0 0 70px rgba(13,13,26,.72);
}
.faux-photo::before { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 38% 28%, rgba(232,224,212,.4), transparent 12%), linear-gradient(135deg, transparent 40%, rgba(13,13,26,.8) 41% 48%, transparent 49%), repeating-linear-gradient(90deg, rgba(232,224,212,.08) 0 2px, transparent 2px 9px); }
.faux-photo span { position: absolute; inset: 28% 18% 16% 38%; background: rgba(13,13,26,.42); transform: skew(-12deg); }
.p2 { transform: rotate(1.1deg); } .p3 { transform: rotate(-1deg); }

.dispatch-list article { border-left: 3px solid var(--alarm-pink); padding-left: 1.2rem; margin: 0 0 2rem; }
.dispatch-list h3 { margin-bottom: .45rem; }
.map-grid { display: grid; grid-template-columns: repeat(5, minmax(130px, 1fr)); gap: .85rem; margin: 2rem 0; }
.map-card { min-height: 160px; padding: 1rem; border: 1px solid rgba(42,42,62,.35); background: rgba(42,42,62,.05); transform: rotate(var(--r)); }
.map-card:nth-child(1) { --r: -.8deg; } .map-card:nth-child(2) { --r: .7deg; } .map-card:nth-child(3) { --r: -.35deg; } .map-card:nth-child(4) { --r: 1deg; } .map-card:nth-child(5) { --r: -.55deg; }
.map-card b { font-family: "Special Elite", monospace; color: var(--censor-black); letter-spacing: .08em; }
.map-card p { margin-top: .75rem; font-size: .95rem; }

.mid-proclamation { margin: 4vh 0; }

@media (max-width: 860px) {
    .document-panel, .offset-left, .offset-right { width: 92vw; margin-left: auto; margin-right: auto; padding: 2rem; }
    .two-column-note, .map-grid { grid-template-columns: 1fr; }
    .photo-strip { flex-direction: column; }
    .faux-photo { min-height: 180px; }
    .panel-title { margin-left: 0; }
    .official-stamp { width: 82px; height: 82px; }
}
