/* docs.kineticpartners.org: Kinetic API Protocol docs */
:root {
  --frost: #F2F0ED; --paper: #FAF9F7; --cobalt: #111518; --cobalt-2: #161b1f;
  --ink: #14181D; --muted: #5C636D; --faint: #71777F;
  --green: #00FF73; --accent-text: #1B7A2A; --hair: rgba(28,33,39,0.13); --hair-2: rgba(28,33,39,0.26);
}
* { box-sizing: border-box; margin: 0; }
body { background: var(--frost); color: var(--ink);
  font-family: "Satoshi", "Inter", -apple-system, sans-serif; font-size: 15px; line-height: 1.55;
  -webkit-font-smoothing: antialiased; overflow-x: hidden; }
.mono { font-family: "Geist Mono", monospace; }
.display { font-family: "Cormorant Garamond", serif; font-weight: 300; }

/* top bar */
.top { display:flex; align-items:center; justify-content:space-between; height:56px;
  padding:0 28px; border-bottom:1px solid var(--hair-2); background:var(--frost);
  position:sticky; top:0; z-index:10; }
.brand { display:flex; align-items:baseline; gap:10px; }
.brand .wm { font-family:"Cormorant Garamond",serif; font-weight:400; font-size:21px; letter-spacing:0.02em; }
.brand { align-items:center; }
.brand .mk { width:15px; height:16px; flex:none; background:url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 32'><circle cx='16' cy='16' r='12' fill='none' stroke='%2300FF73' stroke-width='2'/><circle cx='16' cy='16' r='4' fill='%2300FF73'/></svg>") no-repeat center/contain; }
.brand .wm-caps { font-family:"Geist Mono",monospace; font-size:12px; letter-spacing:0.28em; font-weight:500; }
.brand .delta { color: var(--accent-text); }
.brand .sub { font-family:"Geist Mono",monospace; font-size:11px; letter-spacing:0.22em; text-transform:uppercase; color:var(--muted); }
.top-right { display:flex; align-items:center; gap:22px; font-family:"Geist Mono",monospace; font-size:11px; letter-spacing:0.14em; text-transform:uppercase; color:var(--muted); }
.top-right .env { display:flex; align-items:center; gap:7px; }
.dot { width:6px; height:6px; border-radius:50%; background:var(--green); display:inline-block; }
.btn-key { border:1px solid var(--ink); padding:7px 14px; color:var(--ink); text-decoration:none; }

/* shell */
.shell { display:grid; grid-template-columns: 248px 1fr; min-height: calc(100vh - 56px); }
.shell.three { grid-template-columns: 248px 1fr 460px; }

/* sidebar */
.side { border-right:1px solid var(--hair-2); padding:22px 0 40px; background:var(--frost); }
.nav-fam { font-family:"Geist Mono",monospace; font-size:11px; letter-spacing:0.2em; text-transform:uppercase;
  color:var(--faint); padding: 18px 26px 7px; }
.nav-g { display:flex; justify-content:space-between; align-items:center; padding:5.5px 26px;
  font-size:13.5px; color:var(--ink); text-decoration:none; border-left:2px solid transparent; }
.nav-g .ct { font-family:"Geist Mono",monospace; font-size:11px; color:var(--faint); }
.nav-g.active { border-left:2px solid var(--green); background:rgba(60,180,75,0.07); font-weight:500; }
.side .meta-top { padding: 0 26px 4px; }
.side .search { margin: 0 22px 8px; border:1px solid var(--hair-2); padding:8px 12px; display:flex; gap:8px; align-items:center;
  font-family:"Geist Mono",monospace; font-size:11px; color:var(--faint); background:var(--paper); }
.kbd { border:1px solid var(--hair-2); padding:0 5px; font-size:11px; margin-left:auto; }

/* main column */
.main { padding: 40px 56px 80px; max-width: 880px; }
.eyebrow { font-family:"Geist Mono",monospace; font-size:11px; letter-spacing:0.24em; text-transform:uppercase; color:var(--muted); margin-bottom:14px; }
.eyebrow .acc { color: var(--accent-text); }
h1.hero { font-family:"Cormorant Garamond",serif; font-weight:300; font-size:54px; line-height:1.04; letter-spacing:-0.01em; margin-bottom:18px; }
.lede { font-size:16.5px; color:var(--muted); max-width:620px; margin-bottom:8px; }

/* metrics */
.metrics { display:flex; gap:0; border:1px solid var(--hair-2); margin:34px 0 0; background:var(--paper); }
.metric { flex:1; padding:18px 24px; border-right:1px solid var(--hair); }
.metric:last-child { border-right:none; }
.metric .n { font-family:"Geist Mono",monospace; font-size:26px; font-weight:500; }
.metric .l { font-family:"Geist Mono",monospace; font-size:11px; letter-spacing:0.18em; text-transform:uppercase; color:var(--muted); margin-top:3px; }

/* THE SPINE */
.spine-wrap { margin: 48px 0 10px; }
.spine-head { display:flex; justify-content:space-between; align-items:baseline; margin-bottom:26px; }
.spine-title { font-family:"Geist Mono",monospace; font-size:11px; letter-spacing:0.24em; text-transform:uppercase; color:var(--ink); }
.spine-note { font-family:"Geist Mono",monospace; font-size:11px; color:var(--faint); }
.spine { position:relative; display:flex; justify-content:space-between; }
.spine::before { content:""; position:absolute; top:7px; left:8px; right:8px; height:1px; background:var(--hair-2); }
.station { position:relative; flex:1; text-align:left; padding-top:24px; }
.station::before { content:""; position:absolute; top:3px; left:8px; width:9px; height:9px; border-radius:50%;
  background:var(--frost); border:1.5px solid var(--ink); }
.station.lit::before { background:var(--green); border-color:var(--green); }
.station .s-name { font-size:12.5px; font-weight:500; padding-left:8px; line-height:1.25; }
.station .s-ops { font-family:"Geist Mono",monospace; font-size:11px; color:var(--faint); padding-left:8px; margin-top:2px; }

/* family cards */
.fams { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-top:44px; }
.fam { border:1px solid var(--hair-2); background:var(--paper); padding:20px 22px 18px; position:relative; }
.fam .f-idx { font-family:"Geist Mono",monospace; font-size:11px; letter-spacing:0.16em; color:var(--faint); margin-bottom:10px; display:flex; justify-content:space-between; }
.fam .f-idx .ops { color:var(--ink); }
.fam h3 { font-size:16px; font-weight:600; margin-bottom:5px; }
.fam p { font-size:13px; color:var(--muted); line-height:1.45; }
.fam .f-groups { margin-top:12px; font-family:"Geist Mono",monospace; font-size:11px; color:var(--faint); line-height:1.7; }
.fam:hover { border-color:var(--ink); }

/* section labels */
.sec { font-family:"Geist Mono",monospace; font-size:11px; letter-spacing:0.24em; text-transform:uppercase;
  color:var(--ink); border-bottom:1px solid var(--hair-2); padding-bottom:8px; margin:54px 0 20px; }

/* operation page */
.crumb { font-family:"Geist Mono",monospace; font-size:11px; letter-spacing:0.14em; text-transform:uppercase; color:var(--faint); margin-bottom:18px; }
.crumb b { color:var(--ink); font-weight:500; }
.op-head { display:flex; align-items:center; gap:14px; margin-bottom:10px; flex-wrap:wrap; }
.method { font-family:"Geist Mono",monospace; font-size:11px; font-weight:500; letter-spacing:0.1em;
  padding:4px 10px; border:1px solid var(--ink); }
.method.post { background:var(--ink); color:var(--frost); }
.method.patch { background:#5B4A7A; color:var(--frost); }
.method.delete { background:#7A3B3B; color:var(--frost); }
.path { font-family:"Geist Mono",monospace; font-size:16px; }
.path em { font-style:normal; color:var(--accent-text); }
h2.op-title { font-family:"Cormorant Garamond",serif; font-weight:400; font-size:34px; margin:8px 0 12px; }
.op-desc { color:var(--muted); max-width:560px; margin-bottom:20px; }
.pills { display:flex; gap:8px; margin-bottom:28px; flex-wrap:wrap; }
.pill { font-family:"Geist Mono",monospace; font-size:11px; letter-spacing:0.1em; padding:4px 10px; border:1px solid var(--hair-2); color:var(--muted); }
.pill.scope { border-color:var(--green); color:var(--ink); }
.pill.gate { border-style:dashed; border-color:var(--ink); color:var(--ink); }

.param-t { width:100%; border-collapse:collapse; font-size:13.5px; margin-bottom:8px; }
.param-t th { font-family:"Geist Mono",monospace; font-size:11px; letter-spacing:0.16em; text-transform:uppercase;
  color:var(--faint); text-align:left; padding:7px 10px 7px 0; border-bottom:1px solid var(--hair-2); font-weight:500; }
.param-t td { padding:9px 10px 9px 0; border-bottom:1px solid var(--hair); vertical-align:top; }
.param-t td.mono { font-size:12.5px; }
.req { color:var(--accent-text); font-family:"Geist Mono",monospace; font-size:11px; }
.opt { color:var(--faint); font-family:"Geist Mono",monospace; font-size:11px; }

.gate-call { border:1px solid var(--ink); border-left:3px solid var(--green); background:var(--paper); padding:16px 20px; margin:26px 0; }
.gate-call .gh { font-family:"Geist Mono",monospace; font-size:11px; letter-spacing:0.2em; text-transform:uppercase; margin-bottom:6px; }
.gate-call p { font-size:13.5px; color:var(--muted); }
.gate-call code { font-family:"Geist Mono",monospace; font-size:12px; color:var(--ink); }

.emits { display:flex; gap:8px; flex-wrap:wrap; }
.emit { font-family:"Geist Mono",monospace; font-size:11.5px; padding:5px 12px; border:1px solid var(--hair-2); background:var(--paper); }
.emit::before { content:"● "; color:var(--accent-text); font-size:11px; }

/* right code rail: Aero Cobalt */
.rail { background:var(--cobalt); color:#C9CFD6; padding:28px 26px 60px; font-size:13px; border-left:1px solid var(--hair-2); }
.rail-block { margin-bottom:26px; }
.rail-head { display:flex; justify-content:space-between; align-items:center; margin-bottom:0; }
.rail-tabs { display:flex; gap:2px; }
.rail-tab { font-family:"Geist Mono",monospace; font-size:11px; letter-spacing:0.12em; text-transform:uppercase;
  padding:6px 12px; color:#7E8590; }
.rail-tab.on { color:#F2F0ED; border-bottom:2px solid var(--green); }
.copy { font-family:"Geist Mono",monospace; font-size:11px; color:#7E8590; letter-spacing:0.1em; }
pre.code { font-family:"Geist Mono",monospace; font-size:12px; line-height:1.65; background:var(--cobalt-2);
  border:1px solid rgba(255,255,255,0.07); padding:18px 20px; overflow-x:auto; white-space:pre; margin-top:10px; }
.c-cm { color:#6E7681; } .c-k { color:#8FD19E; } .c-s { color:#E8EAED; } .c-a { color:#00FF73; }
.c-p { color:#9AA0A8; }
.rail-lab { font-family:"Geist Mono",monospace; font-size:11px; letter-spacing:0.2em; text-transform:uppercase; color:#7E8590; margin-bottom:10px; }
pre.code.rail-hidden { display:none; }
.status-line { display:flex; gap:14px; align-items:center; font-family:"Geist Mono",monospace; font-size:11px; color:#7E8590; margin-top:10px; }
.status-line .ok { color:var(--accent-text); }
.try { display:inline-flex; align-items:center; gap:8px; margin-top:4px; font-family:"Geist Mono",monospace;
  font-size:11px; letter-spacing:0.16em; text-transform:uppercase; color:var(--frost);
  border:1px solid var(--green); padding:9px 16px; }
.footer-note { margin-top:60px; padding-top:18px; border-top:1px solid var(--hair); font-family:"Geist Mono",monospace; font-size:11px; letter-spacing:0.14em; text-transform:uppercase; color:var(--faint); display:flex; justify-content:space-between; }

/* ===== generated portal additions ===== */
a { color: inherit; text-decoration: none; }
.main a.link { border-bottom: 1px solid var(--green); }
.shell.three { grid-template-columns: 248px 1fr; }
.op-row { display: grid; grid-template-columns: minmax(0,1fr) 440px; border-bottom: 1px solid var(--hair-2); }
.op-left { padding: 44px 44px 52px 0; min-width: 0; }
.op-right { background: var(--cobalt); color: #C9CFD6; padding: 40px 26px 48px; font-size: 13px; min-width: 0; }
.group-head { padding: 40px 0 8px; }
.main.ref { padding: 0 0 0 56px; max-width: none; }
.main.ref .group-head { padding-right: 44px; }
.op-index { width: 100%; border-collapse: collapse; font-size: 13px; margin: 18px 0 26px; }
.op-index td { padding: 8px 12px 8px 0; border-bottom: 1px solid var(--hair); }
.op-index .m { font-family: "Geist Mono", monospace; font-size: 10.5px; font-weight: 500; width: 64px; }
.op-index .p { font-family: "Geist Mono", monospace; font-size: 12px; }
.op-index tr:hover { background: rgba(60,180,75,0.05); cursor: pointer; }
pre.code .c-num { color: #D2A8FF; }
pre.code .c-b, .c-b { color: #D2A8FF; }
.copy-btn { cursor: pointer; background: none; border: none; font-family: "Geist Mono", monospace; font-size: 10px; color: #7E8590; letter-spacing: 0.1em; }
.copy-btn:hover { color: #F2F0ED; }
.rail-tab { cursor: pointer; background: none; border: none; border-bottom: 2px solid transparent; }
.rail-tab.on { border-bottom: 2px solid var(--green); }
/* search modal */
.smask { display: none; position: fixed; inset: 0; background: rgba(20,24,29,0.45); z-index: 50; }
.smask.open { display: block; }
.sbox { position: absolute; top: 110px; left: 50%; transform: translateX(-50%); width: 620px; max-width: 92vw;
  background: var(--paper); border: 1px solid var(--ink); box-shadow: 0 30px 80px rgba(20,24,29,0.35); }
.sbox input { width: 100%; border: none; outline: none; background: transparent; padding: 18px 20px;
  font-family: "Geist Mono", monospace; font-size: 14px; color: var(--ink); border-bottom: 1px solid var(--hair-2); }
.sres { max-height: 420px; overflow-y: auto; }
.sres a { display: flex; gap: 12px; align-items: baseline; padding: 10px 20px; border-bottom: 1px solid var(--hair); }
.sres a:hover, .sres a.sel { background: rgba(60,180,75,0.08); }
.sres .m { font-family: "Geist Mono", monospace; font-size: 10px; font-weight: 500; width: 52px; flex: none; }
.sres .p { font-family: "Geist Mono", monospace; font-size: 12px; color: var(--muted); }
.sres .t { font-size: 13px; }
.search { cursor: pointer; }
/* guide pages */
.prose h3 { font-size: 17px; font-weight: 600; margin: 34px 0 10px; }
.prose p { color: var(--muted); max-width: 640px; margin-bottom: 12px; }
.prose code { font-family: "Geist Mono", monospace; font-size: 12.5px; background: var(--paper); border: 1px solid var(--hair); padding: 1px 5px; }
.prose pre.lcode { font-family: "Geist Mono", monospace; font-size: 12px; line-height: 1.65; background: var(--cobalt); color: #C9CFD6;
  padding: 18px 20px; overflow-x: auto; margin: 14px 0 22px; max-width: 760px; }

/* multi-language code tabs (curl / Python / Node) */
.lcode-tabs { max-width: 760px; margin: 14px 0 22px; }
.lcode-tabs .tabs { display: flex; gap: 2px; border-bottom: 1px solid var(--hair-2); }
.lcode-tabs .tab { font-family: "Geist Mono", monospace; font-size: 11px; letter-spacing: 0.03em;
  color: var(--muted); background: none; border: none; border-bottom: 2px solid transparent;
  padding: 8px 13px; cursor: pointer; }
.lcode-tabs .tab:hover { color: var(--ink); }
.lcode-tabs .tab.active { color: var(--ink); border-bottom-color: var(--green); }
.lcode-tabs pre.lcode { display: none; margin: 0; max-width: none; }
.lcode-tabs pre.lcode.active { display: block; }
.ev-t { width: 100%; border-collapse: collapse; font-size: 13px; }
.ev-t th { font-family: "Geist Mono", monospace; font-size: 9.5px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--faint);
  text-align: left; padding: 7px 10px 7px 0; border-bottom: 1px solid var(--hair-2); font-weight: 500; }
.ev-t td { padding: 9px 10px 9px 0; border-bottom: 1px solid var(--hair); vertical-align: top; }
.tag-locked { font-family:"Geist Mono",monospace; font-size:11px; color:var(--ink); border:1px solid var(--ink); padding:2px 7px; }
.tag-prop { font-family:"Geist Mono",monospace; font-size:11px; color:var(--muted); border:1px dashed var(--hair-2); padding:2px 7px; }
@media (max-width: 1100px) { .op-row { grid-template-columns: 1fr; } .shell, .shell.three { grid-template-columns: 1fr; } .side { display: none; } }

:focus-visible{outline:2px solid var(--green);outline-offset:2px}
.fam:focus-visible,tr[role=link]:focus-visible{outline:2px solid var(--green);outline-offset:-2px}

/* mobile nav (P0 fix 2026-06-12) */
.menu-btn{display:none;background:none;border:1px solid var(--hair-2);color:var(--ink);font-size:16px;line-height:1;padding:7px 11px;margin-right:14px;cursor:pointer}
@media (max-width: 1100px){
  .menu-btn{display:inline-flex;align-items:center}
  .top{padding:0 16px}
  body.nav-open .side{display:block;position:fixed;top:56px;left:0;bottom:0;width:min(320px,86vw);overflow-y:auto;background:var(--frost);z-index:40;border-right:1px solid var(--hair-2);box-shadow:0 12px 40px rgba(20,24,29,0.18)}
  .main{padding:32px 20px 64px}
}

/* v2 roadmap / coming soon */
.v2-planned { opacity: 0.55; }
.v2-planned:hover { opacity: 0.85; }
.v2-planned.active { opacity: 1; }
.v2-hero-badge { font-family: "Geist Mono", monospace; font-size: 13px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--faint); vertical-align: middle; border: 1px dashed var(--hair-2); padding: 4px 12px; margin-left: 12px; }
.pill.v2-badge { border-style: dashed; border-color: var(--faint); color: var(--faint); }
.nav-fam .ct { margin-left: 6px; }


/* ── GLOBAL NAV STRIP ── */
.gstrip{background:rgba(0,0,0,0.35);border-bottom:1px solid rgba(233,231,226,0.13);padding:7px 0;font-family:'Geist Mono',monospace;font-size:10px;letter-spacing:0.22em}
.gstrip-in{max-width:1080px;margin:0 auto;padding:0 48px;display:flex;align-items:center;gap:24px}
.gstrip-mark{display:flex;align-items:center;gap:7px;color:#9BA1A8}
.gstrip-dot{width:10px;height:10px;border:1px solid #9BA1A8;border-radius:50%;position:relative;display:inline-block}
.gstrip-dot::after{content:"";position:absolute;inset:0;margin:auto;width:3px;height:3px;background:#00FF73;border-radius:50%}
.gstrip-sep{width:1px;height:10px;background:rgba(233,231,226,0.13)}
.gstrip-links{display:flex;gap:20px}
.gstrip-links a{color:#878E96;text-decoration:none;transition:color .15s}
.gstrip-links a:hover{color:#E9E7E2}
.gstrip-links a.gs-active{color:#00FF73}
@media(max-width:640px){
  .gstrip-in{padding:0 16px;gap:12px}
  .gstrip-links{gap:10px}
  .gstrip-links a{font-size:9px}
  .top{padding:0 16px;height:auto;min-height:48px;flex-wrap:wrap;gap:6px 12px;padding-top:8px;padding-bottom:8px}
  .brand .sub{display:none}
  .brand .wm-caps{font-size:11px}
  .top-right{gap:12px;font-size:9px}
  .top-right span:not(.dot){display:none}
  .btn-key{padding:5px 10px;font-size:9px}
  .main{padding:24px 16px 48px}
  .main.ref{padding:0 0 0 16px}
  h1.hero{font-size:28px;line-height:1.12}
  .lede{font-size:14px}
  .metrics{flex-direction:column;border:none;gap:0}
  .metric{padding:12px 0;border-right:none;border-bottom:1px solid var(--hair)}
  .metric:last-child{border-bottom:none}
  .metric .n{font-size:24px}
  .spine-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -16px;padding:0 16px}
  .spine{min-width:600px}
  .station{min-width:0}
  .op-index .p{font-size:10.5px;word-break:break-all}
  .prose pre.lcode{font-size:11px;padding:14px 16px;margin-left:-16px;margin-right:-16px;border-radius:0}
  .lcode-tabs{margin-left:-16px;margin-right:-16px}
  .lcode-tabs .tabs{padding-left:16px}
  /* D1: Family cards → single column */
  .fams{grid-template-columns:1fr;gap:10px}

  /* D2: Reference code rail → stack below content */
  .op-row{grid-template-columns:1fr;gap:0}
  .op-left{padding:24px 16px 20px 0}
  .op-right{padding:20px 16px 28px;border-left:none;border-top:1px solid rgba(255,255,255,0.07)}

  /* D3: Tables → horizontal scroll + smaller font */
  .param-t,.ev-t,.op-index{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;font-size:12px}
  .param-t th,.ev-t th{font-size:9px;white-space:nowrap}
  .param-t td,.ev-t td{font-size:12px}
  .field-table{font-size:12px}

  /* D4: Top bar → hide version/env, tighten */
  .top-right .env{display:none}

  /* D5: Reference left padding */
  .main.ref{padding:0 0 0 16px}
  .main.ref .group-head{padding-right:16px}
  .group-head{padding:24px 0 6px}

  /* D6: Metrics → 2x2 grid instead of single column */
  .metrics{display:grid;grid-template-columns:1fr 1fr;border:1px solid var(--hair-2);gap:0}
  .metric{border-right:1px solid var(--hair);border-bottom:1px solid var(--hair);padding:14px 16px}
  .metric:nth-child(2n){border-right:none}
  .metric:nth-child(n+3){border-bottom:none}
  .metric .n{font-size:22px}

  /* D7: Spine stations → wrap into 2 rows on small screens */
  .spine-head{flex-direction:column;align-items:flex-start;gap:6px}
  .spine{flex-wrap:wrap;gap:4px 0;min-width:0!important}
  .spine::before{display:none}
  .station{flex:0 0 20%;min-width:0;text-align:center;padding-top:20px}
  .station::before{left:50%;transform:translateX(-50%)}
  .station .s-name{padding-left:0;font-size:11px;text-align:center}
  .station .s-ops{padding-left:0;text-align:center;font-size:10px}

  /* D8: Footer note → stack */
  .footer-note{flex-direction:column;gap:8px}

  /* D9: Prevent body horizontal overflow */
  .shell{overflow-x:hidden}
}

/* Strip overrides for light-mode docs */
.gstrip{background:#111518;color:#878E96}
.gstrip a{color:#878E96}
.gstrip a.gs-active{color:#00FF73}
.gstrip a:hover{color:#E9E7E2}
