/* ============================================================
   MOOSE — an on-chain artifact, exhibited
   Aesthetic: museum placard / archival catalogue.
   Cold paper ground, ink type, one hazard-orange accent,
   monospace for every byte that came off the chain.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,600;1,9..144,500&family=Newsreader:ital,opsz,wght@0,6..72,400;0,6..72,500;1,6..72,400&family=JetBrains+Mono:wght@400;500;700&display=swap');

/* ---- palette + tokens ------------------------------------ */
:root{
  --paper:#161512;          /* aged-dark exhibit wall */
  --paper-2:#1d1b16;        /* card / placard stock */
  --paper-3:#22201a;        /* raised plate */
  --ink:#e8e3d4;            /* warm bone text */
  --ink-soft:#b6b0a0;       /* secondary */
  --ink-faint:#7c776a;      /* captions, metadata */
  --accent:#d2691e;         /* hazard / amber — moose-pelt rust */
  --accent-soft:#e08a3c;
  --moss:#5b7355;           /* forest green, used sparingly */
  --hair:rgba(232,227,212,.16);
  --hair-2:rgba(232,227,212,.07);

  --display:'Fraunces',Georgia,serif;
  --body:'Newsreader',Georgia,serif;
  --mono:'JetBrains Mono',ui-monospace,'Courier New',monospace;

  --container:1120px;
  --gutter:64px;
}

/* ---- reset ----------------------------------------------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
html,body{overflow-x:hidden}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--body);
  font-size:18px;
  line-height:1.66;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,svg{display:block}
a{color:var(--accent-soft);text-decoration:none}
ul{list-style:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
::selection{background:var(--accent);color:#161512}

/* ============================================================
   ATMOSPHERE — the exhibit wall: paper grain + vignette
   ============================================================ */
