:root,[data-theme=light]{--bg: #f5f5f5;--surface: #ffffff;--panel: #f0f0f0;--accent: #2563eb;--accent-hover: #1d4ed8;--text: #1a1a1a;--text-secondary: #555;--text-muted: #888;--border: #e0e0e0;--input-bg: #fff;--canvas-bg: #fafafa;--grid-color: #e8e8e8;--shadow: 0 1px 3px rgba(0,0,0,.08);--node-sub: #3b82f6;--node-pond: #22c55e;--node-reach: #f59e0b;--node-junc: #8b5cf6;--link-color: #94a3b8;--node-label: #fff;--node-type-label: rgba(255,255,255,.6);--port-fill: #fff;--selected-stroke: #ef4444;--selected-glow: rgba(239,68,68,.4)}[data-theme=dark]{--bg: #111;--surface: #1a1a1a;--panel: #222;--accent: #3b82f6;--accent-hover: #60a5fa;--text: #e5e5e5;--text-secondary: #aaa;--text-muted: #666;--border: #333;--input-bg: #2a2a2a;--canvas-bg: #141414;--grid-color: #1e1e1e;--shadow: 0 1px 3px rgba(0,0,0,.3);--node-sub: #4a9eff;--node-pond: #34d399;--node-reach: #fbbf24;--node-junc: #a78bfa;--link-color: #64748b;--node-label: #fff;--node-type-label: rgba(255,255,255,.5);--port-fill: #fff;--selected-stroke: #ef4444;--selected-glow: rgba(239,68,68,.5)}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{width:100%;height:100%;overflow:hidden;font-family:Inter,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text)}.app-layout{display:grid;grid-template-columns:200px 1fr 300px;grid-template-rows:44px 1fr 28px;height:100vh;gap:1px;background:var(--border)}.toolbar{grid-column:1 / -1;background:var(--surface);display:flex;align-items:center;padding:0 12px;gap:8px;border-bottom:1px solid var(--border)}.toolbar h1{font-size:14px;font-weight:700;color:var(--text);margin-right:16px;letter-spacing:-.02em}.toolbar button{background:transparent;color:var(--text-secondary);border:1px solid var(--border);border-radius:5px;padding:5px 10px;cursor:pointer;font-size:12px;transition:all .15s}.toolbar button:hover{background:var(--panel);color:var(--text);border-color:var(--text-muted)}.btn-primary{background:var(--accent)!important;color:#fff!important;border-color:var(--accent)!important}.btn-primary:hover{background:var(--accent-hover)!important}.btn-danger{background:transparent!important;color:#dc2626!important;border-color:#dc2626!important}.btn-danger:hover{background:#dc2626!important;color:#fff!important}.theme-toggle{background:transparent!important;border:none!important;font-size:16px!important;padding:4px 6px!important;cursor:pointer;opacity:.6;transition:opacity .15s}.theme-toggle:hover{opacity:1;background:transparent!important}.feedback-btn{display:inline-flex;align-items:center;gap:4px;background:transparent;color:var(--text-muted);border:1px dashed var(--border);border-radius:5px;padding:5px 10px;font-size:12px;text-decoration:none;cursor:pointer;transition:all .15s}.feedback-btn:hover{color:var(--accent);border-color:var(--accent);background:var(--panel)}.stencil-panel{background:var(--surface);padding:12px;overflow-y:auto;border-right:1px solid var(--border)}.stencil-panel h3{font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:8px;font-weight:600}.stencil-item{display:flex;align-items:center;gap:8px;padding:7px 10px;margin-bottom:3px;border-radius:6px;cursor:grab;background:var(--panel);border:1px solid transparent;font-size:12px;color:var(--text-secondary);transition:all .15s}.stencil-item:hover{border-color:var(--border);color:var(--text);background:var(--input-bg)}.stencil-item .icon{width:22px;height:22px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff}.diagram-area{background:var(--canvas-bg);position:relative;overflow:hidden;cursor:grab}.diagram-area.panning{cursor:grabbing}.diagram-area svg{width:100%;height:100%}.node-group{cursor:pointer}.node-group:hover .node-body{filter:brightness(1.1)}.node-body{stroke-width:2;transition:filter .15s}.node-body.selected{stroke:var(--selected-stroke);stroke-width:3;filter:drop-shadow(0 0 6px var(--selected-glow))}.node-label{fill:var(--node-label);font-size:11px;font-family:inherit;text-anchor:middle;pointer-events:none;-webkit-user-select:none;user-select:none}.node-type-label{fill:var(--node-type-label);font-size:9px;font-family:inherit;text-anchor:middle;pointer-events:none;-webkit-user-select:none;user-select:none}.node-port{cursor:crosshair;transition:r .15s}.node-port:hover{r:7}.flow-link{stroke:var(--link-color);stroke-width:2;fill:none;cursor:pointer}.flow-link:hover,.flow-link.selected{stroke:var(--selected-stroke);stroke-width:3}.link-arrow{fill:var(--link-color)}.property-panel{background:var(--surface);padding:12px;overflow-y:auto;border-left:1px solid var(--border)}.property-panel h3{font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:10px;font-weight:600}.property-panel .empty{color:var(--text-muted);font-size:12px;text-align:center;margin-top:40px}.prop-group{margin-bottom:14px}.prop-group label{display:block;font-size:10px;color:var(--text-muted);margin-bottom:3px;text-transform:uppercase;letter-spacing:.05em;font-weight:500}.prop-group input,.prop-group select{width:100%;background:var(--input-bg);color:var(--text);border:1px solid var(--border);border-radius:5px;padding:6px 8px;font-size:12px;transition:border-color .15s}.prop-group input:focus,.prop-group select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px #2563eb26}.prop-row{display:flex;gap:8px}.prop-row .prop-group{flex:1}.result-badge{display:inline-block;background:var(--panel);border:1px solid var(--border);border-radius:5px;padding:3px 8px;font-size:11px;margin-bottom:4px;margin-right:4px}.result-badge .value{font-weight:600;color:var(--accent)}.status-bar{grid-column:1 / -1;background:var(--surface);display:flex;align-items:center;padding:0 12px;font-size:11px;color:var(--text-muted);gap:16px;border-top:1px solid var(--border)}.sub-areas-table{width:100%;font-size:11px;border-collapse:collapse;margin-top:4px}.sub-areas-table th,.sub-areas-table td{padding:3px 4px;border:1px solid var(--border);text-align:left}.sub-areas-table th{background:var(--panel);color:var(--text-muted);font-weight:500;font-size:10px}.sub-areas-table input{width:100%;background:transparent;border:none;color:var(--text);font-size:11px;padding:2px}.sub-areas-table select{background:transparent;color:var(--text);border:none;font-size:11px}
