:root{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#172033;background:#eef2f7}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;overflow:hidden}button,input,select{font:inherit}button:disabled{cursor:not-allowed;opacity:.55}.boot-screen{display:flex;height:100vh;align-items:center;justify-content:center;gap:12px;color:#475569;background:#f6f8fb}.boot-indicator{width:18px;height:18px;border:2px solid #ccd5e1;border-top-color:#1b6cff;border-radius:50%;animation:spin .8s linear infinite}.app-shell{display:flex;height:100vh;min-height:0;overflow:hidden}.sidebar{width:224px;flex:0 0 224px;display:flex;flex-direction:column;gap:18px;padding:18px 14px;color:#f8fafc;background:#162033}.brand{display:flex;align-items:center;gap:10px;height:36px;font-weight:650}.brand-mark{display:inline-flex;width:28px;height:28px;align-items:center;justify-content:center;border-radius:7px;color:#162033;background:#f8fafc}.object-nav{display:flex;flex-direction:column;gap:6px;min-height:0;overflow:auto}.nav-link{display:flex;align-items:center;height:36px;padding:0 10px;border-radius:6px;color:#cbd5e1;text-decoration:none}.nav-link.active,.nav-link:hover{color:#fff;background:#254061}.workspace{flex:1;min-width:0;min-height:0;display:flex;flex-direction:column;overflow:hidden}.workspace-header{height:72px;flex:0 0 72px;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:0 22px;border-bottom:1px solid #d8e0eb;background:#fff}.workspace-header h1{margin:0;font-size:20px;line-height:1.25;letter-spacing:0}.workspace-header p{margin:4px 0 0;color:#64748b;font-size:13px}.user-actions{display:flex;align-items:center;gap:10px}.user-name{max-width:180px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;color:#334155}.object-page{flex:1;min-height:0;display:flex;flex-direction:column;padding:14px 18px 18px;overflow:hidden}.toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:12px}.search-box{display:flex;align-items:center;gap:8px;min-width:min(100%,320px);height:36px;padding:0 10px;border:1px solid #cbd5e1;border-radius:6px;color:#64748b;background:#fff}.search-box input{width:100%;min-width:0;border:0;outline:0;color:#172033}.primary-button,.secondary-button{height:36px;padding:0 12px;border-radius:6px;border:1px solid transparent;cursor:pointer;white-space:nowrap}.primary-button{margin-left:auto;color:#fff;background:#1b6cff}.secondary-button{color:#26384f;border-color:#cbd5e1;background:#fff}.danger-button{color:#b42318;border-color:#f3b8b2}.content-region{position:relative;flex:1;min-width:0;min-height:0;display:flex;overflow:hidden}.table-panel{position:relative;flex:1;min-width:0;min-height:0;overflow:hidden;border:1px solid #d8e0eb;border-radius:8px;background:#fff}.canvas-table-host{width:100%;height:100%}.table-test-fallback{display:none}.fallback-row{width:100%;border:0;background:transparent;text-align:left}.fallback-row.selected{background:#e8f1ff}.state-line{position:absolute;z-index:2;top:12px;left:50%;transform:translate(-50%);padding:6px 10px;border:1px solid #d8e0eb;border-radius:6px;color:#475569;background:#fff}.state-line.error{color:#b42318;border-color:#f3b8b2}.drawer-layer,.modal-layer{position:fixed;inset:0;z-index:20}.drawer-mask{position:absolute;inset:0;border:0;background:#0f172a47}.record-drawer{position:absolute;top:0;right:0;width:min(60vw,720px);min-width:min(100vw,420px);height:100%;overflow:hidden;border-left:1px solid #d8e0eb;background:#f8fafc;box-shadow:-12px 0 30px #0f172a29}.record-drawer form{display:flex;height:100%;min-height:0;flex-direction:column}.drawer-header{height:64px;flex:0 0 64px;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:0 18px;border-bottom:1px solid #d8e0eb;background:#fff}.drawer-header h2,.confirm-dialog h2{margin:0;font-size:18px;line-height:1.3;letter-spacing:0}.drawer-actions,.confirm-actions{display:flex;align-items:center;gap:8px}.icon-button{width:36px;height:36px;border:1px solid #cbd5e1;border-radius:6px;color:#26384f;background:#fff;cursor:pointer}.drawer-body{flex:1;min-height:0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));align-content:start;gap:14px;overflow:auto;padding:18px}.form-field{display:flex;min-width:0;flex-direction:column;gap:6px;color:#475569;font-size:13px}.form-field input,.form-field select{height:36px;min-width:0;border:1px solid #cbd5e1;border-radius:6px;padding:0 10px;color:#172033;background:#fff;outline:0}.modal-layer{display:flex;align-items:center;justify-content:center;background:#0f172a47}.confirm-dialog{width:min(420px,calc(100vw - 32px));padding:18px;border:1px solid #d8e0eb;border-radius:8px;background:#fff;box-shadow:0 16px 36px #0f172a2e}.confirm-dialog p{margin:12px 0 18px;color:#475569}.danger-primary{background:#b42318}.drawer-actions .primary-button,.confirm-actions .primary-button{margin-left:0}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:720px){.app-shell{flex-direction:column}.sidebar{width:100%;flex:0 0 auto;padding:10px}.object-nav{flex-direction:row;overflow-x:auto}.workspace-header{height:auto;min-height:72px;align-items:flex-start;flex-direction:column;padding:14px}.user-actions{width:100%;justify-content:space-between}.primary-button{margin-left:0}.record-drawer{width:100%;min-width:0}.drawer-body{grid-template-columns:1fr}}
