:root {
    --black: #100B08;
    --brown: #2B1A12;
    --vellum: #E7D2A0;
    --gold: #C79235;
    --wax: #8E1F1C;
    --plum: #30172A;
    --pewter: #7F95A3;
    --ash: #B5A995;
    --title: 'UnifrakturMaguntia', cursive;
    --serif: 'Cormorant Garamond', serif;
    --fell: 'IM Fell English', serif;
    --mono: 'JetBrains Mono', monospace;
    --ui: 'Inter', sans-serif;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
    margin: 0;
    color: var(--vellum);
    background:
        radial-gradient(circle at 70% 12%, rgba(199, 146, 53, .18), transparent 22rem),
        radial-gradient(circle at 20% 80%, rgba(48, 23, 42, .58), transparent 28rem),
        linear-gradient(115deg, var(--black), var(--brown) 52%, var(--black));
    font-family: var(--serif);
    overflow-x: hidden;
}

button, a { font: inherit; color: inherit; }

.grain {
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 60;
    opacity: .18;
    background-image: repeating-radial-gradient(circle at 20% 30%, rgba(231, 210, 160, .14) 0 1px, transparent 1px 4px), repeating-linear-gradient(92deg, transparent 0 9px, rgba(0,0,0,.22) 10px 11px);
    mix-blend-mode: overlay;
}

.candle-wander {
    position: fixed;
    width: 22rem;
    height: 22rem;
    border-radius: 50%;
    pointer-events: none;
    z-index: 55;
    background: radial-gradient(circle, rgba(199, 146, 53, .42), rgba(199, 146, 53, .13) 35%, transparent 70%);
    filter: blur(8px);
    transform: translate3d(12vw, 8vh, 0);
    transition: opacity .8s ease;
}

