:root {
  /* tiny seed numbers; Interprets `.org` as a communal puzzle society and public solution ritual */
  --observatory: #11162E;
  --aubergine: #2A1738;
  --parchment: #F2E6C8;
  --amber: #F4B942;
  --cyan: #58D7C8;
  --coral: #FF6F61;
  --violet: #8F6CFF;
  --ink: #071B17;
  --progress: 0;
  --stage: 0;
  --lantern-x: 50vw;
  --lantern-y: 45vh;
}

* { box-sizing: border-box; }

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

body {
  margin: 0;
  min-height: 100vh;
  overflow-x: hidden;
  color: var(--parchment);
  font-family: "Nunito Sans", "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background:
    radial-gradient(circle at 50% 42%, rgba(88, 215, 200, .10), transparent 24rem),
    radial-gradient(circle at 18% 18%, rgba(143, 108, 255, .16), transparent 26rem),
    radial-gradient(circle at 78% 70%, rgba(255, 111, 97, .10), transparent 22rem),
    linear-gradient(135deg, var(--observatory), var(--aubergine) 58%, #080c1f);
}

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

.lantern-cursor,
.paper-dust {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 50;
}

.lantern-cursor {
  opacity: .9;
  mix-blend-mode: screen;
  background:
    radial-gradient(circle 25px at var(--lantern-x) var(--lantern-y), rgba(242, 230, 200, .95), rgba(244, 185, 66, .62) 28%, transparent 64%),
    radial-gradient(circle 210px at var(--lantern-x) var(--lantern-y), rgba(244, 185, 66, .20), rgba(88, 215, 200, .10) 34%, transparent 70%);
  transition: opacity .4s ease;
}

.paper-dust {
  opacity: .22;
  mix-blend-mode: overlay;
  background-image:
    radial-gradient(circle at 20% 30%, rgba(242, 230, 200, .9) 0 1px, transparent 1px),
    radial-gradient(circle at 70% 64%, rgba(244, 185, 66, .7) 0 1px, transparent 1px),
    linear-gradient(90deg, rgba(242, 230, 200, .08) 1px, transparent 1px);
  background-size: 37px 43px, 71px 59px, 11px 11px;
}

.instrument-rim {
  position: fixed;
  right: 24px;
  top: 50%;
  width: 90px;
  height: 340px;
  transform: translateY(-50%);
  z-index: 60;
}

.rim-token {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  color: var(--ink);
  text-decoration: none;
  font-family: "IBM Plex Mono", ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 10px;
  letter-spacing: .1em;
  background: radial-gradient(circle at 35% 28%, #fff0ad, var(--amber) 52%, #8d6418);
  border-radius: 50% 50% 46% 54%;
  box-shadow: inset 0 -8px 13px rgba(0,0,0,.24), 0 10px 22px rgba(0,0,0,.35);
  transform: rotate(calc(var(--i) * 18deg)) translate(-50%, calc(-154px + var(--i) * 77px));
  opacity: .55;
  transition: opacity .35s ease, filter .35s ease, scale .35s ease;
}

.rim-token:nth-child(1) { --i: 0; }
.rim-token:nth-child(2) { --i: 1; }
.rim-token:nth-child(3) { --i: 2; }
.rim-token:nth-child(4) { --i: 3; }
.rim-token:nth-child(5) { --i: 4; }
.rim-token i {
  position: absolute;
  inset: 8px;
  border: 1px dashed rgba(7, 27, 23, .45);
  border-radius: inherit;
}
.rim-token.active { opacity: 1; filter: drop-shadow(0 0 16px rgba(244, 185, 66, .7)); scale: 1.12; }

.assembly-field { position: relative; }

.chamber {
  position: relative;
  min-height: 100vh;
  overflow: hidden;
  isolation: isolate;
  padding: clamp(28px, 5vw, 74px);
  border-top: 1px solid rgba(242, 230, 200, .12);
}

.unsorted-field {
  min-height: 100vh;
  background:
    radial-gradient(circle at 52% 48%, rgba(7, 27, 23, .85) 0 23rem, transparent 23.2rem),
    radial-gradient(circle at 52% 48%, rgba(244, 185, 66, .18) 0 25rem, transparent 25.5rem),
    radial-gradient(circle at 18% 68%, rgba(143, 108, 255, .12), transparent 19rem);
}

.circular-table {
  position: absolute;
  left: 50%;
  top: 50%;
  width: min(118vmin, 1050px);
  aspect-ratio: 1;
  transform: translate(-50%, -50%) rotate(calc(var(--progress) * -16deg));
  border-radius: 50%;
  background:
    repeating-radial-gradient(circle, rgba(242, 230, 200, .06) 0 1px, transparent 1px 64px),
    radial-gradient(circle, rgba(17,22,46,.42), rgba(7,27,23,.94) 55%, rgba(42,23,56,.88));
  box-shadow: inset 0 0 90px rgba(0,0,0,.78), 0 0 75px rgba(88, 215, 200, .13);
}

.orbit-rail {
  position: absolute;
  inset: var(--inset);
  border: 1px dashed rgba(242, 230, 200, .24);
  border-radius: 50%;
  animation: railTurn var(--speed) linear infinite;
}
.rail-one { --inset: 7%; --speed: 38s; }
.rail-two { --inset: 19%; --speed: 50s; border-color: rgba(88, 215, 200, .28); animation-direction: reverse; }
.rail-three { --inset: 32%; --speed: 64s; border-color: rgba(143, 108, 255, .32); }
@keyframes railTurn { to { transform: rotate(360deg); } }

.constellation-map {
  position: absolute;
  inset: 4%;
  overflow: visible;
  transform: rotate(calc(var(--progress) * 20deg));
}
.dotted-path,
.agreement-stroke {
  fill: none;
  stroke-linecap: round;
}
.dotted-path {
  stroke: rgba(242, 230, 200, .46);
  stroke-width: 3;
  stroke-dasharray: 1 22;
  filter: drop-shadow(0 0 5px rgba(242,230,200,.3));
}
.agreement-stroke {
  stroke: var(--cyan);
  stroke-width: 7;
  stroke-dasharray: 680;
  stroke-dashoffset: calc(680 - (var(--progress) * 680));
  filter: drop-shadow(0 0 12px rgba(88, 215, 200, .7));
}

.wordmark-orbit {
  position: absolute;
  inset: 0;
  transition: transform .8s ease;
}
.title-glyph {
  position: absolute;
  left: var(--gx);
  top: var(--gy);
}

.glyph-seed,
.seed-piece,
.voting-token {
  display: grid;
  place-items: center;
  color: var(--ink);
  font-family: "Cinzel Decorative", Georgia, "Times New Roman", serif;
  font-weight: 700;
  background: linear-gradient(145deg, var(--parchment), var(--amber));
  clip-path: polygon(10% 2%, 43% 0, 50% 13%, 58% 0, 90% 4%, 99% 16%, 96% 44%, 86% 50%, 98% 61%, 91% 94%, 58% 100%, 50% 88%, 41% 100%, 12% 94%, 0 82%, 4% 58%, 16% 50%, 2% 38%, 0 14%);
  box-shadow: 0 14px 24px rgba(0,0,0,.42), inset 0 0 0 1px rgba(7,27,23,.18);
}
.glyph-seed {
  --radius: 36vmin;
  width: clamp(58px, 8.5vmin, 108px);
  height: clamp(58px, 8.5vmin, 108px);
  margin: -4vmin 0 0 -4vmin;
  font-size: clamp(2.5rem, 7vmin, 5.8rem);
  transform: rotate(calc(var(--angle) + 90deg)) translateY(calc(var(--progress) * -5vmin)) scale(calc(.82 + var(--progress) * .28));
  transition: transform .6s ease, filter .4s ease;
}
.title-glyph:nth-child(1) { --angle: 252deg; --gx: 39%; --gy: 14%; }
.title-glyph:nth-child(2) { --angle: 288deg; --gx: 61%; --gy: 14%; background: linear-gradient(145deg, var(--cyan), var(--parchment)); }
.title-glyph:nth-child(3) { --angle: 328deg; --gx: 81%; --gy: 30%; background: linear-gradient(145deg, var(--violet), var(--parchment)); }
.title-glyph:nth-child(4) { --angle: 4deg; --gx: 86%; --gy: 50%; }
.title-glyph:nth-child(5) { --angle: 41deg; --gx: 76%; --gy: 73%; background: linear-gradient(145deg, var(--coral), var(--amber)); }
.title-glyph:nth-child(6) { --angle: 79deg; --gx: 57%; --gy: 86%; }
.title-glyph:nth-child(7) { --angle: 116deg; --gx: 34%; --gy: 82%; background: linear-gradient(145deg, var(--cyan), var(--violet)); }
.title-glyph:nth-child(8) { --angle: 155deg; --gx: 16%; --gy: 65%; }
.title-glyph:nth-child(9) { --angle: 192deg; --gx: 13%; --gy: 42%; background: linear-gradient(145deg, var(--violet), var(--coral)); color: var(--parchment); }
.title-glyph:nth-child(10) { --angle: 222deg; --gx: 25%; --gy: 23%; }
.glyph-seed.lit,
.seed-piece.lit { filter: drop-shadow(0 0 18px rgba(244,185,66,.85)); }

.seed-cloud { position: absolute; inset: 0; }
.seed-piece {
  position: absolute;
  left: var(--x);
  top: var(--y);
  width: var(--s);
  height: var(--s);
  font-family: "IBM Plex Mono", ui-monospace, monospace;
  font-size: calc(var(--s) * .34);
  transform: translate(calc(var(--dx) * var(--stage)), calc(var(--dy) * var(--stage))) rotate(calc(var(--r) + var(--stage) * 45deg));
  opacity: .92;
  transition: filter .3s ease, transform .8s cubic-bezier(.2,.9,.18,1);
}
.seed-piece.cyan { background: linear-gradient(145deg, var(--cyan), var(--parchment)); }
.seed-piece.violet { background: linear-gradient(145deg, var(--violet), var(--parchment)); }
.seed-piece.coral { background: linear-gradient(145deg, var(--coral), var(--amber)); color: var(--parchment); }

.missing-shape {
  position: absolute;
  left: 50%;
  top: 50%;
  width: min(34vmin, 330px);
  height: min(28vmin, 275px);
  display: grid;
  place-items: center;
  transform: translate(-50%, -50%) rotate(-8deg);
  color: rgba(242, 230, 200, .44);
  font-family: "IBM Plex Mono", ui-monospace, monospace;
  font-size: 11px;
  letter-spacing: .2em;
  text-transform: uppercase;
  background: radial-gradient(circle, rgba(17,22,46,.92), rgba(7,27,23,.74));
  border: 2px dashed rgba(244,185,66,.5);
  clip-path: polygon(8% 24%, 28% 0, 60% 5%, 83% 21%, 100% 45%, 88% 73%, 58% 100%, 26% 90%, 0 63%);
  box-shadow: inset 0 0 52px rgba(0,0,0,.7), 0 0 42px rgba(244,185,66,.18);
}

.vellum-slip {
  position: absolute;
  z-index: 4;
  color: var(--aubergine);
  background: rgba(242, 230, 200, .88);
  font-family: "Fraunces", Georgia, serif;
  box-shadow: 0 22px 45px rgba(0,0,0,.45), inset 0 0 0 1px rgba(42,23,56,.16);
  backdrop-filter: blur(6px);
}
.vellum-slip::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle, rgba(42,23,56,.12) 0 1px, transparent 1px);
  background-size: 17px 19px;
  opacity: .34;
  pointer-events: none;
}
.entry-slip {
  left: 6vw;
  bottom: 9vh;
  width: min(470px, 82vw);
  padding: 26px 30px 32px;
  transform: rotate(-5deg);
  clip-path: polygon(0 8%, 9% 0, 100% 4%, 94% 100%, 5% 94%);
}
.entry-slip h1,
.chamber-title,
.final-wordmark {
  font-family: "Cinzel Decorative", Georgia, "Times New Roman", serif;
  font-weight: 900;
  letter-spacing: .02em;
}
.entry-slip h1 {
  margin: 4px 0 12px;
  color: var(--aubergine);
  font-size: clamp(2.6rem, 5vw, 5.6rem);
  line-height: .88;
}
.entry-slip p,
.vellum-slip p { position: relative; margin: 0; font-size: clamp(1.05rem, 1.55vw, 1.45rem); line-height: 1.32; }
.ledger-id,
.marginal-note,
.rule-ribbon {
  font-family: "IBM Plex Mono", ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 11px;
  letter-spacing: .16em;
  text-transform: uppercase;
}
.ledger-id { display: block; position: relative; margin-bottom: 8px; color: var(--ink); }
.marginal-note { position: absolute; right: 9vw; bottom: 12vh; color: var(--amber); opacity: .75; }

