/* ══════════════════════════════════════════════════════════════
   THE ORANGE FILE · Bureau of Feline Valuation
   kraft & manila hue family · carmine accent · two typefaces
   ══════════════════════════════════════════════════════════════ */

:root{
  /* palette — one warm paper family + carmine string */
  --board:#16100a;
  --board-2:#221913;
  --paper:#e7d4a8;
  --paper-2:#d9c28c;
  --paper-dark:#c4a76f;
  --kraft:#a97f4c;
  --ink:#2b2118;
  --ink-dim:#6d5b41;
  --carmine:#b3202e;
  --carmine-hot:#d8323f;
  --orange:#d97a24;
  --gold:#c9a227;

  /* type */
  --f-display:'Stardos Stencil', 'Courier New', monospace;
  --f-text:'Special Elite', 'Courier New', monospace;

  /* motion language */
  --dur-stamp:.28s;
  --dur-flip:.55s;
  --dur-drift:1.4s;
  --ease-thunk:cubic-bezier(.2,1.4,.3,1);
  --ease-paper:cubic-bezier(.33,1,.68,1);

  /* paper grain via turbulence, inlined */
  --grain:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3CfeColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 .05 0'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)'/%3E%3C/svg%3E");
}

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

[hidden]{display:none!important}

html{scrollbar-color:var(--kraft) var(--board)}

body{
  background:var(--board);
  color:var(--paper);
  font-family:var(--f-text);
  font-size:17px;
  line-height:1.55;
  min-height:100vh;
  overflow-x:hidden;
  /* default cursor: brass pushpin */
  cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22'%3E%3Ccircle cx='8' cy='8' r='6' fill='%23c9a227' stroke='%232b2118' stroke-width='1.5'/%3E%3Cpath d='M12 12 L20 20' stroke='%232b2118' stroke-width='2.5'/%3E%3C/svg%3E") 8 8, auto;
  background-image:
    radial-gradient(1200px 700px at 70% -10%, rgba(217,122,36,.07), transparent 60%),
    radial-gradient(900px 600px at 10% 110%, rgba(179,32,46,.05), transparent 60%);
}
body::after{ /* film of grain over everything */
  content:"";position:fixed;inset:0;pointer-events:none;z-index:9000;
  background:var(--grain);opacity:.5;mix-blend-mode:overlay;
}

/* cursors: magnifier on interactives (zoom-and-enhance is the house verb) */
a,button,summary,input,[role="button"]{
  cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='26' height='26'%3E%3Ccircle cx='10' cy='10' r='7' fill='none' stroke='%23e7d4a8' stroke-width='2.5'/%3E%3Cpath d='M15.5 15.5 L23 23' stroke='%23e7d4a8' stroke-width='3'/%3E%3C/svg%3E") 10 10, pointer;
}
a:active,button:active,summary:active{
  cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='26' height='26'%3E%3Ccircle cx='10' cy='10' r='7' fill='%23d8323f' fill-opacity='.35' stroke='%23d8323f' stroke-width='2.5'/%3E%3Cpath d='M15.5 15.5 L23 23' stroke='%23d8323f' stroke-width='3'/%3E%3C/svg%3E") 10 10, pointer;
}
button:disabled,.forbidden{
  cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24'%3E%3Cpath d='M5 5 L19 19 M19 5 L5 19' stroke='%23b3202e' stroke-width='3.5'/%3E%3C/svg%3E") 12 12, not-allowed;
}

/* focus: red pencil circle, never removed */
:focus{outline:none}
:focus-visible{outline:2px dashed var(--carmine-hot);outline-offset:4px;border-radius:2px}

::selection{background:var(--carmine);color:var(--paper)}

.skiplink{position:fixed;left:-999px;top:8px;z-index:9999;background:var(--carmine);color:var(--paper);padding:.5rem 1rem;font-family:var(--f-display)}
.skiplink:focus{left:8px}

a{color:var(--orange)}
a:hover{color:var(--carmine-hot)}