.wall-grain{
  position:fixed;inset:0;z-index:-2;pointer-events:none;opacity:.045;
  mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.wall-light{
  position:fixed;inset:0;z-index:-3;pointer-events:none;
  background:
    radial-gradient(70% 44% at 50% -6%, rgba(210,105,30,.10), transparent 70%),
    radial-gradient(120% 80% at 50% 120%, rgba(0,0,0,.5), transparent 60%);
}
.wall-vignette{
  position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:radial-gradient(130% 100% at 50% 40%, transparent 52%, rgba(0,0,0,.55) 100%);
}

/* ============================================================
   TYPE TOKENS
   ============================================================ */
.statement{
  font-family:var(--display);font-weight:600;
  font-size:clamp(34px,4.6vw,62px);line-height:1.04;
  letter-spacing:-.014em;
}
.eyebrow{
  font-family:var(--mono);font-weight:700;
  font-size:11px;text-transform:uppercase;letter-spacing:.22em;
  color:var(--accent-soft);
}
.lede{
  font-family:var(--body);font-weight:400;
  font-size:clamp(19px,1.7vw,22px);line-height:1.6;
  color:var(--ink-soft);max-width:62ch;
}
.lede em{color:var(--ink);font-style:italic}
.caption{
  font-family:var(--mono);font-weight:400;font-size:11.5px;
  letter-spacing:.07em;color:var(--ink-faint);line-height:1.6;
}
.mono{font-family:var(--mono);font-variant-numeric:tabular-nums}

/* a hex string / address rendered as a chain artifact */
.chainval{
  font-family:var(--mono);font-size:13px;letter-spacing:.01em;
  color:var(--accent-soft);word-break:break-all;
}

/* ============================================================
   PLATE — the placard that holds the contract address
   ============================================================ */
.plate{
  display:flex;flex-wrap:wrap;align-items:center;gap:14px 18px;
  background:var(--paper-3);
  border:1px solid var(--hair);
  border-left:3px solid var(--accent);
  padding:16px 20px;
}
.plate-label{
  font-family:var(--mono);font-weight:700;font-size:10px;
  text-transform:uppercase;letter-spacing:.18em;color:var(--ink-faint);
}
.plate-addr{
  font-family:var(--mono);font-size:14px;font-weight:500;
  color:var(--ink);letter-spacing:.02em;word-break:break-all;flex:1;
  min-width:240px;
}
.copy-btn{
  font-family:var(--mono);font-weight:700;font-size:10px;
  text-transform:uppercase;letter-spacing:.14em;
  color:var(--accent-soft);
  border:1px solid var(--hair);
  padding:8px 13px;white-space:nowrap;
  transition:background .14s,color .14s,border-color .14s;
}
.copy-btn:hover{background:var(--accent);color:#161512;border-color:var(--accent)}
.copy-btn.copied{background:var(--moss);color:#161512;border-color:var(--moss)}

/* ============================================================
   HEADER — the catalogue spine
   ============================================================ */
.spine{
  position:sticky;top:0;z-index:40;
  display:flex;align-items:center;gap:18px;
  height:56px;padding:0 var(--gutter);
  background:rgba(22,21,18,.93);
  backdrop-filter:blur(7px);
  border-bottom:1px solid var(--hair);
}
.spine .mark{
  display:flex;align-items:center;gap:9px;flex-shrink:0;
  font-family:var(--display);font-weight:600;font-size:19px;
  letter-spacing:.02em;color:var(--ink);
}
.spine .mark svg{width:24px;height:24px}
.spine .accession{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.13em;
  color:var(--ink-faint);text-transform:uppercase;
  padding-left:18px;border-left:1px solid var(--hair);
  white-space:nowrap;
}
.spine nav{
  margin-left:auto;display:flex;gap:22px;overflow-x:auto;
  scrollbar-width:none;
}
.spine nav::-webkit-scrollbar{display:none}
.spine nav a{
  font-family:var(--mono);font-weight:500;font-size:11px;
  text-transform:uppercase;letter-spacing:.1em;color:var(--ink-faint);
  white-space:nowrap;padding:4px 0;position:relative;
  transition:color .14s;
}
.spine nav a:hover{color:var(--ink)}
.spine nav a::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:1.5px;
  background:var(--accent);transform:scaleX(0);transform-origin:left;
  transition:transform .18s ease-out;
}
.spine nav a:hover::after{transform:scaleX(1)}
.spine .x-link{color:var(--accent-soft)}

/* ============================================================
   SECTION SCAFFOLD
   ============================================================ */
section{position:relative}
.bay{
  max-width:var(--container);margin:0 auto;
  padding:96px var(--gutter);
}
.bay-wide{max-width:1280px}
.sec-rule{
  max-width:var(--container);margin:0 auto;
  border-top:1px solid var(--hair);
}

/* a section header: accession tab + numeral + title */
.bay-head{margin-bottom:44px}
.bay-tab{
  display:flex;align-items:baseline;gap:14px;margin-bottom:18px;
}
.bay-num{
  font-family:var(--mono);font-weight:700;font-size:12px;
  color:var(--accent-soft);letter-spacing:.1em;
}
.bay-tab .rule{flex:1;height:1px;background:var(--hair)}

/* ============================================================
   HERO — the find, exhibited
   ============================================================ */
.hero{
  position:relative;
  min-height:100vh;min-height:100svh;
  display:flex;flex-direction:column;justify-content:center;
  padding:120px var(--gutter) 76px;
  overflow:hidden;
}
.hero-inner{max-width:var(--container);margin:0 auto;width:100%}
.hero-eyebrow{
  display:flex;align-items:center;gap:14px;margin-bottom:30px;
}
.hero-eyebrow .dot{
  width:7px;height:7px;background:var(--accent);border-radius:50%;
  box-shadow:0 0 0 4px rgba(210,105,30,.16);
  animation:breathe 3.4s ease-in-out infinite;
}
.hero-eyebrow .line{flex:0 0 64px;height:1px;background:var(--hair)}
.hero h1{
  font-family:var(--display);font-weight:600;
  font-size:clamp(38px,6vw,84px);line-height:1.02;
  letter-spacing:-.02em;max-width:17ch;
}
.hero h1 .fn{
  font-family:var(--mono);font-weight:700;
  font-size:.74em;color:var(--accent-soft);
  letter-spacing:-.01em;
}
.hero h1 .found{
  font-style:italic;color:var(--ink);
  border-bottom:3px solid var(--accent);
  padding-bottom:.02em;
}
.hero-sub{
  margin-top:30px;font-family:var(--body);
  font-size:clamp(18px,1.7vw,21px);line-height:1.62;
  color:var(--ink-soft);max-width:58ch;
}
.hero-sub em{color:var(--ink);font-style:italic}
.hero-plate{margin-top:38px;max-width:680px}
.hero-meta{
  margin-top:30px;display:flex;flex-wrap:wrap;gap:10px 28px;
}
.hero-meta .mi{
  display:flex;flex-direction:column;gap:3px;
}
.hero-meta .mi-k{
  font-family:var(--mono);font-size:9.5px;text-transform:uppercase;
  letter-spacing:.16em;color:var(--ink-faint);
}
.hero-meta .mi-v{
  font-family:var(--mono);font-weight:700;font-size:14px;color:var(--ink);
}
.hero-scroll{
  margin-top:54px;
  font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--ink-faint);
  display:flex;align-items:center;gap:10px;
}
.hero-scroll::before{
  content:"";width:26px;height:1px;background:var(--ink-faint);
}

/* the moose specimen mark — a tiny pixel moose, drawn in SVG */
.spine svg .pelt{fill:var(--accent)}
.spine svg .antler{fill:var(--ink-soft)}

/* ============================================================
   THE ARTIFACT — the find report
   ============================================================ */
.artifact-grid{
  display:grid;grid-template-columns:1.05fr .95fr;gap:48px;
  align-items:start;
}
.artifact-prose p{margin:0 0 18px;max-width:54ch}
.artifact-prose p:last-child{margin-bottom:0}
.artifact-prose em{font-style:italic;color:var(--ink-soft)}
.artifact-prose .lead-line{
  font-family:var(--display);font-weight:500;
  font-size:22px;line-height:1.4;color:var(--ink);
  margin-bottom:24px;
}

/* the bytecode card — a specimen under glass */
.specimen{
  background:var(--paper-2);
  border:1px solid var(--hair);
  padding:24px 26px;
}
.specimen-head{
  display:flex;justify-content:space-between;align-items:baseline;
  padding-bottom:14px;margin-bottom:16px;
  border-bottom:1px solid var(--hair);
}
.specimen-head .st{
  font-family:var(--mono);font-weight:700;font-size:11px;
  text-transform:uppercase;letter-spacing:.14em;color:var(--ink);
}
.specimen-head .sn{
  font-family:var(--mono);font-size:10px;letter-spacing:.1em;
  color:var(--ink-faint);
}
.specimen dl{display:grid;grid-template-columns:auto 1fr;gap:11px 18px}
.specimen dt{
  font-family:var(--mono);font-size:10.5px;text-transform:uppercase;
  letter-spacing:.1em;color:var(--ink-faint);padding-top:2px;
}
.specimen dd{
  font-family:var(--mono);font-size:13px;color:var(--ink);
  word-break:break-all;line-height:1.5;
}
.specimen dd .hl{color:var(--accent-soft)}
.bytecode{
  margin-top:18px;padding:14px 16px;
  background:#100f0c;border:1px solid var(--hair-2);
  font-family:var(--mono);font-size:11.5px;line-height:1.7;
  color:var(--ink-faint);
  word-break:break-all;max-height:152px;overflow:hidden;
  position:relative;
}
.bytecode::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:54px;
  background:linear-gradient(180deg,transparent,#100f0c);
}
.bytecode .op{color:var(--accent-soft)}
.bytecode-cap{margin-top:10px}

/* the selector callout */
.selector-strip{
  margin-top:26px;
  display:flex;flex-wrap:wrap;align-items:center;gap:8px 16px;
  padding:16px 20px;
  background:var(--paper-3);border:1px solid var(--hair);
}
.selector-strip .sel-eq{
  font-family:var(--mono);font-size:13px;color:var(--ink-soft);
}
.selector-strip .sel-hex{
  font-family:var(--mono);font-weight:700;font-size:18px;
  color:var(--accent-soft);letter-spacing:.04em;
}
.selector-strip .sel-note{
  font-family:var(--mono);font-size:10.5px;color:var(--ink-faint);
  letter-spacing:.06em;
}

/* ============================================================
   WHY MOOSE — the placeholder story
   ============================================================ */
.why{background:var(--paper-2)}
.why .bay{padding-block:104px}
.why-layout{
  display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;
}
.why-quote{
  font-family:var(--display);font-weight:500;font-style:italic;
  font-size:clamp(26px,3vw,40px);line-height:1.26;
  letter-spacing:-.012em;color:var(--ink);
}
.why-quote .hl{
  font-style:normal;color:var(--accent-soft);
  font-family:var(--mono);font-weight:700;font-size:.74em;
}
.why-attrib{
  margin-top:24px;font-family:var(--mono);font-size:11px;
  letter-spacing:.1em;color:var(--ink-faint);text-transform:uppercase;
}
.why-prose p{margin:0 0 18px;color:var(--ink-soft);max-width:50ch}
.why-prose p:last-child{margin-bottom:0}
.why-prose strong{color:var(--ink);font-weight:600}
.why-prose em{font-style:italic;color:var(--ink)}

/* the evidence ledger — the verifiable beats */
.ledger{
  margin-top:48px;
  border-top:1px solid var(--hair);
}
.ledger-row{
  display:grid;grid-template-columns:130px 1fr auto;gap:24px;
  align-items:baseline;
  padding:18px 4px;
  border-bottom:1px solid var(--hair-2);
}
.ledger-row .lr-date{
  font-family:var(--mono);font-weight:700;font-size:12px;
  color:var(--accent-soft);letter-spacing:.06em;
}
.ledger-row .lr-fact{
  font-family:var(--body);font-size:16.5px;color:var(--ink);line-height:1.5;
}
.ledger-row .lr-fact em{font-style:italic;color:var(--ink-soft)}
.ledger-row .lr-src{
  font-family:var(--mono);font-size:10px;text-transform:uppercase;
  letter-spacing:.1em;color:var(--ink-faint);white-space:nowrap;
}

/* ============================================================
   THE MECHANIC — what a buy does
   ============================================================ */
.mech-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:8px;
}
.mech-card{
  background:var(--paper-2);border:1px solid var(--hair);
  padding:30px 30px 32px;
  display:flex;flex-direction:column;gap:14px;
}
.mech-card .mc-tag{
  display:flex;align-items:center;gap:10px;
  font-family:var(--mono);font-weight:700;font-size:10.5px;
  text-transform:uppercase;letter-spacing:.14em;color:var(--accent-soft);
}
.mech-card .mc-tag .num{
  font-size:11px;color:var(--ink-faint);
}
.mech-card h3{
  font-family:var(--display);font-weight:600;font-size:24px;
  line-height:1.15;letter-spacing:-.01em;color:var(--ink);
}
.mech-card p{font-size:16px;color:var(--ink-soft);line-height:1.6}
.mech-card p code{
  font-family:var(--mono);font-size:.84em;
  background:var(--paper-3);padding:1px 5px;color:var(--accent-soft);
}
.mech-card .mc-fig{
  border-top:1px solid var(--hair-2);padding-top:16px;margin-top:auto;
}
.mech-card .mc-fig svg{width:100%;height:auto}

