/* ============================================================
   BushidoCyber — terminal
   Monospace everything. ANSI palette. Prompts, trees, statusline.
   No gradients, no glow, no rounded corners.
   ============================================================ */
:root{
  /* Tokyo Night */
  --bg:#1a1b26;
  --bg-bar:#16161e;
  --panel:#1f2335;
  --sel:#292e42;
  --line:#2b2f44;
  --line-soft:#222637;
  --fg:#c0caf5;
  --dim:#828bb8;
  --faint:#565f89;
  --red:#f7768e;
  --green:#9ece6a;
  --blue:#7aa2f7;
  --cyan:#7dcfff;
  --yellow:#e0af68;
  --maxw:980px;
  --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(--fg);
  font-family:var(--mono);font-size:14.5px;line-height:1.7;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
  padding-bottom:38px; /* clear the fixed statusline */
}
a{color:inherit;text-decoration:none}
::selection{background:var(--sel);color:var(--fg)}
b,strong{font-weight:700}

.wrap{position:relative;z-index:1;max-width:var(--maxw);margin:0 auto;padding:0 28px}
@media(max-width:640px){.wrap{padding:0 18px}}

/* blinking cursor */
.cursor{display:inline-block;width:.62em;height:1.05em;background:var(--red);vertical-align:-2px;margin-left:2px;animation:blink 1.05s steps(1) infinite}
@keyframes blink{50%{opacity:0}}

/* prompt rendering */
.pr{color:var(--dim);user-select:none;white-space:nowrap}
.pr .u{color:var(--green)}
.pr .h{color:var(--blue)}
.pr .d{color:var(--cyan)}
.pr .s{color:var(--red)}
.line{white-space:pre-wrap;word-break:break-word;color:var(--fg)}
.out{color:var(--dim);margin:4px 0 30px}
.out .cmt{color:var(--green)}
.out a{color:var(--blue)}
.out a:hover{color:var(--red)}

/* ---------- title bar (nav) ---------- */
nav{
  position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:space-between;
  padding:11px clamp(18px,4vw,28px);background:var(--bg-bar);border-bottom:1px solid var(--line);
  font-size:13px;
}
.brand{display:flex;align-items:center;gap:9px;color:var(--fg);font-weight:500}
.brand .mark{color:var(--red);font-weight:700}
.brand b{color:var(--fg);font-weight:500}
.brand .name{color:var(--fg)}
.brand .name b{color:var(--red)}
.nav-links{display:flex;gap:22px;align-items:center}
.nav-links a{color:var(--dim);transition:color .15s}
.nav-links a::before{content:'';color:var(--faint)}
.nav-links a:hover{color:var(--red)}
.nav-cta{display:flex;gap:14px;align-items:center}
.menu-btn{display:none;background:none;border:none;color:var(--fg);cursor:pointer;font-size:18px;font-family:var(--mono)}

/* ---------- buttons (TUI) ---------- */
.btn{
  display:inline-flex;align-items:center;gap:8px;cursor:pointer;font-family:var(--mono);font-size:13px;
  padding:8px 16px;border:1px solid var(--line);color:var(--fg);background:transparent;transition:background .15s,color .15s,border-color .15s;
}
.btn::before{content:'[';color:var(--faint);margin-right:2px}
.btn::after{content:']';color:var(--faint);margin-left:2px}
.btn-primary{border-color:var(--red);color:var(--red)}
.btn-primary:hover{background:var(--red);color:var(--bg)}
.btn-primary:hover::before,.btn-primary:hover::after{color:var(--bg)}
.btn-ghost:hover{border-color:var(--fg);color:var(--fg)}
.btn-ghost:hover::before,.btn-ghost:hover::after{color:var(--fg)}

/* ---------- hero / session ---------- */
header.hero{padding:92px 0 18px}
.session .line{margin-top:2px}
.session .line + .out{margin-bottom:26px}
h1.statement{font-size:0;height:0;overflow:hidden} /* legacy guard */
.lead{color:var(--dim)}

/* ---------- tree (tools) ---------- */
.treewrap{margin-top:6px}
.tree{border:1px solid var(--line);background:var(--panel)}
.tree .troot{padding:9px 16px;color:var(--dim);border-bottom:1px solid var(--line);background:var(--bg-bar)}
.trow{
  display:grid;grid-template-columns:30px minmax(110px,160px) 1fr auto;gap:16px;align-items:baseline;
  padding:12px 16px;border-bottom:1px solid var(--line-soft);transition:background .12s;
}
.trow:last-child{border-bottom:none}
.trow:hover{background:var(--sel)}
.trow .br{color:var(--faint)}
.trow:hover .br{color:var(--red)}
.trow .nm{color:var(--fg);font-weight:500}
.trow:hover .nm{color:var(--red)}
.trow .ds{color:var(--dim)}
.trow .lg{color:var(--blue);font-size:12.5px;justify-self:end}
@media(max-width:680px){
  .trow{grid-template-columns:24px 1fr auto;gap:10px;row-gap:4px}
  .trow .ds{grid-column:2 / -1;font-size:13px}
}

