/* IOTSIM Manual — shared theme
   Mirrors the approved Group 5 draft; circuit pattern at 6% (up from 3.5%). */

:root{
  --bg:#0a0c10;--panel:#111318;--surface:#181c24;--surface-2:#1f242e;
  --border:#262d3a;--border-soft:#1e2430;
  --accent:#00D4FF;--accent-dim:#0ea5cf;
  --accent2:#FF6B35;
  --green:#00c853;--red:#ff1744;--gold:#ffd600;--purple:#aa00ff;
  --text:#e0e4ea;--text-soft:#a8b0bd;--dim:#6b7280;--bright:#f5f6f8;
  --font:'DM Sans',system-ui,-apple-system,sans-serif;
  --mono:'Fira Code',ui-monospace,monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;font-family:var(--font);color:var(--text);-webkit-font-smoothing:antialiased}
::-webkit-scrollbar{width:7px;height:7px}
::-webkit-scrollbar-thumb{background:#2a313f;border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:#3a4458}
*{scrollbar-width:thin;scrollbar-color:#2a313f transparent}

body{
  background:
    radial-gradient(ellipse 1400px 900px at 50% -200px, rgba(0,212,255,0.08) 0%, rgba(10,12,16,0) 60%),
    radial-gradient(ellipse 1200px 800px at 100% 110%, rgba(170,0,255,0.05) 0%, rgba(10,12,16,0) 55%),
    var(--bg);
  min-height:100vh;position:relative
}
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:0;opacity:0.06;
  background-image:
    linear-gradient(var(--accent) 1px, transparent 1px),
    linear-gradient(90deg, var(--accent) 1px, transparent 1px),
    radial-gradient(circle at 20px 20px, var(--accent) 1.5px, transparent 2px),
    radial-gradient(circle at 60px 60px, var(--purple) 1.5px, transparent 2px);
  background-size:80px 80px, 80px 80px, 80px 80px, 80px 80px;
}

/* ─── App shell ──────────────────────────────────────────── */
#app{display:flex;height:100vh;height:100dvh;position:relative;z-index:1}
#sidebar{
  width:290px;flex-shrink:0;border-right:1px solid var(--border);
  background:var(--panel);display:flex;flex-direction:column;overflow:hidden
}
.hdr{padding:18px 16px 12px;border-bottom:1px solid var(--border)}
.hdr h1{font-size:13px;font-weight:800;color:var(--accent);letter-spacing:2.8px;margin:0}
.hdr .sub{font-size:10px;color:var(--dim);margin-top:3px;letter-spacing:1px}
.search-wrap{padding:11px 13px;border-bottom:1px solid var(--border);position:relative}
#search{
  width:100%;background:var(--bg);border:1px solid var(--border);color:var(--text);
  padding:9px 32px 9px 12px;border-radius:7px;font-family:var(--font);font-size:12.5px;
  outline:none;transition:border-color .15s, box-shadow .15s
}
#search:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(0,212,255,0.1)}
#search::placeholder{color:var(--dim)}
.search-clear{
  position:absolute;right:20px;top:50%;transform:translateY(-50%);
  background:none;border:none;color:var(--dim);cursor:pointer;font-size:15px;
  display:none;padding:4px;line-height:1
}
.search-clear.show{display:block}

