/* ================================================================
   CYNTRISEC // KUROKAWA SHELL
   Shared across cyntrisec.com (landing, research, docs, spec).
   Version 2026.04
   ================================================================ */
@import url("https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;500;600;700&display=swap");

:root{
  --bg:#000;
  --ink:#fff;
  --ink-dim:rgba(255,255,255,.68);
  --ink-mute:rgba(255,255,255,.50);
  --ink-faint:rgba(255,255,255,.26);
  --rule:rgba(255,255,255,.14);
  --rule-hi:rgba(255,255,255,.28);
  --accent:#ff3838;
  --accent-dim:rgba(255,56,56,.66);
  --info:#8fdcff;
  --info-dim:rgba(143,220,255,.18);
  --danger:#ff5a5a;
  --danger-dim:rgba(255,90,90,.18);
  --green:#39ff7c;
  --amber:#ffb84a;
  --max:1320px;
  --pad:2rem;
  --font:"IBM Plex Mono","Menlo","Monaco",monospace;
}

/* ===== Reset + base ===== */
*{box-sizing:border-box;margin:0;padding:0;font-variant-ligatures:none}
html{scroll-behavior:smooth;background:var(--bg)}
body{
  min-height:100vh;
  background:var(--bg);
  color:var(--ink);
  font:400 13px/1.55 var(--font);
  -webkit-font-smoothing:antialiased;
  letter-spacing:.01em;
  overflow-x:hidden;
}
::selection{background:var(--accent);color:var(--bg)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ===== Header ===== */
.k-header{
  position:sticky;
  top:0;
  z-index:100;
  border-bottom:1px solid var(--rule);
  background:rgba(0,0,0,.82);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}
.k-hdr{
  max-width:var(--max);
  margin:0 auto;
  padding:0 var(--pad);
  min-height:54px;
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:1.5rem;
  align-items:center;
}
.k-brand{
  display:inline-flex;
  align-items:center;
  gap:.55rem;
  font:600 12px/1 var(--font);
  letter-spacing:.18em;
  text-transform:uppercase;
}
.k-brand .mark{width:20px;height:20px;display:block}
.k-brand-ver{
  font:500 10px/1 var(--font);
  color:var(--ink-mute);
  letter-spacing:.16em;
  margin-left:.45rem;
  border-left:1px solid var(--rule);
  padding-left:.55rem;
}
.k-hdr nav{display:flex;gap:.4rem;justify-self:center}
.k-hdr nav a{
  font:500 11px/1 var(--font);
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--ink-dim);
  padding:.5rem .8rem;
  border:1px solid transparent;
  transition:color .15s ease,border-color .15s ease;
}
.k-hdr nav a:hover,.k-hdr nav a.active{color:var(--ink);border-color:var(--rule-hi)}
.k-hdr-meta{
  font:500 10px/1.3 var(--font);
  color:var(--ink-mute);
  letter-spacing:.14em;
  text-transform:uppercase;
  text-align:right;
}
.k-hdr-meta strong{color:var(--ink);font-weight:500}
@media(max-width:760px){
  .k-hdr{grid-template-columns:auto 1fr}
  .k-hdr nav,.k-hdr-meta{display:none}
}

/* ===== Layout helpers ===== */
.k-wrap{max-width:var(--max);margin:0 auto;padding:0 var(--pad);position:relative}
.k-panel{
  position:relative;
  border-bottom:1px solid var(--rule);
  padding:5rem 0;
}
.k-panel-tag{
  position:absolute;top:1rem;left:1.2rem;
  font:500 10px/1 var(--font);
  letter-spacing:.18em;
  color:var(--ink-mute);
  text-transform:uppercase;
}
.k-panel-num{
  position:absolute;top:1rem;right:1.2rem;
  font:500 10px/1 var(--font);
  letter-spacing:.18em;
  color:var(--ink-faint);
}

/* ===== Eyebrow / labels ===== */
.k-eyebrow{
  font:500 11px/1 var(--font);
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--accent-dim);
  display:inline-flex;
  align-items:center;
  gap:.7rem;
}
.k-eyebrow::before{content:"";width:32px;height:1px;background:var(--accent)}
.k-label{
  font:500 10px/1 var(--font);
  color:var(--ink-mute);
  letter-spacing:.22em;
  text-transform:uppercase;
}

