:root{color:#172033;background:#eef1f5;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0}button,input,select{font:inherit}input[type=color]{padding:3px}button{cursor:pointer}button:disabled,input:disabled,select:disabled{cursor:not-allowed;opacity:.55}.app-shell{display:grid;grid-template-columns:330px 1fr;height:100vh;overflow:hidden}.sidebar{display:flex;flex-direction:column;gap:14px;min-height:100vh;padding:18px;overflow-y:auto;background:#fff;border-right:1px solid #d8dee8}.brand{display:flex;align-items:center;gap:12px}.brand-mark{display:grid;place-items:center;width:40px;height:40px;border-radius:7px;background:#1d3557;color:#fff;font-weight:750}.brand h1,.brand p,.topbar h2,.topbar p,.entity-panel h2,.palette h2,.properties h2{margin:0}.brand h1{font-size:18px}.brand p,.topbar p,.muted,.hint{color:#667085;font-size:13px}.flow-hint{display:grid;gap:5px;padding:10px;border:1px solid #c9d8ff;border-radius:7px;background:#edf3ff;color:#243b66;font-size:12px}.flow-hint strong{font-size:13px}.entity-panel{display:grid;gap:10px;padding-top:12px;border-top:1px solid #e2e7ef}.entity-panel h2,.palette h2,.properties h2,.compact-form h2{display:flex;align-items:center;gap:7px;font-size:14px}.entity-list{display:grid;gap:6px}.entity-list button{min-height:34px;padding:7px 9px;text-align:left;border:1px solid #d5dce8;border-radius:7px;background:#f8fafc;color:#273142}.entity-list button.selected{border-color:#2f6bff;background:#edf3ff}.drawing-table{width:100%;border-collapse:collapse;font-size:11.5px;table-layout:fixed}.drawing-table th{text-align:left;font-size:10px;text-transform:uppercase;letter-spacing:.03em;color:#94a3b8;font-weight:700;padding:2px 4px;border-bottom:1px solid #e2e7ef}.drawing-table td{padding:5px 4px;border-bottom:1px solid #eef1f6;color:#273142;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.drawing-table .drawing-table-name{font-weight:600}.drawing-table tbody tr{cursor:pointer}.drawing-table tbody tr:hover{background:#f1f5f9}.drawing-table tbody tr.selected{background:#edf3ff}.drawing-table tbody tr.selected td{color:#1e4eb2;font-weight:650}.compact-form{display:grid;gap:7px}.checkbox-row{display:flex;flex-wrap:wrap;gap:6px}.checkbox-chip{display:inline-flex;align-items:center;gap:5px;padding:4px 8px;border:1px solid #d5dce8;border-radius:7px;background:#f8fafc;font-size:12px;font-weight:600;cursor:pointer}.checkbox-chip input{width:auto;min-height:0;margin:0}.compact-form h3{margin:2px 0 0;color:#3b4658;font-size:12px}input,select{width:100%;min-height:34px;padding:7px 9px;border:1px solid #cfd7e4;border-radius:7px;background:#fff;color:#172033}label{display:grid;gap:6px;font-size:13px;font-weight:650}.primary-button,.secondary-button,.ghost-button,.icon-button{display:inline-flex;align-items:center;justify-content:center;gap:7px;min-height:34px;border-radius:7px;border:1px solid transparent}.primary-button{width:100%;background:#1d3557;color:#fff}.secondary-button{background:#edf3ff;color:#1e4eb2;border-color:#c9d8ff}.ghost-button{margin-top:auto;background:#fff;border-color:#d5dce8;color:#273142}.workspace{display:flex;flex-direction:column;min-width:0;min-height:0;overflow:hidden}.topbar{display:flex;justify-content:space-between;gap:16px;align-items:center;min-height:72px;padding:14px 18px;background:#fff;border-bottom:1px solid #d8dee8}.topbar h2{font-size:18px}.toolbar{align-items:center;display:flex;gap:8px}.toolbar-select{width:auto;min-width:76px;height:38px}.toolbar-check{display:inline-flex;align-items:center;grid-template-columns:none;gap:6px;height:38px;padding:0 10px;border:1px solid #d5dce8;border-radius:7px;background:#f8fafc;color:#273142;font-size:13px}.toolbar-check input{width:auto;min-height:0}.icon-button{width:38px;height:38px;background:#f8fafc;border-color:#d5dce8;color:#273142}.save-status{font-size:12px;font-weight:650;padding:6px 10px;border-radius:7px;white-space:nowrap}.save-status.saved{color:#15803d;background:#f0fdf4}.save-status.saving{color:#b45309;background:#fffbeb}.save-status.dirty{color:#b42318;background:#fff1f0}.search-input{margin-bottom:2px}.status-line{padding:8px 18px;color:#1e4eb2;background:#edf3ff;border-bottom:1px solid #c9d8ff;font-size:13px}.editor-shell{position:relative;display:flex;flex-direction:column;min-height:0;flex:1}.editor-toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:8px 12px;background:#fff;border-bottom:1px solid #d8dee8}.editor-toolbar .tool-group{display:inline-flex;align-items:center;gap:6px}.editor-toolbar .mode-button{display:inline-flex;align-items:center;gap:6px;padding:0 10px}.editor-toolbar .toolbar-select{height:34px}.tool-separator{width:1px;align-self:stretch;margin:2px;background:#e2e7ef}.tool-spacer{flex:1}.editor-body{display:flex;align-items:stretch;flex:1;min-height:0}.editor-left,.editor-right{display:flex;flex-direction:column;gap:12px;flex-shrink:0;padding:14px;background:#f8fafc;overflow-y:auto;transition:width .15s ease,padding .15s ease}.editor-left{width:230px;border-right:1px solid #d8dee8}.editor-right{width:270px;border-left:1px solid #d8dee8}.editor-left.collapsed,.editor-right.collapsed{width:0;padding-left:0;padding-right:0;border:0;overflow:hidden}.palette{display:flex;flex-direction:column;gap:12px;padding:14px;background:#f8fafc;border-right:1px solid #d8dee8;overflow-y:auto}details{display:grid;gap:6px}summary{font-weight:700;padding:7px 0}details button{width:100%;min-height:32px;margin-bottom:6px;border:1px solid #d5dce8;border-radius:7px;background:#fff;color:#273142;text-align:left;padding:6px 8px}.properties{display:grid;gap:9px;padding-top:12px;border-top:1px solid #d8dee8}.check-list{list-style:none;margin:0;padding:0;display:grid;gap:5px}.check-list button{width:100%;text-align:left;padding:6px 8px;border:1px solid #ffe2c2;border-radius:7px;background:#fff8f0;color:#9a3412;font-size:12px}.check-list button:hover{background:#fff1e0}.connection-tools{display:grid;gap:8px;padding:10px;border:1px solid #d8dee8;border-radius:7px;background:#fff}.layout-summary{margin:0;color:#475569;font-size:12px;line-height:1.35}.selection-summary{margin:0;padding:6px 8px;border:1px solid #d8dee8;border-radius:7px;background:#f8fafc;color:#273142;font-size:12px}.mode-button{min-height:34px;border:1px solid #d5dce8;border-radius:7px;background:#f8fafc;color:#273142}.mode-button.active{border-color:#2f6bff;background:#1d3557;color:#fff}.tool-row{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.tool-button{display:inline-flex;align-items:center;justify-content:center;min-height:34px;border:1px solid #d5dce8;border-radius:7px;background:#f8fafc;color:#273142}.tool-button.active{border-color:#2f6bff;background:#1d3557;color:#fff}.connection-list{display:grid;gap:6px}.connection-list button{min-height:30px;padding:5px 8px;border:1px solid #d5dce8;border-radius:7px;background:#fff;color:#273142;text-align:left}.connection-list button.selected{border-color:#2f6bff;background:#edf3ff;color:#1e4eb2}.signal-admin-list{display:grid;gap:8px;padding-top:8px;border-top:1px solid #e2e7ef}.signal-admin-row{display:grid;grid-template-columns:1fr 36px;gap:6px}.signal-admin-row input[type=color]{width:36px;min-width:36px}.signal-admin-row select,.signal-admin-row button{grid-column:1 / -1}.admin-details{padding-top:8px;border-top:1px solid #e2e7ef}.block-template-form,.block-template-admin-list,.block-template-editor{display:grid;gap:6px}.block-template-admin-list{margin-top:8px}.template-size-row,.template-color-row{display:grid;grid-template-columns:1fr 1fr;gap:6px}.template-color-row input[type=color]{width:100%}.block-template-editor{padding:8px 0;border-top:1px solid #edf1f6}.danger-button{display:inline-flex;align-items:center;justify-content:center;min-height:34px;border:1px solid #ffd7c2;border-radius:7px;background:#fff7ed;color:#9a3412}.port{cursor:crosshair}.route-handle{cursor:ew-resize}.context-menu{position:fixed;z-index:20;display:grid;min-width:180px;padding:5px;border:1px solid #cfd7e4;border-radius:7px;background:#fff;box-shadow:0 14px 36px #1018282e}.context-menu button{display:inline-flex;align-items:center;gap:8px;width:100%;min-height:32px;padding:6px 8px;border:0;border-radius:5px;background:transparent;color:#273142;text-align:left}.context-menu button:hover{background:#f1f5f9}.context-menu .danger-menu-item{color:#9a3412}.drawing-surface{flex:1;min-width:0;height:100%;display:block;background:#dfe5ee;touch-action:none}.drawing-surface.select-mode{cursor:default}.drawing-surface.pan-mode{cursor:grab}.drawing-surface.pan-mode:active{cursor:grabbing}.drawing-surface.zoom-mode{cursor:zoom-in}.empty-state,.login-screen{display:grid;place-items:center;min-height:100vh;padding:24px}.empty-state{align-content:center;color:#667085}.empty-state h2{color:#273142;margin:12px 0 4px}.empty-state p{margin:0}.login-screen{background:#eef1f5}.login-panel{display:grid;gap:14px;width:min(430px,100%);padding:22px;background:#fff;border:1px solid #d8dee8;border-radius:8px;box-shadow:0 18px 50px #1018281a}.login-brand{margin-bottom:4px}.input-row{display:flex;align-items:center;gap:8px;padding-left:9px;border:1px solid #cfd7e4;border-radius:7px;background:#fff}.input-row input{border:0;min-height:32px}.divider{height:1px;background:#e2e7ef}.error-box{padding:10px;border-radius:7px;background:#fff1f0;color:#b42318;border:1px solid #ffdad6;font-size:13px}.form-error{margin:-2px 0 0;color:#b42318;font-size:12px}.modal-backdrop{position:fixed;inset:0;z-index:30;display:grid;place-items:center;padding:18px;background:#0f172a52}.modal-panel{display:grid;gap:12px;width:min(430px,100%);padding:18px;border:1px solid #d8dee8;border-radius:8px;background:#fff;box-shadow:0 18px 50px #1018282e}.modal-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.modal-scroll{width:min(480px,100%);max-height:85vh;overflow-y:auto}.settings-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}.user-mgmt{display:grid;gap:8px}.user-mgmt h3{margin:4px 0 0;font-size:13px;color:#3b4658}.user-table{width:100%;border-collapse:collapse;font-size:12px}.user-table th{text-align:left;font-size:10px;text-transform:uppercase;color:#94a3b8;font-weight:700;padding:2px 4px;border-bottom:1px solid #e2e7ef}.user-table td{padding:5px 4px;border-bottom:1px solid #eef1f6}.user-table tr.inactive td{color:#98a2b3}.user-actions{display:flex;gap:8px;white-space:nowrap}.link-button{border:0;background:none;padding:0;color:#1e4eb2;font-size:12px;font-weight:600}.link-button:hover{text-decoration:underline}.user-create{display:grid;grid-template-columns:1fr 1fr auto;gap:6px;align-items:center}.user-create button{grid-column:1 / -1}.modal-header h2,.modal-header p{margin:0}.modal-header h2{font-size:18px}.modal-header p{margin-top:3px;color:#667085;font-size:13px}.modal-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}.modal-button{width:100%;margin-top:0}@media(max-width:980px){.app-shell,.editor-shell{grid-template-columns:1fr}.sidebar{min-height:auto;border-right:0;border-bottom:1px solid #d8dee8}.drawing-surface{height:70vh}}
