/* ===========================================================
   addrenvoy.com — Victorian-engraving dispatch on cold navy
   =========================================================== */

:root {
    --abyss: #070B14;
    --midnight: #0F1A33;
    --prussian: #1A2B52;
    --steel: #3C4A6B;
    --mercury: #A8B5CC;
    --silver: #C9D2E0;
    --brass: #B89968;
    --candle: #E8C99B;

    --ease-engrave: cubic-bezier(0.22, 1, 0.36, 1);
    --dur-slow: 1.2s;
    --dur-deliberate: 1.6s;
    --dur-very-slow: 2s;

    --font-display: 'Major Mono Display', 'Courier New', monospace;
    --font-serif: 'Cormorant Unicase', 'Cormorant Garamond', serif;
    --font-body: 'Space Grotesk', 'Inter', system-ui, sans-serif;
    --font-micro: 'Fraunces', 'Times New Roman', serif;
}

* { box-sizing: border-box; }

html {
    perspective: 1600px;
    transform-style: preserve-3d;
    background: var(--abyss);
    scroll-behavior: smooth;
}

body {
    margin: 0;
    padding: 0;
    background: var(--abyss);
    color: var(--mercury);
    font-family: var(--font-body);
    font-size: 17px;
    line-height: 1.55;
    font-variant-numeric: tabular-nums;
    overflow-x: hidden;
    min-height: 100vh;
    transform-style: preserve-3d;
}

/* Grain / mist overlay */
.abyss-noise {
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 1;
    opacity: 0.04;
    mix-blend-mode: overlay;
    background-image:
        radial-gradient(circle at 20% 30%, rgba(168, 181, 204, 0.08) 0%, transparent 40%),
        radial-gradient(circle at 80% 70%, rgba(168, 181, 204, 0.06) 0%, transparent 50%);
    background-color: var(--mercury);
    filter: contrast(160%) brightness(80%);
}

.abyss-noise::after {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
        repeating-radial-gradient(circle at 10% 20%, rgba(255,255,255,0.04) 0px, transparent 1px, transparent 3px),
        repeating-radial-gradient(circle at 70% 80%, rgba(255,255,255,0.03) 0px, transparent 1px, transparent 4px);
    opacity: 0.6;
}

/* Banknote frame border */
.frame-border {
    position: fixed;
    top: 16px;
    left: 16px;
    right: 16px;
    bottom: 16px;
    width: calc(100vw - 32px);
    height: calc(100vh - 32px);
    pointer-events: none;
    z-index: 100;
}

.frame-rect {
    fill: none;
    stroke: var(--brass);
    stroke-width: 0.6;
    stroke-dasharray: 100;
    stroke-dashoffset: 100;
    animation: ink-in var(--dur-very-slow) var(--ease-engrave) 0.2s forwards;
    filter: drop-shadow(0 0 6px rgba(184, 153, 104, 0.18));
}

@keyframes ink-in {
    to { stroke-dashoffset: 0; }
}

/* ==========================================
   Main dispatch — broken-grid 3D composition
   ========================================== */

.dispatch {
    position: relative;
    transform-style: preserve-3d;
    padding: 0;
    margin: 0;
}

/* Panels — each its own composition */
.panel {
    position: relative;
    min-height: 100vh;
    padding: 14vh 8vw;
    transform-style: preserve-3d;
    isolation: isolate;
}

.panel-inner {
    position: relative;
    background:
        radial-gradient(ellipse at top left, rgba(168, 181, 204, 0.12) 0%, transparent 50%),
        linear-gradient(135deg, var(--midnight) 0%, var(--prussian) 100%);
    border: 1px solid var(--steel);
    padding: 6vh 5vw;
    max-width: 1100px;
    margin: 0 auto;
    transform-style: preserve-3d;
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,0.04),
        0 30px 60px -20px rgba(0,0,0,0.7),
        0 80px 120px -40px rgba(0,0,0,0.6);
}