/* ============================================================
   THE HERD — census gallery
   ============================================================ */
.herd-head{
  display:flex;flex-wrap:wrap;justify-content:space-between;
  align-items:flex-end;gap:24px;margin-bottom:36px;
}
.herd-head .hh-copy{max-width:48ch}
.census-board{
  display:flex;gap:0;flex-wrap:wrap;
  border:1px solid var(--hair);
}
.census-cell{
  flex:1;min-width:150px;
  padding:18px 20px;
  border-left:1px solid var(--hair-2);
}
.census-cell:first-child{border-left:0}
.census-cell .cc-k{
  font-family:var(--mono);font-size:9.5px;text-transform:uppercase;
  letter-spacing:.14em;color:var(--ink-faint);
}
.census-cell .cc-v{
  font-family:var(--display);font-weight:600;font-size:30px;
  color:var(--ink);line-height:1;margin-top:8px;
  font-variant-numeric:tabular-nums;
}
.census-cell .cc-v.live{color:var(--accent-soft)}
.census-cell .cc-n{
  font-family:var(--mono);font-size:10px;color:var(--ink-faint);
  margin-top:6px;letter-spacing:.04em;
}

.herd-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:18px;
  margin-top:30px;
}
.specimen-card{
  background:var(--paper-2);border:1px solid var(--hair);
  display:flex;flex-direction:column;
  transition:border-color .16s,transform .16s;
}
.specimen-card:hover{border-color:var(--accent);transform:translateY(-3px)}
.specimen-card .frame{
  position:relative;
  background:#100f0c;
  border-bottom:1px solid var(--hair);
}
.specimen-card .frame img{
  width:100%;height:auto;
  image-rendering:pixelated;
  display:block;
}
.specimen-card .frame .acc{
  position:absolute;top:8px;left:8px;
  font-family:var(--mono);font-weight:700;font-size:9px;
  letter-spacing:.1em;color:var(--ink-faint);
  background:rgba(16,15,12,.82);padding:3px 6px;
}
.specimen-card .label{
  padding:13px 15px 15px;
  display:flex;flex-direction:column;gap:7px;
}
.specimen-card .label .sl-name{
  font-family:var(--display);font-weight:600;font-size:16px;
  color:var(--ink);line-height:1.1;
}
.specimen-card .label .sl-traits{
  display:flex;flex-wrap:wrap;gap:4px;
}
.specimen-card .label .trait{
  font-family:var(--mono);font-size:9px;text-transform:uppercase;
  letter-spacing:.06em;color:var(--ink-faint);
  border:1px solid var(--hair-2);padding:2px 5px;
}
.specimen-card .label .trait.sig{
  color:var(--accent-soft);border-color:rgba(210,105,30,.32);
}
.herd-note{
  margin-top:26px;
  font-family:var(--mono);font-size:11.5px;color:var(--ink-faint);
  letter-spacing:.04em;line-height:1.7;
  border-left:2px solid var(--hair);padding-left:16px;max-width:70ch;
}
.herd-note .hl{color:var(--accent-soft)}