/* ===== Buttons ===== */
.k-btn{
  display:inline-flex;
  align-items:center;
  gap:.7rem;
  padding:.85rem 1.2rem;
  border:1px solid var(--rule-hi);
  background:transparent;
  color:var(--ink);
  font:600 11px/1 var(--font);
  letter-spacing:.22em;
  text-transform:uppercase;
  transition:background .15s ease,color .15s ease,border-color .15s ease;
  cursor:pointer;
}
.k-btn::before{content:">";color:var(--accent)}
.k-btn:hover{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.k-btn:hover::before{color:var(--bg)}
.k-btn.primary{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.k-btn.primary::before{color:var(--accent)}
.k-btn.primary:hover{background:var(--accent);color:var(--bg);border-color:var(--accent)}
.k-btn.primary:hover::before{color:var(--bg)}

/* ===== Article body (long-form readable mono) ===== */
.k-article{
  max-width:60ch;
  margin:0 auto;
  padding:4rem var(--pad) 5rem;
  font:400 14.5px/1.78 var(--font);
  color:var(--ink-dim);
}
.k-article > * + *{margin-top:1.4rem}
.k-article h1,.k-article h2,.k-article h3{
  color:var(--ink);
  font-weight:600;
  letter-spacing:-.01em;
  text-transform:none;
}
.k-article h1{font-size:2rem;line-height:1.05;margin-top:0}
.k-article h2{font-size:1.4rem;line-height:1.15;margin-top:3rem;text-transform:uppercase;letter-spacing:.04em}
.k-article h3{font-size:1.05rem;line-height:1.25;margin-top:2.2rem}
.k-article p{margin-top:1.2rem;color:var(--ink-dim)}
.k-article ul,.k-article ol{margin-top:1.2rem;padding-left:1.4rem;color:var(--ink-dim)}
.k-article li{margin-bottom:.45rem;line-height:1.7}
.k-article strong{color:var(--ink);font-weight:600}
.k-article em{color:var(--ink);font-style:italic}
.k-article a{color:var(--accent);border-bottom:1px solid var(--accent-dim);transition:opacity .15s ease}
.k-article a:hover{opacity:.7}
.k-article code{
  font-family:var(--font);
  font-size:.92em;
  color:var(--ink);
  background:rgba(255,255,255,.06);
  padding:.1em .35em;
  border:1px solid var(--rule);
}
.k-article pre{
  margin-top:1.4rem;
  padding:1rem 1.2rem;
  background:rgba(255,255,255,.04);
  border:1px solid var(--rule);
  overflow-x:auto;
  font-size:12.5px;
  line-height:1.7;
  color:var(--ink-dim);
}
.k-article pre code{background:none;border:none;padding:0;color:inherit}
.k-article blockquote{
  margin:1.6rem 0;
  padding:.4rem 0 .4rem 1.2rem;
  border-left:2px solid var(--accent);
  color:var(--ink);
  font-style:normal;
}
.k-article hr{
  margin:2.5rem 0;
  border:0;
  border-top:1px solid var(--rule);
}

.k-article-header{
  max-width:var(--max);
  margin:0 auto;
  padding:5rem var(--pad) 2rem;
}
.k-article-header .k-eyebrow{margin-bottom:1.4rem}
.k-article-header h1{
  font:700 clamp(2.4rem,6vw,4.6rem)/.95 var(--font);
  letter-spacing:-.02em;
  text-transform:uppercase;
  color:var(--ink);
  max-width:18ch;
}
.k-article-header .lead{
  margin-top:1.2rem;
  max-width:50ch;
  font:400 15px/1.7 var(--font);
  color:var(--ink-dim);
  border-left:1px solid var(--accent);
  padding-left:1rem;
}
.k-article-header .meta{
  margin-top:1.5rem;
  font:500 11px/1 var(--font);
  color:var(--ink-mute);
  letter-spacing:.18em;
  text-transform:uppercase;
}
.k-article-back{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  font:500 11px/1 var(--font);
  color:var(--ink-mute);
  letter-spacing:.22em;
  text-transform:uppercase;
  margin-bottom:2rem;
  border:1px solid var(--rule);
  padding:.55rem .8rem;
  transition:color .15s ease,border-color .15s ease;
}
.k-article-back:hover{color:var(--ink);border-color:var(--rule-hi)}
.k-article-back::before{content:"<";color:var(--accent);margin-right:.2rem}

/* ===== Footer ===== */
.k-footer{
  position:relative;
  border-top:1px solid var(--rule);
  padding:2.5rem 0 1.5rem;
  background:rgba(0,0,0,.55);
}
.k-ftr{
  max-width:var(--max);
  margin:0 auto;
  padding:0 var(--pad);
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:2rem;
  align-items:flex-end;
}
.k-ftr-links{display:flex;gap:.35rem;flex-wrap:wrap}
.k-ftr-links a{
  font:500 11px/1 var(--font);
  color:var(--ink-mute);
  padding:.4rem .55rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  border:1px solid transparent;
  transition:color .15s ease,border-color .15s ease;
}
.k-ftr-links a:hover{color:var(--ink);border-color:var(--rule-hi)}
.k-ftr-meta{
  font:500 10px/1.4 var(--font);
  color:var(--ink-mute);
  letter-spacing:.16em;
  text-transform:uppercase;
  text-align:right;
}
.k-ftr-badge{display:flex;flex-direction:column;align-items:flex-start;gap:.45rem;min-width:208px}
.k-ftr-badge img{width:208px;max-width:100%;height:auto}
.k-ftr-badge span{
  font:500 8px/1.5 var(--font);
  color:var(--ink-mute);
  letter-spacing:.18em;
  text-transform:uppercase;
}
.k-ftr-bottom{
  max-width:var(--max);
  margin:1.4rem auto 0;
  padding:1.2rem var(--pad) 0;
  border-top:1px solid var(--rule);
  display:flex;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:.6rem;
  font:500 10px/1.4 var(--font);
  color:var(--ink-faint);
  letter-spacing:.18em;
  text-transform:uppercase;
}
@media(max-width:760px){
  .k-ftr{grid-template-columns:1fr}
  .k-ftr-meta,.k-ftr-badge{align-self:flex-start;text-align:left}
}

/* ===== Reveal ===== */
.k-rv{opacity:0;transform:translateY(14px);transition:opacity .55s ease,transform .55s ease}
.k-rv.visible{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  .k-rv{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}