.panel-inner::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: radial-gradient(circle at -10% -10%, rgba(168,181,204,0.12) 0%, transparent 60%);
    mix-blend-mode: screen;
}

/* Filigree corners */
.filigree {
    position: absolute;
    width: 64px;
    height: 64px;
    pointer-events: none;
}
.filigree-tl { top: -1px; left: -1px; }
.filigree-tr { top: -1px; right: -1px; transform: scaleX(-1); }
.filigree-bl { bottom: -1px; left: -1px; transform: scaleY(-1); }
.filigree-br { bottom: -1px; right: -1px; transform: scale(-1,-1); }

.filigree-path {
    fill: none;
    stroke: var(--brass);
    stroke-width: 0.8;
    stroke-linecap: round;
    stroke-dasharray: 100;
    stroke-dashoffset: 100;
    transition: stroke-dashoffset var(--dur-slow) var(--ease-engrave);
    filter: drop-shadow(0 0 1px rgba(184,153,104,0.4));
}

.panel.is-revealed .filigree-path {
    stroke-dashoffset: 0;
}

/* Mercury halo on each panel */
.panel-inner::after {
    content: "";
    position: absolute;
    top: -40px;
    left: -40px;
    width: 240px;
    height: 240px;
    background: radial-gradient(circle, rgba(168,181,204,0.12) 0%, transparent 70%);
    filter: blur(40px);
    pointer-events: none;
    z-index: -1;
}

/* ==========================================
   Micro labels — engraved Fraunces, small
   ========================================== */
.micro-label {
    font-family: var(--font-micro);
    font-style: italic;
    font-size: 10px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--brass);
    margin: 0 0 1.5em 0;
    filter: drop-shadow(0 1px 0 rgba(255,255,255,0.04));
}

.envoy-number {
    position: absolute;
    top: 24px;
    left: 32px;
    margin: 0;
}

.dispatch-label {
    position: absolute;
    top: 24px;
    right: 32px;
    margin: 0;
}

/* ==========================================
   Panel 1 — Brass Plate
   ========================================== */
.panel-brass-plate {
    z-index: 7;
}

.brass-plate {
    position: relative;
    margin: 4vh auto 4vh;
    padding: 5vh 6vw;
    border: 2px solid var(--brass);
    background:
        radial-gradient(ellipse at center, rgba(184,153,104,0.06) 0%, transparent 70%),
        linear-gradient(180deg, rgba(15,26,51,0.5) 0%, rgba(7,11,20,0.7) 100%);
    text-align: center;
    box-shadow:
        inset 0 0 0 1px rgba(184,153,104,0.4),
        inset 0 0 40px rgba(184,153,104,0.06),
        0 0 60px -10px rgba(184,153,104,0.15);
    overflow: hidden;
}

.brass-plate::before,
.brass-plate::after {
    content: "";
    position: absolute;
    left: 12px;
    right: 12px;
    height: 1px;
    background: var(--brass);
    opacity: 0.55;
}
.brass-plate::before { top: 8px; }
.brass-plate::after { bottom: 8px; }

.guilloche {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    opacity: 0.06;
    pointer-events: none;
}
.guilloche path {
    fill: none;
    stroke: var(--steel);
    stroke-width: 0.4;
}

.ip-engraved {
    font-family: var(--font-display);
    font-size: clamp(2.6rem, 9vw, 8rem);
    color: var(--brass);
    margin: 0;
    letter-spacing: 0.04em;
    line-height: 1;
    text-shadow:
        0 1px 0 rgba(232, 201, 155, 0.4),
        0 -1px 0 rgba(7, 11, 20, 0.8),
        0 0 30px rgba(184, 153, 104, 0.2);
    position: relative;
    z-index: 2;
}

.brass-engraving {
    font-family: var(--font-micro);
    font-style: italic;
    font-size: 11px;
    letter-spacing: 0.28em;
    color: var(--brass);
    margin: 0;
    position: relative;
    z-index: 2;
    opacity: 0.78;
}