/* ============================================================
   VERIFY — do it yourself
   ============================================================ */
.verify{background:var(--paper-2)}
.verify .bay{padding-block:104px}
.verify-intro{max-width:60ch;margin-bottom:40px}
.cmd-stack{display:flex;flex-direction:column;gap:18px}
.cmd{
  background:#100f0c;border:1px solid var(--hair);
  border-left:3px solid var(--accent);
}
.cmd-top{
  display:flex;justify-content:space-between;align-items:center;
  padding:11px 16px;border-bottom:1px solid var(--hair-2);
}
.cmd-top .ct-label{
  font-family:var(--mono);font-weight:700;font-size:10px;
  text-transform:uppercase;letter-spacing:.14em;color:var(--ink-faint);
}
.cmd-body{
  padding:16px 18px;overflow-x:auto;
}
.cmd-body pre{
  font-family:var(--mono);font-size:13px;line-height:1.7;
  color:var(--ink);white-space:pre;
}
.cmd-body .prompt{color:var(--accent-soft);user-select:none}
.cmd-body .cm{color:var(--ink-faint)}
.cmd-body .str{color:var(--moss)}
.cmd-out{
  padding:12px 18px;border-top:1px solid var(--hair-2);
  font-family:var(--mono);font-size:12px;color:var(--ink-faint);
  line-height:1.7;
}
.cmd-out .res{color:var(--ink-soft)}