.rule-lanterns {
  background:
    radial-gradient(circle at 24% 48%, rgba(244,185,66,.18), transparent 22rem),
    radial-gradient(circle at 70% 35%, rgba(143,108,255,.15), transparent 21rem),
    linear-gradient(160deg, var(--aubergine), var(--observatory));
}
.chamber-title {
  position: relative;
  z-index: 3;
  max-width: 900px;
  margin: 0;
  color: var(--parchment);
  font-size: clamp(3rem, 8vw, 9rem);
  line-height: .88;
  text-shadow: 0 0 22px rgba(244,185,66,.18), 0 15px 0 rgba(0,0,0,.18);
}
.lantern-array {
  position: absolute;
  inset: 0;
}
.rule-lantern {
  position: absolute;
  width: clamp(160px, 22vw, 285px);
  min-height: 190px;
  padding: 28px 23px 22px;
  border: 0;
  color: var(--ink);
  cursor: pointer;
  background: rgba(242, 230, 200, .82);
  clip-path: polygon(12% 0, 82% 7%, 100% 48%, 83% 100%, 10% 92%, 0 35%);
  box-shadow: 0 24px 45px rgba(0,0,0,.45), 0 0 55px rgba(244,185,66,.12);
  transition: transform .55s cubic-bezier(.18,.9,.2,1.2), filter .45s ease;
}
.rule-lantern span,
.rule-lantern em { display: block; font-family: "IBM Plex Mono", ui-monospace, monospace; font-size: 10px; letter-spacing: .14em; text-transform: uppercase; }
.rule-lantern b { display: block; margin: 14px 0 12px; font-family: "Fraunces", Georgia, serif; font-size: clamp(1.7rem, 3vw, 3rem); line-height: .9; }
.rule-lantern em { font-style: normal; opacity: .72; }
.rule-lantern.amber { left: 12vw; top: 27vh; transform: rotate(-8deg); }
.rule-lantern.cyan { right: 16vw; top: 18vh; background: rgba(88,215,200,.84); transform: rotate(7deg); }
.rule-lantern.violet { left: 47vw; bottom: 13vh; background: rgba(143,108,255,.86); color: var(--parchment); transform: rotate(-2deg); }
.rule-lantern.active { transform: rotate(0deg) scale(1.08); filter: drop-shadow(0 0 24px rgba(244,185,66,.65)); }
.lantern-slip { right: 7vw; bottom: 9vh; width: min(430px, 82vw); padding: 24px 27px; transform: rotate(4deg); clip-path: polygon(0 8%, 100% 0, 94% 92%, 7% 100%); }
.rule-ribbon { position: absolute; left: 8vw; bottom: 31px; color: var(--cyan); transform: rotate(-2deg); }

