:root {
    --ink-night: #140B24;
    --soot-brown: #2A1811;
    --foxglove-violet: #7A3FA0;
    --firefly-chartreuse: #C8FF57;
    --pomegranate-red: #B91E4A;
    --moon-parchment: #F5E8C8;
    --bluebell-smoke: #6C8FB3;
    --display-font: "Grenze Gotisch", serif;
    --story-font: "Literata", serif;
    --label-font: "Nunito Sans", sans-serif;
}

* {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
    background: var(--ink-night);
}

body {
    margin: 0;
    color: var(--moon-parchment);
    background: var(--ink-night);
    font-family: var(--story-font);
    overflow-x: hidden;
}

.woven-night {
    position: fixed;
    inset: 0;
    z-index: -3;
    background:
        radial-gradient(circle at 18% 24%, rgba(200, 255, 87, .08), transparent 10rem),
        radial-gradient(circle at 78% 34%, rgba(122, 63, 160, .24), transparent 22rem),
        radial-gradient(circle at 50% 88%, rgba(185, 30, 74, .16), transparent 20rem),
        linear-gradient(90deg, rgba(245, 232, 200, .035) 1px, transparent 1px),
        linear-gradient(0deg, rgba(245, 232, 200, .026) 1px, transparent 1px),
        var(--ink-night);
    background-size: auto, auto, auto, 34px 34px, 29px 29px, auto;
}

.woven-night::after {
    content: "";
    position: absolute;
    inset: 0;
    opacity: .28;
    background-image:
        repeating-linear-gradient(103deg, transparent 0 18px, rgba(245, 232, 200, .03) 19px, transparent 21px),
        repeating-linear-gradient(7deg, rgba(42, 24, 17, .35) 0 2px, transparent 3px 11px);
    mix-blend-mode: screen;
}

.loom-cursor {
    position: fixed;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    pointer-events: none;
    z-index: 20;
    background: var(--firefly-chartreuse);
    box-shadow: 0 0 18px var(--firefly-chartreuse), 0 0 48px rgba(200, 255, 87, .6);
    transform: translate(-50%, -50%) scale(.7);
    opacity: .72;
}

.thread-nav {
    position: fixed;
    right: 26px;
    top: 50%;
    transform: translateY(-50%);
    z-index: 15;
    display: grid;
    gap: 14px;
    font-family: var(--label-font);
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .16em;
    text-transform: uppercase;
}

.nav-thread {
    color: rgba(245, 232, 200, .62);
    text-decoration: none;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
    transition: color .3s ease, transform .3s ease;
}

.nav-thread span {
    width: 38px;
    height: 2px;
    background: var(--bluebell-smoke);
    box-shadow: 0 0 10px rgba(108, 143, 179, .3);
    transition: width .3s ease, background .3s ease;
}

.nav-thread.is-active {
    color: var(--firefly-chartreuse);
    transform: translateX(-6px);
}

.nav-thread.is-active span {
    width: 72px;
    background: var(--firefly-chartreuse);
}

.loom-panel {
    min-height: 100vh;
    position: relative;
    overflow: hidden;
    padding: clamp(38px, 7vw, 94px);
    border-top: 1px solid rgba(245, 232, 200, .09);
}

.warp-field {
    position: absolute;
    inset: 0;
    display: flex;
    justify-content: space-around;
    z-index: 0;
    opacity: .38;
}

.warp-field i {
    width: 1px;
    min-height: 100%;
    background: linear-gradient(180deg, transparent, rgba(245, 232, 200, .38), transparent);
    box-shadow: 0 0 18px rgba(122, 63, 160, .35);
}

.thread-map {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    overflow: visible;
    pointer-events: none;
}

.stitched-path,
.shadow-path,
.sigil-path,
.sigil-stitch,
.sigil-ring {
    fill: none;
    stroke-linecap: round;
    stroke-linejoin: round;
    vector-effect: non-scaling-stroke;
}