.brass-engraving-top {
    margin-bottom: 1.4em;
}

.brass-engraving-bottom {
    margin-top: 1.4em;
}

.opening-line {
    font-family: var(--font-body);
    font-size: clamp(1rem, 1.4vw, 1.15rem);
    color: var(--mercury);
    max-width: 640px;
    margin: 4vh auto 0;
    text-align: center;
    font-style: italic;
    line-height: 1.7;
}

.time-token {
    font-family: var(--font-display);
    font-style: normal;
    color: var(--brass);
    font-size: 0.95em;
    letter-spacing: 0.05em;
}

/* ==========================================
   Panel 2 — Cartouche of Origin
   ========================================== */
.panel-cartouche {
    z-index: 6;
}

.panel-cartouche .panel-inner {
    max-width: 680px;
    margin-left: auto;
    margin-right: 8vw;
    text-align: center;
    padding-top: 8vh;
    padding-bottom: 8vh;
}

.cartouche-oval {
    width: 100%;
    max-width: 480px;
    height: auto;
    margin: 2vh auto 0;
    display: block;
}

.cartouche-ring-outer,
.cartouche-ring-inner {
    fill: none;
    stroke: var(--brass);
    stroke-width: 1;
    filter: drop-shadow(0 1px 0 rgba(255,255,255,0.05));
}

.cartouche-ring-inner {
    stroke-width: 0.6;
    opacity: 0.7;
}

.cartouche-laurel path {
    fill: var(--brass);
    opacity: 0.55;
}

.cartouche-text {
    position: relative;
    margin-top: -210px;
    padding-bottom: 60px;
    z-index: 2;
}

.cartouche-subtitle {
    font-family: var(--font-micro);
    font-style: italic;
    font-size: 10px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--mercury);
    margin: 0 0 0.6em 0;
    opacity: 0.7;
}

.cartouche-city {
    font-family: var(--font-display);
    color: var(--brass);
    font-size: clamp(2rem, 4.6vw, 3.4rem);
    margin: 0;
    letter-spacing: 0.06em;
    text-shadow: 0 0 30px rgba(184,153,104,0.2);
}

.cartouche-coords {
    font-family: var(--font-body);
    font-size: 13px;
    color: var(--silver);
    margin: 0.6em 0 0 0;
    letter-spacing: 0.12em;
}

.connector {
    position: absolute;
    bottom: -80px;
    right: -120px;
    width: 380px;
    height: 200px;
    pointer-events: none;
    opacity: 0.6;
}

.connector-path {
    fill: none;
    stroke: var(--brass);
    stroke-width: 1;
    stroke-dasharray: 100;
    stroke-dashoffset: 100;
    transition: stroke-dashoffset var(--dur-deliberate) var(--ease-engrave);
}

.panel.is-revealed .connector-path {
    stroke-dashoffset: 0;
}

.compass-vignette circle { fill: var(--brass); }
.compass-vignette path { stroke: var(--brass); stroke-width: 1; fill: none; }

/* ==========================================
   Panel 3 — Manifest
   ========================================== */
.panel-manifest {
    z-index: 5;
}

.panel-manifest .panel-inner {
    max-width: 880px;
    margin-left: 6vw;
    margin-right: auto;
    clip-path: polygon(
        0% 2%,
        2% 0%,
        96% 0%,
        100% 4%,
        100% 92%,
        98% 96%,
        96% 100%,
        4% 100%,
        0% 96%
    );
}

.manifest-header {
    border-bottom: 1px solid var(--steel);
    padding-bottom: 2.4em;
    margin-bottom: 2.4em;
}

.panel-heading {
    font-family: var(--font-display);
    color: var(--brass);
    font-size: clamp(1.6rem, 3vw, 2.4rem);
    margin: 0.2em 0 0.4em;
    letter-spacing: 0.04em;
    line-height: 1.1;
}