/* the disclaimer placard */
.disclaimer{
  margin-top:48px;
  background:var(--paper-3);
  border:1px solid var(--hair);
  border-top:3px solid var(--moss);
  padding:36px 38px;
}
.disclaimer .dc-flag{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--mono);font-weight:700;font-size:10.5px;
  text-transform:uppercase;letter-spacing:.16em;color:var(--moss);
  margin-bottom:18px;
}
.disclaimer .dc-flag::before{
  content:"";width:8px;height:8px;background:var(--moss);
  transform:rotate(45deg);
}
.disclaimer h3{
  font-family:var(--display);font-weight:600;font-size:23px;
  color:var(--ink);margin-bottom:14px;letter-spacing:-.01em;
}
.disclaimer p{
  font-size:16px;color:var(--ink-soft);max-width:64ch;margin:0 0 14px;
}
.disclaimer p:last-child{margin-bottom:0}
.disclaimer strong{color:var(--ink);font-weight:600}
.disclaimer em{font-style:italic;color:var(--ink)}
.disclaimer .dc-addr{
  font-family:var(--mono);font-size:12px;color:var(--accent-soft);
}

/* ============================================================
   CHECK YOUR HERD — the per-wallet lookup console
   ============================================================ */
.herd-check{
  background:var(--paper-2);
  border:1px solid var(--hair);
  border-left:3px solid var(--accent);
  padding:26px 28px 28px;
}

/* the input bar — address field + the two buttons */
.hc-bar{
  display:flex;flex-wrap:wrap;align-items:flex-end;gap:16px 18px;
}
.hc-field{
  flex:1;min-width:260px;
  display:flex;flex-direction:column;gap:8px;
}
.hc-flabel{
  font-family:var(--mono);font-weight:700;font-size:10px;
  text-transform:uppercase;letter-spacing:.16em;color:var(--ink-faint);
}
.hc-field input{
  width:100%;
  font-family:var(--mono);font-size:14px;letter-spacing:.02em;
  color:var(--ink);
  background:#100f0c;
  border:1px solid var(--hair);
  padding:13px 14px;
  transition:border-color .14s;
}
.hc-field input::placeholder{color:var(--ink-faint);opacity:.7}
.hc-field input:focus{outline:none;border-color:var(--accent)}
.hc-actions{display:flex;gap:10px;flex-wrap:wrap}
.hc-btn{
  font-family:var(--mono);font-weight:700;font-size:10.5px;
  text-transform:uppercase;letter-spacing:.14em;
  padding:13px 18px;white-space:nowrap;
  border:1px solid var(--hair);
  transition:background .14s,color .14s,border-color .14s,opacity .14s;
}
.hc-btn-ghost{color:var(--ink-soft)}
.hc-btn-ghost:hover{border-color:var(--ink-soft);color:var(--ink)}
.hc-btn-solid{
  background:var(--accent);color:#161512;border-color:var(--accent);
}
.hc-btn-solid:hover{background:var(--accent-soft);border-color:var(--accent-soft)}
.hc-btn[disabled]{opacity:.4;cursor:not-allowed}
.hc-btn[disabled]:hover{
  background:var(--accent);color:#161512;border-color:var(--accent);
}
.hc-btn-ghost[disabled]:hover{
  background:none;color:var(--ink-soft);border-color:var(--hair);
}

