:root{--bg: #0f1117;--canvas-bg: #14171f;--surface: #1a1e29;--surface-2: #20253200;--border: #2a3040;--text: #e6e9f0;--text-dim: #9aa3b2;--muted: #6b7384;--c-project: #a78bfa;--c-feature: #60a5fa;--c-file: #2dd4bf;--c-function: #fbbf24;--c-service: #34d399;--i-Server: #fb923c;--i-Database: #2dd4bf;--i-API: #60a5fa;--i-Service: #34d399;--i-Auth: #a78bfa;--i-DNS: #94a3b8;--i-CDN: #22d3ee;--i-AI: #818cf8;--i-DevTool: #fbbf24;--i-Gateway: #f87171;--i-Storage: #fde047;--i-Queue: #f472b6;--i-Monitor: #a3e635;--panel-w: 320px;--topbar-h: 52px}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--text);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased}.app{display:flex;flex-direction:column;height:100%}.topbar{height:var(--topbar-h);flex:0 0 var(--topbar-h);display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:0 18px;background:#0c0e14;border-bottom:1px solid var(--border);z-index:10}.brand{font-weight:700;letter-spacing:.08em;font-size:15px}.brand-mark{color:var(--c-feature);margin-right:4px}.layer-tabs{display:flex;gap:6px;justify-self:center}.layer-tab{padding:6px 14px;font-size:13px;font-weight:600;color:var(--text-dim);background:transparent;border:1px solid var(--border);border-radius:999px;cursor:pointer;transition:background .12s ease,color .12s ease,border-color .12s ease}.layer-tab:hover{color:var(--text);border-color:#3a4254}.layer-tab.active{color:#0c0e14;background:var(--c-feature);border-color:var(--c-feature)}.layer-indicator{text-align:right;font-size:12px;color:var(--text-dim)}.project-name-inline{color:var(--text);font-weight:600}.workspace{flex:1 1 auto;display:flex;min-height:0}.canvas{position:relative;flex:1 1 auto;overflow:hidden;background-color:var(--canvas-bg);background-image:radial-gradient(rgba(255,255,255,.16) 1px,transparent 1px);background-size:26px 26px;cursor:grab}.canvas.panning{cursor:grabbing}.canvas-inner{position:absolute;top:0;left:0;transform-origin:0 0;will-change:transform}.canvas-inner.smooth{transition:transform .18s ease-out}.edges{position:absolute;top:0;left:0;overflow:visible;pointer-events:none}.edge-line{stroke:#ffffff2e;stroke-width:1.5}.edge-arrow{fill:#ffffff59}.node{position:absolute;transform:translate(-50%,-50%);min-width:130px;max-width:220px;padding:12px 14px;background:var(--surface);border:1px solid var(--border);border-left:4px solid var(--accent, var(--border));border-radius:10px;cursor:grab;-webkit-user-select:none;user-select:none;box-shadow:0 4px 20px #0006}.node:active{cursor:grabbing}.node.settling{transition:left .6s cubic-bezier(.22,1,.36,1),top .6s cubic-bezier(.22,1,.36,1)}.node-label{margin-top:8px;font-weight:600;font-size:14px}.node-project,.node-feature{min-width:160px}.node-project{--accent: var(--c-project)}.node-feature{--accent: var(--c-feature)}.node-file{--accent: var(--c-file)}.node-function{--accent: var(--c-function)}.node-service{--accent: var(--c-service)}.node.selected,.infra-node.selected{border-color:var(--accent, #fff);box-shadow:0 4px 20px #0006,0 0 0 2px var(--accent, #fff),0 0 22px color-mix(in srgb,var(--accent, #fff) 40%,transparent)}.infra-node{position:absolute;transform:translate(-50%,-50%);width:184px;padding:12px 14px;background:var(--surface);border:1px solid var(--border);border-top:3px solid var(--accent, var(--border));border-radius:12px;cursor:grab;-webkit-user-select:none;user-select:none;box-shadow:0 4px 20px #0006}.infra-node:active{cursor:grabbing}.infra-node.settling{transition:left .6s cubic-bezier(.22,1,.36,1),top .6s cubic-bezier(.22,1,.36,1)}.infra-node.unconnected{border-style:dashed;border-color:var(--border)}.infra-head{display:flex;align-items:center;gap:8px}.infra-icon-wrap{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:7px;color:var(--accent, var(--text));background:color-mix(in srgb,var(--accent, #fff) 14%,transparent)}.infra-icon{width:18px;height:18px}.infra-badge{color:var(--accent, var(--text-dim))}.infra-label{margin-top:9px;font-weight:600;font-size:14px}.infra-desc{margin-top:5px;font-size:11.5px;line-height:1.4;color:var(--text-dim);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.infra-status{display:flex;align-items:center;gap:6px;margin-top:10px;font-size:10.5px;letter-spacing:.03em;color:var(--muted)}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--muted);flex:0 0 auto}.infra-Server{--accent: var(--i-Server)}.infra-Database{--accent: var(--i-Database)}.infra-API{--accent: var(--i-API)}.infra-Service{--accent: var(--i-Service)}.infra-Auth{--accent: var(--i-Auth)}.infra-DNS{--accent: var(--i-DNS)}.infra-CDN{--accent: var(--i-CDN)}.infra-AI{--accent: var(--i-AI)}.infra-DevTool{--accent: var(--i-DevTool)}.infra-Gateway{--accent: var(--i-Gateway)}.infra-Storage{--accent: var(--i-Storage)}.infra-Queue{--accent: var(--i-Queue)}.infra-Monitor{--accent: var(--i-Monitor)}.badge{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:2px 7px;border-radius:999px;background:#ffffff0f}.badge-project{color:var(--c-project)}.badge-feature{color:var(--c-feature)}.badge-file{color:var(--c-file)}.badge-function{color:var(--c-function)}.badge-service{color:var(--c-service)}.itype-Server{color:var(--i-Server)}.itype-Database{color:var(--i-Database)}.itype-API{color:var(--i-API)}.itype-Service{color:var(--i-Service)}.itype-Auth{color:var(--i-Auth)}.itype-DNS{color:var(--i-DNS)}.itype-CDN{color:var(--i-CDN)}.itype-AI{color:var(--i-AI)}.itype-DevTool{color:var(--i-DevTool)}.itype-Gateway{color:var(--i-Gateway)}.itype-Storage{color:var(--i-Storage)}.itype-Queue{color:var(--i-Queue)}.itype-Monitor{color:var(--i-Monitor)}.dot.itype-Server{background:var(--i-Server)}.dot.itype-Database{background:var(--i-Database)}.dot.itype-API{background:var(--i-API)}.dot.itype-Service{background:var(--i-Service)}.dot.itype-Auth{background:var(--i-Auth)}.dot.itype-DNS{background:var(--i-DNS)}.dot.itype-CDN{background:var(--i-CDN)}.dot.itype-AI{background:var(--i-AI)}.dot.itype-DevTool{background:var(--i-DevTool)}.dot.itype-Gateway{background:var(--i-Gateway)}.dot.itype-Storage{background:var(--i-Storage)}.dot.itype-Queue{background:var(--i-Queue)}.dot.itype-Monitor{background:var(--i-Monitor)}.canvas-tools{position:absolute;top:14px;left:14px;display:flex;gap:8px;z-index:5}.canvas-tools button{padding:7px 13px;font-size:12.5px;font-weight:600;color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:8px;cursor:pointer;box-shadow:0 2px 10px #0000004d}.canvas-tools button:hover{background:#232838}.canvas-tools .load-btn{color:#0c0e14;background:var(--c-feature);border-color:var(--c-feature)}.canvas-tools .load-btn:hover{filter:brightness(1.07);background:var(--c-feature)}.zoom-controls{position:absolute;right:16px;bottom:16px;display:flex;flex-direction:column;gap:6px}.zoom-controls button{width:34px;height:34px;font-size:18px;line-height:1;color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:8px;cursor:pointer}.zoom-controls button:hover{background:#232838}.detail-panel{position:relative;flex:0 0 var(--panel-w);width:var(--panel-w);background:var(--surface);border-left:1px solid var(--border);padding:20px 18px;overflow-y:auto}.close-btn{position:absolute;top:12px;right:12px;width:26px;height:26px;font-size:18px;line-height:1;color:var(--text-dim);background:transparent;border:none;border-radius:6px;cursor:pointer}.close-btn:hover{background:#ffffff14;color:var(--text)}.detail-title{margin:10px 0 8px;font-size:20px}.detail-desc{margin:0;color:var(--text-dim);font-size:13px;line-height:1.55}.detail-section{margin-top:22px}.detail-section h3{margin:0 0 10px;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.connected-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.connected-link{display:flex;align-items:center;gap:8px;width:100%;text-align:left;padding:8px 10px;font-size:13px;color:var(--text);background:#ffffff08;border:1px solid var(--border);border-radius:8px;cursor:pointer}.connected-link:hover{background:#ffffff14}.dot{width:8px;height:8px;border-radius:50%;flex:0 0 auto}.dot-project{background:var(--c-project)}.dot-feature{background:var(--c-feature)}.dot-file{background:var(--c-file)}.dot-function{background:var(--c-function)}.dot-service{background:var(--c-service)}.muted{color:var(--muted);font-size:13px}.ask-row{display:flex;gap:6px}.ask-row input{flex:1 1 auto;min-width:0;padding:9px 11px;font-size:13px;color:var(--text);background:#0e1118;border:1px solid var(--border);border-radius:8px}.ask-row input:focus{outline:none;border-color:var(--c-feature)}.ask-row button{padding:0 14px;font-size:13px;font-weight:600;color:#0c0e14;background:var(--c-feature);border:none;border-radius:8px;cursor:pointer}.ask-row button:disabled{opacity:.5;cursor:not-allowed}.ai-loading{margin-top:12px;font-size:13px;color:var(--text-dim)}.ai-error{margin-top:12px;padding:10px 12px;font-size:12px;color:#fca5a5;background:#f8717114;border:1px solid rgba(248,113,113,.3);border-radius:8px;white-space:pre-wrap}.ai-answer{margin-top:12px;padding:12px 14px;font-size:13px;line-height:1.6;color:var(--text);background:#60a5fa12;border:1px solid rgba(96,165,250,.22);border-radius:8px;white-space:pre-wrap}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#06080ca8;display:flex;align-items:center;justify-content:center;z-index:50}.modal{width:min(620px,92vw);max-height:86vh;display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:0 24px 70px #0009;padding:20px}.modal-head{display:flex;align-items:center;justify-content:space-between}.modal-head h2{margin:0;font-size:18px}.modal-head .close-btn{position:static}.modal-tabs{display:flex;gap:6px;margin:16px 0 14px}.modal-tab{padding:7px 16px;font-size:13px;font-weight:600;color:var(--text-dim);background:transparent;border:1px solid var(--border);border-radius:8px;cursor:pointer}.modal-tab.active{color:#0c0e14;background:var(--c-feature);border-color:var(--c-feature)}.modal-body{flex:1 1 auto;min-height:0}.blueprint-textarea{width:100%;height:320px;resize:vertical;padding:12px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:12.5px;line-height:1.5;color:var(--text);background:#0e1118;border:1px solid var(--border);border-radius:8px}.blueprint-textarea:focus{outline:none;border-color:var(--c-feature)}.upload-body{display:flex;flex-direction:column;gap:12px}.upload-drop{display:flex;flex-direction:column;align-items:center;gap:10px;padding:40px 20px;border:1.5px dashed var(--border);border-radius:12px;cursor:pointer;text-align:center}.upload-drop:hover{border-color:var(--c-feature)}.upload-cta{font-weight:600;color:var(--text)}.upload-file{font-size:12.5px;color:var(--c-feature)}.modal-error{margin-top:14px}.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:16px}.btn-ghost{padding:8px 16px;font-size:13px;font-weight:600;color:var(--text);background:transparent;border:1px solid var(--border);border-radius:8px;cursor:pointer}.btn-ghost:hover{background:#ffffff0f}.btn-primary{padding:8px 18px;font-size:13px;font-weight:600;color:#0c0e14;background:var(--c-feature);border:none;border-radius:8px;cursor:pointer}.btn-primary:hover{filter:brightness(1.07)}