.manifest-flavor,
.itinerary-flavor {
    font-family: var(--font-body);
    font-style: italic;
    font-size: 14px;
    color: var(--mercury);
    line-height: 1.7;
    max-width: 560px;
    margin: 0;
    opacity: 0.85;
}

.manifest-list {
    margin: 0;
    padding: 0;
}

.manifest-row {
    display: grid;
    grid-template-columns: 220px 1fr;
    gap: 2em;
    padding: 1.4em 0;
    border-bottom: 1px solid rgba(60, 74, 107, 0.5);
    align-items: baseline;
}

.manifest-row:last-child {
    border-bottom: 1px solid rgba(60, 74, 107, 0.5);
}

.manifest-key {
    font-family: var(--font-display);
    font-size: 13px;
    color: var(--brass);
    letter-spacing: 0.1em;
    margin: 0;
    text-transform: lowercase;
}

.manifest-value {
    font-family: var(--font-body);
    font-size: 16px;
    color: var(--mercury);
    margin: 0;
    line-height: 1.6;
}

.manifest-value em {
    color: var(--silver);
    font-style: italic;
    font-family: var(--font-serif);
    font-size: 1.05em;
    letter-spacing: 0.02em;
}

.manifest-attest {
    font-family: var(--font-micro);
    font-style: italic;
    font-size: 11px;
    color: var(--brass);
    margin: 2.4em 0 0 0;
    letter-spacing: 0.18em;
    text-align: right;
    opacity: 0.8;
}

/* ==========================================
   Panel 4 — The Sigil
   ========================================== */
.panel-sigil {
    z-index: 8;
}

.panel-sigil .panel-inner {
    max-width: 720px;
    margin-left: auto;
    margin-right: 6vw;
    text-align: center;
}

.sigil-stage {
    position: relative;
    width: min(440px, 80vw);
    height: min(440px, 80vw);
    margin: 4vh auto;
    perspective: 1200px;
    transform-style: preserve-3d;
}

.sigil-disc {
    position: absolute;
    inset: 0;
    transform-style: preserve-3d;
    transform: rotateY(0deg);
    will-change: transform;
    cursor: none;
}

.sigil-face {
    position: absolute;
    inset: 0;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}

.sigil-face-1 { transform: rotateY(0deg); }
.sigil-face-2 { transform: rotateY(120deg); }
.sigil-face-3 { transform: rotateY(240deg); }

.sigil-svg {
    width: 100%;
    height: 100%;
    filter: drop-shadow(0 8px 20px rgba(7,11,20,0.6));
}

.sigil-rim-outer,
.sigil-rim-inner,
.sigil-rim-thin {
    fill: none;
    stroke: var(--brass);
    stroke-width: 1.4;
    filter: drop-shadow(0 1px 0 rgba(255,255,255,0.05));
}

.sigil-rim-inner {
    stroke-width: 1;
    opacity: 0.7;
}

.sigil-rim-thin {
    stroke-width: 0.6;
    opacity: 0.55;
}

.sigil-ornament path {
    fill: var(--brass);
    opacity: 0.85;
}

.sigil-label-top,
.sigil-label-bottom {
    fill: var(--brass);
    font-family: var(--font-micro);
    font-style: italic;
    font-size: 11px;
    letter-spacing: 0.24em;
}

.sigil-label-main {
    fill: var(--silver);
    font-family: var(--font-display);
    font-size: 18px;
    letter-spacing: 0.06em;
}

.sigil-motto-line {
    fill: var(--brass);
    font-family: var(--font-serif);
    font-style: italic;
    font-size: 20px;
    letter-spacing: 0.08em;
}

.sigil-shadow {
    position: absolute;
    bottom: -10px;
    left: 50%;
    width: 80%;
    height: 30px;
    transform: translateX(-50%);
    background: radial-gradient(ellipse, rgba(7,11,20,0.7) 0%, transparent 70%);
    filter: blur(14px);
    z-index: -1;
}