/* ---------- sections ---------- */
section{position:relative;padding:clamp(16px,2.6vw,30px) 0}
.sec-head{margin-bottom:34px}
.kicker{color:var(--green);font-size:13px;margin-bottom:14px}
.kicker::before{content:'# ';color:var(--faint)}
h2.sec-title{font-size:clamp(20px,3vw,28px);font-weight:700;color:var(--fg);letter-spacing:-.01em;margin-bottom:12px}
h2.sec-title::before{content:'## ';color:var(--dim);font-weight:400}
.sec-head p{color:var(--dim);max-width:70ch}

/* ethos as comment block */
.ethos{display:flex;flex-direction:column;gap:14px;border-left:2px solid var(--line);padding-left:20px}
.ethos > div .k{color:var(--green)}
.ethos > div{color:var(--dim)}
.ethos > div b{color:var(--fg);font-weight:500}

/* contact */
.contact-out{display:flex;flex-direction:column;gap:8px}
.contact-out .key{color:var(--yellow);display:inline-block;min-width:84px}

/* ---------- project subpage hero ---------- */
.proj-hero{padding:116px 0 30px;position:relative}
.proj-hero .kj-big{display:none}
.crumb{color:var(--dim);margin-bottom:22px;font-size:13.5px}
.crumb .s{color:var(--red)}
.crumb .u{color:var(--green)}
.crumb .h{color:var(--blue)}
.crumb a:hover{color:var(--red)}
.proj-hero h1{font-size:clamp(28px,5vw,46px);font-weight:700;color:var(--fg);letter-spacing:-.01em;margin-bottom:16px}
.proj-hero .tagline{color:var(--dim);max-width:74ch;margin-bottom:22px}
.proj-hero .tagline b{color:var(--fg);font-weight:500}
.proj-hero .meta{display:flex;gap:9px;flex-wrap:wrap;margin-bottom:26px}

/* ---------- content ---------- */
.content{max-width:760px}
.content h2{font-size:clamp(18px,2.6vw,23px);font-weight:700;color:var(--fg);margin:0 0 14px}
.content h2::before{content:'## ';color:var(--dim);font-weight:400}
.content h3{font-size:16px;font-weight:700;color:var(--fg);margin:30px 0 12px}
.content h3::before{content:'### ';color:var(--faint);font-weight:400}
.content h3:first-child{margin-top:0}
.content p{color:var(--dim);margin-bottom:14px;line-height:1.75}
.content p:last-child{margin-bottom:0}
.content p b{color:var(--fg);font-weight:500}
.block{margin-top:46px}
code{font-family:var(--mono);color:var(--yellow);font-size:.92em}
.content p code,.note code,.cap li code,.spec code{color:var(--yellow)}

.feature-list{list-style:none;display:flex;flex-direction:column;gap:11px;margin-top:6px}
.feature-list li{display:flex;gap:12px;align-items:flex-start;color:var(--dim);line-height:1.65}
.feature-list li::before{content:'-';color:var(--red);flex:0 0 auto;font-weight:700}
.feature-list li b{color:var(--fg);font-weight:700}

/* capability grid -> bordered cells */
.cap-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(208px,1fr));gap:0;border:1px solid var(--line);background:var(--panel);margin-top:6px}
.cap{padding:16px 18px;border-right:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft)}
.cap h4{font-size:12.5px;color:var(--fg);margin-bottom:11px;font-weight:700}
.cap h4 .src{color:var(--red);font-weight:700}
.cap h4 .src::before{content:'['}
.cap h4 .src::after{content:'] '}
.cap ul{list-style:none;display:flex;flex-direction:column;gap:6px}
.cap li{font-size:13px;color:var(--dim);display:flex;justify-content:space-between;gap:10px;align-items:baseline}
.cap li b{color:var(--fg);font-weight:500}
.cap li code{color:var(--yellow)}
.cap li .sev{font-size:10.5px;padding:1px 6px;flex:0 0 auto;text-transform:uppercase;border:1px solid}
.sev-crit{color:var(--bg);background:var(--red);border-color:var(--red)}
.sev-high{color:var(--red);border-color:var(--red)}
.sev-med{color:var(--yellow);border-color:var(--yellow)}
.sev-low{color:var(--dim);border-color:var(--line)}

