/* ── RepoQL design system — bio palette, one family across website / portal / dashboard ── */

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  /* Bio palette — canonical */
  --bg:#060d14;        /* deep navy background */
  --c:#2dd4bf;         /* network: branches, tip dots, accents */
  --cp:#5eead4;        /* electrical pulse highlights */
  --text:#d0ece4;      /* teal-tinted white — never pure white */
  --mid:#80e0d0;       /* primary branches from letters */
  /* Surface tints derived from the palette */
  --panel:rgba(13,26,34,0.62);
  --panel-solid:#0b161f;
  --panel-edge:rgba(45,212,191,0.14);
  --hair:rgba(128,224,208,0.12);
  --fg:#d0ece4;
  --fg2:#8fb3ab;
  --fg3:#5f807a;
  --warn:#e8c47c;      /* honest-warning amber — status only, never decoration */
  --vio:#a78bfa;       /* symbols & modifiers — the address magic */
  --copper:#e0a674;    /* budgets & costs — tokens, spent deliberately */
  --font-display:'Newsreader',Georgia,serif;
  --font-body:'DM Sans',system-ui,sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,monospace;
}
html{font-size:clamp(15px,1.05vw,18px);scroll-behavior:smooth}
body{
  background:var(--bg);color:var(--fg);font-family:var(--font-body);
  line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased;overflow-x:hidden;
}
/* fine film grain — luminosity from contrast, never blur */
body::after{content:'';position:fixed;inset:0;z-index:900;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.025'/%3E%3C/svg%3E");background-size:256px}

/* ── the substrate: mycelium behind everything ── */
#bg-mycelium{position:fixed;inset:0;width:100%;height:100%;pointer-events:none;z-index:0;opacity:0.3;contain:strict}
#bg-ellipse{position:fixed;inset:-60% -10%;pointer-events:none;z-index:1;
  background:radial-gradient(ellipse 46% 52% at 50% 42%,var(--bg) 66%,rgba(6,13,20,0.72) 74%,rgba(6,13,20,0.32) 82%,transparent 90%)}

a{color:var(--c);text-decoration:none}
a:hover{color:var(--cp)}
::selection{background:rgba(45,212,191,.25)}

/* ── shared chrome: top nav ── */
.nav{position:relative;z-index:5;display:flex;align-items:center;gap:28px;
  max-width:1180px;margin:0 auto;padding:20px 28px}
.nav__brand{display:flex;align-items:center;gap:12px;color:var(--text)}
.nav__brand svg{width:32px;height:32px;border-radius:9px;background:var(--bg);border:1px solid #0f1e2e}
.nav__brand span{font-family:var(--font-display);font-size:1.12rem;letter-spacing:.01em}
.nav__links{display:flex;gap:22px;margin-left:auto;align-items:center}
.nav__links a{font-size:.9rem;color:var(--fg2)}
.nav__links a:hover,.nav__links a.active{color:var(--text)}
.nav__links a.active{position:relative}
.nav__links a.active::after{content:'';position:absolute;left:0;right:0;bottom:-6px;height:2px;border-radius:2px;background:var(--c);opacity:.7}
.nav__links a.btn--primary,.nav__links a.btn--primary:hover{color:#04211c}

/* ── buttons: geometric, predictable — organic shapes never signal "click here" ── */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-body);font-weight:600;
  font-size:.92rem;border-radius:12px;padding:11px 20px;cursor:pointer;border:1px solid transparent;
  transition:transform .15s,background .15s,border-color .15s}
