:root{
  --bg:#0a1622; --panel:#0f2032; --panel2:#13283d; --line:#244563;
  --ink:#e6eef5; --dim:#8fb6d8; --accent:#5b9bd5; --gold:#e0b24a;
  --ok:#8fd0a0; --warn:#f0b75e; --bad:#e08080;
}
*{box-sizing:border-box}
html,body{margin:0}
body{
  background:var(--bg); color:var(--ink);
  font:14px/1.5 ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
}
a{color:var(--accent)}

.topbar{padding:18px 24px;border-bottom:1px solid var(--line);background:linear-gradient(180deg,#0d1b2a,#0a1622)}
.crumb{font-size:12px;color:var(--dim);text-decoration:none}
.brand h1{margin:6px 0 2px;font-size:26px;letter-spacing:.06em;color:var(--gold)}
.brand p{margin:0;color:var(--dim);font-size:13px;max-width:70ch}

main{
  display:grid;
  grid-template-columns:280px minmax(360px,1fr) minmax(420px,1.2fr);
  gap:18px;padding:18px 24px;align-items:start;
}
@media(max-width:1100px){
  main{grid-template-columns:1fr}
  /* single-column: the controls must scroll with the page, not pin themselves
     while the stack scrolls over and the drawing scrolls under */
  .controls{position:static;top:auto}
}

h2{font-size:13px;text-transform:uppercase;letter-spacing:.1em;color:var(--dim);margin:0 0 12px;border-bottom:1px solid var(--line);padding-bottom:6px}

/* controls */
.controls{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:16px;position:sticky;top:12px}
.controls label{display:block;margin-bottom:12px;font-size:12px;color:var(--dim)}
.controls label small{color:#5d7e9c}
.controls select,.controls input{
  width:100%;margin-top:4px;background:var(--panel2);color:var(--ink);
  border:1px solid var(--line);border-radius:6px;padding:7px 8px;font:inherit;
}
.adv{margin:6px 0 12px;border:1px dashed var(--line);border-radius:6px;padding:8px}
.adv summary{cursor:pointer;color:var(--dim);font-size:12px}
/* pinout editor */
.pinout{font-size:11px}
.pinout .ph{display:grid;grid-template-columns:1fr 46px 46px;gap:4px;color:#5d7e9c;padding:2px 0;border-bottom:1px solid var(--line)}
.pinout .pr{display:grid;grid-template-columns:1fr 46px 46px;gap:4px;align-items:center;padding:2px 0}
.pinout .pr .sig{display:flex;align-items:center;gap:5px;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pinout select{margin:0;padding:3px 2px;font-size:11px;background:var(--panel2);color:var(--ink);border:1px solid var(--line);border-radius:4px}

.exports{display:flex;flex-direction:column;gap:8px;margin-top:8px}
.exports button{
  background:var(--panel2);color:var(--ink);border:1px solid var(--accent);
  border-radius:6px;padding:9px;font:inherit;cursor:pointer;
}
.exports button:hover{background:#1b3650}

/* stack */
.stack{display:flex;flex-direction:column;gap:10px}
.layer{display:flex;gap:12px;background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:12px;position:relative}
.layer-n{
  flex:0 0 34px;height:34px;border-radius:50%;display:grid;place-items:center;
  background:var(--panel2);border:1px solid var(--accent);color:var(--gold);font-weight:700;
}
.layer-body{flex:1;min-width:0}
.layer-title{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--dim)}
.layer-name{font-size:15px;color:var(--ink);font-weight:700;margin:2px 0 8px}
table.kv{width:100%;border-collapse:collapse;margin-bottom:8px}
table.kv th{text-align:left;color:var(--dim);font-weight:400;padding:2px 10px 2px 0;vertical-align:top;white-space:nowrap;width:1%}
table.kv td{color:var(--ink);padding:2px 0}
.rationale{font-size:12px;color:var(--dim);border-left:2px solid var(--accent);padding-left:10px}
.alts{font-size:11px;color:#6f93b3;margin-top:6px}

/* output */
.output{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:16px}
.summary{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}
.chip{background:var(--panel2);border:1px solid var(--line);border-radius:20px;padding:3px 12px;font-size:12px;color:var(--dim)}
.drawing{border:1px solid var(--line);border-radius:8px;overflow:hidden;background:#0d1b2a}
.drawing svg{display:block}

.warnbox{margin:12px 0}
.warn{background:#2a1c0d;border:1px solid var(--warn);color:var(--warn);border-radius:6px;padding:8px 10px;margin-bottom:6px;font-size:12px}
.ok{background:#0d2a18;border:1px solid var(--ok);color:var(--ok);border-radius:6px;padding:8px 10px;font-size:12px}

.tabs{display:flex;gap:6px;margin:6px 0}
.tab{background:transparent;border:1px solid var(--line);color:var(--dim);border-radius:6px 6px 0 0;padding:6px 14px;cursor:pointer;font:inherit}
.tab.active{background:var(--panel2);color:var(--ink);border-bottom-color:var(--panel2)}
.panel{display:none}
.panel.active{display:block}
table.data{width:100%;border-collapse:collapse;font-size:12px}
table.data th{text-align:left;color:var(--dim);font-weight:600;border-bottom:1px solid var(--line);padding:6px 8px}
table.data td{padding:5px 8px;border-bottom:1px solid #18324a;color:var(--ink)}
.dot{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:6px;vertical-align:middle}

footer{padding:18px 24px;border-top:1px solid var(--line);color:#5d7e9c;font-size:11px}
footer a{color:var(--accent)}

@media print{
  body{background:#fff;color:#000}
  .controls,.topbar .crumb,footer,.tabs{display:none}
  .output,.stackcol{break-inside:avoid}
  main{grid-template-columns:1fr;display:block}
}
