/* ClawTerminal - elegant-ASCII design system (shared across all pages).
   Black, JetBrains Mono, one coral accent. Load with:
     <link href="https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;700&display=swap" rel="stylesheet">
     <link rel="stylesheet" href="/ascii.css">
   Components (auto-wired by /ascii.js): #ct-chart, #ct-flow, #ct-tape. */

:root{
  --bg:#060405; --panel:#0a0708; --panel-2:#0d0a0b;
  --ink:#e9e4dd; --soft:#b3a99f; --dim:#6f655f; --faint:#2c2724;
  --accent:#ee5741; --accent-dim:#9a4034; --green:#7ed4a3;
  --line:rgba(233,228,221,.08); --line-2:rgba(233,228,221,.14);
  --mono:"JetBrains Mono",ui-monospace,"SFMono-Regular","Menlo","Consolas",monospace;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--bg);color:var(--ink);font-family:var(--mono);font-size:14px;line-height:1.6;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
  background-image:radial-gradient(120% 70% at 50% -5%,rgba(238,87,65,.05),transparent 55%);
}
.wrap{max-width:980px;margin:0 auto;padding:0 24px}
a{color:inherit;text-decoration:none}
em{font-style:normal;color:var(--accent)}
::selection{background:var(--accent);color:var(--bg)}

/* nav */
.ct-nav{display:flex;justify-content:space-between;align-items:center;padding:20px 0;font-size:11px;letter-spacing:.18em;color:var(--dim);border-bottom:1px solid var(--line)}
.ct-nav .brand{color:var(--ink);font-weight:700}
.ct-nav .brand b{color:var(--accent)}
.ct-nav .links a{margin-left:22px}
.ct-nav .links a:hover{color:var(--ink)}

/* hero + candlestick */
.ct-hero{padding:70px 0 30px;display:flex;flex-direction:column;align-items:center;gap:26px;text-align:center}
pre.ct-chart{font-size:12.5px;line-height:1.02;color:var(--dim);white-space:pre;margin:0;user-select:none;text-shadow:0 0 14px rgba(0,0,0,.5)}
pre.ct-chart .up{color:var(--soft)} pre.ct-chart .last{color:var(--accent)}
h1.ct-h{font-weight:500;font-size:clamp(22px,3.4vw,36px);letter-spacing:.01em;color:var(--ink)}
h1.ct-h .cur{color:var(--accent);animation:ct-blink 1.1s steps(1) infinite}
@keyframes ct-blink{50%{opacity:0}}
.ct-sub{font-size:13px;color:var(--dim);letter-spacing:.02em}

/* buttons */
.ct-btn{display:inline-block;font-size:12px;letter-spacing:.12em;color:var(--bg);background:var(--accent);padding:11px 22px;border-radius:5px;font-weight:500;transition:filter .15s}
.ct-btn:hover{filter:brightness(1.08)}
.ct-btn.ghost{background:transparent;color:var(--ink);border:1px solid var(--line-2)}
.ct-btn.ghost:hover{border-color:var(--accent);color:var(--accent)}

/* news tape */
.ct-tape{border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;white-space:nowrap;padding:9px 0;font-size:12px;color:var(--dim);background:var(--panel)}
.ct-tape .row{display:inline-block;animation:ct-marq 38s linear infinite}
.ct-tape .src{color:var(--accent);font-weight:500}
@keyframes ct-marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* sections + ascii divider */
section.ct-blk{padding:64px 0;border-top:1px solid var(--line)}
section.ct-blk:first-of-type{border-top:none}
.ct-divider{display:flex;align-items:center;gap:14px;color:var(--faint);font-size:11px;letter-spacing:.22em;margin-bottom:30px}
.ct-divider::before,.ct-divider::after{content:"";height:1px;background:var(--line);flex:1}
.ct-divider span{color:var(--dim)}
h2.ct-blk-h{font-size:clamp(20px,2.8vw,30px);font-weight:500;letter-spacing:.01em;color:var(--ink);margin-bottom:10px;line-height:1.2}
p.ct-lead{color:var(--dim);max-width:64ch}

/* convergence flow motif */
.ct-flow{display:flex;justify-content:center;padding:14px 0}
pre.ct-flowart{font-size:13px;line-height:1.25;color:var(--dim);white-space:pre;margin:0;user-select:none}
pre.ct-flowart .src{color:var(--soft)} pre.ct-flowart .dot{color:var(--accent)} pre.ct-flowart .box{color:var(--ink)}

/* cards / grid */
.ct-grid{display:grid;gap:1px;background:var(--line);border:1px solid var(--line)}
.ct-grid.c2{grid-template-columns:repeat(2,1fr)} .ct-grid.c3{grid-template-columns:repeat(3,1fr)}
.ct-card{background:var(--bg);padding:24px}
.ct-card h3{font-size:13px;color:var(--ink);font-weight:500;letter-spacing:.02em;margin-bottom:8px}
.ct-card h3 .mk{color:var(--accent);margin-right:8px}
.ct-card p{color:var(--dim);font-size:13px}
@media(max-width:720px){.ct-grid.c2,.ct-grid.c3{grid-template-columns:1fr}}

/* mono table */
table.ct-tbl{width:100%;border-collapse:collapse;font-size:13px}
table.ct-tbl th{text-align:left;color:var(--dim);font-weight:500;letter-spacing:.1em;font-size:11px;padding:8px 12px;border-bottom:1px solid var(--line)}
table.ct-tbl td{padding:9px 12px;border-bottom:1px solid var(--line);color:var(--soft)}
table.ct-tbl td.pos{color:var(--accent)} table.ct-tbl td.neg{color:var(--dim)}
table.ct-tbl tr:hover td{background:var(--panel)}

/* terminal-style code/install block */
.ct-term{background:var(--panel);border:1px solid var(--line);border-radius:6px;padding:16px 18px;font-size:13px;color:var(--soft);overflow-x:auto}
.ct-term .cm{color:var(--accent)} .ct-term .dim{color:var(--dim)}

/* footer */
.ct-foot{border-top:1px solid var(--line);padding:28px 0;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:11px;letter-spacing:.16em;color:var(--dim)}
.ct-foot a:hover{color:var(--ink)}

/* reveal on scroll */
.reveal{opacity:0;transform:translateY(14px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none}.ct-tape .row{animation:none}}