.consensus-loom {
  background:
    radial-gradient(circle at 50% 50%, rgba(88,215,200,.18), transparent 27rem),
    linear-gradient(180deg, #0b1028, var(--observatory) 55%, var(--aubergine));
}
.loom-table {
  position: absolute;
  left: 50%;
  top: 53%;
  width: min(86vmin, 760px);
  aspect-ratio: 1;
  transform: translate(-50%, -50%);
  border-radius: 50%;
}
.consensus-ring {
  position: absolute;
  border-radius: 50%;
  border: 2px solid rgba(88,215,200,.42);
  box-shadow: inset 0 0 40px rgba(88,215,200,.08), 0 0 30px rgba(88,215,200,.1);
  animation: ringPulse 4s ease-in-out infinite;
}
.ring-a { inset: 3%; }
.ring-b { inset: 19%; border-color: rgba(143,108,255,.5); animation-delay: .8s; }
.ring-c { inset: 35%; border-color: rgba(244,185,66,.5); animation-delay: 1.6s; }
@keyframes ringPulse { 50% { transform: scale(1.035); opacity: .58; } }
.agreement-wave {
  position: absolute;
  inset: 18%;
  border-radius: 50%;
  border: 3px solid var(--cyan);
  opacity: 0;
  animation: agreementWave 4s ease-out infinite;
}
.wave-two { animation-delay: 2s; border-color: var(--violet); }
@keyframes agreementWave { 0% { transform: scale(.2); opacity: .75; } 70%,100% { transform: scale(1.35); opacity: 0; } }
.loom-thread {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 72%;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--cyan), transparent);
  transform-origin: left center;
}
.thread-one { transform: rotate(18deg) translateX(-50%); }
.thread-two { transform: rotate(138deg) translateX(-50%); background: linear-gradient(90deg, transparent, var(--violet), transparent); }
.thread-three { transform: rotate(268deg) translateX(-50%); background: linear-gradient(90deg, transparent, var(--amber), transparent); }
.voting-token {
  position: absolute;
  width: 76px;
  height: 76px;
  border: 0;
  border-radius: 50%;
  cursor: pointer;
  font-family: "IBM Plex Mono", ui-monospace, monospace;
}
.token-a { left: 5%; top: 46%; }
.token-b { right: 18%; top: 12%; background: linear-gradient(145deg, var(--cyan), var(--parchment)); }
.token-c { right: 11%; bottom: 19%; background: linear-gradient(145deg, var(--violet), var(--parchment)); }
.token-d { left: 33%; bottom: 4%; background: linear-gradient(145deg, var(--coral), var(--amber)); }
.voting-token.chosen { filter: drop-shadow(0 0 18px rgba(88,215,200,.9)); transform: scale(1.12); }
.loom-slip { left: 8vw; bottom: 9vh; width: min(430px, 82vw); padding: 25px; transform: rotate(-4deg); clip-path: polygon(6% 0, 100% 6%, 90% 100%, 0 90%); }