h1,h2,h3,h4{font-family:var(--f-display);font-weight:700;letter-spacing:.04em;color:var(--paper)}

.dim{color:var(--ink-dim);font-size:.85rem}
.paper .dim{color:var(--ink-dim)}

/* ── paper card ─────────────────────────────────────────────── */
.paper{
  background:
    var(--grain),
    linear-gradient(174deg, var(--paper) 0%, var(--paper-2) 70%, var(--paper-dark) 100%);
  color:var(--ink);
  border-radius:2px;
  box-shadow:0 2px 3px rgba(0,0,0,.5), 0 12px 30px rgba(0,0,0,.35);
  position:relative;
  rotate:var(--tilt, 0deg);
}
.paper h2,.paper h3,.paper h4{color:var(--ink)}
.paper a{color:var(--carmine)}
.paper a:hover{color:var(--carmine-hot)}

/* pushpin */
.pin::before{
  content:"";position:absolute;top:-9px;left:50%;translate:-50% 0;
  width:16px;height:16px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%, #f4e08a, var(--gold) 55%, #7a5f14);
  box-shadow:0 3px 4px rgba(0,0,0,.5);
  z-index:2;
}

/* ── stamps ─────────────────────────────────────────────────── */
.stamp{
  display:inline-block;font-family:var(--f-display);font-weight:700;
  border:3px double currentColor;padding:.1em .5em;letter-spacing:.14em;
  color:var(--ink-dim);text-transform:uppercase;font-size:.75rem;
  rotate:-2deg;opacity:.9;
}
.stamp-red{color:var(--carmine);rotate:2deg}
.stamp.big{font-size:1.1rem;rotate:-4deg}
@keyframes stampIn{from{scale:2.2;opacity:0}to{scale:1;opacity:.9}}
.stamp-in{animation:stampIn var(--dur-stamp) var(--ease-thunk) both}