/* the status line — one honest message */
.hc-status{
  display:flex;align-items:baseline;gap:10px;
  margin-top:18px;
  font-family:var(--mono);font-size:11.5px;line-height:1.6;
  letter-spacing:.04em;color:var(--ink-faint);
}
.hc-status .hc-dot{
  flex:0 0 7px;width:7px;height:7px;border-radius:50%;
  background:var(--ink-faint);transform:translateY(1px);
}
.hc-status.is-loading .hc-dot{
  background:var(--accent);animation:breathe 2s ease-in-out infinite;
}
.hc-status.is-loading{color:var(--accent-soft)}
.hc-status.is-error .hc-dot{background:var(--accent)}
.hc-status.is-error{color:var(--accent-soft)}
.hc-status.is-ok .hc-dot{background:var(--moss)}
.hc-status.is-empty .hc-dot{background:var(--ink-soft)}

/* the resolved-wallet line — a quiet caption above the grid */
.hc-resolved-line{
  display:flex;flex-wrap:wrap;align-items:baseline;gap:8px;
  margin-top:20px;
}
.hc-resolved-line .hc-rl-k{
  font-family:var(--mono);font-size:9.5px;text-transform:uppercase;
  letter-spacing:.14em;color:var(--ink-faint);
}
.hc-resolved-line .hc-rl-addr{
  font-family:var(--mono);font-size:12.5px;font-weight:500;
  color:var(--ink);word-break:break-all;
}

/* census strip — collection-wide stats, spare and compact */
.hc-census{
  display:flex;flex-wrap:wrap;gap:0;
  margin-top:14px;
  border:1px solid var(--hair);
}
.hc-stat{
  flex:1;min-width:120px;
  display:flex;flex-direction:column;gap:6px;
  padding:14px 18px;
  border-left:1px solid var(--hair-2);
}
.hc-stat:first-child{border-left:0}
.hc-stat .hc-stat-v{
  font-family:var(--display);font-weight:600;font-size:26px;
  color:var(--accent-soft);line-height:1;
  font-variant-numeric:tabular-nums;
}
.hc-stat .hc-stat-k{
  font-family:var(--mono);font-size:9.5px;text-transform:uppercase;
  letter-spacing:.14em;color:var(--ink-faint);
}

/* the rendered herd gallery — uniform squares, generous gap, art is the hero */
.hc-gallery{
  display:grid;grid-template-columns:repeat(4,1fr);gap:20px;
  margin-top:22px;
}
.hc-moose{
  display:flex;flex-direction:column;gap:9px;
}
.hc-moose .hc-frame{
  position:relative;
  aspect-ratio:1/1;
  background:#100f0c;
  border:1px solid var(--hair);
  overflow:hidden;
  transition:border-color .16s,transform .16s;
}
.hc-moose:hover .hc-frame{border-color:var(--accent);transform:translateY(-3px)}
.hc-moose .hc-frame svg,
.hc-moose .hc-frame img{
  width:100%;height:100%;display:block;
  object-fit:contain;
  image-rendering:pixelated;
}
/* the caption sits underneath the tile — the Herd ID, nothing else */
.hc-moose .hc-cap{
  font-family:var(--mono);font-size:11px;font-weight:500;
  letter-spacing:.06em;color:var(--ink-soft);
  text-align:center;
}
/* a placeholder tile while herdArt() is in flight */
.hc-moose.is-pending .hc-frame{
  display:flex;align-items:center;justify-content:center;
}
.hc-moose.is-pending .hc-frame::before{
  content:"reading…";
  font-family:var(--mono);font-size:10px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--ink-faint);
  animation:breathe 2s ease-in-out infinite;
}
/* a tile whose herdArt() call failed */
.hc-moose.is-failed .hc-frame{
  display:flex;align-items:center;justify-content:center;
}
.hc-moose.is-failed .hc-frame::before{
  content:"unreadable";
  font-family:var(--mono);font-size:10px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--accent-soft);
}