#nav{flex:1;overflow-y:auto;padding:6px 4px 14px}
.nav-part{
  padding:14px 12px 5px;font-size:10.5px;font-weight:800;color:var(--accent2);
  letter-spacing:1.8px;text-transform:uppercase
}
.nav-part:first-child{padding-top:8px}
.nav-group{margin-bottom:1px}
.nav-group-head{
  display:flex;align-items:center;gap:8px;padding:7px 11px;border-radius:6px;
  cursor:pointer;color:var(--text-soft);font-size:12px;font-weight:600;
  transition:background .12s,color .12s;user-select:none
}
.nav-group-head:hover{background:#ffffff08;color:var(--text)}
.nav-group-head .chev{transition:transform .18s;font-size:9px;width:10px;color:var(--dim)}
.nav-group.open .chev{transform:rotate(90deg)}
.nav-group-head .nm{flex:1;line-height:1.35}
.nav-group-body{display:none;padding:2px 0 4px 14px;border-left:1px solid var(--border);margin-left:14px}
.nav-group.open .nav-group-body{display:block}
.nav-item{
  display:block;padding:5px 9px;border-radius:5px;color:var(--dim);font-size:11.5px;
  cursor:pointer;border-left:2px solid transparent;margin-bottom:1px;
  line-height:1.35;transition:color .12s,background .12s;user-select:none;
  text-decoration:none
}
.nav-item:hover{color:var(--text);background:#ffffff06}
.nav-item.on{color:var(--accent);background:#00D4FF12;border-left-color:var(--accent);font-weight:600}
.nav-single{
  display:flex;align-items:center;gap:8px;padding:8px 11px;border-radius:6px;cursor:pointer;
  color:var(--text-soft);font-size:12.5px;font-weight:500;margin-bottom:1px;
  border-left:3px solid transparent;transition:all .12s;user-select:none;
  text-decoration:none
}
.nav-single:hover{background:#ffffff08;color:var(--text)}
.nav-single.on{background:#00D4FF15;color:var(--bright);font-weight:700;border-left-color:var(--accent)}

.ft{padding:10px;border-top:1px solid var(--border);font-size:10px;color:var(--dim);text-align:center}

/* Mobile */
#mt{display:none;position:fixed;top:12px;left:12px;z-index:200;background:var(--panel);border:1px solid var(--border);color:var(--text);padding:9px 14px;border-radius:8px;font-size:20px;cursor:pointer;line-height:1}
#mo{display:none;position:fixed;inset:0;z-index:199;background:rgba(10,12,16,0.96);padding:52px 10px 20px;overflow-y:auto}
#mo.show{display:block}
@media(max-width:860px){
  #sidebar{display:none}
  #mt{display:block}
  #mo #sidebar{display:flex;position:static;width:auto;max-width:340px;margin:0 auto;height:calc(100vh - 80px);border-radius:10px;border:1px solid var(--border)}
}

/* ─── Main content ───────────────────────────────────────── */
#ct{flex:1;overflow-y:auto;scroll-behavior:smooth}
#ct-inner{max-width:880px;margin:0 auto;padding:32px 40px 100px}
@media(max-width:860px){#ct-inner{padding:60px 18px 60px}}

/* ─── Chapter header ─────────────────────────────────────── */
.stripe{
  height:3px;margin:0 0 22px;border-radius:2px;
  background:linear-gradient(90deg,var(--purple) 0%, var(--accent) 35%, var(--green) 70%, var(--gold) 100%);
  opacity:0.85
}
.header-row{display:flex;align-items:flex-end;gap:16px;margin-bottom:10px;flex-wrap:wrap}
.header-text{flex:1;min-width:240px}
.kicker{font-size:11px;font-weight:800;color:var(--accent);letter-spacing:3px;text-transform:uppercase;margin:0 0 4px}
.h1{font-size:34px;font-weight:800;color:var(--bright);margin:0 0 10px;line-height:1.15;letter-spacing:-0.5px}
.pane{font-family:var(--mono);font-size:11px;color:var(--dim);letter-spacing:.6px;padding:8px 12px;background:rgba(0,212,255,0.05);border:1px solid rgba(0,212,255,0.15);border-radius:5px;display:inline-block;margin:0 0 20px}

/* Quick/Full view toggle */
.view-toggle{display:inline-flex;gap:0;background:var(--surface);border:1px solid var(--border);border-radius:999px;padding:3px;font-size:11.5px}
.vt-btn{padding:7px 16px;border-radius:999px;cursor:pointer;border:none;background:none;color:var(--dim);font-family:var(--font);font-weight:700;letter-spacing:.4px;font-size:11px;transition:all .15s;text-transform:uppercase}
.vt-btn.on{background:var(--accent);color:#000}
.vt-btn:not(.on):hover{color:var(--text)}

/* ─── Typography ─────────────────────────────────────────── */
.intro{font-size:15px;line-height:1.75;margin:0 0 24px;color:var(--text-soft)}
.h2{font-size:22px;font-weight:700;color:var(--accent2);margin:36px 0 12px;letter-spacing:-0.2px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.h2::before{content:"";width:4px;height:22px;background:var(--accent2);border-radius:2px;flex-shrink:0}
.h3{font-size:16px;font-weight:700;color:var(--accent);margin:22px 0 8px}
.p{font-size:14.5px;line-height:1.75;margin:10px 0;color:var(--text)}
.p b, .b{font-weight:700;color:var(--bright)}

/* ─── Main settings table ────────────────────────────────── */
.tw{overflow-x:auto;margin:14px 0;border-radius:10px;border:1px solid var(--border);box-shadow:0 2px 8px rgba(0,0,0,0.2)}
.tb{width:100%;border-collapse:collapse;font-size:13px;table-layout:fixed}
.tb col.c-set{width:22%}
.tb col.c-opt{width:22%}
.tb col.c-desc{width:56%}
.tb th{padding:11px 14px;background:var(--bg);color:var(--bright);font-weight:700;text-align:left;border-bottom:2px solid var(--border);letter-spacing:.4px;font-size:11.5px;text-transform:uppercase}
.tb td{padding:12px 14px;border-bottom:1px solid var(--border-soft);line-height:1.6;vertical-align:top;font-size:13.5px}
.tb tr:last-child td{border-bottom:none}
.tb tr{transition:background .12s}
.tb tbody tr:hover td{background:rgba(0,212,255,0.04)}
.tb tbody tr:nth-child(even) td{background:rgba(24,28,36,0.6)}
.tb tbody tr:nth-child(odd) td{background:rgba(17,19,24,0.4)}
.tb td.s{color:var(--accent);font-weight:700;font-family:var(--mono);font-size:12.5px;background:rgba(0,212,255,0.04) !important}
.tb td.o{color:var(--gold);font-family:var(--mono);font-size:11.5px;background:rgba(255,214,0,0.03) !important}
.tb td.d{color:var(--text)}

/* ─── Drawers ────────────────────────────────────────────── */
.drawers{margin:18px 0 10px}
.drawers-hdr{font-size:11px;font-weight:800;color:var(--accent);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:8px;display:flex;align-items:center;gap:8px}
.drawers-hdr::before{content:"▾";color:var(--accent)}
.drawer{border:1px solid var(--border);border-radius:8px;margin-bottom:8px;overflow:hidden;background:var(--surface);transition:border-color .15s}
.drawer:hover{border-color:var(--accent-dim)}
.drawer.open{border-color:var(--accent)}
.drawer-head{padding:12px 16px;cursor:pointer;display:flex;align-items:center;gap:12px;user-select:none;transition:background .12s}
.drawer-head:hover{background:rgba(0,212,255,0.04)}
.drawer-head .chev{color:var(--dim);font-size:11px;transition:transform .2s;width:10px;flex-shrink:0}
.drawer.open .drawer-head .chev{transform:rotate(90deg);color:var(--accent)}
.drawer-head .nm{color:var(--accent);font-family:var(--mono);font-weight:700;font-size:13px;flex:1}
.drawer-head .tg{color:var(--dim);font-size:10.5px;letter-spacing:.5px;text-transform:uppercase;padding:3px 8px;border-radius:4px;background:rgba(107,114,128,0.15)}
.drawer-body{max-height:0;overflow:hidden;transition:max-height .25s ease;border-top:0 solid var(--border)}
.drawer.open .drawer-body{max-height:4000px;border-top-width:1px}
.drawer-body-inner{padding:14px 18px 16px}
.drawer-body .p{font-size:14px;margin:8px 0}
.drawer-body .p:first-child{margin-top:0}
.drawer-body .p:last-child{margin-bottom:0}

body.full-view .drawer{border-color:var(--border-soft)}
body.full-view .drawer-body{max-height:none;border-top:1px solid var(--border)}
body.full-view .drawer-head .chev{display:none}
body.full-view .drawer-head{cursor:default;background:transparent}
body.full-view .drawers-hdr::before{content:"▸"}

/* ─── Interactive badge ──────────────────────────────────── */
.interactive-tag{
  display:inline-flex;align-items:center;gap:6px;
  font-size:10px;font-weight:800;letter-spacing:1.2px;text-transform:uppercase;
  color:var(--purple);background:rgba(170,0,255,0.12);
  padding:4px 10px;border-radius:999px;border:1px solid rgba(170,0,255,0.3)
}
.interactive-tag::before{
  content:"";width:6px;height:6px;border-radius:50%;background:var(--purple);
  box-shadow:0 0 8px var(--purple);animation:pulse 2s ease-in-out infinite
}
@keyframes pulse{0%,100%{opacity:0.5;transform:scale(0.85)}50%{opacity:1;transform:scale(1.15)}}

.ixn{margin:22px 0;padding:18px 20px;background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--purple);border-radius:10px;position:relative}
.ixn .hdr{font-size:11px;font-weight:800;color:var(--purple);letter-spacing:1px;text-transform:uppercase;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.ixn .hdr::before{content:"▸ TRY IT";font-size:9px;padding:3px 8px;background:rgba(170,0,255,0.18);border-radius:4px;letter-spacing:.8px}

/* ─── Mirror demo ────────────────────────────────────────── */
.mirror-modes{display:flex;gap:6px;margin-bottom:16px;flex-wrap:wrap}
.mirror-btn{flex:1;min-width:140px;padding:10px 14px;border-radius:7px;cursor:pointer;border:1px solid var(--border);background:var(--panel);color:var(--dim);font-family:var(--font);font-size:12px;font-weight:600;transition:all .15s;text-align:center}
.mirror-btn:hover{color:var(--text);border-color:var(--accent)}
.mirror-btn.on{background:rgba(0,212,255,0.12);border-color:var(--accent);color:var(--accent);font-weight:700}
.mirror-stage{display:flex;gap:14px;align-items:stretch}
@media(max-width:620px){.mirror-stage{flex-direction:column}}
.mirror-side{flex:1;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:14px;transition:all .3s}
.mirror-side.src{border-color:rgba(0,200,83,0.4);background:rgba(0,200,83,0.03)}
.mirror-side.dst-mirrored{border-color:rgba(170,0,255,0.45);background:rgba(170,0,255,0.05)}
.mirror-side.dst-indep{border-color:rgba(255,107,53,0.4);background:rgba(255,107,53,0.03)}
.mirror-side .hd{font-size:11px;font-weight:800;letter-spacing:1px;margin-bottom:10px;text-transform:uppercase}
.mirror-side .hd .badge{font-size:9px;padding:2px 7px;border-radius:10px;margin-left:6px;font-weight:700;letter-spacing:.4px}
.mirror-side.src .hd{color:var(--green)}
.mirror-side.src .badge{background:rgba(0,200,83,0.2);color:var(--green)}
.mirror-side.dst-mirrored .hd{color:var(--purple)}
.mirror-side.dst-mirrored .badge{background:rgba(170,0,255,0.25);color:var(--purple)}
.mirror-side.dst-indep .hd{color:var(--accent2)}
.mirror-side.dst-indep .badge{background:rgba(255,107,53,0.2);color:var(--accent2)}
.mirror-row{display:flex;justify-content:space-between;gap:8px;padding:6px 0;font-size:12px;border-bottom:1px dashed var(--border)}
.mirror-row:last-child{border-bottom:none}
.mirror-row .k{color:var(--dim)}
.mirror-row .v{color:var(--text);font-family:var(--mono);font-size:11.5px;font-weight:600}
.mirror-arrow{display:flex;align-items:center;justify-content:center;font-size:22px;color:var(--purple);width:28px;flex-shrink:0;transition:opacity .3s}
.mirror-note{margin-top:12px;font-size:12.5px;color:var(--text);line-height:1.6;padding:10px 14px;background:var(--panel);border-radius:6px;border-left:3px solid var(--accent)}
.mirror-note strong{color:var(--bright)}

/* ─── ON/OFF toggles ─────────────────────────────────────── */
.toggle-demo{display:flex;gap:0;background:var(--panel);border-radius:8px;padding:4px;width:fit-content;margin-bottom:12px;border:1px solid var(--border)}
.toggle-btn{padding:9px 22px;border-radius:6px;cursor:pointer;border:none;background:none;color:var(--dim);font-family:var(--mono);font-weight:700;font-size:12px;letter-spacing:1px;transition:all .15s}
.toggle-btn:hover{color:var(--text)}
.toggle-btn.on[data-v="ON"]{background:var(--green);color:#000}
.toggle-btn.on[data-v="OFF"]{background:var(--red);color:#fff}
.toggle-panel{padding:14px 16px;background:var(--panel);border-radius:8px;border-left:3px solid var(--accent-dim);font-size:13.5px;line-height:1.7;color:var(--text);min-height:80px;transition:all .2s}
.toggle-panel.on-state{border-left-color:var(--green);background:rgba(0,200,83,0.04)}
.toggle-panel.off-state{border-left-color:var(--red);background:rgba(255,23,68,0.04)}
.toggle-panel b{color:var(--bright)}

/* ─── Dropdown demo ──────────────────────────────────────── */
.dd-wrap{margin-bottom:12px}
.dd-label{font-size:11px;color:var(--dim);letter-spacing:.5px;text-transform:uppercase;margin-bottom:6px}
select.dd{appearance:none;width:100%;max-width:420px;padding:10px 36px 10px 14px;background:var(--panel);color:var(--text);border:1px solid var(--border);border-radius:7px;font-family:var(--mono);font-size:13px;font-weight:600;cursor:pointer;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='7' viewBox='0 0 12 7'><path d='M1 1l5 5 5-5' stroke='%2300D4FF' stroke-width='1.6' fill='none' stroke-linecap='round'/></svg>");background-repeat:no-repeat;background-position:right 14px center;transition:border-color .15s}
select.dd:focus{outline:none;border-color:var(--accent)}
.dd-panel{margin-top:10px;padding:14px 16px;background:var(--panel);border-radius:8px;border-left:3px solid var(--accent);font-size:13.5px;line-height:1.7}
.dd-panel .sub{font-size:11px;color:var(--dim);letter-spacing:.5px;text-transform:uppercase;margin:10px 0 4px}
.dd-panel .sub:first-child{margin-top:0}
.dd-panel b{color:var(--bright)}

/* ─── Calculator ─────────────────────────────────────────── */
.calc{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:620px){.calc{grid-template-columns:1fr}}
.calc-col{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:14px}
.calc-col .hd{font-size:11px;font-weight:800;letter-spacing:1px;text-transform:uppercase;margin-bottom:10px}
.calc-col.input .hd{color:var(--accent)}
.calc-col.output .hd{color:var(--green)}
.calc-input-row{margin-bottom:12px}
.calc-input-row:last-child{margin-bottom:0}
.calc-input-row label{display:block;font-size:11.5px;color:var(--dim);margin-bottom:4px;letter-spacing:.3px}
.calc-input-row input{width:100%;padding:8px 10px;background:var(--panel);border:1px solid var(--border);color:var(--text);border-radius:6px;font-family:var(--mono);font-size:13px;transition:border-color .15s}
.calc-input-row input:focus{outline:none;border-color:var(--accent)}
.calc-out{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px dashed var(--border);font-size:13px}
.calc-out:last-child{border-bottom:none}
.calc-out .k{color:var(--dim)}
.calc-out .v{color:var(--green);font-family:var(--mono);font-weight:700}
.calc-formula{margin-top:12px;padding:10px 12px;background:rgba(0,212,255,0.04);border-radius:6px;font-family:var(--mono);font-size:11.5px;color:var(--text-soft);line-height:1.6}
.calc-formula b{color:var(--accent)}

/* ─── Callouts ───────────────────────────────────────────── */
.co{border-left:4px solid var(--accent);border-radius:0 10px 10px 0;padding:14px 18px;margin:16px 0;background:rgba(0,212,255,0.06)}
.co .ct{font-weight:700;font-size:13.5px;margin-bottom:6px;color:var(--accent);letter-spacing:.3px}
.co .cb{font-size:14px;line-height:1.7}
.co .cb strong, .co .cb b{color:var(--bright)}
.co.orange{border-left-color:var(--accent2);background:rgba(255,107,53,0.08)}
.co.orange .ct{color:var(--accent2)}
.co.green{border-left-color:var(--green);background:rgba(0,200,83,0.06)}
.co.green .ct{color:var(--green)}
.co.red{border-left-color:var(--red);background:rgba(255,23,68,0.06)}
.co.red .ct{color:var(--red)}
.co.gold{border-left-color:var(--gold);background:rgba(255,214,0,0.06)}
.co.gold .ct{color:var(--gold)}
.co.purple{border-left-color:var(--purple);background:rgba(170,0,255,0.07)}
.co.purple .ct{color:var(--purple)}

/* ─── Reference sub-tables ───────────────────────────────── */
.tb-ref{width:100%;border-collapse:collapse;font-size:13.5px;margin:10px 0;border-radius:8px;overflow:hidden;border:1px solid var(--border)}
.tb-ref th{padding:11px 14px;background:var(--bg);color:var(--bright);font-weight:700;text-align:left;font-size:11.5px;letter-spacing:.4px;text-transform:uppercase;border-bottom:2px solid var(--border)}
.tb-ref td{padding:10px 14px;border-bottom:1px solid var(--border-soft);vertical-align:top;line-height:1.55}
.tb-ref tr:last-child td{border-bottom:none}
.tb-ref td.v{color:var(--accent);font-family:var(--mono);font-weight:700;font-size:12.5px;background:rgba(0,212,255,0.04);white-space:nowrap}
.tb-ref td.sc-name{color:var(--accent);font-weight:600;font-family:var(--mono);font-size:12.5px;background:rgba(0,212,255,0.04)}
.tb-ref td.sc-off{color:var(--text-soft);background:rgba(255,23,68,0.03)}
.tb-ref td.sc-on{color:var(--text);background:rgba(0,200,83,0.03)}

/* Prev/Next */
.nb{display:flex;justify-content:space-between;gap:12px;margin-top:56px;padding-top:24px;border-top:1px solid var(--border)}
.bn{padding:11px 22px;border-radius:8px;cursor:pointer;font-size:13px;font-weight:600;border:1px solid var(--border);background:var(--surface);color:var(--text-soft);transition:all .15s;text-decoration:none;display:inline-flex;align-items:center;gap:8px;font-family:var(--font)}
.bn:hover{filter:brightness(1.2);color:var(--text);border-color:var(--accent-dim)}
.bn.nx{background:rgba(0,212,255,0.08);border-color:rgba(0,212,255,0.4);color:var(--accent);font-weight:700}

/* Search results */
.search-results{display:flex;flex-direction:column;gap:6px;padding:10px 4px}
.search-result{padding:11px 14px;border-radius:7px;cursor:pointer;color:var(--text);font-size:12px;line-height:1.45;background:var(--surface);border:1px solid var(--border);transition:all .12s}
.search-result:hover{border-color:var(--accent);background:rgba(0,212,255,0.06)}
.search-result .title{font-weight:700;color:var(--bright);margin-bottom:4px}
.search-result .ctx{color:var(--text-soft);font-size:11.5px;line-height:1.45}
.search-result mark{background:rgba(255,107,53,0.30);color:var(--bright);padding:0 3px;border-radius:2px;font-weight:600}
.search-empty{padding:24px;color:var(--dim);font-size:12.5px;text-align:center;font-style:italic}
.search-count{padding:8px 12px;color:var(--dim);font-size:10.5px;letter-spacing:.5px;text-transform:uppercase;font-weight:600}

/* Install banner */
#ib{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--panel);border-top:1px solid var(--border);padding:12px 20px;z-index:300;text-align:center}
#ib.show{display:block}

/* ─── Killzone / Macro timeline ──────────────────────────── */
.kz-tl-wrap{position:relative;padding:28px 0 18px;margin:14px 0}
.kz-tl-scale{position:relative;height:18px;border-bottom:1px solid var(--border);margin-bottom:10px}
.kz-tl-tick{position:absolute;top:0;font-size:10px;color:var(--dim);font-family:var(--mono);transform:translateX(-50%)}
.kz-tl-tick span{display:block;padding-bottom:2px}
.kz-tl-rows{display:flex;flex-direction:column;gap:6px}
.kz-tl-row{display:flex;align-items:center;gap:10px}
.kz-tl-label{width:110px;font-size:11.5px;color:var(--text-soft);flex-shrink:0;font-weight:600}
.kz-tl-track{flex:1;position:relative;height:22px;background:rgba(0,0,0,0.3);border-radius:4px;overflow:hidden}
.kz-tl-bar{position:absolute;top:2px;bottom:2px;border-radius:3px;opacity:0.75;display:flex;align-items:center;padding:0 6px;transition:all .2s}
.kz-tl-bar span{font-family:var(--mono);font-size:10px;color:rgba(0,0,0,0.9);font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.kz-tl-bar.active{opacity:1;box-shadow:0 0 0 1px rgba(255,255,255,0.3),0 0 8px rgba(0,212,255,0.3)}
.kz-tl-now{position:absolute;top:0;bottom:0;width:2px;background:var(--accent);z-index:3;pointer-events:none}
.kz-tl-now span{position:absolute;top:-20px;left:50%;transform:translateX(-50%);font-size:10px;color:var(--accent);white-space:nowrap;font-family:var(--mono);font-weight:700;background:var(--bg);padding:2px 6px;border-radius:3px;border:1px solid var(--accent)}

/* ─── Entry Level Fibonacci visualiser (Group 6/17) ─────── */
.fib-vis{margin:14px 0;padding:18px 22px;background:var(--bg);border:1px solid var(--border);border-radius:10px}
.fib-vis-track{position:relative;height:14px;background:linear-gradient(90deg,rgba(0,200,83,0.15) 0%,rgba(170,0,255,0.15) 50%,rgba(255,23,68,0.15) 100%);border-radius:7px;margin:40px 0 28px}
.fib-vis-marker{position:absolute;top:-10px;bottom:-10px;width:2px;background:var(--accent);transform:translateX(-50%);transition:left .25s ease}
.fib-vis-marker::before{content:"";position:absolute;top:-6px;left:50%;transform:translateX(-50%);width:14px;height:14px;background:var(--accent);border-radius:50%;border:2px solid var(--bg);box-shadow:0 0 12px var(--accent)}
.fib-vis-marker-label{position:absolute;bottom:calc(100% + 4px);left:50%;transform:translateX(-50%);font-family:var(--mono);font-size:11px;color:var(--accent);font-weight:700;white-space:nowrap;background:var(--bg);padding:2px 8px;border-radius:4px;border:1px solid var(--accent)}
.fib-vis-labels{position:relative;height:18px;margin-top:6px}
.fib-vis-label{position:absolute;top:0;transform:translateX(-50%);font-size:10.5px;color:var(--dim);font-family:var(--mono)}
.fib-vis-endpoints{display:flex;justify-content:space-between;font-size:11px;color:var(--dim);margin:10px 0 -10px;font-weight:600;letter-spacing:.3px}
.fib-vis-endpoints .lo{color:var(--green)}
.fib-vis-endpoints .hi{color:var(--red)}
.fib-vis-btns{display:flex;flex-wrap:wrap;gap:5px;margin-top:14px}
.fib-btn{padding:6px 12px;border:1px solid var(--border);background:var(--panel);color:var(--dim);font-family:var(--mono);font-size:11.5px;border-radius:5px;cursor:pointer;font-weight:600;transition:all .15s}
.fib-btn:hover{color:var(--text);border-color:var(--accent)}
.fib-btn.on{background:rgba(0,212,255,0.12);border-color:var(--accent);color:var(--accent)}
.fib-desc{margin-top:12px;padding:10px 14px;background:var(--panel);border-radius:6px;border-left:3px solid var(--accent);font-size:13px;line-height:1.65}

/* ─── SL Method selector (Group 11/22) ────────────────────── */
.sl-method{margin:14px 0;padding:16px 18px;background:var(--surface);border:1px solid var(--border);border-radius:10px;border-left:3px solid var(--purple)}
.sl-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:6px;margin-bottom:14px}
.sl-btn{padding:8px 10px;border:1px solid var(--border);background:var(--panel);color:var(--dim);font-family:var(--mono);font-size:11px;border-radius:5px;cursor:pointer;font-weight:600;text-align:center;transition:all .15s}
.sl-btn:hover{color:var(--text);border-color:var(--accent)}
.sl-btn.on{background:rgba(170,0,255,0.15);border-color:var(--purple);color:var(--purple)}
.sl-detail{padding:14px 16px;background:var(--panel);border-radius:8px;border-left:3px solid var(--purple);font-size:13.5px;line-height:1.7}
.sl-detail .sub{font-size:11px;color:var(--dim);letter-spacing:.5px;text-transform:uppercase;margin:10px 0 4px}
.sl-detail .sub:first-child{margin-top:0}

/* ─── Alert Template builder (Group 45) ──────────────────── */
.alert-builder{margin:14px 0;padding:18px;background:var(--surface);border:1px solid var(--border);border-radius:10px;border-left:3px solid var(--purple)}
.alert-builder label{display:block;font-size:11px;color:var(--dim);letter-spacing:.5px;text-transform:uppercase;margin-bottom:6px}
.alert-builder textarea{width:100%;background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:6px;padding:10px 12px;font-family:var(--mono);font-size:12.5px;resize:vertical;min-height:68px;transition:border-color .15s}
.alert-builder textarea:focus{outline:none;border-color:var(--purple)}
.alert-placeholders{display:flex;flex-wrap:wrap;gap:5px;margin:10px 0}
.alert-ph{padding:4px 10px;background:rgba(170,0,255,0.1);color:var(--purple);border:1px solid rgba(170,0,255,0.3);border-radius:12px;font-family:var(--mono);font-size:10.5px;cursor:pointer;font-weight:600;transition:all .15s}
.alert-ph:hover{background:rgba(170,0,255,0.2)}
.alert-output{margin-top:10px;padding:12px 14px;background:var(--bg);border:1px solid var(--border);border-radius:6px;font-family:var(--mono);font-size:12.5px;color:var(--green);word-break:break-word;min-height:40px;line-height:1.6}
