:root{--bg:#0d1117;--panel:#161b22;--panel-2:#1c2330;--border:#2a3140;--text:#e8eaf0;--muted:#8b93a3;--accent:#2d6cdf;--health:#e0457b;--network:#1f9d72;--volume:#d98324;--host:#7a7f8c;--warn:#d9a324;--error:#e0457b}*{box-sizing:border-box}html,body{background:var(--bg);height:100%;color:var(--text);margin:0;font:14px/1.45 -apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.topbar{background:var(--panel);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;height:48px;padding:0 16px;display:flex}.brand{align-items:center;gap:8px;font-weight:600;display:flex}.logo{font-size:18px}.topbar-actions{align-items:center;gap:12px;display:flex}.layout-field{color:var(--muted);align-items:center;gap:6px;font-size:12px;display:flex}.app{height:calc(100% - 48px);display:flex}.sidebar{background:var(--panel);border-right:1px solid var(--border);flex:0 0 340px;width:340px;padding:12px;overflow-y:auto}.panel{margin-bottom:18px}.panel h2{text-transform:uppercase;letter-spacing:.05em;color:var(--muted);align-items:center;gap:8px;margin:0 0 8px;font-size:12px;display:flex}.canvas-wrap{flex:1;position:relative}#cy{background:radial-gradient(circle at 50% 40%,#11161f,#0a0d13);position:absolute;inset:0}.dropzone{border:1px dashed var(--border);text-align:center;color:var(--muted);border-radius:8px;padding:14px;font-size:13px;transition:border-color .15s,background .15s}.dropzone.drag{border-color:var(--accent);background:#2d6cdf1f}.link-btn{color:var(--accent);cursor:pointer;text-decoration:underline}textarea{resize:vertical;background:var(--bg);width:100%;height:150px;color:var(--text);border:1px solid var(--border);border-radius:8px;margin-top:10px;padding:10px;font:12px/1.45 ui-monospace,SFMono-Regular,Menlo,monospace}.row{gap:8px;margin-top:10px;display:flex}.btn{background:var(--panel-2);color:var(--text);border:1px solid var(--border);cursor:pointer;border-radius:8px;padding:7px 12px;font-size:13px}.btn:hover{border-color:var(--accent)}.btn.primary{background:var(--accent);border-color:var(--accent)}.btn.primary:hover{filter:brightness(1.1)}select{background:var(--panel-2);color:var(--text);border:1px solid var(--border);border-radius:6px;padding:4px 6px}.parse-error{color:var(--error);margin:10px 0 0;font-size:12px}.file-list{flex-direction:column;gap:4px;margin:10px 0 0;padding:0;list-style:none;display:flex}.file-item{background:var(--panel-2);border:1px solid var(--border);border-radius:6px;align-items:center;gap:8px;padding:5px 8px;font-size:12.5px;display:flex}.file-ord{background:var(--accent);color:#fff;border-radius:50%;flex:0 0 18px;justify-content:center;align-items:center;width:18px;height:18px;font-size:11px;font-weight:700;display:inline-flex}.file-name{text-overflow:ellipsis;white-space:nowrap;flex:1;font-family:ui-monospace,monospace;overflow:hidden}.file-actions{gap:2px;display:flex}.mini{color:var(--muted);cursor:pointer;background:0 0;border:0;border-radius:4px;padding:2px 4px;font-size:12px}.mini:hover{background:var(--border);color:var(--text)}.mode-field{justify-content:space-between;align-items:center;gap:8px;margin-top:12px;display:flex}.mode-label{color:var(--muted);font-size:12px}.mode-hint{color:var(--muted);margin:6px 0 0;font-size:11.5px}.paste-box{margin-top:12px}.paste-box summary{cursor:pointer;color:var(--accent);font-size:12.5px}.paste-box textarea{height:110px}.paste-box .btn{margin-top:8px}.seg{border:1px solid var(--border);border-radius:8px;display:inline-flex;overflow:hidden}.seg-btn{background:var(--panel-2);color:var(--muted);cursor:pointer;border:0;padding:6px 12px;font-size:13px}.seg-btn+.seg-btn{border-left:1px solid var(--border)}.seg-btn.active{background:var(--accent);color:#fff}.seg-btn.disabled{opacity:.35;cursor:not-allowed}select:disabled{opacity:.4;cursor:not-allowed}.startup{flex-direction:column;gap:10px;display:flex}.wave{border-left:2px solid var(--border);padding-left:10px}.wave-h{color:var(--muted);text-transform:uppercase;letter-spacing:.04em;align-items:center;gap:8px;margin-bottom:4px;font-size:11px;display:flex}.wave-n{background:var(--accent);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:11px;font-weight:700;display:inline-flex}.wave-h .parallel{color:var(--network)}.wstep{cursor:pointer;border-radius:6px;padding:5px 8px}.wstep:hover{background:var(--panel-2)}.wstep b{font-size:13px}.wreason{color:var(--muted);margin-top:2px;font-size:11.5px}.cyc{color:var(--error);font-size:11px}.critpath{color:#ffce8a;cursor:pointer;background:#ffae4224;border:1px solid #ffae4266;border-radius:6px;margin-bottom:4px;padding:6px 8px;font-size:12px}.critpath:hover{background:#ffae423d}.critpath:before{content:"○ "}.critpath.active{background:#ffae424d;border-color:#ffae42}.critpath.active:before{content:"● "}.diff-key{margin-bottom:8px;font-size:12px}.d-added{color:#1f9d72}.d-removed{color:var(--error)}.d-changed{color:var(--warn)}.toggles{flex-direction:column;gap:6px;font-size:13px;display:flex}.toggles label{cursor:pointer;align-items:center;gap:8px;display:flex}.legend{color:var(--muted);flex-direction:column;gap:5px;margin:0;padding:0;font-size:12px;list-style:none;display:flex}.legend li{align-items:center;gap:8px;display:flex}.sw{border-radius:3px;flex:0 0 14px;width:14px;height:14px}.sw.svc{background:var(--accent)}.sw.svc-health{background:var(--accent);box-shadow:0 0 0 2px var(--health)}.sw.net{background:var(--network);border-radius:2px;transform:rotate(45deg)}.sw.vol{background:var(--volume);border-radius:7px/3px}.sw.cfg{background:#4b8fa6;border-radius:3px}.sw.sec{clip-path:polygon(20% 0,100% 0,100% 80%,80% 100%,0 100%,0 20%);background:#c75c7a}.sw.host{background:var(--host)}.ln{border-top:3px solid;flex:0 0 18px;width:18px;height:0}.ln.started{border-color:#8a8f9c}.ln.healthy{border-color:var(--accent)}.ln.completed{border-color:var(--network)}.ln.mount{border-top-style:dashed;border-color:var(--volume)}.ln.network{border-color:#3a7a63}.ln.connect{border-color:#b07cff;border-top-style:dashed}.ln.namespace{border-color:#e0457b;border-top-width:4px}.ln.extends{border-color:#8a8f9c;border-top-style:dashed}.sw.reachable{box-shadow:0 0 0 2px var(--network);background:0 0;border-radius:4px}.badge{background:var(--border);color:var(--text);border-radius:10px;padding:1px 8px;font-size:11px}.badge-warn{background:var(--warn);color:#000}.badge-error{background:var(--error)}.warnings{flex-direction:column;gap:6px;margin:0;padding:0;font-size:12.5px;list-style:none;display:flex}.warn{border-left:3px solid var(--muted);background:var(--panel-2);border-radius:6px;padding:7px 9px}.warn-error{border-left-color:var(--error)}.warn-warning{border-left-color:var(--warn)}.warn-info{border-left-color:var(--accent)}.warn.clickable{cursor:pointer}.warn.clickable:hover{background:var(--border)}.details{font-size:13px}.details h3{margin:0 0 8px;font-size:14px}.d-row{border-bottom:1px solid #ffffff0a;gap:8px;padding:3px 0;display:flex}.d-key{color:var(--muted);flex:0 0 90px}.d-val{word-break:break-word}.d-block{margin-top:8px}.d-block .d-key{margin-bottom:4px;display:block}.d-block ul{margin:4px 0;padding-left:18px}.d-block li{margin:2px 0}.details pre{background:var(--bg);border-radius:6px;padding:8px;font-size:11px;overflow-x:auto}.chip{background:var(--panel-2);border:1px solid var(--border);border-radius:10px;margin:1px 0;padding:1px 8px;font-size:12px;display:inline-block}.health .hc{background:var(--bg);border-radius:6px;padding:6px;font-family:ui-monospace,monospace;font-size:12px}.cond{border-radius:8px;padding:1px 6px;font-size:10px}.cond-service_healthy{background:#2d6cdf4d}.cond-service_started{background:#8a8f9c4d}.cond-service_completed_successfully{background:#1f9d724d}.sidebar-footer{border-top:1px solid var(--border);color:var(--muted);flex-direction:column;gap:3px;margin-top:4px;padding-top:12px;font-size:11.5px;display:flex}.footer-title{color:#fff;vertical-align:middle;background:#1d63ed;border-radius:9px;padding:1px 6px;font-size:10px;font-weight:600;display:inline-block}.footer-links{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.footer-links a{color:var(--accent);text-decoration:none}.footer-links a:hover{text-decoration:underline}.footer-links .sep{color:var(--border)}.muted{color:var(--muted)}.small{font-size:11px}code{background:var(--panel-2);border-radius:4px;padding:1px 5px;font-size:12px}