.misfit-archive {
  background:
    radial-gradient(circle at 70% 28%, rgba(255,111,97,.18), transparent 22rem),
    radial-gradient(circle at 20% 68%, rgba(244,185,66,.12), transparent 19rem),
    var(--observatory);
}
.archive-drawers {
  position: absolute;
  left: 12vw;
  top: 27vh;
  width: min(620px, 78vw);
  transform: rotate(-4deg);
}
.drawer {
  display: block;
  width: 100%;
  margin: 0 0 18px;
  padding: 22px 28px;
  text-align: left;
  border: 0;
  color: var(--aubergine);
  cursor: pointer;
  background: linear-gradient(90deg, rgba(242,230,200,.96), rgba(244,185,66,.84));
  box-shadow: 0 14px 28px rgba(0,0,0,.36), inset 0 -7px 0 rgba(7,27,23,.12);
  clip-path: polygon(0 0, 95% 4%, 100% 52%, 94% 100%, 3% 93%);
  transition: transform .45s ease, filter .45s ease;
}
.drawer:nth-child(2) { transform: translateX(38px); }
.drawer.coral { background: linear-gradient(90deg, var(--coral), var(--parchment)); transform: translateX(-20px); }
.drawer.open,
.drawer:hover { transform: translateX(78px); filter: drop-shadow(0 0 18px rgba(255,111,97,.48)); }
.drawer span { display: block; font-family: "IBM Plex Mono", ui-monospace, monospace; font-size: 11px; letter-spacing: .13em; text-transform: uppercase; }
.drawer b { display: block; margin-top: 8px; font-family: "Fraunces", Georgia, serif; font-size: clamp(1.4rem, 2.6vw, 2.4rem); }
.fingerprint-seal {
  position: absolute;
  right: 14vw;
  top: 31vh;
  width: clamp(170px, 24vw, 300px);
  aspect-ratio: 1;
  display: grid;
  place-items: center;
  border-radius: 47% 53% 49% 51%;
  color: var(--parchment);
  font-family: "Cinzel Decorative", Georgia, serif;
  font-size: clamp(3rem, 7vw, 7rem);
  background:
    repeating-radial-gradient(ellipse at 54% 46%, rgba(242,230,200,.16) 0 3px, transparent 3px 9px),
    var(--coral);
  box-shadow: inset 0 -20px 30px rgba(0,0,0,.28), 0 22px 42px rgba(0,0,0,.44);
  transform: rotate(12deg);
}
.archive-slip { right: 8vw; bottom: 9vh; width: min(450px, 82vw); padding: 25px; transform: rotate(5deg); clip-path: polygon(0 9%, 91% 0, 100% 86%, 12% 100%); }

