/* RocketHour Docs — shared theme + app shell for the internal knowledge base.
   Intent: a WORK TOOL with personality — dense + scannable, but alive (brand colour,
   gradient accents, motion, clear section markers). Persistent left sidebar = the nav
   (Category › System › Section, scroll-spy). Built by kb.js from systems.json + the
   page's own <section> headings, so it stays DRY. Tooltips (.tt) carry extra detail. */
:root{
  --space:#07081a; --panel:#11132a; --panel-2:#181a36; --sidebar:#0a0b1f;
  --line:rgba(150,160,220,.13); --line-strong:rgba(150,160,220,.26);
  --white:#eef0fb; --mist:#b3b8d4; --faint:#7077a0;
  --purple:#B95DCD; --blue:#748DF4; --yellow:#C9E74C; --orange:#DA5A33; --danger:#ff6b81;
  --accent:#8fa2f6;
  --grad:linear-gradient(120deg,#748DF4,#B95DCD);
  --grad-soft:linear-gradient(120deg,rgba(116,141,244,.16),rgba(185,93,205,.16));
  --fs:14.5px; --sb:266px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--space);color:var(--white);
  font-family:Montserrat,system-ui,sans-serif;font-size:var(--fs);line-height:1.6;
  -webkit-font-smoothing:antialiased;
  background-image:radial-gradient(800px 420px at 78% -8%,rgba(116,141,244,.10),transparent 60%),
    radial-gradient(680px 460px at -6% 102%,rgba(185,93,205,.10),transparent 58%);
  background-attachment:fixed}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
code{background:rgba(143,162,246,.13);color:#e7eaff;padding:1px 6px;border-radius:5px;
  font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.85em}
/* command / code blocks (engineering pages) */
pre.cmd{background:var(--sidebar);border:1px solid var(--line);border-left:3px solid var(--accent);
  border-radius:9px;padding:12px 14px;margin:12px 0;overflow-x:auto;
  font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12.5px;line-height:1.6;color:#dfe3fb}
pre.cmd code{background:none;padding:0;font-size:inherit;color:inherit}
pre.cmd .c{color:var(--faint)}
::selection{background:rgba(185,93,205,.35)}

/* ── app shell ── */
.shell{display:grid;grid-template-columns:var(--sb) minmax(0,1fr);min-height:100vh}
.content{min-width:0;padding:0 34px 60px;max-width:880px;margin:0 auto;width:100%}
.doc{animation:rise .4s ease both}
@keyframes rise{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ── sidebar ── */
.sidebar{position:sticky;top:0;align-self:start;height:100vh;overflow-y:auto;background:var(--sidebar);
  border-right:1px solid var(--line);padding:18px 14px 40px;scrollbar-width:thin}
.sidebar::-webkit-scrollbar{width:7px}.sidebar::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:9px}
.sb-brand{display:flex;align-items:center;gap:9px;padding:6px 8px 14px;font-weight:700;font-size:15px}
.sb-brand img{height:20px}
.sb-brand .g{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.sb-search{width:100%;background:var(--panel);border:1px solid var(--line-strong);border-radius:9px;
  padding:8px 11px;color:var(--white);font-family:inherit;font-size:13px;margin-bottom:12px}
.sb-search::placeholder{color:var(--faint)}.sb-search:focus{outline:none;border-color:var(--accent)}
.sb-group{margin:14px 0 4px}
.sb-group-label{display:flex;align-items:center;gap:7px;font-size:10.5px;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;color:var(--faint);padding:4px 8px}
.sb-group-label .ic{font-size:12px}
.sb-sys{display:flex;align-items:center;gap:8px;padding:7px 9px;border-radius:8px;color:var(--mist);
  font-weight:600;font-size:13.5px;transition:background .12s,color .12s}
.sb-sys:hover{background:var(--panel);color:var(--white);text-decoration:none}
.sb-sys.active{color:var(--white);background:var(--grad-soft);box-shadow:inset 2px 0 0 var(--purple)}
.sb-sys .ic{font-size:13px}
.sb-secs{margin:2px 0 6px 16px;border-left:1px solid var(--line);display:flex;flex-direction:column}
.sb-sec{padding:5px 12px;font-size:12.7px;color:var(--faint);border-left:2px solid transparent;margin-left:-1px;
  transition:color .12s,border-color .12s}
.sb-sec:hover{color:var(--mist);text-decoration:none}
.sb-sec.active{color:var(--white);border-left-color:var(--purple);font-weight:600}
.sb-foot{margin-top:24px;padding:10px 8px 0;border-top:1px solid var(--line);font-size:11px;color:var(--faint)}

/* mobile top bar + off-canvas */
.topbar{display:none;position:sticky;top:0;z-index:40;background:rgba(7,8,26,.92);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);padding:10px 16px;align-items:center;gap:12px}
.topbar .menu{background:var(--panel);border:1px solid var(--line-strong);color:var(--white);border-radius:8px;
  padding:6px 11px;font-size:16px;line-height:1;cursor:pointer}
.topbar .t{font-weight:700;font-size:14px}
.scrim{display:none}

/* ── page header ── */
.page-head{padding:30px 0 6px}
.eyebrow{font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;margin:0 0 9px}
h1{font-size:27px;font-weight:700;line-height:1.18;margin:0;letter-spacing:-.015em}
.page-head p.intro{color:var(--mist);font-size:14.5px;max-width:62ch;margin:9px 0 0}

/* compact safety strip */
.facts{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:18px 0 0}
.facts div{background:var(--panel);border:1px solid var(--line);border-radius:11px;padding:13px 15px;
  font-size:12.5px;color:var(--mist);position:relative;overflow:hidden}
.facts div::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--grad)}
.facts b{color:var(--white);display:block;font-size:12.5px;margin-bottom:3px}