.sigil-caption {
    font-family: var(--font-body);
    font-style: italic;
    font-size: 14px;
    color: var(--mercury);
    max-width: 480px;
    margin: 2vh auto 0;
    line-height: 1.7;
    opacity: 0.85;
}

/* ==========================================
   Panel 5 — The Itinerary (diagonal)
   ========================================== */
.panel-itinerary {
    z-index: 4;
    min-height: 110vh;
}

.panel-itinerary .panel-inner {
    max-width: 920px;
    margin: 0 auto;
}

.itinerary-header {
    margin-bottom: 2em;
}

.itinerary-map {
    width: 100%;
    height: auto;
    max-height: 360px;
    margin: 1em 0 2em;
    display: block;
}

.itinerary-route {
    fill: none;
    stroke: var(--brass);
    stroke-width: 1;
    stroke-dasharray: 100;
    stroke-dashoffset: 100;
    transition: stroke-dashoffset 2s var(--ease-engrave);
}

.panel.is-revealed .itinerary-route {
    stroke-dashoffset: 0;
}

.hop-anchor {
    fill: var(--brass);
    opacity: 0.9;
}

.hop-cross {
    stroke: var(--brass);
    stroke-width: 0.6;
    fill: none;
}

.hop-ship {
    fill: var(--brass);
    opacity: 0.7;
}

.itinerary-hops {
    list-style: none;
    margin: 0;
    padding: 0;
    counter-reset: hop;
    border-top: 1px solid var(--steel);
}

.hop-entry {
    display: grid;
    grid-template-columns: 60px 1fr auto;
    align-items: baseline;
    gap: 1.5em;
    padding: 1em 0;
    border-bottom: 1px solid rgba(60, 74, 107, 0.5);
}

.hop-num {
    font-family: var(--font-serif);
    font-style: italic;
    color: var(--brass);
    font-size: 18px;
    letter-spacing: 0.04em;
}

.hop-name {
    font-family: var(--font-display);
    font-size: 14px;
    color: var(--mercury);
    letter-spacing: 0.04em;
}

.hop-time {
    font-family: var(--font-body);
    font-size: 13px;
    color: var(--silver);
    letter-spacing: 0.08em;
    text-align: right;
}

/* ==========================================
   Panel 6 — The Reading Room
   ========================================== */
.panel-reading-room {
    z-index: 3;
    padding: 0;
    min-height: 120vh;
    overflow: hidden;
}

.reading-room-render {
    position: absolute;
    inset: 0;
    z-index: 0;
    pointer-events: none;
}

.reading-room-svg {
    width: 100%;
    height: 100%;
    display: block;
    filter: blur(0.3px);
}

.rr-dome {
    fill: var(--prussian);
    opacity: 0.5;
}

.rr-dome-ring {
    fill: none;
    stroke: var(--silver);
    stroke-width: 0.6;
    opacity: 0.3;
}

.rr-coffers path {
    stroke: var(--silver);
    stroke-width: 0.4;
    opacity: 0.25;
    fill: none;
}

.rr-columns rect {
    fill: var(--prussian);
    stroke: var(--silver);
    stroke-width: 0.4;
    opacity: 0.55;
}

.rr-floor path {
    fill: none;
    stroke: var(--silver);
    stroke-width: 0.4;
    opacity: 0.3;
}

.rr-floor path:first-child {
    fill: var(--prussian);
    opacity: 0.3;
}

.rr-lamps g circle {
    fill: var(--candle);
    opacity: 0.7;
    filter: drop-shadow(0 0 8px var(--candle));
}

.rr-lamps g line {
    stroke: var(--silver);
    stroke-width: 0.5;
    opacity: 0.4;
}

.rr-central-lamp line {
    stroke: var(--silver);
    stroke-width: 1;
    opacity: 0.5;
}

