/* thoth · uma oracle court — editorial-forensic ledger.
   near-black navy, parchment ink, gold rules. mono for evidence, serif for verdicts. */

@font-face { font-family:'Playfair Display'; src:url('/assets/fonts/playfair.woff2') format('woff2');
  font-weight:400 900; font-display:swap; }
@font-face { font-family:'Cormorant Garamond'; src:url('/assets/fonts/cormorant.woff2') format('woff2');
  font-weight:300 700; font-style:normal; font-display:swap; }
@font-face { font-family:'Cormorant Garamond'; src:url('/assets/fonts/cormorant-italic.woff2') format('woff2');
  font-weight:300 700; font-style:italic; font-display:swap; }
@font-face { font-family:'JetBrains Mono'; src:url('/assets/fonts/jetbrains.woff2') format('woff2');
  font-weight:100 800; font-display:swap; }

:root {
  --bg:#05060c; --bg2:#0a1336; --bg3:#122254;
  --ink:#EDE6D6; --mut:#7E8AB8; --mut2:#9AA6D4;
  --gold:#C9A24B; --gold2:#E8C36A; --bad:#C25B4A;
  --hair:rgba(201,162,75,.22); --hair2:rgba(201,162,75,.12);
  --mono:'JetBrains Mono',ui-monospace,monospace;
  --serif:'Playfair Display',Georgia,serif;
  --garamond:'Cormorant Garamond',Georgia,serif;
}