.public-solution {
  display: grid;
  place-items: center;
  background:
    radial-gradient(circle at 50% 50%, rgba(244,185,66,.23), transparent 25rem),
    radial-gradient(circle at 51% 53%, rgba(7,27,23,.88) 0 20rem, transparent 20.4rem),
    linear-gradient(145deg, var(--aubergine), var(--observatory));
}
.solution-void {
  position: absolute;
  width: min(78vw, 900px);
  height: 42vh;
  border: 2px dashed rgba(244,185,66,.48);
  box-shadow: inset 0 0 70px rgba(0,0,0,.55), 0 0 55px rgba(244,185,66,.12);
  clip-path: polygon(4% 14%, 17% 4%, 29% 13%, 42% 3%, 51% 16%, 62% 7%, 76% 14%, 94% 6%, 100% 23%, 92% 40%, 100% 58%, 90% 91%, 70% 85%, 58% 96%, 45% 86%, 30% 96%, 17% 84%, 3% 92%, 0 60%, 9% 45%, 0 31%);
}
.final-wordmark {
  position: relative;
  z-index: 2;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: clamp(0px, .7vw, 11px);
  margin: 0;
  color: var(--parchment);
  font-size: clamp(3.4rem, 11vw, 12rem);
  line-height: .85;
  text-shadow: 0 0 24px rgba(244,185,66,.2);
}
.final-wordmark span {
  display: inline-block;
  transform: translate(var(--fx), var(--fy)) rotate(var(--fr));
  transition: transform 1.25s cubic-bezier(.16,.9,.1,1.1), color .7s ease, text-shadow .7s ease;
}
.final-wordmark.unsolved span:nth-child(1) { --fx: -13vw; --fy: -8vh; --fr: -18deg; }
.final-wordmark.unsolved span:nth-child(2) { --fx: 9vw; --fy: 13vh; --fr: 24deg; }
.final-wordmark.unsolved span:nth-child(3) { --fx: -7vw; --fy: 15vh; --fr: -8deg; }
.final-wordmark.unsolved span:nth-child(4) { --fx: 12vw; --fy: -11vh; --fr: 17deg; }
.final-wordmark.unsolved span:nth-child(5) { --fx: -14vw; --fy: 5vh; --fr: -22deg; }
.final-wordmark.unsolved span:nth-child(6) { --fx: 7vw; --fy: -13vh; --fr: 11deg; }
.final-wordmark.unsolved span:nth-child(7) { --fx: -6vw; --fy: -8vh; --fr: 32deg; }
.final-wordmark.unsolved span:nth-child(8) { --fx: 6vw; --fy: 14vh; --fr: -15deg; }
.final-wordmark.unsolved span:nth-child(9) { --fx: 14vw; --fy: -4vh; --fr: 18deg; }
.final-wordmark.unsolved span:nth-child(10) { --fx: -8vw; --fy: 9vh; --fr: -12deg; }
.final-wordmark.solved span { --fx: 0; --fy: 0; --fr: 0deg; color: var(--amber); text-shadow: 0 0 26px rgba(244,185,66,.48); }
.public-seal {
  position: absolute;
  right: 10vw;
  top: 13vh;
  width: 160px;
  height: 160px;
  display: grid;
  place-items: center;
  padding: 20px;
  text-align: center;
  border-radius: 50%;
  color: var(--parchment);
  background: var(--coral);
  font-family: "IBM Plex Mono", ui-monospace, monospace;
  font-weight: 700;
  font-size: 12px;
  letter-spacing: .14em;
  box-shadow: inset 0 -14px 25px rgba(0,0,0,.26), 0 17px 30px rgba(0,0,0,.4);
  transform: rotate(-12deg);
}
.solution-slip { left: 8vw; bottom: 8vh; width: min(470px, 84vw); padding: 25px; transform: rotate(3deg); clip-path: polygon(0 0, 93% 8%, 100% 88%, 12% 100%); }
.ledger-link {
  position: relative;
  display: inline-block;
  margin-top: 18px;
  padding: 10px 18px;
  color: var(--ink);
  background: var(--amber);
  text-decoration: none;
  font-family: "IBM Plex Mono", ui-monospace, monospace;
  text-transform: uppercase;
  letter-spacing: .1em;
  clip-path: polygon(0 0, 84% 0, 100% 50%, 84% 100%, 0 100%, 8% 50%);
}

@media (max-width: 820px) {
  .instrument-rim { right: 4px; width: 50px; height: 260px; }
  .rim-token { width: 32px; height: 32px; font-size: 8px; }
  .chamber { padding: 26px 20px 94px; }
  .circular-table { width: 125vmin; }
  .entry-slip { left: 5vw; bottom: 8vh; }
  .marginal-note { right: 15vw; bottom: 3vh; }
  .rule-lantern { width: 150px; min-height: 150px; padding: 20px 16px; }
  .rule-lantern.amber { left: 5vw; top: 34vh; }
  .rule-lantern.cyan { right: 12vw; top: 29vh; }
  .rule-lantern.violet { left: 25vw; bottom: 16vh; }
  .lantern-slip, .loom-slip, .archive-slip, .solution-slip { left: 6vw; right: auto; bottom: 7vh; }
  .loom-table { width: 96vmin; }
  .archive-drawers { left: 4vw; width: 84vw; }
  .fingerprint-seal { right: 8vw; top: 18vh; width: 140px; }
  .public-seal { width: 116px; height: 116px; right: 8vw; top: 12vh; font-size: 9px; }
}