.stitched-path {
    stroke-width: 7px;
    stroke-dasharray: 16 12 4 10;
    filter: drop-shadow(0 4px 4px rgba(0, 0, 0, .55));
    animation: stitch-drift 9s linear infinite;
}

.hero-thread .stitched-path {
    stroke-dasharray: 1180;
    stroke-dashoffset: var(--draw, 1180);
    animation: none;
}

.shadow-path {
    stroke: rgba(42, 24, 17, .75);
    stroke-width: 13px;
    transform: translate(8px, 11px);
}

.chartreuse-thread { stroke: var(--firefly-chartreuse); }
.violet-thread { stroke: var(--foxglove-violet); }
.red-thread { stroke: var(--pomegranate-red); }
.smoke-thread { stroke: var(--bluebell-smoke); }

.hero-copy {
    position: absolute;
    left: 13vw;
    top: 18vh;
    z-index: 3;
    max-width: 680px;
}

.loom-label {
    margin: 0 0 12px;
    font-family: var(--label-font);
    font-weight: 900;
    letter-spacing: .2em;
    text-transform: uppercase;
    color: var(--firefly-chartreuse);
}

h1,
h2 {
    margin: 0;
    font-family: var(--display-font);
    font-weight: 800;
    line-height: .82;
    color: var(--moon-parchment);
    text-shadow: 0 7px 0 rgba(42, 24, 17, .65), 0 0 30px rgba(122, 63, 160, .5);
}

h1 {
    font-size: clamp(86px, 16vw, 220px);
    max-width: 900px;
}

h2 {
    font-size: clamp(68px, 10vw, 150px);
}

.spell-line {
    margin: 18px 0 0;
    font-family: var(--display-font);
    font-size: clamp(36px, 5vw, 76px);
    color: var(--firefly-chartreuse);
}

.single-knot {
    position: absolute;
    left: var(--knot-x, 18%);
    top: var(--knot-y, 52%);
    width: 82px;
    height: 82px;
    z-index: 5;
    transform: translate(-50%, -50%);
    cursor: grab;
}

.knot-core,
.knot-ring {
    position: absolute;
    inset: 0;
    border-radius: 50%;
}