/* graceful empty / zero state — spare, centred, placard voice */
.hc-empty{
  margin-top:22px;
  border:1px dashed var(--hair);
  padding:48px 28px;
  display:flex;flex-direction:column;align-items:center;gap:10px;
  text-align:center;
}
.hc-empty .hc-empty-mark{
  width:38px;height:38px;opacity:.5;
}
.hc-empty .hc-empty-mark .antler{fill:var(--ink-faint)}
.hc-empty .hc-empty-mark .pelt{fill:var(--ink-faint)}
.hc-empty .hc-empty-line{
  font-family:var(--display);font-weight:600;font-size:19px;
  color:var(--ink);
}
.hc-empty .hc-empty-sub{
  font-family:var(--mono);font-size:11.5px;letter-spacing:.04em;
  color:var(--ink-faint);max-width:42ch;
}

/* ============================================================
   DEV RECIPES — the demoted, collapsible cast section
   ============================================================ */
.dev-recipes{
  border:1px solid var(--hair);
  background:#100f0c;
}
.dev-recipes summary{
  display:flex;align-items:center;gap:14px;
  padding:16px 20px;
  cursor:pointer;list-style:none;
  transition:background .14s;
}
.dev-recipes summary::-webkit-details-marker{display:none}
.dev-recipes summary:hover{background:var(--paper-3)}
.dev-recipes .dr-flag{
  font-family:var(--mono);font-weight:700;font-size:9.5px;
  text-transform:uppercase;letter-spacing:.16em;color:var(--ink-faint);
  border:1px solid var(--hair);padding:4px 8px;white-space:nowrap;
}
.dev-recipes .dr-title{
  font-family:var(--mono);font-weight:500;font-size:12px;
  letter-spacing:.04em;color:var(--ink-soft);flex:1;
}
.dev-recipes .dr-title code{
  font-size:.9em;color:var(--accent-soft);
}
.dev-recipes .dr-chevron{
  width:9px;height:9px;flex:0 0 9px;
  border-right:1.6px solid var(--ink-faint);
  border-bottom:1.6px solid var(--ink-faint);
  transform:rotate(45deg) translateY(-2px);
  transition:transform .18s ease-out;
}
.dev-recipes[open] .dr-chevron{transform:rotate(-135deg) translateY(-1px)}
.dev-recipes .cmd-stack{
  padding:4px 20px 20px;
}
.dev-recipes .cmd{background:var(--paper);}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{
  border-top:1px solid var(--hair);
}
.footer-main{
  max-width:var(--container);margin:0 auto;
  padding:54px var(--gutter);
  display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;
  align-items:start;
}
.footer-mark{
  display:flex;align-items:center;gap:11px;
  font-family:var(--display);font-weight:600;font-size:26px;
  color:var(--ink);
}
.footer-mark svg{width:30px;height:30px}
.footer-tag{
  margin-top:14px;font-family:var(--mono);font-size:11px;
  color:var(--ink-faint);letter-spacing:.06em;line-height:1.7;
  max-width:34ch;
}
.footer-col h4{
  font-family:var(--mono);font-weight:700;font-size:10px;
  text-transform:uppercase;letter-spacing:.16em;color:var(--ink-faint);
  margin-bottom:14px;
}
.footer-col a,.footer-col span{
  display:block;
  font-family:var(--mono);font-size:12px;color:var(--ink-soft);
  margin:7px 0;letter-spacing:.02em;
  transition:color .14s;
}
.footer-col a:hover{color:var(--accent-soft)}
.footer-base{
  border-top:1px solid var(--hair-2);
  max-width:var(--container);margin:0 auto;
  padding:20px var(--gutter);
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:12px;
}
.footer-base span{
  font-family:var(--mono);font-size:10px;letter-spacing:.08em;
  color:var(--ink-faint);
}

/* ============================================================
   KEYFRAMES
   ============================================================ */
@keyframes breathe{
  0%,100%{box-shadow:0 0 0 4px rgba(210,105,30,.16)}
  50%{box-shadow:0 0 0 8px rgba(210,105,30,.04)}
}
[data-rise]{
  opacity:0;transform:translateY(16px);
  transition:opacity .6s ease-out,transform .6s ease-out;
}
[data-rise].in{opacity:1;transform:none}

/* ============================================================
   RESPONSIVE — tablet
   ============================================================ */
@media (max-width:1000px){
  :root{--gutter:40px}
  .artifact-grid{grid-template-columns:1fr;gap:40px}
  .why-layout{grid-template-columns:1fr;gap:36px}
  .mech-grid{grid-template-columns:1fr}
  .herd-grid{grid-template-columns:repeat(3,1fr)}
  .hc-gallery{grid-template-columns:repeat(3,1fr)}
  .footer-main{grid-template-columns:1fr 1fr}
}

/* ============================================================
   MULTI-PAGE — sticky footer, active nav, exhibit index, pager
   ============================================================ */