.rr-candle-flame {
    fill: var(--candle);
    opacity: 0.95;
    filter: drop-shadow(0 0 20px var(--candle));
    animation: candle-flicker 3.5s infinite ease-in-out;
}

@keyframes candle-flicker {
    0%, 100% { opacity: 0.95; transform: scaleY(1); }
    20% { opacity: 0.85; transform: scaleY(0.96); }
    50% { opacity: 1; transform: scaleY(1.04); }
    80% { opacity: 0.9; transform: scaleY(0.98); }
}

.rr-candle-stem {
    fill: var(--silver);
    opacity: 0.6;
}

.rr-envoy rect, .rr-envoy ellipse, .rr-envoy path {
    fill: var(--silver);
    opacity: 0.4;
    filter: blur(0.6px);
}

.rr-desk {
    fill: var(--prussian);
    opacity: 0.8;
}

.reading-room-inner {
    position: relative;
    z-index: 2;
    max-width: 720px;
    margin: 0 auto;
    background: linear-gradient(180deg, rgba(7,11,20,0.55) 0%, rgba(7,11,20,0.75) 100%);
    border: 1px solid rgba(184, 153, 104, 0.3);
    padding: 8vh 5vw;
    backdrop-filter: blur(2px);
    -webkit-backdrop-filter: blur(2px);
    top: 18vh;
}

.rr-label,
.reading-room-heading {
    text-align: center;
}

.reading-room-heading {
    color: var(--candle);
    text-shadow: 0 0 30px rgba(232,201,155,0.3);
}

.reading-room-prose p {
    font-family: var(--font-body);
    font-size: 17px;
    color: var(--mercury);
    line-height: 1.85;
    max-width: 580px;
    margin: 1.4em auto 0;
}

.reading-room-prose em {
    font-family: var(--font-serif);
    font-style: italic;
    color: var(--silver);
    font-size: 1.05em;
}

/* ==========================================
   Panel 7 — Departure Stamp
   ========================================== */
.panel-departure {
    z-index: 9;
    text-align: center;
}

.panel-departure .panel-inner {
    max-width: 640px;
    margin: 0 auto;
    padding-bottom: 12vh;
}

.departure-stage {
    position: relative;
    width: min(360px, 70vw);
    height: min(360px, 70vw);
    margin: 3vh auto 4vh;
}

.seal {
    position: relative;
    width: 100%;
    height: 100%;
    transform: scale(1) rotate(0deg);
    transform-origin: center;
}

.seal.is-pressed {
    animation: seal-press 180ms cubic-bezier(0.2, 0, 0.4, 1) forwards;
}

@keyframes seal-press {
    0% { transform: scale(1.18) rotate(-4deg); opacity: 0.6; }
    60% { transform: scale(0.94) rotate(1deg); opacity: 1; }
    100% { transform: scale(1) rotate(0deg); opacity: 1; }
}

.seal-svg {
    width: 100%;
    height: 100%;
    filter: drop-shadow(0 8px 16px rgba(7,11,20,0.7));
}

.seal-wax-outer {
    fill: var(--candle);
    opacity: 0.92;
}

.seal-wax-inner {
    fill: none;
    stroke: var(--brass);
    stroke-width: 1.2;
    opacity: 0.85;
}

.seal-brass-rim {
    fill: none;
    stroke: var(--brass);
    stroke-width: 0.8;
    opacity: 0.7;
}

.seal-engraving text {
    fill: var(--prussian);
}

.seal-text-top, .seal-text-bottom {
    font-family: var(--font-micro);
    font-style: italic;
    font-size: 11px;
    letter-spacing: 0.22em;
}

.seal-text-main {
    font-family: var(--font-display);
    font-size: 26px;
    letter-spacing: 0.12em;
}

.seal-text-sub {
    font-family: var(--font-serif);
    font-style: italic;
    font-size: 13px;
    letter-spacing: 0.14em;
}

.seal-ornament path {
    fill: var(--brass);
    opacity: 0.5;
}

