@import "https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;500;600;700&family=Playfair+Display:wght@400;600;700&display=swap";:root{--user-0:#2c6e49;--user-1:#8b4049;--user-2:#4a6b8a;--user-3:#8b6e4e;--user-4:#6b5b7b;--user-5:#7a8b4a;--user-6:#8b5e3c;--user-7:#4a7b6b;--font-mono:"IBM Plex Mono","Courier Prime","JetBrains Mono",monospace;--font-script:"Playfair Display","Libre Baskerville",Georgia,serif;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--space-3xl:64px;--z-canvas-ui:10;--z-chrome:100;--z-modal:1000;--radius:0;--shadow:none}:root,:root[data-theme=light]{--canvas-bg:#e8e0d2;--canvas-grid:#e1ddd5;--canvas-grid-major:#d7d1c7;--bg-primary:#e8e0d0;--bg-secondary:#f2ece0;--bg-tertiary:#f5efe5;--bg-nav:#d8d0c0;--bg-status-bar:#d0c8b8;--text-primary:#2c2416;--text-secondary:#5c5040;--text-tertiary:#8c8070;--text-nav:#5c5040;--text-nav-active:#2c2416;--accent-green:#4a7c5c;--accent-error:#8b4049;--accent-highlight:#8c6c2c;--accent-active:#6b4c2a;--border-default:#a09080;--border-subtle:#c8c0b0;--obj-cream:#f5f0e8;--obj-sage:#b8c5b0;--obj-terracotta:#c4a882;--obj-slate:#9aa3ad;--obj-dust:#c2a8a0;--obj-gold:#c9b97a;--obj-stone:#a8a298;--obj-moss:#8b9e7e}:root[data-theme=dark]{--canvas-bg:#1f1d1a;--canvas-grid:#35312d;--canvas-grid-major:#46413b;--bg-primary:#1c1a18;--bg-secondary:#252220;--bg-tertiary:#34302b;--bg-nav:#0f0e0d;--bg-status-bar:#1c1a18;--text-primary:#e8e0d2;--text-secondary:#9a9488;--text-tertiary:#5a554d;--text-nav:#7a756d;--text-nav-active:#e8e0d2;--accent-green:#4f9770;--accent-error:#b85a63;--accent-highlight:#b08b63;--accent-active:#cfab84;--border-default:#3a3632;--border-subtle:#2a2724;--obj-cream:#2c2824;--obj-sage:#3a4436;--obj-terracotta:#4a3d30;--obj-slate:#343a40;--obj-dust:#443838;--obj-gold:#3e3a28;--obj-stone:#343230;--obj-moss:#2e3828}*{box-sizing:border-box;margin:0;padding:0}html,body{width:100%;height:100%;min-height:100dvh}body{font-family:var(--font-mono);background:var(--bg-primary);color:var(--text-secondary);-webkit-font-smoothing:antialiased;font-size:13px;line-height:1.6;overflow:hidden}input,textarea,select{font-family:inherit;font-size:inherit;color:inherit;box-shadow:none;border:1px solid var(--border-default);background:var(--bg-secondary);border-radius:0;outline:none}button{font-family:inherit;font-size:inherit;color:inherit;cursor:pointer;background:0 0;border:none;transition:background .15s,color .15s,border-color .15s,opacity .15s}button:hover{color:var(--text-primary);background:0 0}button:disabled{opacity:.5;cursor:default}input:focus,textarea:focus,select:focus{border-color:var(--text-primary)}:focus-visible{outline:2px solid var(--accent-active);outline-offset:2px}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-default)}a{color:inherit;text-decoration:none;transition:color .15s}a:hover{color:var(--text-primary)}.btn{border:1px solid var(--border-default);height:30px;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);background:0 0;padding:0 12px;font-size:10px;font-weight:600;transition:background .12s ease-out,color .12s ease-out,border-color .12s ease-out}.btn--primary{border-color:var(--accent-active);color:var(--accent-active)}.btn--primary:hover{background:var(--accent-active);color:var(--bg-secondary)}.btn--danger{border-color:var(--accent-error);color:var(--accent-error)}.btn--danger:hover{background:var(--accent-error);color:var(--bg-primary)}.ui-tooltip{position:relative}.ui-tooltip:after{content:attr(title);border:1px solid var(--border-default);background:var(--bg-nav);color:var(--text-nav-active);font-family:var(--font-mono);letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;pointer-events:none;opacity:0;visibility:hidden;z-index:120;padding:2px 6px;font-size:9px;transition:opacity .12s;position:absolute;top:50%;left:calc(100% + 8px);transform:translateY(-50%)}.ui-tooltip:hover:after{opacity:1;visibility:visible}.ui-tooltip--left:after{left:auto;right:calc(100% + 8px)}.left-panel,.right-panel{pointer-events:auto;flex-direction:row;flex-shrink:0;height:100%;display:flex;position:relative}.left-panel__header,.right-panel__header{height:40px;padding:0 var(--space-sm);background:var(--bg-nav);border-bottom:1px solid var(--border-default);flex-shrink:0;align-items:center;display:flex}.left-panel__title,.right-panel__title{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;color:var(--text-secondary);flex:1;font-size:11px;font-weight:600}.left-panel__close,.right-panel__close,.tool-rail__btn,.tool-rail__toggle,.right-panel__rail-button,.right-panel__toggle{background:0 0;border:none;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.left-panel__close,.right-panel__close{color:var(--text-secondary);font-size:14px;line-height:1}.left-panel__close:hover,.right-panel__close:hover{color:var(--text-primary);background:0 0}.tool-rail__btn,.tool-rail__toggle,.right-panel__rail-button,.right-panel__toggle{color:var(--text-nav)}.tool-rail__btn:hover,.tool-rail__toggle:hover,.right-panel__rail-button:hover,.right-panel__toggle:hover{color:var(--text-nav-active);background:0 0}.left-panel__resize-handle-rail,.right-panel__resize-handle-rail{cursor:col-resize;z-index:6;pointer-events:auto;width:12px;height:100%;position:absolute;top:0}.left-panel__resize-handle-rail:before,.right-panel__resize-handle-rail:before{content:"";background:color-mix(in oklab,var(--accent-highlight)24%,var(--border-default));width:2px;height:100%;position:absolute;top:0;left:50%;transform:translate(-50%)}.left-panel__resize-handle-rail:hover:before,.right-panel__resize-handle-rail:hover:before{background:color-mix(in oklab,var(--accent-highlight)65%,var(--border-default))}.tool-rail__btn svg,.tool-strip__option svg,.right-panel__rail-button svg,.right-panel__toggle svg{stroke:currentColor;fill:none;stroke-width:1.5px;stroke-linecap:square;stroke-linejoin:miter}.login-page{justify-content:center;align-items:center;gap:var(--space-sm);background:var(--bg-primary);flex-direction:column;width:100vw;height:100dvh;display:flex}.login-card{border:1px solid var(--border-default);background:var(--bg-secondary);width:min(420px,100vw - 48px);padding:var(--space-xl)var(--space-lg);align-items:center;gap:var(--space-md);flex-direction:column;display:flex}.login-card__subtitle{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;color:var(--text-tertiary);font-size:10px}.login-button{height:32px;padding:0 var(--space-md);border:1px solid var(--accent-green);color:var(--accent-green);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;background:0 0;justify-content:center;align-items:center;font-size:10px;font-weight:600;display:inline-flex}.login-button:hover{background:var(--accent-green);color:var(--bg-primary)}.login-form{gap:var(--space-sm);flex-direction:column;width:100%;display:flex}.login-input{width:100%;height:32px;padding:0 var(--space-sm);border:1px solid var(--border-default);background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-mono);font-size:12px}.login-input:focus{border-color:var(--accent-green)}.login-input--code{letter-spacing:.18em;text-transform:uppercase}.login-code-inputs{gap:var(--space-xs);grid-template-columns:repeat(6,minmax(0,1fr));display:grid}.login-code-input{border:1px solid var(--border-default);background:var(--bg-primary);text-align:center;width:100%;height:40px;font-family:var(--font-mono);padding:0;font-size:20px;font-weight:700;line-height:1}.login-code-input:focus{border-color:var(--accent-green)}.login-dev-code{width:100%;margin-top:var(--space-xs);padding:var(--space-sm);border:1px solid var(--border-default);background:var(--bg-primary)}.login-dev-code__title{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;color:var(--text-secondary);margin-bottom:var(--space-xs);font-size:9px;font-weight:600}.login-dev-code__letters{gap:var(--space-xs);grid-template-columns:repeat(6,minmax(0,1fr));display:grid}.login-dev-code__char{border:1px solid var(--border-default);background:var(--bg-secondary);min-height:34px;font-family:var(--font-mono);letter-spacing:.06em;color:var(--accent-green);text-transform:uppercase;justify-content:center;align-items:center;font-size:20px;font-weight:700;line-height:1;display:inline-flex}.login-message{width:100%;font-family:var(--font-mono);color:var(--text-secondary);text-align:left;font-size:10px;line-height:1.5}.login-message--code{color:var(--accent-green)}.login-divider{background:var(--border-default);width:100%;height:1px}.login-repo-link{width:min(420px,100vw - 48px);padding:var(--space-sm);border:1px solid var(--border-default);background:color-mix(in srgb,var(--bg-primary)82%,transparent);flex-direction:column;gap:2px;text-decoration:none;transition:border-color .15s,color .15s,background .15s;display:flex}.login-repo-link__label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.09em;color:var(--text-secondary);font-size:9px;font-weight:600}.login-repo-link__url{font-family:var(--font-mono);color:var(--text-primary);font-size:11px}.login-repo-link:hover{border-color:var(--accent-green);background:color-mix(in srgb,var(--bg-primary)90%,transparent)}.login-repo-link:hover .login-repo-link__label,.login-repo-link:hover .login-repo-link__url{color:var(--accent-green)}.dashboard-page{background:var(--bg-primary);flex-direction:column;height:100dvh;display:flex}.dashboard-page__header{padding:0}.dashboard-page__grid{padding:var(--space-lg);gap:var(--space-lg);flex-direction:column;flex:1;display:flex;overflow-y:auto}.dashboard-page__section{gap:var(--space-sm);flex-direction:column;display:flex}.dashboard-page__section-header{border-bottom:1px solid var(--border-default);padding-bottom:var(--space-sm);margin-bottom:var(--space-md);justify-content:space-between;align-items:center;display:flex}.dashboard-page__section-title{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;color:var(--text-secondary);font-size:10px;font-weight:700}.dashboard-page__section-count{font-family:var(--font-mono);color:var(--text-tertiary);font-size:10px}.dashboard-page__cards{gap:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(275px,1fr));align-content:start;display:grid}.dashboard-page__new-card{aspect-ratio:4/3;border:1px dashed var(--border-default);color:var(--text-tertiary);background:0 0;justify-content:center;align-items:center;font-size:0;display:flex}.dashboard-page__new-card:hover{border-color:var(--text-secondary);color:var(--text-secondary);background:0 0}.dashboard-page__new-icon{stroke:currentColor;fill:none;stroke-width:1.5px;width:32px;height:32px}.dialog-backdrop{z-index:var(--z-modal);background:rgba(0,0,0,.4);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.dialog{background:var(--bg-primary);border:1px solid var(--border-default);width:min(320px,100vw - 24px);padding:var(--space-md)var(--space-lg);gap:var(--space-md);flex-direction:column;display:flex}.dialog--object-text{width:min(520px,100vw - 24px)}.dialog h2{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;color:var(--text-secondary);font-size:9px;font-weight:600}.dialog__label{gap:var(--space-xs);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;color:var(--text-secondary);flex-direction:column;font-size:9px;font-weight:600;display:flex}.dialog__input{border:none;border-bottom:1px solid var(--border-default);width:100%;padding:var(--space-xs)0;font-family:var(--font-script);color:var(--text-primary);background:0 0;font-size:22px}.dialog__input:focus{border-color:var(--accent-green)}.dialog__textarea{border:1px solid var(--border-default);width:100%;min-height:160px;padding:var(--space-sm);resize:vertical;font-family:var(--font-script);color:var(--text-primary);background:0 0;font-size:22px;line-height:1.25}.dialog__textarea:focus{border-color:var(--accent-green)}.dialog__actions{justify-content:flex-end;gap:var(--space-sm);display:flex}.dialog__danger{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em;color:var(--accent-error);font-size:10px}.dialog__hint{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);font-size:10px}.dialog__code{font-family:var(--font-mono);letter-spacing:.3em;text-align:center;color:var(--accent-green);padding:var(--space-md)0;-webkit-user-select:all;user-select:all;font-size:28px;font-weight:700}.dialog--profile{width:min(400px,100vw - 24px)}.dialog__profile-row{align-items:baseline;gap:var(--space-sm);display:flex}.dialog__profile-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;color:var(--text-secondary);flex-shrink:0;min-width:80px;font-size:9px;font-weight:600}.dialog__profile-value{font-family:var(--font-mono);color:var(--text-primary);word-break:break-all;font-size:11px}.dialog__profile-value--mono{color:var(--text-secondary);font-size:10px}.dialog__profile-token-box{align-items:center;gap:var(--space-sm);background:var(--bg-secondary);border:1px solid var(--border-default);padding:var(--space-sm);display:flex;overflow:hidden}.dialog__profile-token-text{font-family:var(--font-mono);color:var(--text-primary);word-break:break-all;-webkit-user-select:all;user-select:all;flex:1;font-size:10px}.dialog__profile-token-copy{text-transform:uppercase;letter-spacing:.08em;flex-shrink:0;font-size:10px}.board-page{--board-toolbar-height:48px;--board-status-height:32px;--canvas-overlay-edge-offset:var(--space-md);--left-rail-width:52px;--right-rail-width:52px;--left-expanded-offset:212px;--right-expanded-offset:372px;--canvas-overlay-left-offset:calc(var(--space-md) + var(--left-rail-width));--canvas-overlay-right-offset:calc(var(--space-md) + var(--right-rail-width));--canvas-dial-size:74px;--canvas-dial-gap:calc(var(--space-md) + 4px);grid-template-areas:"toolbar toolbar toolbar""left canvas right""status status status";grid-template-rows:var(--board-toolbar-height)minmax(0,1fr)var(--board-status-height);background:var(--bg-primary);grid-template-columns:auto 1fr auto;height:100dvh;display:grid;position:relative;overflow:hidden}.board-page.board-page--trace{grid-template-columns:1fr auto;grid-template-areas:"toolbar toolbar""canvas right""status status"}.board-page.board-page--left-expanded{--canvas-overlay-left-offset:calc(var(--space-md) + var(--left-expanded-offset))}.board-page.board-page--right-expanded{--canvas-overlay-right-offset:calc(var(--space-md) + var(--right-expanded-offset))}.board-page__toolbar{z-index:var(--z-chrome);grid-area:toolbar}.board-page__left-panel{z-index:var(--z-chrome);grid-area:left;min-width:52px;min-height:0}.board-page__canvas{z-index:0;background:var(--canvas-bg);grid-area:canvas;width:100vw;height:100dvh;min-height:0;position:fixed;inset:0}.board-page.board-page--trace .board-page__canvas{z-index:auto;width:100%;min-width:0;height:100%;position:relative;inset:auto}.board-page:not(.board-page--trace) .canvas-host{width:100vw;height:100dvh;position:fixed;inset:0}.board-page__right-panel{z-index:var(--z-chrome);grid-area:right;min-width:52px;min-height:0}.board-page__status-bar{z-index:var(--z-chrome);grid-area:status}.board-page__input-overlay{left:50%;bottom:calc(var(--board-status-height) + var(--space-md));width:clamp(320px,60%,920px);z-index:var(--z-chrome);position:absolute;transform:translate(-50%)}.board-page__prompt-bar,.board-page__input-row{width:100%;position:relative}.board-page__prompt-preview{flex-direction:column;gap:6px;width:100%;margin-bottom:6px;display:flex}.board-page__prompt-preview--empty{display:none}.board-page__prompt-preview-row{width:100%;min-height:16px;padding:0 var(--space-xs);font-family:var(--font-mono);color:color-mix(in oklab,var(--text-primary)74%,var(--text-secondary));background:0 0;align-items:center;gap:0;font-size:10px;line-height:16px;display:flex}.board-page__prompt-preview-row--user{font-family:var(--font-script);color:color-mix(in oklab,var(--text-primary)72%,var(--text-secondary));font-size:17px;line-height:1.15}.board-page__prompt-preview-row--assistant{color:color-mix(in oklab,var(--text-primary)70%,var(--text-secondary))}.board-page__prompt-preview-row--error{color:var(--accent-error)}.board-page__prompt-preview-row--empty{display:none}.board-page__prompt-preview-text{white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;overflow:hidden}.board-page__prompt-preview-row--assistant{align-items:flex-start}.board-page__prompt-preview-row--assistant .board-page__prompt-preview-text{white-space:pre-wrap;text-overflow:clip;line-height:1.3;overflow:visible}.board-page__prompt-preview-more{color:var(--accent-highlight);font-family:var(--font-mono);white-space:nowrap;cursor:pointer;vertical-align:baseline;background:0 0;border:none;margin-left:6px;padding:0;font-size:10px;line-height:1.3;text-decoration:underline;display:inline}.board-page__prompt-preview-more:hover{color:color-mix(in oklab,var(--accent-highlight)70%,var(--text-primary));background:0 0}.board-page__input-line{border:1px solid var(--border-strong);background:var(--bg-tertiary);width:100%;height:34px;color:var(--text-primary);font-family:var(--font-mono);padding:0 calc(var(--space-md) + 18px)0 var(--space-sm);font-size:12px}.board-page__input-line::placeholder{color:var(--text-tertiary)}.board-page__prompt-status{top:50%;right:var(--space-sm);pointer-events:none;justify-content:center;align-items:center;width:14px;height:14px;display:inline-flex;position:absolute;transform:translateY(-50%)}.board-page__prompt-icon-spacer{width:14px;height:14px}.board-page__prompt-spinner{border:2px solid color-mix(in oklab,var(--text-tertiary)50%,transparent);border-top-color:var(--text-primary);border-radius:50%;width:12px;height:12px;animation:.7s linear infinite spin}.board-page__prompt-icon{fill:none;stroke-width:2px;stroke-linecap:square;stroke-linejoin:miter;width:14px;height:14px}.board-page__prompt-icon path{stroke:currentColor}.board-page__prompt-icon--success{color:var(--accent-green)}.board-page__prompt-icon--error{color:var(--accent-error)}.canvas-host{background:0 0;width:100%;height:100%;display:block}.rewind-shelf{background:var(--bg-primary);flex-direction:column;width:100%;min-height:0;display:flex}.rewind-shelf__toolbar{padding:var(--space-sm);border-bottom:1px solid var(--border-default);background:var(--bg-secondary);justify-content:flex-end;display:flex}.rewind-shelf__create{border:1px solid var(--border-default);background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;padding:6px 8px;font-size:10px}.rewind-shelf__create:hover{border-color:var(--text-secondary)}.rewind-shelf__records{gap:var(--space-sm);min-height:0;padding:var(--space-sm);flex-direction:column;flex:1;display:flex;overflow-y:auto}.rewind-record{border:1px solid var(--border-default);background:var(--bg-primary);text-align:left;width:100%;padding:var(--space-sm);flex-direction:column;gap:4px;display:flex}.rewind-record--stack{flex-shrink:0}.rewind-shelf__empty{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary);padding:var(--space-sm);font-size:10px}.rewind-record__title{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--text-primary);font-size:10px;font-weight:700}.rewind-record__meta{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.07em;color:var(--text-tertiary);font-size:9px}.canvas-cursors{pointer-events:none;z-index:3;position:absolute;inset:0}.canvas-world-overlay{z-index:3;pointer-events:none;position:absolute;inset:0}.canvas-cursor{position:absolute;top:0;left:0}.canvas-cursor:before{content:"";background:var(--cursor-color,var(--accent-green));border:1px solid var(--bg-primary);width:10px;height:10px;position:absolute;top:-6px;left:-6px}.canvas-cursor__name{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.05em;color:var(--bg-primary);background:var(--cursor-color,var(--accent-green));white-space:nowrap;padding:1px 4px;font-size:9px;line-height:1.2;position:absolute;top:8px;left:8px}.canvas-compass{right:calc(100% + var(--space-md));bottom:var(--canvas-overlay-edge-offset);width:var(--canvas-dial-size);height:var(--canvas-dial-size);border:1px solid var(--border-default);background:color-mix(in srgb,var(--bg-primary)90%,transparent);z-index:var(--z-canvas-ui);pointer-events:auto;touch-action:none;-webkit-user-select:none;user-select:none;border-radius:999px;position:absolute;overflow:visible}.canvas-object-rotate{left:calc(100% + var(--space-md));bottom:var(--canvas-overlay-edge-offset);width:var(--canvas-dial-size);height:var(--canvas-dial-size);border:1px solid var(--border-default);background:color-mix(in srgb,var(--bg-primary)90%,transparent);z-index:var(--z-canvas-ui);pointer-events:auto;touch-action:none;-webkit-user-select:none;user-select:none;border-radius:999px;position:absolute;overflow:visible}.canvas-object-rotate--disabled{opacity:.44;pointer-events:none}.canvas-object-zoom{left:calc(100% + var(--space-md));bottom:calc(var(--canvas-overlay-edge-offset) + var(--canvas-dial-size) + var(--canvas-dial-gap));width:var(--canvas-dial-size);height:var(--canvas-dial-size);border:1px solid var(--border-default);background:color-mix(in srgb,var(--bg-primary)90%,transparent);z-index:var(--z-canvas-ui);pointer-events:auto;touch-action:none;-webkit-user-select:none;user-select:none;border-radius:999px;position:absolute;overflow:visible}.canvas-object-zoom--disabled{opacity:.44;pointer-events:none}.canvas-object-color{left:calc(100% + var(--space-md));top:var(--canvas-overlay-edge-offset);width:var(--canvas-dial-size);height:var(--canvas-dial-size);border:1px solid var(--border-default);background:color-mix(in srgb,var(--bg-primary)90%,transparent);z-index:var(--z-canvas-ui);pointer-events:auto;touch-action:none;-webkit-user-select:none;user-select:none;border-radius:999px;position:absolute;overflow:visible}.canvas-object-color--disabled{opacity:.44;pointer-events:none}.canvas-object-border{left:calc(100% + var(--space-md));top:calc(var(--canvas-overlay-edge-offset) + var(--canvas-dial-size) + var(--canvas-dial-gap));width:var(--canvas-dial-size);height:var(--canvas-dial-size);border:1px solid var(--border-default);background:color-mix(in srgb,var(--bg-primary)90%,transparent);z-index:var(--z-canvas-ui);pointer-events:auto;touch-action:none;-webkit-user-select:none;user-select:none;border-radius:999px;position:absolute;overflow:visible}.canvas-object-border--disabled{opacity:.44;pointer-events:none}.canvas-object-text-style{left:calc(100% + var(--space-md));top:calc(var(--canvas-overlay-edge-offset) + (var(--canvas-dial-size) + var(--canvas-dial-gap))*2);width:var(--canvas-dial-size);height:var(--canvas-dial-size);border:1px solid var(--border-default);background:color-mix(in srgb,var(--bg-primary)90%,transparent);z-index:var(--z-canvas-ui);pointer-events:auto;touch-action:none;-webkit-user-select:none;user-select:none;border-radius:999px;position:absolute;overflow:visible}.canvas-object-text-style--disabled{opacity:.44;pointer-events:none}.canvas-compass__snap{border:1px solid var(--border-default);background:var(--bg-secondary);width:16px;height:16px;color:var(--text-secondary);font-family:var(--font-mono);pointer-events:auto;justify-content:center;align-items:center;font-size:8px;line-height:1;display:inline-flex;position:absolute;transform:translate(-50%,-50%)}.canvas-compass__snap--n{top:10px;left:50%}.canvas-compass__snap--e{top:50%;left:calc(100% - 10px)}.canvas-compass__snap--s{top:calc(100% - 10px);left:50%}.canvas-compass__snap--w{top:50%;left:10px}.canvas-compass__reset{border:1px solid var(--border-default);background:var(--bg-primary);width:34px;height:34px;color:var(--text-primary);font-family:var(--font-mono);letter-spacing:.04em;pointer-events:auto;border-radius:999px;font-size:8px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.canvas-compass__knob-track{pointer-events:none;position:absolute;inset:0;overflow:visible}.canvas-compass__knob{background:var(--accent-error);border:1px solid color-mix(in srgb,var(--bg-primary)72%,transparent);pointer-events:auto;cursor:grab;border-radius:999px;width:14px;height:14px;position:absolute;top:-7px;left:50%;transform:translate(-50%);box-shadow:0 1px 3px rgba(0,0,0,.35)}.canvas-object-rotate__knob{background:var(--accent-highlight);border:1px solid color-mix(in srgb,var(--bg-primary)72%,transparent);pointer-events:auto;cursor:grab;border-radius:999px;width:14px;height:14px;position:absolute;top:-7px;left:50%;transform:translate(-50%);box-shadow:0 1px 3px rgba(0,0,0,.35)}.canvas-object-zoom__knob{background:var(--accent-green);border:1px solid color-mix(in srgb,var(--bg-primary)72%,transparent);pointer-events:auto;cursor:grab;border-radius:999px;width:14px;height:14px;position:absolute;top:-7px;left:50%;transform:translate(-50%);box-shadow:0 1px 3px rgba(0,0,0,.35)}.canvas-object-color__knob{background:color-mix(in oklab,var(--accent-highlight)60%,var(--accent-green));border:1px solid color-mix(in srgb,var(--bg-primary)72%,transparent);pointer-events:auto;cursor:grab;border-radius:999px;width:14px;height:14px;position:absolute;top:-7px;left:50%;transform:translate(-50%);box-shadow:0 1px 3px rgba(0,0,0,.35)}.canvas-object-border__knob{background:var(--accent-error);border:1px solid color-mix(in srgb,var(--bg-primary)72%,transparent);pointer-events:auto;cursor:grab;border-radius:999px;width:14px;height:14px;position:absolute;top:-7px;left:50%;transform:translate(-50%);box-shadow:0 1px 3px rgba(0,0,0,.35)}.canvas-object-text-style__knob{background:var(--accent-green);border:1px solid color-mix(in srgb,var(--bg-primary)72%,transparent);pointer-events:auto;cursor:grab;border-radius:999px;width:14px;height:14px;position:absolute;top:-7px;left:50%;transform:translate(-50%);box-shadow:0 1px 3px rgba(0,0,0,.35)}.canvas-color-dial__tick{background:color-mix(in oklab,var(--text-secondary)70%,transparent);pointer-events:none;border-radius:999px;width:4px;height:4px;position:absolute;transform:translate(-50%,-50%)}.canvas-color-dial__tick--n{top:10px;left:50%}.canvas-color-dial__tick--ne{top:calc(50% - 19px);left:calc(50% + 19px)}.canvas-color-dial__tick--e{top:50%;left:calc(100% - 10px)}.canvas-color-dial__tick--se{top:calc(50% + 19px);left:calc(50% + 19px)}.canvas-color-dial__tick--sw{top:calc(50% + 19px);left:calc(50% - 19px)}.canvas-color-dial__tick--w{top:50%;left:10px}.canvas-color-dial__tick--nw{top:calc(50% - 19px);left:calc(50% - 19px)}.canvas-color-dial__reset{border:1px solid var(--border-default);background:var(--bg-secondary);width:20px;height:20px;color:var(--text-secondary);font-family:var(--font-mono);pointer-events:auto;justify-content:center;align-items:center;padding:0;font-size:9px;line-height:1;display:inline-flex;position:absolute;top:calc(100% - 10px);left:50%;transform:translate(-50%,-50%)}.canvas-color-dial__readout{border:1px solid var(--border-default);background:var(--bg-primary);width:34px;height:34px;color:var(--text-primary);font-family:var(--font-mono);letter-spacing:.04em;pointer-events:auto;border-radius:999px;font-size:8px;position:absolute;top:50%;left:50%;overflow:hidden;transform:translate(-50%,-50%)}.canvas-color-dial__swatch{border:1px solid var(--border-default);pointer-events:none;border-radius:999px;position:absolute;inset:0}.canvas-color-dial__label{color:#fff;font-family:var(--font-mono);letter-spacing:.04em;text-transform:uppercase;text-shadow:0 0 2px rgba(0,0,0,.75);pointer-events:none;font-size:8px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.canvas-color-dial__picker{opacity:0;cursor:pointer;border:0;width:100%;height:100%;padding:0;position:absolute;inset:0}.canvas-color-dial__knob-track{pointer-events:none;position:absolute;inset:0}.canvas-zoom-wheel{right:calc(100% + var(--space-md));bottom:calc(var(--canvas-overlay-edge-offset) + var(--canvas-dial-size) + var(--canvas-dial-gap));width:var(--canvas-dial-size);height:var(--canvas-dial-size);border:1px solid var(--border-default);background:color-mix(in srgb,var(--bg-primary)90%,transparent);z-index:var(--z-canvas-ui);pointer-events:auto;touch-action:none;-webkit-user-select:none;user-select:none;border-radius:999px;position:absolute;overflow:visible}.canvas-zoom-wheel__tick{background:color-mix(in oklab,var(--text-secondary)70%,transparent);pointer-events:none;border-radius:999px;width:6px;height:6px;position:absolute;transform:translate(-50%,-50%)}.canvas-zoom-wheel__tick--n{top:10px;left:50%}.canvas-zoom-wheel__tick--ne{top:calc(50% - 19px);left:calc(50% + 19px)}.canvas-zoom-wheel__tick--e{top:50%;left:calc(100% - 10px)}.canvas-zoom-wheel__tick--se{top:calc(50% + 19px);left:calc(50% + 19px)}.canvas-zoom-wheel__tick--sw{top:calc(50% + 19px);left:calc(50% - 19px)}.canvas-zoom-wheel__tick--w{top:50%;left:10px}.canvas-zoom-wheel__tick--nw{top:calc(50% - 19px);left:calc(50% - 19px)}.canvas-zoom-wheel__reset{border:1px solid var(--border-default);background:var(--bg-secondary);width:20px;height:20px;color:var(--text-secondary);font-family:var(--font-mono);pointer-events:auto;justify-content:center;align-items:center;padding:0;font-size:9px;line-height:1;display:inline-flex;position:absolute;top:calc(100% - 10px);left:50%;transform:translate(-50%,-50%)}.canvas-zoom-wheel__readout{border:1px solid var(--border-default);background:var(--bg-primary);width:34px;height:34px;color:var(--text-primary);font-family:var(--font-mono);letter-spacing:.04em;pointer-events:auto;border-radius:999px;font-size:8px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.canvas-zoom-wheel__knob-track{pointer-events:none;position:absolute;inset:0;overflow:visible}.canvas-zoom-wheel__knob{background:var(--accent-green);border:1px solid color-mix(in srgb,var(--bg-primary)72%,transparent);pointer-events:auto;cursor:grab;border-radius:999px;width:14px;height:14px;position:absolute;top:-7px;left:50%;transform:translate(-50%);box-shadow:0 1px 3px rgba(0,0,0,.35)}.canvas-placement-ghost{border:2px solid color-mix(in oklab,var(--accent-green)70%,var(--bg-primary));background:color-mix(in srgb,var(--accent-green)18%,transparent);pointer-events:none;z-index:8;width:28px;height:28px;box-shadow:0 0 0 4px color-mix(in srgb,var(--accent-green)22%,transparent);border-radius:999px;position:absolute;transform:translate(-50%,-50%)}.canvas-placement-ghost:before{content:"";background:var(--accent-green);border-radius:999px;width:8px;height:8px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.canvas-placement-ghost:after{content:"";background:var(--bg-primary);border-radius:999px;width:2px;height:2px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.canvas-video-overlay{z-index:12;pointer-events:none;background:#111;border:2px solid #1f1a17;position:absolute;overflow:hidden;box-shadow:0 8px 20px rgba(0,0,0,.35)}.canvas-video-overlay__close{z-index:2;color:#f5f0e8;pointer-events:auto;background:rgba(31,26,23,.7);border:1px solid #f5f0e8;justify-content:center;align-items:center;width:22px;height:22px;font-size:12px;line-height:1;display:inline-flex;position:absolute;top:4px;right:4px}.canvas-video-overlay__close:hover{background:rgba(31,26,23,.9)}.canvas-video-overlay__frame{pointer-events:auto;border:0;display:block;position:absolute}.toolbar{pointer-events:auto;background:var(--bg-nav);height:48px;padding:0 var(--space-lg);align-items:center;gap:var(--space-sm);border-bottom:1px solid var(--border-default);display:flex}.toolbar__back{width:auto;height:32px;padding:0 var(--space-md);color:var(--text-nav);text-transform:uppercase;letter-spacing:.08em;border:1px solid transparent;justify-content:center;align-items:center;font-size:10px;font-weight:600;line-height:1;display:inline-flex}.toolbar__back:hover{color:var(--text-nav-active)}.toolbar__breadcrumb{align-items:center;gap:var(--space-xs);margin-right:2rem;display:inline-flex}.toolbar__crumb-btn{height:30px;color:var(--text-secondary);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;background:0 0;border:1px solid transparent;align-items:center;padding:0 8px;font-size:10px;font-weight:600;display:inline-flex}.toolbar__crumb-btn:hover{color:var(--text-nav-active);background:color-mix(in oklab,var(--accent-active)10%,transparent)}.toolbar__crumb-sep{color:var(--text-tertiary);font-family:var(--font-mono);font-size:10px;font-weight:600}.toolbar__crumb-current{color:var(--text-nav-active);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;font-size:10px;font-weight:700}.toolbar__board-name{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;color:var(--text-nav-active);margin-right:2rem;font-size:12px;font-weight:600}.toolbar__divider{background:var(--border-default);width:1px;height:24px}.toolbar__presence{align-items:center;gap:var(--space-sm);margin-left:var(--space-md);flex:1;min-width:0;display:flex;overflow:hidden}.toolbar__presence-chip{align-items:center;gap:var(--space-xs);padding-left:var(--space-xs);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--text-nav);white-space:nowrap;text-overflow:ellipsis;background:0 0;border:none;border-left:2px solid;max-width:180px;font-size:10px;font-weight:600;display:inline-flex;overflow:hidden}.toolbar__presence-chip:hover{color:var(--text-nav-active)}.toolbar__presence-dot{flex-shrink:0;width:6px;height:6px}.toolbar__spacer{flex:1}.toolbar__right-controls{align-items:center;gap:var(--space-xs);display:inline-flex}.toolbar__action-btn,.toolbar__logout{width:auto;height:30px;padding:0 var(--space-md);color:var(--text-nav);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;background:0 0;border:1px solid transparent;font-size:10px;font-weight:600;line-height:1}.toolbar__segment{background:color-mix(in oklab,var(--accent-highlight)8%,var(--bg-secondary));border-radius:0;align-items:center;display:inline-flex;overflow:hidden}.toolbar__segment-btn{border:0;border-right:1px solid var(--border-default);min-width:60px;height:30px;color:var(--text-secondary);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;background:0 0;padding:0 10px;font-size:10px;font-weight:700}.toolbar__segment-btn:last-child{border-right:0}.toolbar__segment-btn--active{background:color-mix(in oklab,var(--accent-highlight)24%,var(--bg-tertiary));color:color-mix(in oklab,var(--accent-highlight)70%,var(--text-nav-active));box-shadow:inset 0 -2px 0 var(--accent-highlight)}.toolbar__self{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary);padding:0 var(--space-xs);font-size:10px;font-weight:600}.toolbar__self-method{color:color-mix(in oklab,var(--text-secondary)72%,transparent)}.toolbar__info-btn{width:auto;height:32px;padding:0 var(--space-md);color:var(--text-nav);text-transform:uppercase;letter-spacing:.08em;justify-content:center;align-items:center;font-size:10px;font-weight:600;line-height:1;display:inline-flex}.toolbar__info-btn svg{flex-shrink:0;width:14px;height:14px;display:block}.toolbar__logout{color:var(--text-nav-active)}.toolbar__action-btn:hover,.toolbar__logout:hover{color:var(--text-nav-active);background:color-mix(in oklab,var(--accent-active)10%,transparent)}.toolbar__logout:hover{color:var(--accent-error);background:color-mix(in oklab,var(--accent-error)14%,transparent)}.left-panel__panel{background:var(--bg-secondary);border-right:1px solid var(--border-default);flex-direction:column;flex-shrink:0;width:160px;height:100%;display:flex}.left-panel__resize-handle-rail{right:0;transform:translate(50%)}.left-panel__content{flex-direction:column;flex:1;display:flex;overflow:hidden}.left-panel__collapsed-toggle{display:none}.left-panel__strip-anchor{z-index:var(--z-chrome);position:fixed}.left-panel__dials-mount,.right-panel__dials-mount{pointer-events:none;z-index:var(--z-chrome);position:absolute;inset:0}.tool-rail{background:var(--bg-nav);width:52px;padding:var(--space-sm)0;align-items:center;gap:var(--space-xs);border-right:1px solid var(--border-default);flex-direction:column;flex-shrink:0;height:100%;display:flex}.tool-rail__btn{cursor:pointer;transition:color .15s,background .15s;position:relative}.tool-rail__btn--active{color:var(--text-nav-active)}.tool-rail__btn--active:before{content:"";background:var(--accent-green);width:2px;position:absolute;top:6px;bottom:6px;left:0}.tool-rail__btn--disabled{opacity:.3;cursor:default}.tool-rail__btn svg{width:20px;height:20px}.tool-rail__separator{background:var(--border-default);width:24px;height:1px;margin:var(--space-xs)0}.tool-rail__spacer{flex:1}.tool-rail__toggle{font-size:12px}.tool-strip{align-items:center;gap:var(--space-sm);padding:var(--space-xs)var(--space-sm);background:var(--bg-nav);border:1px solid var(--border-default);white-space:nowrap;border-left:none;height:36px;display:flex}.tool-strip__options{gap:2px;display:flex}.tool-strip__option{width:28px;height:28px;color:var(--text-secondary);background:0 0;border:1px solid transparent;justify-content:center;align-items:center;display:flex}.tool-strip__option:hover{color:var(--text-primary)}.tool-strip__option--active{color:var(--text-primary);border-color:var(--accent-green)}.tool-strip__option svg{width:18px;height:18px}.tool-strip__swatch{background:0 0;border:1px solid transparent;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.tool-strip__swatch:hover{border-color:var(--text-secondary)}.tool-strip__swatch--active{border-color:var(--accent-green)}.tool-strip__swatch-color{width:16px;height:16px;display:block}.tool-strip__divider{background:var(--border-default);flex-shrink:0;width:1px;height:20px}.tool-strip__add{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em;color:#fff;border:none;padding:4px 12px;font-size:10px;font-weight:600;line-height:1}.tool-strip__add:hover{opacity:.85}.inspector-panel{padding:var(--space-sm);gap:var(--space-md);flex-direction:column;flex:1;display:flex;overflow-y:auto}.inspector-panel__empty{justify-content:center;align-items:center;gap:var(--space-xs);color:var(--text-tertiary);text-align:center;flex-direction:column;flex:1;display:flex}.inspector-panel__empty-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;font-size:11px}.inspector-panel__empty-hint{color:var(--text-secondary);font-size:11px}.inspector-panel__section{gap:var(--space-sm);flex-direction:column;display:flex}.inspector-panel__kind{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--text-primary);font-size:12px;font-weight:600}.inspector-panel__section-title{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);border-bottom:1px solid var(--border-default);padding-bottom:var(--space-xs);font-size:10px;font-weight:600}.inspector-panel__field-grid{gap:var(--space-xs)var(--space-sm);grid-template-columns:auto 1fr;align-items:center;display:grid}.inspector-panel__label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);font-size:10px}.inspector-panel__input{width:100%;height:24px;line-height:1.2;font-family:var(--font-mono);background:var(--bg-primary);padding:4px 6px;font-size:11px}.inspector-panel__text-area{resize:vertical;width:100%;min-height:88px;font-family:var(--font-mono);background:var(--bg-primary);padding:8px;font-size:12px;line-height:1.35}.inspector-panel__inline{justify-content:space-between;align-items:center;gap:var(--space-sm);display:flex}.inspector-panel__inline .inspector-panel__input{width:68px}.inspector-panel__color-row{justify-content:space-between;align-items:center;display:flex}.inspector-panel__color-input{border:1px solid var(--border-default);background:0 0;width:28px;height:24px;padding:0}.inspector-panel__meta{padding-top:var(--space-sm);margin-top:auto}.inspector-panel__meta-row{justify-content:space-between;align-items:center;display:flex}.inspector-panel__value{font-family:var(--font-mono);color:var(--text-primary);font-size:11px;font-weight:500}.inspector-panel__delete{margin-top:var(--space-sm);width:100%;height:28px}.right-panel__rail{background:var(--bg-nav);width:52px;padding:var(--space-sm)0;align-items:center;gap:var(--space-xs);border-left:1px solid var(--border-default);flex-direction:column;flex-shrink:0;height:100%;display:flex}.right-panel__rail-button{position:relative}.right-panel__rail-button--active{color:var(--text-nav-active)}.right-panel__rail-button--active:before{content:"";background:var(--accent-green);width:2px;position:absolute;top:6px;bottom:6px;right:0}.right-panel__rail-button--disabled{opacity:.35;cursor:default}.right-panel__rail-button svg,.right-panel__toggle svg{width:20px;height:20px}.right-panel__rail-spacer{flex:1}.right-panel__toggle{font-size:12px}.right-panel__panel{background:var(--bg-secondary);border-left:1px solid var(--border-default);flex-direction:column;flex-shrink:0;height:100%;display:flex;position:relative}.right-panel__resize-handle-rail{left:0;transform:translate(-50%)}.right-panel__content{flex:1;min-height:0;display:flex}.right-panel__content>*{flex:1;min-width:0}.user-list-panel{background:var(--bg-primary);flex-direction:column;min-height:0;display:flex}.user-list-panel__summary{padding:var(--space-sm);border-bottom:1px solid var(--border-default);font-family:var(--font-mono);letter-spacing:.04em;text-transform:uppercase;color:var(--text-secondary);background:var(--bg-secondary);font-size:11px}.user-list-panel__table-wrap{flex:1;overflow:auto}.user-list-panel__table{border-collapse:collapse;width:100%;font-family:var(--font-mono);color:var(--text-primary);font-size:12px}.user-list-panel__table th{text-align:left;letter-spacing:.05em;text-transform:uppercase;color:var(--text-secondary);padding:var(--space-xs)var(--space-sm);border-bottom:1px solid var(--border-subtle);background:var(--bg-secondary);z-index:1;font-size:10px;position:sticky;top:0}.user-list-panel__table td{padding:var(--space-xs)var(--space-sm);border-bottom:1px solid var(--border-subtle);vertical-align:middle}.user-list-panel__user{align-items:center;gap:var(--space-xs);display:flex}.user-list-panel__dot{border:1px solid rgba(0,0,0,.2);border-radius:999px;flex-shrink:0;width:8px;height:8px}.user-list-panel__mono{color:var(--text-secondary);font-size:11px}.user-list-panel__action-btn{border:1px solid var(--border-default);background:var(--bg-secondary);width:22px;height:22px;color:var(--text-primary);cursor:pointer;justify-content:center;align-items:center;padding:0;display:inline-flex}.user-list-panel__action-btn:hover{border-color:var(--accent-green);color:var(--text-nav-active)}.user-list-panel__action-btn svg{fill:none;stroke:currentColor;stroke-width:1.6px;stroke-linecap:round;stroke-linejoin:round;width:14px;height:14px}.user-list-panel__action-btn--active{border-color:var(--accent-green);color:var(--accent-green)}.user-list-panel__na{color:var(--text-tertiary);font-family:var(--font-mono);font-size:11px}.user-list-panel__empty{font-family:var(--font-mono);color:var(--text-tertiary);text-align:center;padding:var(--space-lg)var(--space-sm);font-size:11px}.chat-panel{flex-direction:column;flex:1;min-height:0;display:flex}.chat-panel__messages{padding:var(--space-sm);gap:var(--space-xs);background:var(--bg-primary);flex-direction:column;flex:1;display:flex;overflow-y:auto}.chat-panel__empty{font-family:var(--font-mono);color:var(--text-tertiary);text-align:center;padding:var(--space-lg)var(--space-sm);font-size:11px}.chat-panel__message{flex-direction:column;gap:2px;display:flex}.chat-panel__author{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em;font-size:10px;font-weight:600;line-height:1}.chat-panel__text{font-family:var(--font-mono);color:var(--text-primary);white-space:pre-wrap;word-break:break-word;font-size:13px;line-height:1.5}.chat-panel__input-row{gap:var(--space-xs);padding:var(--space-sm);border-top:1px solid var(--border-default);background:var(--bg-secondary);display:flex}.chat-panel__input{background:var(--bg-primary);border:1px solid var(--border-default);color:var(--text-primary);font-family:var(--font-mono);padding:var(--space-xs)var(--space-sm);flex:1;font-size:13px;line-height:1.4}.chat-panel__input:focus{border-color:var(--accent-green)}.chat-panel__input::placeholder{color:var(--text-tertiary)}.chat-panel__input-row .btn{background:var(--accent-green);height:28px;color:var(--bg-primary);border:none}.chat-panel__input-row .btn:hover{opacity:.9;background:var(--accent-green)}.chat-panel__send:disabled{opacity:.4;cursor:not-allowed}.ai-panel{flex-direction:column;flex:1;min-height:0;display:flex}.ai-panel__messages{padding:var(--space-md)var(--space-sm);background:var(--bg-primary);flex-direction:column;flex:1;gap:0;display:flex;overflow-y:auto}.ai-panel__empty{font-family:var(--font-mono);color:var(--text-tertiary);text-align:center;padding:var(--space-lg)var(--space-sm);font-size:11px;line-height:28px}.ai-panel__message{padding:0 var(--space-sm);font-family:var(--font-script);color:var(--text-primary);font-size:18px;line-height:28px}.ai-panel__message--assistant{font-family:var(--font-mono);color:var(--text-secondary);margin-left:var(--space-xs);padding-left:var(--space-sm);font-size:11px}.ai-panel__message--error{font-family:var(--font-mono);color:var(--accent-error);border-left:2px solid var(--accent-error);margin-left:var(--space-xs);padding-left:var(--space-sm);font-size:13px}.ai-panel__role{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;margin-right:var(--space-xs);color:var(--text-tertiary);font-size:9px;display:inline}.ai-panel__content{white-space:pre-wrap;word-break:break-word;display:inline}.ai-panel__content.ai-panel__markdown{white-space:normal;display:block}.ai-panel__markdown-body{white-space:normal;line-height:1.45;display:block}.ai-panel__markdown-body p,.ai-panel__markdown-body ul,.ai-panel__markdown-body ol,.ai-panel__markdown-body pre,.ai-panel__markdown-body blockquote{margin:.4em 0}.ai-panel__markdown-body ul,.ai-panel__markdown-body ol{padding-left:1.2em}.ai-panel__markdown-body code{font-family:var(--font-mono);border:1px solid var(--border-default);background:color-mix(in srgb,var(--bg-secondary)80%,transparent);padding:0 .2em;font-size:10px}.ai-panel__markdown-body pre code{padding:.5em .6em;display:block;overflow-x:auto}.ai-panel__markdown-body a{color:var(--accent-green);text-decoration:underline}.ai-panel__mutations{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary);font-size:10px;line-height:28px;display:block}.ai-panel__loading{font-family:var(--font-mono);color:var(--text-tertiary);padding:0 var(--space-sm);font-size:13px;line-height:28px;animation:1.5s infinite pulse}.ai-panel__input-row{gap:var(--space-xs);padding:var(--space-sm);border-top:1px solid var(--border-default);background:var(--bg-secondary);display:flex}.ai-panel__input{background:var(--bg-primary);border:1px solid var(--border-default);color:var(--text-primary);font-family:var(--font-mono);padding:var(--space-xs)var(--space-sm);flex:1;font-size:13px;line-height:1.4}.ai-panel__input:focus{border-color:var(--accent-green)}.ai-panel__input::placeholder{color:var(--text-tertiary)}.ai-panel__input-row .btn{background:var(--accent-green);height:28px;color:var(--bg-primary);border:none}.ai-panel__input-row .btn:hover{opacity:.9;background:var(--accent-green)}.ai-panel__send:disabled{opacity:.4;cursor:not-allowed}@keyframes pulse{0%,to{opacity:.4}50%{opacity:1}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.mission-control{scrollbar-width:none;background:var(--bg-primary);width:100%;height:100%;overflow-y:auto}.mission-control::-webkit-scrollbar{display:none}.mission-control__inner{gap:var(--space-sm);padding:var(--space-sm);flex-direction:column;display:flex}.mission-control__loading{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary);font-size:10px}.status-bar{pointer-events:auto;background:var(--bg-status-bar);border-top:1px solid var(--border-default);height:32px;padding:0 var(--space-lg);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary);justify-content:space-between;align-items:center;font-size:10px;line-height:1;display:flex}.status-bar__section{align-items:center;gap:var(--space-md);line-height:1;display:flex}.status-bar__item{align-items:center;gap:var(--space-xs);display:flex}.status-bar__item--identity{color:var(--text-secondary)}.status-bar__help{color:var(--text-tertiary);font:inherit;text-transform:inherit;letter-spacing:inherit;cursor:pointer;background:0 0;border:0;padding:0}.status-bar__help:hover{color:var(--text-primary)}.status-bar__item--locked{color:var(--accent-error);font-weight:700}.status-bar__dot{background:var(--text-tertiary);width:7px;height:7px}.status-bar__dot--connected{background:var(--accent-green)}.status-bar__dot--connecting{background:var(--obj-gold)}.status-bar__dot--disconnected{background:var(--accent-error)}.status-bar__divider{background:var(--border-default);width:1px;height:14px;font-size:0}.status-bar__board-name{color:var(--text-primary);font-weight:600}.status-bar__user-chip{color:var(--text-secondary);align-items:center;gap:3px;font-size:10px;display:flex}.status-bar__user-dot{flex-shrink:0;width:6px;height:6px}.help-shortcuts-modal__backdrop{z-index:100;background:rgba(10,10,10,.55);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.help-shortcuts-modal{background:var(--bg-primary);border:1px solid var(--border-default);flex-direction:column;width:min(920px,100vw - 48px);max-height:calc(100vh - 48px);display:flex;box-shadow:0 12px 48px rgba(0,0,0,.32)}.help-shortcuts-modal__header{padding:var(--space-md);border-bottom:1px solid var(--border-default);justify-content:space-between;align-items:center;display:flex}.help-shortcuts-modal__header h2{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em;margin:0;font-size:14px}.help-shortcuts-modal__close{border:1px solid var(--border-default);background:var(--bg-secondary);width:24px;height:24px;color:var(--text-primary);cursor:pointer}.help-shortcuts-modal__close:hover{border-color:var(--text-secondary)}.help-shortcuts-modal__subtitle{padding:0 var(--space-md)var(--space-sm);color:var(--text-secondary);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.04em;font-size:11px}.help-shortcuts-modal__table-wrap{padding:0 var(--space-md)var(--space-md);overflow:auto}.help-shortcuts-modal__table{border-collapse:collapse;table-layout:fixed;width:100%;font-family:var(--font-mono);color:var(--text-primary);font-size:12px}.help-shortcuts-modal__table th,.help-shortcuts-modal__table td{width:50%}.help-shortcuts-modal__table th{text-align:left;letter-spacing:.05em;text-transform:uppercase;color:var(--text-secondary);padding:var(--space-xs)var(--space-sm);border-bottom:1px solid var(--border-subtle);background:var(--bg-primary);font-size:10px;position:sticky;top:0}.help-shortcuts-modal__table td{padding:var(--space-xs)var(--space-sm);border-bottom:1px solid var(--border-subtle);vertical-align:top}.help-shortcuts-modal__keys{color:var(--text-secondary)}.board-card{aspect-ratio:4/3;border:1px solid var(--border-default);background:var(--bg-primary);padding:var(--space-sm)var(--space-md);cursor:pointer;color:var(--text-primary);flex-direction:column;transition:border-color .15s;display:flex;position:relative}.board-card:hover{border-color:var(--text-secondary)}.board-card--active{border-color:var(--accent-green)}.board-card__name{font-family:var(--font-script);text-overflow:ellipsis;white-space:nowrap;font-size:22px;line-height:1.2;overflow:hidden}.board-card__id{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary);margin-top:2px;font-size:9px;font-weight:500}.board-card__delete{background:color-mix(in srgb,var(--bg-primary)88%,transparent);width:22px;height:22px;color:var(--accent-error);opacity:0;pointer-events:none;border:1px solid transparent;font-size:12px;line-height:1;position:absolute;top:6px;right:6px}.board-card:hover .board-card__delete{opacity:1;pointer-events:auto}.board-card__delete:hover{border-color:var(--accent-error)}.board-card__preview{margin-top:var(--space-sm);border:1px solid var(--border-default);background:#f6f1e7;flex:1;min-height:90px;position:relative;overflow:hidden}.board-card__preview-canvas{width:100%;height:100%;display:block}.board-card__preview-meta{font-family:var(--font-mono);letter-spacing:.05em;text-transform:uppercase;color:var(--text-secondary);background:color-mix(in srgb,var(--bg-primary)75%,transparent);border:1px solid var(--border-default);padding:1px 4px;font-size:8px;position:absolute;bottom:4px;right:4px}.board-card--mini{aspect-ratio:unset;padding:0 var(--space-sm);flex-direction:row;flex-shrink:0;align-items:center;gap:0;height:22px}.board-card--mini .board-card__name{font-family:var(--font-mono);max-width:140px;font-size:10px;font-weight:500}.board-card--mini .board-card__id,.board-card--mini .board-card__preview,.board-card--mini .board-card__delete{display:none}.board-stamp{display:contents}.board-stamp__minimap{top:calc(var(--board-toolbar-height) + var(--space-md));right:var(--canvas-overlay-right-offset);z-index:var(--z-canvas-ui);pointer-events:auto;cursor:crosshair;opacity:.9;width:min(240px,calc(100% - var(--canvas-overlay-left-offset) - var(--canvas-overlay-right-offset) - var(--space-md)));background:0 0;border:0;height:140px;display:block;position:absolute}.user-field-report{z-index:var(--z-modal);position:fixed;inset:0}.user-field-report__backdrop{position:absolute;inset:0}.user-field-report__popover{z-index:var(--z-modal);width:240px;position:fixed}.user-field-report__card{background:var(--bg-primary);border:1px solid var(--border-default);padding:var(--space-sm)var(--space-md)}.user-field-report__header{align-items:center;gap:var(--space-sm);margin-bottom:var(--space-sm);padding-bottom:var(--space-sm);border-bottom:1px solid var(--border-default);display:flex}.user-field-report__avatar{object-fit:cover;flex-shrink:0;width:28px;height:28px}.user-field-report__header-info{flex-direction:column;gap:1px;min-width:0;display:flex}.user-field-report__name{font-family:var(--font-script);color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:20px;line-height:1.1;overflow:hidden}.user-field-report__badge{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary);font-size:9px;font-weight:500}.user-field-report__section{margin-bottom:var(--space-sm)}.user-field-report__section-title{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;color:var(--text-tertiary);margin-bottom:var(--space-xs);font-size:9px;font-weight:600}.user-field-report__row{justify-content:space-between;align-items:baseline;padding:1px 0;display:flex}.user-field-report__row-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);font-size:10px}.user-field-report__row-value{font-family:var(--font-mono);color:var(--text-primary);font-size:10px;font-weight:600}.user-field-report__syscall-bar{align-items:center;gap:var(--space-xs);display:flex}.user-field-report__syscall-name{font-family:var(--font-mono);color:var(--text-secondary);min-width:80px;font-size:9px}.user-field-report__syscall-count{font-family:var(--font-mono);color:var(--text-primary);font-size:9px;font-weight:600}.user-field-report__loading{font-family:var(--font-mono);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.08em;padding:var(--space-sm)0;text-align:center;font-size:10px;animation:1.5s infinite pulse}@media (width<=980px){.board-page{--canvas-overlay-left-offset:calc(var(--space-md) + var(--left-rail-width));--canvas-overlay-right-offset:calc(var(--space-md) + var(--right-rail-width));grid-template-columns:1fr 1fr;grid-template-areas:"toolbar toolbar""canvas canvas""status status";grid-template-rows:var(--board-toolbar-height)minmax(0,1fr)var(--board-status-height)}.board-page.board-page--left-expanded{--canvas-overlay-left-offset:calc(var(--space-md) + var(--left-expanded-offset))}.board-page.board-page--right-expanded{--canvas-overlay-right-offset:calc(var(--space-md) + var(--right-expanded-offset))}.board-page__left-panel,.board-page__right-panel{top:var(--board-toolbar-height);bottom:var(--board-status-height);max-width:calc(100vw - 52px);position:fixed}.board-page__left-panel{left:0}.board-page__right-panel{right:0}.toolbar__presence,.toolbar__user{display:none}.dashboard-page__grid{padding:var(--space-md)}.rewind-shelf{height:100%}.board-stamp__minimap{width:min(220px,calc(100% - var(--canvas-overlay-left-offset) - var(--canvas-overlay-right-offset) - var(--space-md)))}.board-page__input-overlay{width:calc(100% - var(--space-md)*2);max-width:720px}}.trace-view{background:var(--bg-primary);width:100%;height:100%;font-family:var(--font-mono);color:var(--text-primary);flex-direction:row;font-size:12px;display:flex;overflow:hidden}.trace-view__col{border-right:1px solid var(--border-default);flex-direction:column;display:flex;overflow:hidden}.trace-view__col--summary{flex-shrink:0;width:240px}.trace-view__col--log{flex:1;min-width:0}.trace-summary{height:100%;padding:var(--space-sm);gap:var(--space-sm);flex-direction:column;display:flex;overflow-y:auto}.trace-summary__section{flex-direction:column;gap:4px;display:flex}.trace-summary__section--index{flex:1;min-height:0}.trace-summary__section-label{letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary);border-bottom:1px solid var(--border-subtle);padding-bottom:2px;font-size:10px;font-weight:600}.trace-summary__metric{padding:var(--space-xs)0;flex-direction:column;display:flex}.trace-summary__metric-value{color:var(--text-primary);font-size:28px;font-weight:600;line-height:1}.trace-summary__metric-label{letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary);font-size:9px}.trace-summary__kv{justify-content:space-between;gap:var(--space-xs);font-size:11px;display:flex}.trace-summary__kv-key{color:var(--text-secondary)}.trace-summary__kv-value{color:var(--text-primary);font-weight:500}.trace-summary__divider{background:var(--border-subtle);height:1px;margin:2px 0}.trace-summary__conn-status{font-size:11px;font-weight:500}.trace-summary__conn-status--open{color:#4ad981}.trace-summary__conn-status--connecting{color:#e6a23c}.trace-summary__conn-status--closed{color:var(--text-secondary)}.trace-summary__context-card{border:1px solid var(--border-default);padding:var(--space-xs)var(--space-sm);flex-direction:column;gap:4px;display:flex}.trace-summary__index-list{flex-direction:column;flex:1;gap:2px;display:flex;overflow-y:auto}.trace-summary__index-empty{color:var(--text-secondary);padding:var(--space-xs)0;font-size:11px}.trace-summary__index-row{padding:4px var(--space-xs);font-family:var(--font-mono);color:var(--text-primary);text-align:left;cursor:pointer;background:0 0;border:none;border-left:2px solid transparent;flex-direction:column;align-items:stretch;gap:2px;width:100%;font-size:11px;display:flex}.trace-summary__index-row:hover{background:var(--bg-secondary)}.trace-summary__index-row--active{border-left-color:var(--accent-highlight);background:var(--bg-secondary)}.trace-summary__index-dot{color:var(--accent-highlight)}.trace-summary__index-main{align-items:center;gap:6px;min-width:0;display:flex}.trace-summary__index-id{flex:1;min-width:0;font-weight:600;overflow:hidden}.trace-summary__index-count,.trace-summary__index-duration{color:var(--text-secondary)}.trace-summary__index-meta{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;padding-left:14px;font-size:10px;overflow:hidden}.trace-log{flex-direction:column;height:100%;display:flex;overflow:hidden}.trace-log__header{gap:var(--space-xs);padding:6px var(--space-sm);background:var(--bg-secondary);border-bottom:1px solid var(--border-default);letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary);flex-shrink:0;font-size:10px;font-weight:600;display:flex}.trace-log__head-btn{color:inherit;font:inherit;letter-spacing:inherit;text-transform:inherit;text-align:left;background:0 0;border:none;padding:0}.trace-log__head-btn:hover{color:var(--text-primary);background:0 0}.trace-log__rows{flex-direction:column;flex:1;display:flex;overflow-y:auto}.trace-log__empty{padding:var(--space-md);color:var(--text-secondary);font-size:12px}.trace-log__row{gap:var(--space-xs);padding:4px var(--space-sm);font-family:var(--font-mono);color:var(--text-primary);text-align:left;cursor:pointer;background:0 0;border:none;border-left:2px solid transparent;align-items:center;width:100%;font-size:12px;display:flex}.trace-log__row:hover{background:var(--bg-secondary)}.trace-log__row--active{border-left-color:var(--accent-highlight);background:var(--bg-secondary)}.trace-log__col--ts{flex-shrink:0;width:108px}.trace-log__col--badge{text-align:center;flex-shrink:0;width:20px;font-weight:700}.trace-log__col--syscall{flex:1;align-items:baseline;gap:6px;min-width:0;display:flex;overflow:hidden}.trace-log__col--status{flex-shrink:0;width:60px}.trace-log__col--from{flex-shrink:0;width:100px;overflow:hidden}.trace-log__ts{color:var(--text-secondary);font-size:11px}.trace-log__syscall{white-space:nowrap;text-overflow:ellipsis;font-weight:500;overflow:hidden}.trace-log__sub-label,.trace-log__from{color:var(--text-secondary);white-space:nowrap;font-size:11px}.trace-log__status{letter-spacing:.04em;font-size:11px;font-weight:600}.trace-log__status--request{color:#e6a23c}.trace-log__status--item{color:var(--text-secondary)}.trace-log__status--done{color:#4ad981}.trace-log__status--error{color:var(--accent-highlight)}.trace-log__status--cancel{color:var(--text-secondary)}.trace-inspector{background:var(--bg-primary);flex-direction:column;flex:1;min-width:0;height:100%;display:flex;overflow:hidden}.trace-inspector__empty{padding:var(--space-md);color:var(--text-secondary);font-size:12px}.trace-inspector__content{flex-direction:column;height:100%;display:flex;overflow-y:auto}.trace-inspector__header{padding:var(--space-sm)var(--space-md);border-bottom:1px solid var(--border-default);background:var(--bg-secondary);flex-shrink:0}.trace-inspector__header-row{align-items:center;gap:var(--space-sm);display:flex}.trace-inspector__prefix-badge{font-size:18px;font-weight:700;line-height:1}.trace-inspector__syscall{flex:1;font-size:13px;font-weight:600}.trace-inspector__close{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;padding:2px 4px;font-size:14px;line-height:1}.trace-inspector__close:hover{color:var(--text-primary)}.trace-inspector__sub-label{color:var(--text-secondary);padding-top:2px;font-size:12px}.trace-inspector__from{color:var(--text-secondary);padding-top:2px;font-size:11px}.trace-inspector__section{padding:var(--space-sm)var(--space-md);border-bottom:1px solid var(--border-subtle);flex-direction:column;gap:4px;display:flex}.trace-inspector__section-label{letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary);border-bottom:1px solid var(--border-subtle);margin-bottom:2px;padding-bottom:2px;font-size:10px;font-weight:600}.trace-inspector__id-card{border:1px solid var(--border-default);padding:var(--space-xs)var(--space-sm)}.trace-inspector__id-syscall{font-size:13px;font-weight:600}.trace-inspector__id-from{color:var(--text-secondary);font-size:11px}.trace-inspector__kv{justify-content:space-between;gap:var(--space-xs);font-size:11px;display:flex}.trace-inspector__field-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;font-size:10px}.trace-inspector__field-value{color:var(--text-primary);text-align:right;word-break:break-all;font-weight:500}.trace-inspector__status{font-size:11px;font-weight:600}.trace-inspector__status--request{color:#e6a23c}.trace-inspector__status--item{color:var(--text-secondary)}.trace-inspector__status--done{color:#4ad981}.trace-inspector__status--error{color:var(--accent-highlight)}.trace-inspector__status--cancel{color:var(--text-secondary)}.trace-inspector__json{font-family:var(--font-mono);background:var(--bg-secondary);padding:var(--space-sm);white-space:pre;color:var(--text-primary);border:1px solid var(--border-subtle);margin:0;font-size:11px;line-height:1.5;overflow-x:auto}