/* ONCRIX site — shared design system. No external deps. */
:root{
  --bg:#0a0e16; --bg2:#0d1320; --panel:#111a2b; --panel2:#0e1626; --line:#1c2a42;
  --txt:#cdd6e6; --dim:#8a97ad; --faint:#5a6781;
  --accent:#48e0c0; --accent2:#7aa2ff; --warn:#f2c969; --pink:#ff7ab2;
  --mono:ui-monospace,"SF Mono","JetBrains Mono","Fira Code",Menlo,Consolas,monospace;
  --sans:system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --maxw:1080px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--bg);color:var(--txt);font-family:var(--sans);
  line-height:1.65;-webkit-font-smoothing:antialiased;
  background-image:
    radial-gradient(900px 500px at 82% -10%, rgba(72,224,192,.07), transparent 60%),
    radial-gradient(820px 520px at -5% 0%, rgba(122,162,255,.06), transparent 55%);
  background-attachment:fixed;
}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.mono{font-family:var(--mono)}
.accent{color:var(--accent)}
.accent2{color:var(--accent2)}

/* nav */
header.nav{position:sticky;top:0;z-index:20;backdrop-filter:blur(8px);
  background:rgba(10,14,22,.74);border-bottom:1px solid var(--line)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:60px}
.brand{display:flex;align-items:center;gap:10px;font-weight:700;letter-spacing:.5px}
.brand svg{display:block}
.brand b{color:#fff}
.navlinks{display:flex;gap:20px;font-size:14px;align-items:center}
.navlinks a{color:var(--dim)}
.navlinks a:hover{color:#fff;text-decoration:none}
.navlinks a.active{color:#fff}
.navlinks a.gh{border:1px solid var(--line);padding:6px 13px;border-radius:8px}
.navlinks a.gh:hover{border-color:var(--accent)}
.menu-btn{display:none;background:none;border:1px solid var(--line);color:var(--txt);
  border-radius:8px;padding:6px 10px;font-size:18px;cursor:pointer}

.btn{display:inline-block;padding:9px 16px;border-radius:8px;font-weight:600;font-size:14px;
  border:1px solid var(--line);color:var(--txt);transition:.15s}
.btn:hover{text-decoration:none;border-color:var(--accent);color:#fff}
.btn.primary{background:linear-gradient(180deg,#16e0bd,#12b89c);color:#04140f;border-color:transparent}
.btn.primary:hover{filter:brightness(1.08);color:#04140f}

/* page header (sub pages) */
.phead{padding:64px 0 30px;border-bottom:1px solid var(--line)}
.crumb{font-family:var(--mono);font-size:12px;color:var(--faint);letter-spacing:1px;text-transform:uppercase;margin-bottom:12px}
.crumb a{color:var(--dim)}
.phead h1{font-size:clamp(32px,6vw,52px);line-height:1.05;margin:0 0 10px;letter-spacing:-1px;color:#fff;font-weight:800}
.phead p{font-size:clamp(16px,2.4vw,19px);color:var(--dim);max-width:680px;margin:0}

/* hero (home) */
.hero{padding:84px 0 60px;text-align:center}
.kicker{font-family:var(--mono);font-size:13px;color:var(--accent);letter-spacing:2px;text-transform:uppercase}
.hero h1{font-size:clamp(40px,8vw,76px);line-height:1.02;margin:14px 0 6px;letter-spacing:-1.5px;color:#fff;font-weight:800}
.hero h1 .dot{color:var(--accent)}
.expand{font-family:var(--mono);font-size:clamp(13px,2.4vw,16px);color:var(--dim);margin:0 0 8px}
.expand b{color:var(--accent2);font-weight:600}
.lead{max-width:660px;margin:18px auto 28px;font-size:clamp(16px,2.5vw,19px);color:var(--dim)}
.cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.badges{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-top:30px;font-family:var(--mono);font-size:12px}
.badge{border:1px solid var(--line);background:var(--bg2);color:var(--dim);padding:5px 11px;border-radius:999px}
.badge b{color:var(--txt)}

/* terminal */
.term{max-width:720px;margin:46px auto 0;background:var(--bg2);border:1px solid var(--line);
  border-radius:12px;overflow:hidden;box-shadow:0 30px 80px -40px rgba(0,0,0,.8);text-align:left}
.term .bar{display:flex;align-items:center;gap:7px;padding:11px 14px;border-bottom:1px solid var(--line);background:#0b1120}
.term .bar i{width:11px;height:11px;border-radius:50%;display:block}
.term .bar .t{margin-left:8px;font-family:var(--mono);font-size:12px;color:var(--faint)}
.term pre{margin:0;padding:18px;font-family:var(--mono);font-size:13.5px;line-height:1.7;color:var(--txt);overflow-x:auto}
.term .c{color:var(--faint)} .term .p{color:var(--accent)} .term .k{color:var(--accent2)}
.term .o{color:var(--warn)} .term .g{color:var(--accent)}

/* sections */
section{padding:60px 0;border-top:1px solid var(--line)}
section.flush{border-top:none}
.h2{font-size:13px;font-family:var(--mono);letter-spacing:2px;text-transform:uppercase;color:var(--accent);margin:0 0 6px}
.sect-title{font-size:clamp(24px,4vw,32px);font-weight:700;color:#fff;margin:0 0 8px;letter-spacing:-.5px}
.sect-sub{color:var(--dim);max-width:660px;margin:0 0 32px}

/* grids + cards */
.grid{display:grid;gap:16px}
.grid.g4{grid-template-columns:repeat(4,1fr)}
.grid.g3{grid-template-columns:repeat(3,1fr)}
.grid.g2{grid-template-columns:repeat(2,1fr)}
@media(max-width:820px){.grid.g4{grid-template-columns:repeat(2,1fr)}.grid.g3{grid-template-columns:1fr}}
@media(max-width:560px){.grid.g4,.grid.g2{grid-template-columns:1fr}}
.card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:22px;transition:.18s}
.card:hover{border-color:#2b3e60;transform:translateY(-2px)}
.card .ic{font-family:var(--mono);font-size:13px;color:var(--accent);margin-bottom:10px}
.card h3{margin:0 0 7px;font-size:17px;color:#fff;font-weight:650}
.card p{margin:0;color:var(--dim);font-size:14.5px}
.card a.more{display:inline-block;margin-top:12px;font-size:13.5px;font-family:var(--mono)}
a.cardlink{display:block}
a.cardlink:hover{text-decoration:none}

/* crates */
.crates{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}
@media(max-width:820px){.crates{grid-template-columns:repeat(3,1fr)}}
@media(max-width:480px){.crates{grid-template-columns:repeat(2,1fr)}}
.crate{background:var(--bg2);border:1px solid var(--line);border-radius:9px;padding:13px 12px}
.crate .n{font-family:var(--mono);font-size:13px;color:var(--accent2);font-weight:600}
.crate .d{font-size:12px;color:var(--faint);margin-top:3px}

/* specs */
.specs{display:grid;grid-template-columns:repeat(2,1fr);border:1px solid var(--line);border-radius:12px;overflow:hidden}
@media(max-width:560px){.specs{grid-template-columns:1fr}}
.spec{display:flex;justify-content:space-between;gap:14px;padding:15px 18px;border-bottom:1px solid var(--line);border-right:1px solid var(--line)}
.spec .l{color:var(--dim);font-size:14px}
.spec .v{font-family:var(--mono);font-size:13.5px;color:var(--txt);text-align:right}

/* prose (content pages) */
.prose{max-width:760px}
.prose h2{font-size:clamp(20px,3.4vw,26px);color:#fff;margin:46px 0 12px;font-weight:700;letter-spacing:-.3px}
.prose h2:first-child{margin-top:8px}
.prose h3{font-size:17px;color:#fff;margin:28px 0 8px;font-weight:650}
.prose p{color:var(--dim);margin:0 0 16px}
.prose strong{color:var(--txt);font-weight:650}
.prose code{font-family:var(--mono);font-size:.88em;background:var(--bg2);border:1px solid var(--line);
  border-radius:5px;padding:1px 6px;color:var(--accent)}
.prose ul,.prose ol{color:var(--dim);margin:0 0 18px;padding-left:22px}
.prose li{margin:6px 0}
.prose li::marker{color:var(--accent)}
.prose a{border-bottom:1px solid rgba(72,224,192,.3)}
.prose hr{border:none;border-top:1px solid var(--line);margin:34px 0}

/* code block */
.code{background:var(--bg2);border:1px solid var(--line);border-radius:10px;margin:0 0 20px;overflow:hidden}
.code .h{font-family:var(--mono);font-size:11.5px;color:var(--faint);padding:9px 14px;border-bottom:1px solid var(--line);
  letter-spacing:.5px;text-transform:uppercase}
.code pre{margin:0;padding:14px 16px;font-family:var(--mono);font-size:13px;line-height:1.7;color:var(--txt);overflow-x:auto}
.code .c{color:var(--faint)} .code .p{color:var(--accent)} .code .k{color:var(--accent2)} .code .o{color:var(--warn)}

/* callout */
.note{border:1px solid var(--line);border-left:3px solid var(--accent);background:var(--panel2);
  border-radius:8px;padding:14px 18px;margin:0 0 20px;color:var(--dim);font-size:14.5px}
.note.warn{border-left-color:var(--warn)}
.note b{color:var(--txt)}

/* flow diagram (text-based) */
.flow{font-family:var(--mono);font-size:13px;background:var(--bg2);border:1px solid var(--line);
  border-radius:10px;padding:18px;color:var(--dim);overflow-x:auto;line-height:1.9;margin:0 0 20px}
.flow b{color:var(--accent)} .flow i{color:var(--accent2);font-style:normal}

/* table */
.tbl{width:100%;border-collapse:collapse;margin:0 0 22px;font-size:14px}
.tbl th,.tbl td{text-align:left;padding:11px 14px;border-bottom:1px solid var(--line)}
.tbl th{color:var(--dim);font-weight:600;font-size:12.5px;text-transform:uppercase;letter-spacing:.5px}
.tbl td{color:var(--dim)}
.tbl td .mono,.tbl td code{color:var(--accent2)}
.tbl tr:hover td{background:rgba(122,162,255,.04)}

/* status pills / timeline */
.pill{display:inline-block;font-family:var(--mono);font-size:11px;padding:2px 9px;border-radius:999px;border:1px solid var(--line)}
.pill.done{color:var(--accent);border-color:rgba(72,224,192,.4)}
.pill.wip{color:var(--warn);border-color:rgba(242,201,105,.4)}
.pill.plan{color:var(--faint)}
.timeline{border-left:2px solid var(--line);margin:0;padding:0 0 0 24px;list-style:none}
.timeline li{position:relative;margin:0 0 24px}
.timeline li::before{content:"";position:absolute;left:-31px;top:6px;width:10px;height:10px;border-radius:50%;
  background:var(--bg);border:2px solid var(--accent)}
.timeline h3{margin:0 0 4px;color:#fff;font-size:16px}
.timeline p{margin:0;color:var(--dim);font-size:14px}

/* footer */
footer{border-top:1px solid var(--line);padding:40px 0;color:var(--faint);font-size:13.5px}
.foot{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:22px}
.foot .col h4{margin:0 0 10px;color:var(--dim);font-size:12px;text-transform:uppercase;letter-spacing:1px}
.foot .col a{display:block;color:var(--faint);margin:5px 0}
.foot .col a:hover{color:var(--txt)}
.disc{margin-top:26px;font-size:12.5px;color:var(--faint);max-width:760px}

@media(max-width:640px){
  .navlinks{position:absolute;top:60px;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;
    background:var(--bg2);border-bottom:1px solid var(--line);padding:6px 0;display:none}
  .navlinks.open{display:flex}
  .navlinks a{padding:11px 22px}
  .navlinks a.gh{border:none;border-radius:0}
  .menu-btn{display:inline-block}
}