.btn:active{transform:translateY(1px)}
.btn--primary{background:var(--c);color:#04211c}
.btn--primary:hover{background:var(--cp);color:#04211c}
.btn--ghost{background:transparent;color:var(--text);border-color:var(--panel-edge)}
.btn--ghost:hover{border-color:rgba(45,212,191,.4);color:var(--cp)}
.btn--sm{padding:7px 14px;font-size:.82rem;border-radius:10px}

/* ── panels & cards ── */
.panel{background:var(--panel);border:1px solid var(--panel-edge);border-radius:20px;padding:28px 30px;backdrop-filter:blur(3px)}
.card{background:var(--panel);border:1px solid var(--panel-edge);border-radius:18px;padding:24px}
.card h3{font-family:var(--font-display);font-weight:500;font-size:1.15rem;margin-bottom:10px;color:var(--text)}
.card p{font-size:.92rem;color:var(--fg2)}

/* ── type helpers ── */
.eyebrow{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.34em;text-transform:uppercase;color:var(--c);opacity:.85}
.kicker{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.28em;text-transform:uppercase;color:var(--c);opacity:.75;margin-bottom:14px}
h1{font-family:var(--font-display);font-weight:400;letter-spacing:-.02em;line-height:1.08}
h1 em,h2 em{font-style:italic;color:var(--c)}
h2{font-family:var(--font-display);font-weight:400;font-size:1.9rem;letter-spacing:-.015em}
.sub{color:var(--fg2);max-width:62ch}
.mono{font-family:var(--font-mono);font-size:.85em;color:var(--c)}

/* ── code blocks ── */
.code{background:rgba(4,10,16,.8);border:1px solid var(--hair);border-radius:14px;white-space:pre;
  font-family:var(--font-mono);font-size:.84rem;line-height:1.7;padding:18px 22px;overflow-x:auto;color:var(--fg)}
.code{scrollbar-width:thin;scrollbar-color:rgba(45,212,191,.25) transparent}
.code::-webkit-scrollbar{height:8px}
.code::-webkit-scrollbar-track{background:transparent}
.code::-webkit-scrollbar-thumb{background:rgba(45,212,191,.2);border-radius:4px}
.code .cm{color:var(--fg3)}          /* comment */
.code .kw{color:var(--c)}            /* keyword / command */
.code .st{color:var(--mid)}          /* string */
.code .mod{color:var(--vio)}         /* fragment / => modifier — the address magic */
.code .bud{color:var(--copper)}      /* token budget — the bet being placed */
.code .pr{color:var(--fg3);user-select:none}  /* prompt */
.copyable{position:relative;cursor:pointer}
.copyable::after{content:'copy';position:absolute;top:12px;right:16px;font-family:var(--font-mono);
  font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--fg3);cursor:pointer}
.copyable:hover::after{color:var(--c)}
.copyable.copied::after{content:'copied';color:var(--cp)}

/* ── tables ── */
table{width:100%;border-collapse:collapse;font-size:.88rem}
th{text-align:left;font-family:var(--font-mono);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--c);opacity:.75;font-weight:400;padding:0 14px 12px;border-bottom:1px solid var(--hair)}
td{padding:11px 14px;border-bottom:1px solid rgba(128,224,208,.06);color:var(--fg2);vertical-align:top}
td:first-child{color:var(--text)}
td code{font-family:var(--font-mono);font-size:.82em;color:var(--c)}
tr:last-child td{border-bottom:none}

/* ── status dot — working / ready / stuck / stale read differently at a glance ── */
.dot{display:inline-block;width:8px;height:8px;border-radius:50%;vertical-align:middle}
.dot--ready{background:var(--c);box-shadow:0 0 0 3px rgba(45,212,191,.14)}
.dot--working{background:var(--cp);animation:workpulse 1.6s ease-in-out infinite}
.dot--warn{background:var(--warn);box-shadow:0 0 0 3px rgba(232,196,124,.14)}
.dot--stale{background:var(--fg3)}
@keyframes workpulse{0%,100%{opacity:1}50%{opacity:.35}}
@media (prefers-reduced-motion: reduce){.dot--working{animation:none}}

/* ── footer ── */
.footer{position:relative;z-index:3;border-top:1px solid var(--hair);margin-top:110px}
.footer__in{max-width:1180px;margin:0 auto;padding:36px 28px;display:flex;flex-wrap:wrap;gap:28px;justify-content:space-between;align-items:baseline}
.footer__in p{font-size:.82rem;color:var(--fg3)}
.footer__in nav{display:flex;gap:20px}
.footer__in nav a{font-size:.82rem;color:var(--fg2)}

/* ── layout helpers ── */
.wrap{max-width:1180px;margin:0 auto;padding:0 28px;position:relative;z-index:3}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media (max-width:900px){.grid3,.grid4{grid-template-columns:1fr 1fr}.grid2{grid-template-columns:1fr}}
@media (max-width:600px){.grid3,.grid4{grid-template-columns:1fr}}
