:root{--bg:#0b1020;--panel:#111831;--panel2:#0f1630;--text:#e8ecff;--muted:#9aa7d6;--accent:#7aa2ff;--danger:#ff5d7a;--ok:#57f287;--stroke:rgba(255,255,255,.14);--soft:rgba(255,255,255,.06);--soft2:rgba(255,255,255,.08);}*{box-sizing:border-box}body{font-family:system-ui;margin:0;background:var(--bg);color:var(--text)}a{color:var(--accent)}main{max-width:none;margin:0 auto;padding:18px 16px;line-height:1.6}code,pre{background:var(--soft);border:1px solid var(--soft2);border-radius:12px}pre{padding:12px;overflow:auto}.topbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;padding:12px;border:1px solid var(--soft2);border-radius:16px;background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.03));position:sticky;top:0;z-index:20;backdrop-filter:blur(8px);}.btn{padding:10px 12px;border-radius:14px;border:1px solid var(--soft2);background:rgba(255,255,255,.06);color:var(--text);cursor:pointer;user-select:none;transition:transform .08s ease,background .12s ease,border-color .12s ease;font-weight:600;display:inline-flex;align-items:center;gap:8px;}.btn:hover{transform:translateY(-1px);background:rgba(255,255,255,.09)}.btn:active{transform:translateY(0px)}.btn.primary{border-color:rgba(122,162,255,.55);background:rgba(122,162,255,.12)}.btn.danger{border-color:rgba(255,93,122,.55);background:rgba(255,93,122,.12)}.btn.ok{border-color:rgba(87,242,135,.55);background:rgba(87,242,135,.10)}.pill{padding:6px 10px;border-radius:999px;border:1px solid var(--soft2);background:rgba(255,255,255,.05);color:var(--muted);font-size:12px}.pill strong{color:var(--text)}.sep{width:1px;height:34px;background:rgba(255,255,255,.08);margin:0 2px}.ad-slot{border:1px dashed rgba(122,162,255,.45);background:rgba(122,162,255,.07);border-radius:14px;padding:14px;color:rgba(232,236,255,.9);text-align:center;font-size:14px;margin:14px 0;}.ad-slot small{display:block;color:var(--muted);margin-top:6px}.diagram-wrap{position:relative;border-radius:18px;border:1px solid var(--soft2);overflow:hidden;background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.02));min-height:78vh;width:100%;margin-top:12px;}.diagram{position:relative;width:100%;height:100%;min-height:78vh;background:radial-gradient(circle at 18px 18px,rgba(255,255,255,.06) 1px,transparent 1px) 0 0 / 22px 22px;}.wires{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:12;}.wire{pointer-events:none;}.wire-hit{pointer-events:stroke;cursor:pointer;opacity:0;}.link-selected{filter:drop-shadow(0 0 10px rgba(122,162,255,.55));}.kbd{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.06);padding:2px 6px;border-radius:8px;color:rgba(232,236,255,.95)}.uml-node{position:absolute;z-index:10;min-width:220px;max-width:360px;border-radius:14px;border:1px solid rgba(255,255,255,.16);box-shadow:0 12px 30px rgba(0,0,0,.28);overflow:hidden;user-select:none;}.uml-node.selected{outline:2px solid rgba(122,162,255,.55);box-shadow:0 14px 34px rgba(122,162,255,.10),0 12px 30px rgba(0,0,0,.30);}.uml-head{padding:10px 12px;display:flex;gap:10px;align-items:center;justify-content:space-between;cursor:grab;border-bottom:1px solid rgba(255,255,255,.12);}.uml-head:active{cursor:grabbing}.uml-name{display:flex;flex-direction:column;line-height:1.2;min-width:0;}.stereo{font-size:11px;opacity:.85}.title{font-weight:800;letter-spacing:.2px;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}.badge{font-size:11px;padding:4px 8px;border-radius:999px;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.07);color:rgba(232,236,255,.95);flex:0 0 auto;}.uml-body{padding:10px 12px}.comp{border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.04);border-radius:12px;padding:8px 10px;margin-top:8px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:12px;line-height:1.35;white-space:pre;overflow:auto;max-height:220px;}.float-panel{position:fixed;right:16px;top:84px;width:340px;max-height:78vh;overflow:auto;z-index:40;border-radius:18px;border:1px solid rgba(255,255,255,.12);background:linear-gradient(180deg,rgba(17,24,49,.98),rgba(15,22,48,.98));box-shadow:0 24px 70px rgba(0,0,0,.55);display:none;}.float-panel.open{display:block}.fp-head{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.10);}.fp-head h3{margin:0;font-size:14px}.fp-body{padding:12px 14px}.xbtn{border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.06);color:var(--text);border-radius:12px;padding:8px 10px;cursor:pointer;font-weight:800;}.xbtn:hover{background:rgba(255,255,255,.10)}.field{display:flex;flex-direction:column;gap:6px;margin:10px 0}.row2{display:grid;grid-template-columns:1fr 1fr;gap:10px}label{font-size:12px;color:var(--muted)}input[type="text"],textarea,select{width:100%;border-radius:14px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.06);color:var(--text);padding:10px 12px;outline:none;}textarea{min-height:120px;resize:vertical;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:12px}select option{color:#0b1020;background:#ffffff}.mini-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}.muted{color:var(--muted)}.toast{margin-top:10px;padding:10px 12px;border-radius:14px;border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.05);color:var(--muted);font-size:13px;}.toast.ok{border-color:rgba(87,242,135,.35);background:rgba(87,242,135,.08)}.toast.bad{border-color:rgba(255,93,122,.40);background:rgba(255,93,122,.10);color:rgba(255,220,227,.95)}@media (max-width:720px){.float-panel{left:12px;right:12px;width:auto;top:auto;bottom:12px;max-height:62vh;}}.modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,.55);z-index:60;padding:16px;}.modal.open{display:flex}.modal-card{width:min(980px,96vw);max-height:86vh;border-radius:18px;border:1px solid rgba(255,255,255,.12);background:linear-gradient(180deg,rgba(17,24,49,.98),rgba(15,22,48,.98));box-shadow:0 24px 70px rgba(0,0,0,.55);overflow:hidden;display:flex;flex-direction:column;}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.10);}.modal-head h3{margin:0;font-size:14px}.modal-body{padding:12px 14px;overflow:auto}.modal-body pre{margin:0}