.knot-core {
    inset: 19px;
    background: radial-gradient(circle, #F5E8C8 0 10%, #C8FF57 22% 58%, #7A3FA0 61% 100%);
    box-shadow: 0 0 22px #C8FF57, 0 0 70px rgba(200, 255, 87, .86);
    animation: pulse-knot 2.1s ease-in-out infinite;
}

.knot-ring {
    border: 4px dashed var(--firefly-chartreuse);
    box-shadow: inset 0 0 18px rgba(200, 255, 87, .3), 0 0 18px rgba(200, 255, 87, .55);
    animation: spin-ring 7s linear infinite;
}

.vellum-tag,
.vellum-strip,
.rhyme-card,
.ending-tab,
.seal-message {
    color: var(--soot-brown);
    background: linear-gradient(135deg, rgba(245, 232, 200, .98), rgba(245, 232, 200, .78));
    border: 2px solid rgba(42, 24, 17, .62);
    box-shadow: 8px 12px 0 rgba(42, 24, 17, .45), 0 0 28px rgba(245, 232, 200, .1);
}

.vellum-tag {
    position: absolute;
    z-index: 4;
    max-width: 230px;
    padding: 18px 20px;
    transform: rotate(var(--tilt, -4deg)) scale(.86);
    opacity: 0;
    transition: opacity .5s ease, transform .5s ease;
}

.vellum-tag.is-blooming {
    opacity: 1;
    transform: rotate(var(--tilt, -4deg)) scale(1);
}

.vellum-tag b,
.ending-tab,
.bead,
.scroll-charm {
    font-family: var(--label-font);
    font-weight: 900;
    letter-spacing: .12em;
    text-transform: uppercase;
}

.vellum-tag span {
    display: block;
    margin-top: 8px;
    font-size: 17px;
}

.tag-rumor { left: 39%; top: 44%; --tilt: 6deg; }
.tag-proof { left: 63%; top: 28%; --tilt: -7deg; }
.tag-proof b { color: var(--pomegranate-red); }

.scroll-charm {
    position: absolute;
    left: 50%;
    bottom: 34px;
    padding: 10px 14px;
    color: var(--firefly-chartreuse);
    border: 1px solid rgba(200, 255, 87, .5);
    border-radius: 999px;
    transform: translateX(-50%);
}

.panel-title {
    position: relative;
    z-index: 4;
    max-width: 650px;
}

.diagonal-title {
    margin-left: 8vw;
    margin-top: 6vh;
    transform: rotate(-5deg);
}

.panel-title span,
.forest-copy p,
.bargain-copy p,
.seal-copy p,
.panel-title p {
    font-size: clamp(19px, 2vw, 27px);
    line-height: 1.35;
}

.panel-title span {
    font-family: var(--label-font);
    letter-spacing: .18em;
    color: var(--bluebell-smoke);
    text-transform: uppercase;
}

.puppet {
    position: absolute;
    z-index: 3;
    display: grid;
    place-items: center;
    font-family: var(--display-font);
    font-size: 42px;
    color: var(--moon-parchment);
    background: var(--soot-brown);
    border: 3px solid rgba(245, 232, 200, .32);
    clip-path: polygon(50% 0, 100% 20%, 86% 100%, 15% 100%, 0 20%);
    box-shadow: 18px 20px 0 rgba(0,0,0,.35);
}

.fox { width: 160px; height: 130px; left: 18%; bottom: 14%; transform: rotate(9deg); color: var(--firefly-chartreuse); }
.tower { width: 150px; height: 235px; right: 18%; top: 22%; transform: rotate(-4deg); color: var(--bluebell-smoke); }
.key { width: 118px; height: 118px; left: 48%; bottom: 23%; border-radius: 50% 50% 12% 12%; color: var(--pomegranate-red); }

.bead {
    position: absolute;
    z-index: 6;
    width: 94px;
    height: 94px;
    border-radius: 50%;
    color: var(--soot-brown);
    border: 0;
    box-shadow: inset -10px -12px 0 rgba(42, 24, 17, .24), 0 0 28px rgba(245, 232, 200, .25);
    cursor: pointer;
}

.conflict-bead { left: 34%; top: 52%; background: var(--pomegranate-red); color: var(--moon-parchment); }
.motif-bead { left: 58%; top: 32%; background: var(--bluebell-smoke); }
.character-bead { left: 72%; top: 58%; background: var(--firefly-chartreuse); }

.rhyme-card {
    position: absolute;
    z-index: 7;
    right: 8vw;
    bottom: 9vh;
    max-width: 360px;
    padding: 24px;
    font-size: 20px;
    transform: rotate(3deg);
}

.crossing-strip {
    position: absolute;
    left: 8vw;
    bottom: 9vh;
    z-index: 5;
    max-width: 510px;
    padding: 20px 28px;
    font-size: 21px;
    transform: rotate(-2deg);
}

.bargain-copy {
    position: relative;
    z-index: 5;
    max-width: 650px;
    margin-left: auto;
    margin-right: 8vw;
    text-align: right;
}

.branch-stage {
    position: absolute;
    inset: 0;
}

.choice-knot {
    position: absolute;
    left: 42%;
    top: 48%;
    z-index: 6;
    width: 142px;
    height: 142px;
    display: grid;
    place-items: center;
    border-radius: 50%;
    background: radial-gradient(circle, var(--pomegranate-red), var(--soot-brown));
    border: 6px dashed var(--moon-parchment);
    color: var(--moon-parchment);
    font-family: var(--label-font);
    font-weight: 900;
    text-align: center;
    text-transform: uppercase;
    box-shadow: 0 0 52px rgba(185, 30, 74, .65);
}

.ending-path {
    opacity: .32;
    transition: opacity .3s ease, stroke-width .3s ease, filter .3s ease;
}

.branch-stage.is-awake .ending-path,
.ending-path.is-hot {
    opacity: 1;
    stroke-width: 10px;
    filter: drop-shadow(0 0 16px currentColor);
}

.ending-tab {
    position: absolute;
    z-index: 5;
    padding: 16px 20px;
}

.end-a { right: 8%; top: 17%; transform: rotate(5deg); }
.end-b { right: 7%; top: 47%; transform: rotate(-4deg); }
.end-c { right: 9%; bottom: 13%; transform: rotate(3deg); }

.wax-seal {
    position: absolute;
    left: 18%;
    bottom: 18%;
    z-index: 4;
    width: 152px;
    height: 152px;
    display: grid;
    place-items: center;
    border-radius: 44% 51% 46% 49%;
    background: var(--pomegranate-red);
    color: var(--moon-parchment);
    font-family: var(--display-font);
    font-size: 42px;
    box-shadow: inset -12px -14px 0 rgba(42, 24, 17, .32), 0 0 40px rgba(185, 30, 74, .5);
}

.forest-copy {
    position: relative;
    z-index: 5;
    max-width: 720px;
}

.motif-rings {
    position: absolute;
    inset: 10vh 8vw 8vh 8vw;
    z-index: 4;
}

.motif-ring {
    position: absolute;
    display: grid;
    place-items: center;
    width: clamp(170px, 19vw, 270px);
    height: clamp(170px, 19vw, 270px);
    border-radius: 50%;
    border: 3px dashed var(--moon-parchment);
    color: var(--moon-parchment);
    background: radial-gradient(circle, rgba(245,232,200,.1), transparent 65%);
    box-shadow: inset 0 0 40px rgba(108, 143, 179, .15), 0 0 44px rgba(122, 63, 160, .25);
    text-align: center;
    animation: ring-breathe 5s ease-in-out infinite;
}

.motif-ring span {
    font-family: var(--display-font);
    font-size: clamp(34px, 4vw, 58px);
    line-height: .9;
}

.motif-ring em {
    position: absolute;
    bottom: 20px;
    font-family: var(--label-font);
    font-style: normal;
    font-weight: 900;
    color: var(--firefly-chartreuse);
    text-transform: uppercase;
}

.ring-moon { left: 30%; top: 0; border-color: var(--bluebell-smoke); }
.ring-thorn { right: 6%; top: 20%; border-color: var(--pomegranate-red); animation-delay: -1s; }
.ring-door { left: 9%; bottom: 4%; border-color: var(--firefly-chartreuse); animation-delay: -2s; }
.ring-seal { left: 50%; bottom: 0; border-color: var(--foxglove-violet); animation-delay: -3s; }

.forest-cutout {
    position: absolute;
    bottom: -4vh;
    width: 42vw;
    height: 56vh;
    background: var(--soot-brown);
    opacity: .86;
    clip-path: polygon(0 100%, 0 36%, 8% 44%, 15% 18%, 21% 49%, 32% 12%, 41% 52%, 53% 22%, 62% 55%, 72% 24%, 84% 50%, 100% 31%, 100% 100%);
}

.forest-left { left: -8vw; }
.forest-right { right: -8vw; transform: scaleX(-1); }

.glyph-cloud {
    position: absolute;
    right: 9vw;
    bottom: 8vh;
    z-index: 7;
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    max-width: 330px;
}

.glyph-cloud span {
    padding: 8px 13px;
    border: 1px solid rgba(245, 232, 200, .42);
    color: var(--firefly-chartreuse);
    font-family: var(--label-font);
    text-transform: uppercase;
    transform: rotate(var(--r, -4deg));
}

.glyph-cloud span:nth-child(2) { --r: 5deg; color: var(--bluebell-smoke); }
.glyph-cloud span:nth-child(3) { --r: -8deg; color: var(--pomegranate-red); }
.glyph-cloud span:nth-child(4) { --r: 3deg; }

.seal-panel {
    display: grid;
    grid-template-columns: minmax(280px, 1fr) minmax(280px, 560px);
    align-items: center;
    gap: 5vw;
}

.final-sigil {
    width: min(52vw, 690px);
    max-width: 100%;
    justify-self: center;
    filter: drop-shadow(0 0 35px rgba(200, 255, 87, .22));
}

.sigil-ring {
    stroke: var(--moon-parchment);
    stroke-width: 3;
    stroke-dasharray: 4 14;
    animation: spin-sigil 34s linear infinite;
    transform-origin: center;
}

.ring-two {
    stroke: var(--bluebell-smoke);
    animation-direction: reverse;
}

.sigil-path {
    stroke: var(--firefly-chartreuse);
    stroke-width: 7;
    stroke-dasharray: 18 14;
}

.sigil-stitch {
    stroke: var(--foxglove-violet);
    stroke-width: 11;
    stroke-dasharray: 2 18;
}

.seal-copy {
    position: relative;
    z-index: 4;
}

.seal-button {
    margin-top: 22px;
    padding: 18px 28px;
    border: 2px solid var(--moon-parchment);
    border-radius: 999px;
    color: var(--ink-night);
    background: var(--firefly-chartreuse);
    font-family: var(--label-font);
    font-weight: 900;
    letter-spacing: .12em;
    text-transform: uppercase;
    cursor: pointer;
    box-shadow: 0 0 26px rgba(200, 255, 87, .38);
}

.seal-message {
    position: absolute;
    left: 50%;
    bottom: 7vh;
    z-index: 8;
    padding: 18px 24px;
    opacity: 0;
    transform: translateX(-50%) translateY(20px) rotate(-2deg);
    transition: opacity .4s ease, transform .4s ease;
}

.seal-message.is-visible {
    opacity: 1;
    transform: translateX(-50%) translateY(0) rotate(-2deg);
}

.seal-panel.is-sealed .final-sigil {
    animation: seal-flare .8s ease;
}

@keyframes pulse-knot {
    0%, 100% { transform: scale(.9); }
    50% { transform: scale(1.16); }
}

@keyframes spin-ring {
    to { transform: rotate(360deg); }
}

@keyframes stitch-drift {
    to { stroke-dashoffset: -168; }
}

@keyframes ring-breathe {
    0%, 100% { transform: scale(.98) rotate(-2deg); }
    50% { transform: scale(1.04) rotate(2deg); }
}

@keyframes spin-sigil {
    to { transform: rotate(360deg); }
}

@keyframes seal-flare {
    0% { transform: scale(1); }
    50% { transform: scale(1.05); filter: drop-shadow(0 0 64px rgba(200, 255, 87, .85)); }
    100% { transform: scale(1); }
}

@media (max-width: 780px) {
    .thread-nav { display: none; }
    .loom-panel { padding: 34px 22px; }
    .hero-copy { left: 24px; top: 14vh; }
    .tag-rumor { left: 14%; top: 62%; }
    .tag-proof { left: 38%; top: 70%; }
    .diagonal-title { margin-left: 0; transform: rotate(-2deg); }
    .puppet { opacity: .58; }
    .bead { width: 78px; height: 78px; font-size: 10px; }
    .rhyme-card { right: 22px; bottom: 20px; max-width: 280px; }
    .crossing-strip { left: 22px; bottom: 155px; max-width: 300px; }
    .bargain-copy { margin: 0; text-align: left; }
    .choice-knot { left: 28%; top: 50%; }
    .ending-tab { right: auto; left: 54%; }
    .motif-rings { position: relative; inset: auto; min-height: 620px; }
    .motif-ring { width: 190px; height: 190px; }
    .seal-panel { display: block; }
    .final-sigil { width: 100%; margin-top: 15vh; }
}