.seal-dust {
    position: absolute;
    inset: -30%;
    pointer-events: none;
}

.seal-dust .dust {
    position: absolute;
    width: 4px;
    height: 4px;
    border-radius: 50%;
    background: var(--mercury);
    opacity: 0;
}

.seal.is-pressed .dust {
    animation: dust-puff 1.4s ease-out forwards;
}

.dust-1 { top: 50%; left: 10%; }
.dust-2 { top: 10%; left: 50%; animation-delay: 60ms !important; }
.dust-3 { top: 50%; right: 10%; animation-delay: 120ms !important; }
.dust-4 { bottom: 10%; left: 50%; animation-delay: 80ms !important; }
.dust-5 { top: 30%; left: 30%; animation-delay: 100ms !important; }
.dust-6 { top: 30%; right: 30%; animation-delay: 40ms !important; }

@keyframes dust-puff {
    0% { transform: scale(0) translate(0,0); opacity: 0; }
    20% { opacity: 0.6; }
    100% { transform: scale(2) translate(var(--dx, 30px), var(--dy, -30px)); opacity: 0; }
}

.dust-1 { --dx: -40px; --dy: 0px; }
.dust-2 { --dx: 0px; --dy: -50px; }
.dust-3 { --dx: 40px; --dy: 0px; }
.dust-4 { --dx: 0px; --dy: 50px; }
.dust-5 { --dx: -30px; --dy: -30px; }
.dust-6 { --dx: 30px; --dy: -30px; }

.departure-blessing {
    font-family: var(--font-serif);
    font-style: italic;
    font-size: clamp(1.1rem, 1.6vw, 1.35rem);
    color: var(--silver);
    margin: 2em 0 1em;
    letter-spacing: 0.04em;
    line-height: 1.6;
}

.departure-link {
    margin: 1.5em 0 0;
}

.hairline-link {
    font-family: var(--font-body);
    font-size: 13px;
    color: var(--brass);
    text-decoration: none;
    border-bottom: 0.5px solid var(--brass);
    padding-bottom: 2px;
    letter-spacing: 0.16em;
    transition: opacity var(--dur-slow) var(--ease-engrave), color var(--dur-slow) var(--ease-engrave);
    opacity: 0.75;
    cursor: none;
}

.hairline-link:hover {
    opacity: 1;
    color: var(--candle);
}

/* ==========================================
   Candlelight toggle
   ========================================== */
.candlelight-toggle {
    position: fixed;
    bottom: 32px;
    left: 32px;
    z-index: 200;
    background: none;
    border: none;
    color: var(--mercury);
    font-family: var(--font-body);
    font-style: italic;
    font-size: 12px;
    letter-spacing: 0.18em;
    opacity: 0.5;
    cursor: pointer;
    border-bottom: 0.5px solid var(--mercury);
    padding: 4px 0;
    transition: opacity var(--dur-slow) var(--ease-engrave), color var(--dur-slow) var(--ease-engrave);
}

.candlelight-toggle:hover {
    opacity: 1;
    color: var(--brass);
    border-bottom-color: var(--brass);
}

.candlelight-toggle.is-active {
    color: var(--candle);
    border-bottom-color: var(--candle);
    opacity: 1;
}

body.is-candlelit {
    transition: background-color 1.8s var(--ease-engrave);
}

body.is-candlelit .panel-inner::before {
    background: radial-gradient(circle at 50% 50%, rgba(232,201,155,0.08) 0%, transparent 60%);
}

/* ==========================================
   Custom cursor (sigil + departure only)
   ========================================== */
.custom-cursor {
    position: fixed;
    top: 0;
    left: 0;
    width: 12px;
    height: 12px;
    pointer-events: none;
    z-index: 300;
    transform: translate(-50%, -50%);
    opacity: 0;
    transition: opacity 0.4s var(--ease-engrave);
    will-change: transform;
}