/* ── section markers (clear!) ── */
section{padding:30px 0 2px;scroll-margin-top:24px}
section > .tag{display:inline-flex;align-items:center;gap:7px;font-family:ui-monospace,monospace;font-size:10.5px;
  color:var(--white);font-weight:700;padding:3px 11px 3px 4px;border-radius:999px;letter-spacing:.04em;
  margin-bottom:12px;background:var(--panel-2);border:1px solid var(--line-strong)}
section > .tag .n{display:inline-grid;place-items:center;width:17px;height:17px;border-radius:50%;
  background:var(--grad);color:#fff;font-size:10px}
h2.sec{font-size:19px;font-weight:700;margin:0 0 4px;letter-spacing:-.01em;display:flex;align-items:center;gap:9px}
h2.sec .em{font-size:18px}
h2.sec + .lead{color:var(--mist);font-size:14px;margin:0 0 16px}

/* cards */
.card{background:var(--panel);border:1px solid var(--line);border-radius:13px;padding:18px 20px;margin:12px 0;
  transition:border-color .14s,transform .14s}
.card:hover{border-color:var(--line-strong)}
.card h3{font-size:14.5px;font-weight:700;margin:0 0 13px;display:flex;align-items:center;gap:9px}
.card h3 .dot{width:7px;height:7px;border-radius:50%;background:var(--grad);flex:none;box-shadow:0 0 8px 1px rgba(143,162,246,.5)}

/* steps */
ol.steps{list-style:none;counter-reset:s;margin:0;padding:0}
ol.steps>li{counter-increment:s;position:relative;padding:0 0 14px 34px;margin:0;font-size:13.8px}
ol.steps>li:last-child{padding-bottom:0}
ol.steps>li::before{content:counter(s);position:absolute;left:0;top:-1px;width:23px;height:23px;border-radius:50%;
  background:var(--grad);color:#fff;font-weight:700;font-size:11.5px;display:grid;place-items:center;
  box-shadow:0 2px 8px -2px rgba(116,141,244,.6)}
ol.steps>li::after{content:"";position:absolute;left:11px;top:23px;bottom:3px;width:1px;background:var(--line-strong)}
ol.steps>li:last-child::after{display:none}
ol.steps b{color:var(--white);font-weight:600}
ol.steps .sub{color:var(--faint);font-size:12.5px;display:block;margin-top:3px;line-height:1.5}

/* tables */
table{width:100%;border-collapse:collapse;margin:4px 0;font-size:13.5px}
th,td{text-align:left;padding:9px 12px;border-bottom:1px solid var(--line);vertical-align:top}
th{color:var(--accent);font-size:10.5px;text-transform:uppercase;letter-spacing:.07em;font-weight:700}
td:first-child{font-weight:600;width:36%;color:var(--white)}
tr:hover td{background:rgba(143,162,246,.04)}

/* callouts */
.note{border-radius:10px;padding:12px 15px 12px 16px;margin:13px 0;font-size:13px;border:1px solid;
  color:var(--mist);position:relative}
.note.go{background:rgba(201,231,76,.06);border-color:rgba(201,231,76,.26)}.note.go b{color:var(--yellow)}
.note.warn{background:rgba(218,90,51,.07);border-color:rgba(218,90,51,.3)}.note.warn b{color:var(--orange)}
.note.info{background:rgba(116,141,244,.08);border-color:rgba(116,141,244,.3)}.note.info b{color:var(--accent)}
.note .h{display:block;font-weight:700;margin-bottom:3px}
.ecard{border-color:rgba(218,90,51,.36) !important;background:linear-gradient(180deg,rgba(218,90,51,.06),var(--panel)) !important}
.ecard h3 .dot{background:var(--orange);box-shadow:0 0 8px 1px rgba(218,90,51,.5)}

/* tooltip */
.tt{border-bottom:1px dotted var(--line-strong);cursor:help;position:relative}
.tt::after{content:"i";display:inline-grid;place-items:center;width:12px;height:12px;margin-left:3px;
  vertical-align:super;font-size:8px;font-style:normal;font-weight:700;border-radius:50%;
  background:var(--grad);color:#fff}
.tt .tip{position:absolute;left:0;bottom:calc(100% + 7px);width:290px;max-width:80vw;background:var(--panel-2);
  border:1px solid var(--line-strong);border-radius:10px;padding:11px 13px;font-size:12px;line-height:1.5;
  color:var(--mist);font-weight:400;box-shadow:0 14px 38px rgba(0,0,0,.55);opacity:0;visibility:hidden;
  transform:translateY(4px);transition:opacity .13s,transform .13s;z-index:60}
.tt .tip b{color:var(--white)}
.tt:hover .tip{opacity:1;visibility:visible;transform:translateY(0)}

/* badges */
.badge{font-family:ui-monospace,monospace;font-size:10px;font-weight:700;padding:2px 8px;border-radius:999px;white-space:nowrap}
.badge.live{background:rgba(201,231,76,.14);color:var(--yellow)}
.badge.draft{background:rgba(218,90,51,.15);color:var(--orange)}

/* homepage cards */
.home-hero{padding:34px 0 6px}
.home-hero h1{font-size:26px}
.home-hero h1 .g{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.home-hero p{color:var(--mist);font-size:14.5px;margin:9px 0 0;max-width:60ch}
.cat{padding:24px 0 0}
.cat-h{display:flex;align-items:center;gap:9px;margin:0 0 3px}
.cat-h .ic{font-size:15px}
.cat-h h2{font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--mist);margin:0}
.cat .blurb{color:var(--faint);font-size:13px;margin:0 0 12px}
.sys-list{display:grid;gap:9px}
.sys-card{display:flex;align-items:flex-start;gap:13px;background:var(--panel);border:1px solid var(--line);
  border-radius:11px;padding:14px 16px;transition:border-color .14s,transform .14s,background .14s;position:relative;overflow:hidden}
.sys-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--grad);opacity:0;transition:opacity .14s}
.sys-card:hover{border-color:var(--line-strong);transform:translateY(-2px);background:var(--panel-2);text-decoration:none}
.sys-card:hover::before{opacity:1}
.sys-card .ic{font-size:18px;margin-top:1px}
.sys-card .main{flex:1;min-width:0}
.sys-card h3{font-size:14.5px;font-weight:700;color:var(--white);margin:0 0 2px}
.sys-card p{color:var(--mist);font-size:13px;margin:0}
.sys-card .meta{color:var(--faint);font-size:10.5px;font-family:ui-monospace,monospace;white-space:nowrap;margin-top:2px}
.empty{color:var(--faint);text-align:center;padding:30px 0;font-size:13.5px}

/* provenance + footer */
.provenance{background:var(--panel);border:1px dashed var(--line-strong);border-radius:11px;
  padding:14px 18px;margin:34px 0 0;font-size:12.5px;color:var(--faint)}
.provenance b{color:var(--mist);display:block;margin-bottom:5px;font-size:10.5px;letter-spacing:.1em;text-transform:uppercase}
.provenance ul{margin:0;padding-left:16px}.provenance li{margin:2px 0}.provenance code{font-size:11.5px}
footer{margin:46px 0 0;padding-top:18px;border-top:1px solid var(--line);font-size:12px;color:var(--faint)}

@media(max-width:860px){
  .shell{grid-template-columns:1fr}
  .topbar{display:flex}
  .sidebar{position:fixed;top:0;left:0;z-index:50;width:280px;transform:translateX(-100%);transition:transform .22s ease}
  .sidebar.open{transform:none;box-shadow:0 0 60px rgba(0,0,0,.6)}
  .scrim.show{display:block;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:45}
  .content{padding:0 20px 50px}
  .facts{grid-template-columns:1fr}
  td:first-child{width:auto}
}