/* every page fills the viewport; the footer sits at the base */
body{min-height:100vh;display:flex;flex-direction:column}
main{flex:1 0 auto}

/* the current page, marked in the spine nav */
.spine nav a[aria-current="page"]{color:var(--ink)}
.spine nav a[aria-current="page"]::after{transform:scaleX(1)}

/* the hero cue is now a real link down to the exhibit index */
.hero-scroll{transition:color .14s}
a.hero-scroll:hover{color:var(--accent-soft)}
a.hero-scroll:hover::before{background:var(--accent)}

/* ---- the exhibit index — home-page room directory ---- */
.exhibit-index{
  display:flex;flex-direction:column;
  border-top:1px solid var(--hair);
}
.ex-room{
  display:flex;align-items:center;gap:26px;
  padding:26px 10px;
  border-bottom:1px solid var(--hair);
  color:inherit;
  transition:background .15s,padding-left .15s;
}
.ex-room:hover{background:var(--paper-2);padding-left:22px}
.ex-num{
  flex:0 0 auto;
  font-family:var(--mono);font-weight:700;font-size:13px;
  letter-spacing:.1em;color:var(--accent-soft);
}
.ex-body{display:flex;flex-direction:column;gap:5px;flex:1;min-width:0}
.ex-name{
  font-family:var(--display);font-weight:600;font-size:25px;
  line-height:1.1;letter-spacing:-.01em;color:var(--ink);
}
.ex-desc{
  font-family:var(--body);font-size:16px;line-height:1.5;
  color:var(--ink-soft);
}
.ex-go{
  flex:0 0 auto;
  font-family:var(--mono);font-size:20px;color:var(--ink-faint);
  transition:color .15s,transform .15s;
}
.ex-room:hover .ex-go{color:var(--accent);transform:translateX(5px)}

/* ---- the room pager — prev / next at the foot of each room ---- */
.room-pager{
  max-width:var(--container);
  margin:0 auto;width:100%;
  display:flex;gap:18px;
  padding:34px var(--gutter) 100px;
}
.room-pager a{
  flex:1;min-width:0;
  display:flex;flex-direction:column;gap:7px;
  padding:22px 24px;
  background:var(--paper-2);
  border:1px solid var(--hair);
  color:inherit;
  transition:border-color .15s,background .15s;
}
.room-pager a:hover{border-color:var(--accent);background:var(--paper-3)}
.rp-next{text-align:right}
.rp-dir{
  font-family:var(--mono);font-weight:700;font-size:10px;
  text-transform:uppercase;letter-spacing:.15em;color:var(--ink-faint);
}
.rp-name{
  font-family:var(--display);font-weight:600;font-size:21px;
  line-height:1.1;color:var(--ink);
}
.room-pager a:hover .rp-name{color:var(--accent-soft)}

/* ============================================================
   RESPONSIVE — mobile
   ============================================================ */
@media (max-width:680px){
  :root{--gutter:20px}
  body{font-size:17px}
  .bay{padding:68px var(--gutter)}
  .hero{padding:104px var(--gutter) 64px}
  .spine{padding:0 16px;gap:12px}
  .spine .accession{display:none}
  .herd-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .hc-gallery{grid-template-columns:repeat(2,1fr);gap:12px}
  .census-board{flex-direction:column}
  .census-cell{border-left:0;border-top:1px solid var(--hair-2)}
  .census-cell:first-child{border-top:0}
  .herd-check{padding:22px 18px 24px}
  .hc-actions{width:100%}
  .hc-actions .hc-btn{flex:1}
  .dev-recipes summary{flex-wrap:wrap;gap:8px 12px}
  .dev-recipes .cmd-stack{padding:4px 12px 16px}
  .ledger-row{
    grid-template-columns:1fr;gap:6px;
  }
  .ledger-row .lr-src{justify-self:start}
  .footer-main{grid-template-columns:1fr;gap:32px}
  .disclaimer{padding:28px 22px}
  .verify .bay,.why .bay{padding-block:72px}
  .ex-room{gap:14px;padding:20px 4px}
  .ex-room:hover{padding-left:10px}
  .ex-name{font-size:20px}
  .ex-desc{font-size:14.5px}
  .ex-go{font-size:17px}
  .room-pager{padding:24px var(--gutter) 64px;gap:10px}
  .room-pager a{padding:16px 15px}
  .rp-name{font-size:16px}
}

/* ============================================================
   REDUCED MOTION
   ============================================================ */
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{
    animation-duration:.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.001ms !important;
  }
  [data-rise]{opacity:1;transform:none}
}