.custom-cursor svg {
    width: 100%;
    height: 100%;
    overflow: visible;
}

.custom-cursor circle {
    fill: none;
    stroke: var(--brass);
    stroke-width: 1;
}

.custom-cursor line {
    stroke: var(--brass);
    stroke-width: 1;
}

.custom-cursor.is-visible {
    opacity: 1;
}

/* ==========================================
   Reveal — panel enters viewport
   ========================================== */
.panel {
    opacity: 0;
    transition: opacity var(--dur-deliberate) var(--ease-engrave);
}

.panel.is-revealed {
    opacity: 1;
}

.ip-engraved,
.cartouche-city,
.panel-heading,
.reading-room-heading {
    opacity: 0;
    transform: translateY(8px);
    transition: opacity var(--dur-deliberate) var(--ease-engrave), transform var(--dur-deliberate) var(--ease-engrave);
}

.panel.is-revealed .ip-engraved,
.panel.is-revealed .cartouche-city,
.panel.is-revealed .panel-heading,
.panel.is-revealed .reading-room-heading {
    opacity: 1;
    transform: translateY(0);
    transition-delay: 0.4s;
}

.opening-line,
.cartouche-text,
.manifest-list,
.itinerary-hops,
.reading-room-prose,
.departure-blessing,
.departure-link,
.sigil-caption,
.itinerary-flavor,
.manifest-flavor {
    opacity: 0;
    transition: opacity var(--dur-slow) var(--ease-engrave);
}

.panel.is-revealed .opening-line,
.panel.is-revealed .cartouche-text,
.panel.is-revealed .manifest-list,
.panel.is-revealed .itinerary-hops,
.panel.is-revealed .reading-room-prose,
.panel.is-revealed .departure-blessing,
.panel.is-revealed .departure-link,
.panel.is-revealed .sigil-caption,
.panel.is-revealed .itinerary-flavor,
.panel.is-revealed .manifest-flavor {
    opacity: 1;
    transition-delay: 0.8s;
}

/* Panel transforms — broken grid with rotation */
.panel-brass-plate .panel-inner { transform: rotate(-1.6deg); }
.panel-cartouche .panel-inner { transform: rotate(2.1deg); }
.panel-sigil .panel-inner { transform: rotate(-0.8deg); }
.panel-itinerary .panel-inner { transform: rotate(8deg); }
.panel-departure .panel-inner { transform: rotate(0deg); }

/* Mobile: collapse but keep rotations subdued */
@media (max-width: 760px) {
    .panel {
        padding: 8vh 4vw;
        min-height: auto;
    }

    .panel-inner {
        padding: 5vh 6vw;
        max-width: 100%;
        margin: 0;
    }

    .panel-cartouche .panel-inner,
    .panel-sigil .panel-inner,
    .panel-manifest .panel-inner,
    .panel-itinerary .panel-inner {
        margin: 0;
    }

    .panel-itinerary .panel-inner { transform: rotate(4deg); }
    .panel-brass-plate .panel-inner { transform: rotate(-0.8deg); }
    .panel-cartouche .panel-inner { transform: rotate(1deg); }

    .manifest-row {
        grid-template-columns: 1fr;
        gap: 0.4em;
    }

    .hop-entry {
        grid-template-columns: 40px 1fr;
    }

    .hop-time {
        grid-column: 2;
        text-align: left;
    }

    .envoy-number,
    .dispatch-label {
        position: static;
        font-size: 9px;
    }

    .connector {
        display: none;
    }

    .sigil-stage {
        width: min(320px, 80vw);
        height: min(320px, 80vw);
    }

    .frame-border {
        top: 8px;
        left: 8px;
        right: 8px;
        bottom: 8px;
        width: calc(100vw - 16px);
        height: calc(100vh - 16px);
    }
}

/* Print fallback (in case engraving is requested on paper) */
@media print {
    .candlelight-toggle, .custom-cursor { display: none; }
    body { background: white; color: black; }
}