/* spec key/value */
.spec{border:1px solid var(--line);background:var(--panel);margin-top:6px}
.spec .row{display:flex;gap:18px;padding:11px 16px;border-bottom:1px solid var(--line-soft)}
.spec .row:last-child{border-bottom:none}
.spec .row .k{color:var(--yellow);flex:0 0 168px}
.spec .row .v{color:var(--dim)}
.spec .row .v b{color:var(--fg);font-weight:500}
@media(max-width:640px){.spec .row{flex-direction:column;gap:4px}.spec .row .k{flex-basis:auto}}

/* tags / chips */
.tag{font-size:11.5px;color:var(--red);border:1px solid var(--red);padding:3px 9px}
.tag::before{content:'#'}
.chip{font-size:11.5px;color:var(--dim);border:1px solid var(--line);padding:3px 9px}

/* code block (terminal) */
.codeblock{background:#08090c;border:1px solid var(--line);margin:6px 0 0;overflow:hidden}
.codeblock .cb-head{display:flex;align-items:center;justify-content:space-between;padding:7px 14px;border-bottom:1px solid var(--line);background:var(--bg-bar)}
.codeblock .cb-head .dots{color:var(--faint);font-size:12px}
.codeblock .cb-head .dots::before{content:'-- terminal --'}
.codeblock .cb-head .dots i{display:none}
.copy-btn{font-family:var(--mono);font-size:11.5px;color:var(--dim);background:none;border:1px solid var(--line);padding:3px 11px;cursor:pointer;transition:color .15s,border-color .15s}
.copy-btn::before{content:'copy '}
.copy-btn:hover{color:var(--red);border-color:var(--red)}
.copy-btn.done{color:var(--green);border-color:var(--green)}
.codeblock pre{margin:0;padding:15px 16px;overflow-x:auto}
.codeblock code{font-family:var(--mono);font-size:13px;color:var(--fg);line-height:1.75;white-space:pre}
.codeblock .cm{color:var(--green)}
.note{font-size:13px;color:var(--faint);margin-top:13px}
.note::before{content:'// ';color:var(--faint)}
.note b{color:var(--dim)}
.note a{color:var(--blue)}
.note a:hover{color:var(--red)}

/* CTA block */
.cta-band{border:1px solid var(--line);border-left:2px solid var(--red);background:var(--panel);padding:clamp(28px,5vw,44px)}
.cta-band .kj-big{display:none}
.cta-band h2{font-size:clamp(19px,3vw,26px);font-weight:700;color:var(--fg);margin-bottom:12px}
.cta-band h2::before{content:'$ ';color:var(--red);font-weight:400}
.cta-band p{color:var(--dim);max-width:62ch;margin:0 0 24px}
.cta-band .hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}

/* ---------- footer = vim statusline ---------- */
footer{position:fixed;left:0;right:0;bottom:0;z-index:40}
.statusline{display:flex;align-items:stretch;font-size:12.5px;border-top:1px solid var(--line);background:var(--bg-bar)}
.statusline .seg{display:flex;align-items:center;padding:7px 14px;color:var(--dim)}
.statusline .mode{background:var(--blue);color:var(--bg);font-weight:700;letter-spacing:.05em}
.statusline .seg.path{color:var(--cyan)}
.statusline .spacer{flex:1}
.statusline a{color:var(--dim)}
.statusline a:hover{color:var(--red)}
.foot-bottom,.foot-grid,.foot-brand,.foot-cols,.foot-col{all:unset}
.foot-cols,.foot-grid{display:none}

/* reveal */
.reveal{opacity:0;transform:translateY(8px);transition:opacity .4s ease,transform .4s ease}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}

/* 404 */
.err-wrap{min-height:100vh;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;position:relative;z-index:1;max-width:var(--maxw);margin:0 auto;padding:0 28px}
.err-wrap .kj{color:var(--red);font-size:clamp(34px,7vw,64px);font-weight:700;margin-bottom:18px;line-height:1.1}
.err-wrap h1{font-size:clamp(18px,3vw,24px);font-weight:700;color:var(--fg);margin-bottom:12px}
.err-wrap p{color:var(--dim);margin-bottom:26px;max-width:60ch}

@media(max-width:680px){
  .nav-links{display:none}
  .menu-btn{display:block}
  .nav-cta .btn-ghost{display:none}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
  .cursor{animation:none}
}