body.moonlit .candle-wander { opacity: .08; }
body.moonlit { background: radial-gradient(circle at 68% 24%, rgba(127, 149, 163, .34), transparent 28rem), linear-gradient(120deg, #100B08, #30172A 55%, #100B08); }

.docket-nav {
    position: fixed;
    right: 1.2rem;
    top: 50%;
    transform: translateY(-50%);
    z-index: 70;
    display: grid;
    gap: .45rem;
    font-family: var(--mono);
    font-size: .7rem;
}

.docket-nav a {
    width: 2rem;
    height: 2rem;
    display: grid;
    place-items: center;
    text-decoration: none;
    border: 1px solid rgba(231, 210, 160, .32);
    background: rgba(16, 11, 8, .68);
    color: var(--ash);
    transition: .3s ease;
}

.docket-nav a.active, .docket-nav a:hover { color: var(--gold); border-color: var(--wax); box-shadow: 0 0 1rem rgba(142,31,28,.32); }

.proceeding {
    min-height: 100vh;
    position: relative;
    display: grid;
    place-items: center;
    padding: 7rem 5vw 5rem;
    overflow: hidden;
    isolation: isolate;
}

.proceeding::before {
    content: attr(data-proceeding);
    position: absolute;
    left: 4vw;
    bottom: 3vh;
    font-family: var(--mono);
    font-size: .65rem;
    letter-spacing: .22em;
    color: rgba(181, 169, 149, .42);
    writing-mode: vertical-rl;
}

.judge-rail {
    position: absolute;
    top: 11vh;
    left: 8vw;
    right: 12vw;
    height: 3.3rem;
    transform: rotate(-1.6deg);
    border-top: 2px solid rgba(231, 210, 160, .22);
    border-bottom: 1px solid rgba(199, 146, 53, .42);
    background: linear-gradient(90deg, transparent, rgba(43, 26, 18, .78), transparent);
    display: grid;
    place-items: center;
    box-shadow: 0 1.2rem 2.4rem rgba(0,0,0,.4);
}

.judge-rail span { font-family: var(--fell); letter-spacing: .12em; color: var(--ash); font-size: .86rem; }

.bench-lines {
    position: absolute;
    inset: 0;
    background: repeating-linear-gradient(168deg, transparent 0 3.6rem, rgba(231,210,160,.045) 3.7rem 3.78rem), repeating-linear-gradient(86deg, rgba(0,0,0,.16) 0 .15rem, transparent .15rem 7rem);
    opacity: .65;
    transform: rotate(-2deg) scale(1.05);
}

.summons-paper, .deposition-sheet, .verdict-page, .testimony-column {
    background:
        radial-gradient(circle at 28% 16%, rgba(142,31,28,.11), transparent 9rem),
        repeating-linear-gradient(176deg, rgba(43,26,18,.05) 0 1px, transparent 1px 12px),
        var(--vellum);
    color: var(--brown);
    box-shadow: 0 2.5rem 5rem rgba(0,0,0,.58), inset 0 0 0 1px rgba(43,26,18,.18), inset 0 0 3rem rgba(43,26,18,.18);
}

.summons-paper {
    position: relative;
    width: min(43rem, 82vw);
    min-height: 31rem;
    padding: 5rem 4rem;
    text-align: center;
    transform: rotate(-4deg) perspective(900px) rotateX(4deg);
    transition: transform 1s cubic-bezier(.2,.8,.2,1), filter .8s ease;
}

.summons-paper.opened { transform: rotate(-1deg) perspective(900px) rotateX(0deg) scale(1.035); filter: brightness(1.08); }

.fold { position: absolute; top: 0; bottom: 0; width: 32%; background: linear-gradient(90deg, rgba(43,26,18,.14), transparent); transition: transform 1s cubic-bezier(.2,.8,.2,1); }
.fold-left { left: 0; transform-origin: left center; }
.fold-right { right: 0; transform-origin: right center; }
.summons-paper.opened .fold-left { transform: rotateY(-18deg); }
.summons-paper.opened .fold-right { transform: rotateY(18deg); }

.clerk-mark { font-family: var(--mono); font-size: .68rem; letter-spacing: .18em; text-transform: uppercase; color: rgba(43,26,18,.64); }

h1, h2 { margin: 0; font-family: var(--title); font-weight: 400; }
h1 { font-size: clamp(4rem, 12vw, 9rem); line-height: .78; color: var(--brown); text-shadow: 0 2px 0 rgba(142,31,28,.4), 0 0 1.4rem rgba(199,146,53,.28); }
h2 { font-size: clamp(2.8rem, 7vw, 6.5rem); line-height: .85; }

.summons-copy { margin: 2rem auto 3rem; max-width: 29rem; font-size: 1.55rem; line-height: 1.2; font-style: italic; }

.wax-seal {
    position: absolute;
    left: 50%;
    bottom: -2.9rem;
    transform: translateX(-50%);
    width: 8.8rem;
    height: 8.8rem;
    border: 0;
    border-radius: 48% 53% 46% 50%;
    background: radial-gradient(circle at 35% 30%, #C79235, #8E1F1C 34%, #30172A 92%);
    box-shadow: 0 1rem 2rem rgba(0,0,0,.45), inset 0 0 0 .55rem rgba(43,26,18,.2), inset 0 0 1.5rem rgba(16,11,8,.58);
    cursor: pointer;
}

.wax-seal span::before { content: 'W'; font-family: var(--title); font-size: 4rem; color: rgba(231,210,160,.5); }
.wax-seal.cracked { animation: crackSeal .7s forwards; }
.wax-seal.cracked::after { content: ''; position: absolute; inset: 18% 48%; background: var(--black); transform: rotate(17deg); box-shadow: 1.1rem 1.8rem 0 rgba(16,11,8,.8), -.8rem 2.8rem 0 rgba(16,11,8,.7); }

@keyframes crackSeal { 55% { transform: translateX(-50%) scale(1.08) rotate(3deg); } 100% { transform: translateX(-50%) scale(.92) rotate(-4deg); filter: saturate(.72); } }

.marginalia { position: absolute; font-family: var(--fell); font-style: italic; color: rgba(181,169,149,.62); }
.left-note { left: 11vw; top: 58vh; transform: rotate(-11deg); }
.right-note { right: 13vw; top: 33vh; transform: rotate(8deg); }

.paper-fan { position: relative; width: min(70rem, 90vw); height: 38rem; }
.deposition-sheet.primary { position: absolute; inset: 3rem 13% 0; padding: 3.5rem; transform: rotate(2deg); z-index: 2; }
.ink-line { font-size: 1.55rem; line-height: 1.35; max-width: 43rem; }
.clause { margin: .5rem .45rem .5rem 0; padding: .7rem .9rem; border: 1px solid rgba(142,31,28,.55); background: transparent; color: var(--wax); font-family: var(--fell); cursor: pointer; }
.clause.active { background: rgba(142,31,28,.14); box-shadow: inset 0 -2px 0 var(--wax); }
.revealed-clause { min-height: 3rem; font-size: 1.4rem; color: var(--brown); font-style: italic; }
.ink-pool { position: absolute; right: 12%; bottom: 12%; width: 4rem; height: 4rem; border-radius: 50%; background: var(--brown); opacity: .18; filter: blur(4px); transform: scale(.4); transition: transform 1.1s ease, opacity 1.1s ease; }
.ink-pool.spread { transform: scale(3.8); opacity: .32; }
.deposition-strip { position: absolute; padding: 1.3rem 3rem; background: var(--vellum); color: var(--brown); font-family: var(--fell); box-shadow: 0 1.2rem 2.8rem rgba(0,0,0,.45); }
.strip-one { left: 0; top: 8rem; transform: rotate(-16deg); }
.strip-two { right: 0; top: 2rem; transform: rotate(13deg); }
.strip-three { right: 8%; bottom: 0; transform: rotate(-7deg); }

.accused-ring { position: relative; width: min(38rem, 78vw); aspect-ratio: 1; border: 1px dashed rgba(231,210,160,.34); border-radius: 50%; animation: turnRing 32s linear infinite; box-shadow: inset 0 0 3rem rgba(142,31,28,.16), 0 0 5rem rgba(0,0,0,.3); }
@keyframes turnRing { to { transform: rotate(360deg); } }
.ring-core { position: absolute; inset: 33%; border-radius: 50%; display: grid; place-items: center; font-family: var(--title); font-size: clamp(2rem, 6vw, 4.4rem); color: var(--wax); background: radial-gradient(circle, rgba(142,31,28,.18), transparent 65%); animation: counterRing 32s linear infinite; }
@keyframes counterRing { to { transform: rotate(-360deg); } }
.name-token { position: absolute; left: 50%; top: 50%; transform: rotate(var(--angle)) translate(18rem) rotate(calc(-1 * var(--angle))); transform-origin: 0 0; border: 0; background: rgba(231,210,160,.9); color: var(--brown); padding: .55rem .8rem; font-family: var(--fell); box-shadow: 0 .6rem 1rem rgba(0,0,0,.34); cursor: pointer; transition: color .25s, background .25s, box-shadow .25s; animation: counterRing 32s linear infinite; }
.name-token.stained { color: var(--vellum); background: var(--wax); box-shadow: 0 0 1.6rem rgba(142,31,28,.65); }
.circle-caption { position: absolute; bottom: 10vh; font-family: var(--fell); color: var(--ash); }

.smoke-columns { width: min(74rem, 90vw); display: grid; grid-template-columns: 1.1fr .9fr; gap: 4rem; transform: rotate(-1deg); }
.testimony-column { padding: 3.5rem; min-height: 26rem; position: relative; }
.testimony-column p { font-size: 1.55rem; line-height: 1.3; }
.contradiction { color: var(--wax); text-decoration: line-through; text-decoration-thickness: 3px; }
.snuffer { margin: 2rem 0; padding: 1rem 1.25rem; border: 1px solid var(--brown); background: var(--brown); color: var(--vellum); font-family: var(--fell); cursor: pointer; }
.moon-panel.revealed { background: linear-gradient(135deg, rgba(127,149,163,.45), rgba(231,210,160,.93)); }
.smoke-shape { position: absolute; width: 24rem; height: 16rem; border-radius: 48% 52% 63% 37%; background: radial-gradient(circle, rgba(181,169,149,.18), transparent 66%); filter: blur(18px); animation: smokeMorph 8s ease-in-out infinite alternate; }
.smoke-shape.one { left: 12vw; top: 28vh; }
.smoke-shape.two { right: 12vw; top: 20vh; animation-delay: -3s; }
.smoke-shape.three { left: 44vw; bottom: 10vh; animation-delay: -5s; }
@keyframes smokeMorph { to { transform: translate(2rem, -3rem) rotate(20deg) scale(1.25); border-radius: 35% 65% 42% 58%; opacity: .62; } }

.verdict-page { position: relative; width: min(48rem, 84vw); padding: 4rem; text-align: center; transform: rotate(1.8deg); z-index: 2; overflow: hidden; }
.verdict-page::before { content: ''; position: absolute; inset: -2rem 48% -2rem auto; width: .18rem; background: rgba(142,31,28,.55); transform: rotate(10deg); opacity: .6; }
.guilty { margin: 1.2rem 0; font-family: var(--title); font-size: clamp(4rem, 15vw, 10rem); line-height: .75; color: var(--wax); position: relative; transition: opacity 1.2s ease, filter 1.2s ease; }
.guilty::after { content: ''; position: absolute; left: 5%; right: 5%; top: 52%; height: .35rem; background: var(--brown); transform: scaleX(0) rotate(-3deg); transform-origin: left; transition: transform 1.4s cubic-bezier(.2,.8,.2,1); }
.verdict-page.unwritten .guilty { opacity: .08; filter: blur(2px); }
.verdict-page.unwritten .guilty::after { transform: scaleX(1) rotate(-3deg); }
.survivor { font-family: var(--title); font-size: clamp(2.6rem, 8vw, 6rem); color: var(--brown); opacity: .08; transition: opacity 1.4s ease 1s; }
.verdict-page.unwritten .survivor { opacity: 1; }
.verdict-page p:last-child { font-size: 1.35rem; }
.clearing span { position: absolute; bottom: -5vh; width: .35rem; height: 60vh; background: linear-gradient(var(--pewter), transparent); opacity: .38; transform: rotate(var(--r, 6deg)); }
.clearing span:nth-child(1) { left: 14vw; --r: -8deg; }
.clearing span:nth-child(2) { left: 28vw; --r: 5deg; }
.clearing span:nth-child(3) { right: 24vw; --r: -3deg; }
.clearing span:nth-child(4) { right: 10vw; --r: 9deg; }

@media (max-width: 780px) {
    .proceeding { padding: 6rem 1rem 4rem; }
    .summons-paper { padding: 4rem 1.4rem; width: 88vw; }
    .paper-fan { height: auto; min-height: 47rem; }
    .deposition-sheet.primary { inset: 2rem 0 auto; padding: 2rem; }
    .deposition-strip { display: none; }
    .name-token { transform: rotate(var(--angle)) translate(38vw) rotate(calc(-1 * var(--angle))); }
    .smoke-columns { grid-template-columns: 1fr; gap: 1.2rem; }
    .testimony-column, .verdict-page { padding: 2rem; }
    .docket-nav { right: .4rem; }
}