* { margin:0; padding:0; box-sizing:border-box; }
html { -webkit-text-size-adjust:100%; }
body {
  background:var(--bg); color:var(--ink); font-family:var(--mono);
  font-size:14px; line-height:1.55; min-height:100vh; position:relative;
}
body::before { /* navy glow, as on the cards */
  content:''; position:fixed; inset:0; z-index:-2; pointer-events:none;
  background:radial-gradient(90% 55% at 50% -10%, var(--bg3) 0%, var(--bg2) 38%, var(--bg) 75%);
}
body::after { /* grain */
  content:''; position:fixed; inset:0; z-index:-1; pointer-events:none; opacity:.045;
  background-image:repeating-linear-gradient(0deg,#fff 0 1px,transparent 1px 3px);
  mix-blend-mode:overlay;
}

.wrap { max-width:1060px; margin:0 auto; padding:0 22px 90px; }
a { color:var(--gold2); text-decoration:none; }
a:hover { text-decoration:underline; text-underline-offset:3px; }

/* ------------------------------------------------ header */
header { padding:30px 0 0; }
.topline { display:flex; justify-content:space-between; align-items:center; gap:16px; }
.brand { display:flex; align-items:center; gap:13px; color:var(--gold); }
.brand:hover { text-decoration:none; }
.brand svg { width:40px; height:30px; filter:drop-shadow(0 0 10px rgba(232,195,106,.35)); flex:none; }
.brand span { font-size:12px; letter-spacing:6px; text-transform:uppercase; font-weight:500; }
nav { display:flex; gap:22px; font-size:12px; letter-spacing:3px; text-transform:uppercase; }
nav a { color:var(--mut2); }
nav a.on, nav a:hover { color:var(--gold2); text-decoration:none; }
.goldrule { height:1px; margin:24px 0 0;
  background:linear-gradient(90deg,var(--gold) 0%,rgba(201,162,75,.25) 55%,rgba(201,162,75,0) 100%); }

/* ------------------------------------------------ hero + eyefield (webgl particles) */
#eyefield { position:absolute; left:0; right:0; top:0; height:660px; z-index:-1;
  pointer-events:auto; overflow:hidden;
  -webkit-mask-image:linear-gradient(180deg,#000 0%,#000 78%,transparent 100%);
  mask-image:linear-gradient(180deg,#000 0%,#000 78%,transparent 100%); }
#eyefield canvas { display:block; }
body { position:relative; }
.hero { padding:64px 0 8px; max-width:820px; position:relative; }
@media (max-width:720px) { #eyefield { opacity:.4; } }
.hero h1 { font-family:var(--serif); font-weight:700; font-size:clamp(34px,6vw,58px);
  line-height:1.06; letter-spacing:.5px; }
.hero h1 em { font-style:normal; color:var(--gold2); }
.hero .sub { margin-top:22px; color:var(--mut2); font-size:14.5px; max-width:640px; }
.hero .sub b { color:var(--ink); font-weight:500; }
.tagline { margin-top:18px; font-family:var(--garamond); font-style:italic; font-size:21px;
  letter-spacing:1px; color:var(--gold); }

/* stats strip */
.stats { display:flex; flex-wrap:wrap; margin:44px 0 0; border-top:1px solid var(--hair);
  border-bottom:1px solid var(--hair); }
.stat { flex:1 1 130px; padding:18px 10px 16px; text-align:center; border-right:1px solid var(--hair2); }
.stat:last-child { border-right:none; }
.stat .k { font-size:10.5px; letter-spacing:3px; color:var(--mut); text-transform:uppercase; }
.stat .v { margin-top:7px; font-size:23px; font-weight:600; color:var(--ink); }
.stat .v.gold { color:var(--gold2); }

/* ------------------------------------------------ caveats (the trust feature, not fine print) */
.caveats { position:relative; margin:54px 0 0; padding:34px 38px 30px;
  border:2px solid rgba(201,162,75,.8); }
.caveats::before { content:''; position:absolute; inset:7px; border:1px solid rgba(232,195,106,.32);
  pointer-events:none; }
.caveats .dm { position:absolute; width:9px; height:9px; background:var(--gold);
  transform:rotate(45deg); box-shadow:0 0 8px rgba(201,162,75,.5); }
.caveats .d1{ top:-5px; left:-5px; } .caveats .d2{ top:-5px; right:-5px; }
.caveats .d3{ bottom:-5px; left:-5px; } .caveats .d4{ bottom:-5px; right:-5px; }
.caveats h2 { font-size:12px; letter-spacing:5px; text-transform:uppercase; color:var(--gold2);
  margin-bottom:18px; }
.caveats ol { list-style:none; counter-reset:cv; }
.caveats li { counter-increment:cv; position:relative; padding:10px 0 10px 44px;
  color:var(--mut2); font-size:13.5px; border-top:1px solid var(--hair2); }
.caveats li:first-child { border-top:none; }
.caveats li::before { content:counter(cv,decimal-leading-zero); position:absolute; left:0; top:11px;
  color:var(--gold); font-size:12px; letter-spacing:1px; }
.caveats li b { color:var(--ink); font-weight:500; }

/* ------------------------------------------------ sections + tables */
section { margin-top:64px; }
.sechead { display:flex; align-items:baseline; justify-content:space-between; gap:14px;
  flex-wrap:wrap; margin-bottom:6px; }
.sechead h2 { font-family:var(--serif); font-weight:600; font-size:26px; }
.sechead .note { color:var(--mut); font-size:12px; letter-spacing:1px; }
.sechead .more { font-size:12px; letter-spacing:2px; text-transform:uppercase; }

.tblwrap { overflow-x:auto; margin-top:14px; }
table { width:100%; border-collapse:collapse; font-size:13px; white-space:nowrap; }
th { font-size:10.5px; letter-spacing:2.5px; text-transform:uppercase; color:var(--mut);
  font-weight:500; text-align:left; padding:10px 14px 8px 0;
  border-bottom:1px solid var(--hair); cursor:pointer; user-select:none; }
th.n, td.n { text-align:right; }
th:hover { color:var(--gold2); }
th .arr { color:var(--gold2); }
td { padding:9px 14px 9px 0; border-bottom:1px solid var(--hair2); vertical-align:middle; }
tr:hover td { background:rgba(201,162,75,.045); }
td.t { white-space:normal; min-width:230px; max-width:520px; }
td .mut { color:var(--mut); }
.addr { color:var(--gold2); }
.ok { color:var(--gold); }
.no { color:var(--bad); }
.pill { display:inline-block; border:1px solid rgba(232,195,106,.7); color:var(--gold2);
  padding:2px 10px; font-size:11px; letter-spacing:2.5px; text-transform:uppercase; }
.pill.bad { border-color:rgba(194,91,74,.7); color:var(--bad); }

/* inline meter (against% / concentration) */
.m { display:inline-flex; align-items:center; gap:8px; }
.m i { display:inline-block; width:52px; height:5px; background:rgba(126,138,184,.18); flex:none; }
.m i b { display:block; height:100%; background:var(--gold); }
.m i b.bad { background:var(--bad); }

/* search */
.search { margin-top:16px; }
.search input { width:100%; max-width:420px; background:rgba(126,138,184,.07);
  border:1px solid var(--hair); color:var(--ink); font-family:var(--mono); font-size:13px;
  padding:9px 13px; outline:none; }
.search input:focus { border-color:var(--gold); }
.search input::placeholder { color:var(--mut); }

/* ------------------------------------------------ detail pages */
.crumb { margin-top:46px; font-size:11px; letter-spacing:3px; text-transform:uppercase; color:var(--mut); }
.crumb a { color:var(--mut2); }
.dtitle { margin-top:14px; font-family:var(--serif); font-weight:600;
  font-size:clamp(26px,4.5vw,40px); line-height:1.14; max-width:860px; }
.dmeta { margin-top:16px; display:flex; align-items:center; gap:18px; flex-wrap:wrap;
  font-size:12px; letter-spacing:2px; text-transform:uppercase; color:var(--mut2); }
.waddr { margin-top:14px; font-size:clamp(15px,2.8vw,22px); color:var(--gold2);
  word-break:break-all; font-weight:500; letter-spacing:.5px; }

/* hash-chain receipt */
.receipt { margin-top:40px; border:1px dashed rgba(201,162,75,.45); padding:20px 24px;
  font-size:12px; color:var(--mut2); }
.receipt .rk { color:var(--mut); letter-spacing:2.5px; text-transform:uppercase; font-size:10.5px; }
.receipt .rv { color:var(--ink); word-break:break-all; margin:3px 0 12px; }
.receipt .rv:last-child { margin-bottom:0; }
.receipt .rv.gold { color:var(--gold2); }

/* ------------------------------------------------ method + footer */
.method p { color:var(--mut2); font-size:13.5px; max-width:760px; margin-top:12px; }
.method p b { color:var(--ink); font-weight:500; }
.method code { color:var(--gold2); font-size:12.5px; word-break:break-all; }
.dl { margin-top:18px; display:flex; gap:14px; flex-wrap:wrap; }
.dl a { border:1px solid var(--hair); padding:8px 16px; font-size:12px; letter-spacing:2px;
  text-transform:uppercase; }
.dl a:hover { border-color:var(--gold); text-decoration:none; }

footer { margin-top:90px; border-top:1px solid var(--hair); padding-top:28px;
  display:flex; justify-content:space-between; align-items:flex-end; gap:18px; flex-wrap:wrap; }
footer .l { color:var(--mut); font-size:12px; letter-spacing:2px; }
footer .l a { color:var(--mut2); }
footer .eye { font-size:20px; color:var(--gold2); }
footer .tag { font-family:var(--garamond); font-style:italic; font-size:19px; color:var(--gold); }

/* load motion: one staggered rise */
@media (prefers-reduced-motion:no-preference) {
  .hero, .stats, .caveats, section { animation:rise .55s cubic-bezier(.2,.7,.2,1) both; }
  .stats { animation-delay:.06s; } .caveats { animation-delay:.12s; }
  section { animation-delay:.18s; }
  @keyframes rise { from { opacity:0; transform:translateY(14px); } to { opacity:1; transform:none; } }
}

@media (max-width:640px) {
  .topline { flex-wrap:wrap; }
  .brand span { letter-spacing:3px; white-space:nowrap; }
  nav { gap:14px; width:100%; overflow-x:auto; padding-bottom:2px; }
  .caveats { padding:24px 18px 20px; }
  .stat { flex:1 1 45%; border-right:none; }
}