.chip{font-family:var(--f-display);font-size:.62rem;letter-spacing:.12em;border:1.5px solid currentColor;padding:.05em .45em;vertical-align:middle}
.chip-doc{color:#3f6b3f}
.chip-dram{color:var(--carmine)}
.zone-head .chip-doc{color:#8fbf8f}
.zone-head .chip-dram{color:var(--carmine-hot)}

/* ── entry ritual ───────────────────────────────────────────── */
.ritual{
  position:fixed;inset:0;z-index:5000;display:grid;place-items:center;
  background:var(--board) url("../img/board.jpg") center/cover no-repeat;
  background-blend-mode:luminosity;
}
.ritual::before{content:"";position:absolute;inset:0;background:rgba(22,16,10,.82)}
.ritual-folder{
  position:relative;max-width:560px;width:calc(100% - 2rem);padding:2.5rem 2rem 2rem;
  background:var(--grain), linear-gradient(172deg,#caa96d,#b8905a 80%);
  color:var(--ink);border-radius:4px 14px 4px 4px;
  box-shadow:0 30px 80px rgba(0,0,0,.7);
  text-align:center;
}
.ritual-folder::before{ /* folder tab */
  content:"BFV · 4-3-98";font-family:var(--f-display);font-size:.7rem;letter-spacing:.2em;
  position:absolute;top:-26px;left:24px;background:inherit;padding:.3em 1.2em;
  border-radius:6px 6px 0 0;color:var(--ink-dim);
}
.ritual-stamps{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-bottom:1.2rem}
.ritual-title{font-size:clamp(2rem,6vw,3rem);letter-spacing:.08em}
.ritual-case{font-size:.85rem;letter-spacing:.06em;margin:.4rem 0 1rem;color:var(--ink-dim)}
.ritual-note{margin-bottom:1.6rem}
.ritual-hint{font-size:.8rem;color:var(--ink-dim);margin-top:.8rem}
.ritual-content-note{font-size:.72rem;color:var(--ink-dim);margin-top:1.4rem;border-top:1px dashed var(--kraft);padding-top:.8rem}

.seal{
  background:none;border:none;font-family:var(--f-display);color:var(--carmine);
  display:inline-grid;place-items:center;gap:.6rem;padding:.5rem;
  -webkit-tap-highlight-color:transparent;touch-action:none;
}
.seal svg{width:120px;height:120px;overflow:visible}
.seal-ring{fill:rgba(179,32,46,.08);stroke:var(--carmine);stroke-width:3}
.seal-progress{
  fill:none;stroke:var(--carmine-hot);stroke-width:5;stroke-linecap:round;
  stroke-dasharray:100;stroke-dashoffset:calc(100 - var(--hold,0));
  transform:rotate(-90deg);transform-origin:center;
  transition:stroke-dashoffset .05s linear;
}
.seal-paw{fill:var(--carmine)}
.seal-label{letter-spacing:.18em;font-size:.8rem}
.seal:hover .seal-ring{fill:rgba(179,32,46,.16)}
@keyframes sealTear{
  40%{rotate:6deg;scale:1.06;opacity:1}
  100%{rotate:22deg;scale:.2;opacity:0}
}
.seal.torn svg{animation:sealTear .6s var(--ease-thunk) forwards}
@keyframes ritualOut{to{opacity:0;translate:0 -3vh}}
.ritual.done{animation:ritualOut .7s var(--ease-paper) forwards;pointer-events:none}

/* ── letterhead ─────────────────────────────────────────────── */
.letterhead{
  display:flex;align-items:center;gap:1.2rem;flex-wrap:wrap;
  padding:.8rem 1.2rem;border-bottom:1px solid rgba(231,212,168,.15);
  position:sticky;top:0;z-index:100;background:rgba(22,16,10,.92);backdrop-filter:blur(4px);
}
.wordmark svg{height:30px;width:auto;display:block}
.wm-the,.wm-file{font:700 26px var(--f-display);fill:var(--paper)}
.wm-orange{font:700 26px var(--f-display);fill:var(--orange)}
.wm-string{fill:none;stroke:var(--carmine);stroke-width:1.6}
.case-line{font-size:.72rem;letter-spacing:.18em;color:var(--ink-dim)}
.head-tools{margin-left:auto;display:flex;align-items:center;gap:1rem}

.progress{display:flex;gap:.35rem;list-style:none}
.progress li{
  font-family:var(--f-display);font-size:.7rem;width:1.7em;height:1.7em;
  display:grid;place-items:center;border:1.5px solid var(--ink-dim);color:var(--ink-dim);
  rotate:-3deg;
}
.progress li.done{border-color:var(--carmine-hot);color:var(--carmine-hot);rotate:2deg}

.tool-btn{
  background:none;border:1.5px solid var(--ink-dim);color:var(--paper);
  font-family:var(--f-display);font-size:.68rem;letter-spacing:.12em;padding:.35em .7em;
}
.tool-btn .tool-off{display:none}
.tool-btn[aria-pressed="true"] .tool-on{display:none}
.tool-btn[aria-pressed="true"] .tool-off{display:inline;color:var(--carmine-hot)}

/* ── zones ──────────────────────────────────────────────────── */
main{max-width:1160px;margin:0 auto;padding:2.2rem 1.2rem 5rem}
.zone{view-transition-name:zone}
.zone-head{margin-bottom:1.6rem}
.zone-head h2{font-size:clamp(1.3rem,3.4vw,2rem)}
.register{font-size:.85rem;color:var(--paper-dark);max-width:70ch;margin-top:.4rem}

.btn-red,.btn-plain{
  font-family:var(--f-display);letter-spacing:.14em;font-size:.8rem;
  padding:.55em 1.1em;border-radius:2px;border:2px solid var(--carmine);
  background:var(--carmine);color:var(--paper);
  transition:translate var(--dur-stamp) var(--ease-thunk), box-shadow var(--dur-stamp);
  box-shadow:0 3px 0 rgba(0,0,0,.35);
}
.btn-red:hover:not(:disabled){translate:0 -2px;box-shadow:0 5px 0 rgba(0,0,0,.35)}
.btn-red:active:not(:disabled){translate:0 1px;box-shadow:0 1px 0 rgba(0,0,0,.35)}
.btn-red:disabled{opacity:.45}
.btn-plain{background:transparent;color:var(--ink);border-color:var(--ink-dim)}
.paper .btn-plain:hover{border-color:var(--ink)}

.term{
  font-size:.8rem;background:var(--board);color:var(--orange);
  padding:.6rem .8rem;border-radius:2px;min-height:2.2em;margin-top:.8rem;
  box-shadow:inset 0 0 18px rgba(0,0,0,.6);
}
.term p{margin:.15em 0}

/* ── hub / cover sheet ──────────────────────────────────────── */
.cover-sheet{max-width:860px;margin:0 auto;padding:2.4rem 2.2rem 2.8rem;--tilt:-.4deg}
.cover-head{display:flex;gap:1rem;flex-wrap:wrap;align-items:center;margin-bottom:1.6rem}
.cover-title{font-size:clamp(1.8rem,5vw,2.8rem)}
.cover-sub{letter-spacing:.05em;margin:.3rem 0 1.1rem;color:var(--ink-dim)}
.cover-brief{max-width:64ch;margin-bottom:.7rem}

/* the four red circles: stage 1 hides in plain sight */
.pin-l{
  font-style:normal;font-weight:inherit;position:relative;color:var(--carmine);
}
.pin-l::before{
  content:"";position:absolute;inset:-.34em -.30em;border:1.8px solid var(--carmine-hot);
  border-radius:50% 46% 52% 48%;rotate:-6deg;opacity:.85;
}
.pin-l::after{
  content:attr(data-n);position:absolute;top:-1.15em;right:-.9em;
  font-size:.5em;color:var(--carmine-hot);font-family:var(--f-display);
}

.tabs{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:1.1rem;margin-top:2rem}
.tab{
  display:block;padding:1rem 1rem 1.1rem;text-decoration:none;color:var(--ink);
  --tilt:0deg;transition:translate var(--dur-stamp) var(--ease-paper), rotate var(--dur-stamp) var(--ease-paper), box-shadow var(--dur-stamp);
}
.tab:nth-child(odd){--tilt:-.8deg}
.tab:nth-child(even){--tilt:.7deg}
.tab:hover{translate:0 -4px;rotate:0deg;box-shadow:0 6px 6px rgba(0,0,0,.35), 0 18px 40px rgba(0,0,0,.4);color:var(--ink)}
.tab-no{display:block;font-family:var(--f-display);font-size:.66rem;letter-spacing:.2em;color:var(--carmine)}
.tab-name{display:block;font-family:var(--f-display);font-size:1.15rem;margin:.2em 0 .3em}
.tab-desc{display:block;font-size:.8rem;color:var(--ink-dim)}

/* ── exhibit A / enhance ────────────────────────────────────── */
.enhance-rig{display:grid;grid-template-columns:minmax(0,3fr) minmax(260px,2fr);gap:1.4rem;align-items:start}
.photo-frame{padding:1rem 1rem 0.8rem;--tilt:-.6deg}
.photo-viewport{position:relative;overflow:hidden;background:#000;aspect-ratio:4/3}
.photo-viewport img{
  width:100%;height:100%;object-fit:cover;display:block;
  transform-origin:var(--ox,50%) var(--oy,50%);
  scale:var(--zoom,1);
  transition:scale var(--dur-flip) var(--ease-paper), transform-origin var(--dur-flip) var(--ease-paper), filter var(--dur-flip);
  filter:contrast(var(--ct,1)) saturate(var(--sat,1));
}
.enhance-grid{
  position:absolute;inset:0;pointer-events:none;opacity:0;transition:opacity .3s;
  background:
    linear-gradient(rgba(217,122,36,.35) 1px, transparent 1px) 0 0/25% 25%,
    linear-gradient(90deg, rgba(217,122,36,.35) 1px, transparent 1px) 0 0/25% 25%;
}
.enhance-rig.armed .enhance-grid{opacity:1}
.photo-viewport::after{ /* scanline sweep while enhancing */
  content:"";position:absolute;inset:0;pointer-events:none;opacity:0;
  background:linear-gradient(transparent 46%, rgba(217,122,36,.25) 50%, transparent 54%) 0 0/100% 200%;
}
@keyframes sweep{from{background-position:0 200%}to{background-position:0 -100%}}
.photo-viewport.enhancing::after{opacity:1;animation:sweep .9s linear}
.photo-frame figcaption{font-size:.72rem;letter-spacing:.1em;color:var(--ink-dim);padding-top:.6rem;text-align:center}

.enhance-panel{padding:1.2rem}
.enhance-controls{display:flex;gap:.8rem;align-items:center;flex-wrap:wrap;margin-top:.9rem}
.sector-pad{display:grid;grid-template-columns:1fr 1fr;gap:4px}
.sector{
  font-family:var(--f-display);font-size:.72rem;padding:.5em .9em;
  border:1.5px solid var(--ink-dim);background:transparent;color:var(--ink);
}
.sector[aria-pressed="true"]{background:var(--ink);color:var(--paper)}

.findings{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.1rem;margin-top:1.6rem}
.finding{padding:1.1rem 1.2rem;--tilt:.5deg}
.finding:nth-child(2){--tilt:-.6deg}
.finding h4{font-size:.85rem;color:var(--carmine);margin-bottom:.4rem}
@keyframes findingIn{from{opacity:0;translate:0 14px;rotate:0deg}to{opacity:1}}
.finding{animation:findingIn var(--dur-flip) var(--ease-paper) both}

/* ── subject ────────────────────────────────────────────────── */
.dossier{display:grid;grid-template-columns:260px minmax(0,1fr);gap:1.4rem;align-items:start}
.id-card{padding:1.1rem;--tilt:-.8deg;position:sticky;top:84px}
.id-photo{position:relative;margin-bottom:.9rem}
.id-photo svg{width:100%;display:block;border-radius:2px}
.idp-bg{fill:var(--paper-dark)}
.idp-head,.idp-torso{fill:var(--kraft)}
.id-photo .stamp{position:absolute;bottom:8px;left:50%;translate:-50% 0;background:rgba(231,212,168,.85)}
.id-facts{display:grid;grid-template-columns:auto 1fr;gap:.25rem .8rem;font-size:.85rem}
.id-facts dt{font-family:var(--f-display);font-size:.62rem;letter-spacing:.14em;color:var(--ink-dim);align-self:center}
.dossier-body{display:grid;gap:1.4rem}
.memo{padding:1.4rem 1.5rem}
.memo h3{font-size:1rem;margin-bottom:.8rem;letter-spacing:.1em}
.record{list-style:none;display:grid;gap:.8rem}
.record li{padding-left:1.2rem;position:relative}
.record li::before{content:"▪";position:absolute;left:0;color:var(--carmine)}
.record b{font-family:var(--f-display);font-weight:700}

.memo-crypt{--tilt:.4deg}
.vigenere{display:flex;gap:.7rem;align-items:center;flex-wrap:wrap;margin:.6rem 0 .9rem}
.vigenere label{font-family:var(--f-display);font-size:.66rem;letter-spacing:.18em;color:var(--ink-dim)}
.vigenere input{
  font-family:var(--f-text);font-size:1.05rem;letter-spacing:.4em;text-transform:uppercase;
  background:transparent;border:none;border-bottom:2px dashed var(--ink-dim);
  color:var(--ink);width:9ch;padding:.15em .2em;
}
.ciphertext{
  font-size:.95rem;letter-spacing:.06em;background:rgba(43,33,24,.07);
  padding:.8rem 1rem;border-left:3px solid var(--carmine);
}

/* ── event timeline ─────────────────────────────────────────── */
.timeline{position:relative;display:grid;gap:1.6rem;max-width:760px;margin:0 auto;padding:.5rem 0 .5rem 1.5rem}
.string-svg{position:absolute;inset:0;width:100%;height:100%;z-index:1;pointer-events:none}
.string-svg path{fill:none;stroke:var(--carmine);stroke-width:1.8;opacity:.9}
.string-svg circle{fill:var(--gold);stroke:var(--ink);stroke-width:1}
.t-node{padding:1.2rem 1.4rem;position:relative;z-index:2;--tilt:calc((var(--i) - 2.5) * .35deg)}
.t-node h3{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.95rem}
.t-date{color:var(--carmine);font-size:.7rem;letter-spacing:.16em;align-self:center}
.t-node p{margin-top:.5rem;max-width:62ch}
.t-key{border:2px solid var(--carmine)}
.src{font-size:.72rem;letter-spacing:.08em;margin-top:.6rem;color:var(--ink-dim)}

/* ── asset ──────────────────────────────────────────────────── */
.asset-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.4rem;align-items:start}
#chart{width:100%;height:auto;background:rgba(43,33,24,.06);border-radius:2px}
.do-not{margin-top:1rem}
.memo-audio{grid-column:1/-1}
.audio-rig{display:flex;gap:.8rem;flex-wrap:wrap;margin:.8rem 0}
#purr-wave{width:100%;height:64px;background:var(--board);border-radius:2px;display:block}
.transcript{margin-top:.9rem;border-top:1px dashed var(--kraft);padding-top:.9rem}
.morse-line{font-size:1.05rem;letter-spacing:.12em;margin:.4rem 0;color:var(--carmine)}
.morse-card{font-size:.8rem;line-height:2;letter-spacing:.05em}
details summary{font-family:var(--f-display);font-size:.72rem;letter-spacing:.14em;color:var(--ink-dim);margin-top:.5rem}
@keyframes shake{
  10%,90%{translate:-1px 0}20%,80%{translate:2px 1px}30%,50%,70%{translate:-3px -1px}40%,60%{translate:3px 1px}
}
body.shaken main{animation:shake .5s linear}

/* ── evidence locker / idol ─────────────────────────────────── */
.locker-rig{display:grid;grid-template-columns:minmax(0,3fr) minmax(280px,2fr);gap:1.4rem;align-items:start}
.idol-stage{padding:.8rem;--tilt:.4deg;background:linear-gradient(174deg,#241b12,#16100a);box-shadow:0 2px 3px rgba(0,0,0,.5), 0 12px 30px rgba(0,0,0,.35)}
#idol-canvas-wrap{aspect-ratio:1/1;position:relative}
#idol-canvas-wrap canvas{width:100%!important;height:100%!important;display:block;border-radius:2px;touch-action:none}
.idol-loading{position:absolute;inset:auto 0 0 0;margin:0;background:transparent;box-shadow:none}
#idol-fallback{width:100%;display:block;border-radius:2px}
.locker-panel{padding:1.3rem 1.4rem}
.ring-controls{display:grid;gap:.5rem;margin-top:1rem}
.ring-row{display:flex;align-items:center;gap:.7rem;font-family:var(--f-display);font-size:.75rem;letter-spacing:.12em}
.ring-row span{width:4.5em}
.ring-row output{min-width:3ch;text-align:center;color:var(--carmine)}
.ring-btn{border:1.5px solid var(--ink-dim);background:transparent;color:var(--ink);font-size:.8rem;padding:.3em .7em}
.ring-btn:hover{border-color:var(--carmine);color:var(--carmine)}

/* ── unresolved ─────────────────────────────────────────────── */
.theories{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.3rem}
.theory{padding:1.3rem 1.4rem}
.theory:nth-child(1){--tilt:-.7deg}.theory:nth-child(2){--tilt:.5deg}.theory:nth-child(3){--tilt:-.4deg}.theory:nth-child(4){--tilt:.6deg}
.theory h3{font-size:.9rem;color:var(--carmine);margin-bottom:.5rem}
.open-qs ul{list-style:none;display:grid;gap:.6rem}
.open-qs li{padding-left:1.1rem;position:relative}
.open-qs li::before{content:"?";position:absolute;left:0;color:var(--carmine);font-family:var(--f-display)}
/* selection reveal: invisible until selected */
.reveal{color:transparent;text-shadow:none}
.reveal::selection{background:var(--carmine);color:var(--paper)}

/* ── hints drawer ───────────────────────────────────────────── */
.hints{position:fixed;right:0;bottom:18vh;z-index:800;display:flex;align-items:flex-start}
.hints-tab{
  writing-mode:vertical-rl;font-family:var(--f-display);font-size:.68rem;letter-spacing:.2em;
  background:var(--carmine);color:var(--paper);border:none;padding:1em .45em;border-radius:3px 0 0 3px;
}
.hints-body{width:min(340px,86vw);max-height:60vh;overflow:auto;padding:1.1rem 1.2rem}
.hints-body h3{font-size:.85rem}
.hint-stage{margin-top:.9rem;border-top:1px dashed var(--kraft);padding-top:.7rem}
.hint-stage h4{font-size:.72rem;letter-spacing:.14em;color:var(--ink-dim)}
.hint-btn{display:block;margin-top:.45rem;background:none;border:1px solid var(--ink-dim);color:var(--ink);font-family:var(--f-display);font-size:.66rem;letter-spacing:.1em;padding:.35em .7em}
.hint-text{font-size:.85rem;margin-top:.4rem}

/* ── footer ─────────────────────────────────────────────────── */
.site-foot{max-width:1160px;margin:0 auto;padding:2rem 1.2rem 3rem;border-top:1px solid rgba(231,212,168,.12);font-size:.8rem;color:var(--paper-dark)}
.site-foot p{max-width:80ch}

/* ── eggs: cat run + idle paw ───────────────────────────────── */
#cat-run{position:fixed;bottom:4vh;left:-160px;z-index:9500;pointer-events:none}
#cat-run svg{width:120px;height:auto}
@keyframes catRun{from{translate:0 0}to{translate:calc(100vw + 320px) 0}}
#cat-run.go{animation:catRun 2.6s linear forwards}
@keyframes catBob{0%,100%{rotate:-2deg}50%{rotate:3deg}}
#cat-run.go svg{animation:catBob .3s ease-in-out infinite}

#paw-idle{position:fixed;top:-140px;right:12vw;z-index:9400;pointer-events:none}
#paw-idle svg{width:90px;height:auto}
@keyframes pawPeek{0%{translate:0 0}35%{translate:0 150px}65%{translate:0 150px}100%{translate:0 0}}
#paw-idle.peek{animation:pawPeek 3.2s var(--ease-paper) forwards}

/* ── print secret: the un-redacted memo ─────────────────────── */
.print-memo{display:none}
@media print{
  body{background:#fff;color:#000}
  body::after{display:none}
  .letterhead,main,.site-foot,.hints,.ritual,#cat-run,#paw-idle{display:none!important}
  .print-memo{display:block;font-family:'Courier New',monospace;padding:2cm;color:#000}
  .print-memo .redact{background:#000;color:#000;padding:0 .3em}
  .print-memo .unredacted{background:none;color:#000;border:2px solid #000;padding:0 .3em}
}

/* ── responsive ─────────────────────────────────────────────── */
@media (max-width:880px){
  .enhance-rig,.locker-rig{grid-template-columns:1fr}
  .dossier{grid-template-columns:1fr}
  .id-card{position:static;max-width:340px}
  .head-tools{margin-left:0}
}
@media (max-width:560px){
  body{font-size:15.5px}
  .letterhead{gap:.6rem;padding:.6rem .8rem}
  .case-line{display:none}
  .cover-sheet{padding:1.6rem 1.2rem 2rem}
  .hints{bottom:8vh}
}

/* ── reduced motion: complete, quiet, nothing broken ────────── */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001s!important;animation-iteration-count:1!important;transition-duration:.001s!important}
  .photo-viewport img{transition:none}
  #cat-run,#paw-idle{display:none!important}
  .paper{--tilt:0deg!important}
}
