@import"https://fonts.googleapis.com/css2?family=General+Sans:wght@400;500;600;700&family=Geist+Mono:wght@400;500&display=swap";:root{--font-display: "General Sans", "Segoe UI", system-ui, sans-serif;--font-mono: "Geist Mono", "SF Mono", "Menlo", monospace;--color-primary: #D14343;--color-primary-dark: #C83A3A;--color-primary-light: #FFB3B3;--color-accent: #4ECDC4;--color-accent-dark: #3DB8B0;--color-accent-light: #A5E6E1;--color-surface: #FAFAFA;--color-surface-elevated: #FFFFFF;--color-surface-subtle: #F0F0F0;--color-text-primary: #1A1A1A;--color-text-secondary: #6B7280;--color-text-tertiary: #9CA3AF;--color-border: rgba(0, 0, 0, .08);--color-border-hover: rgba(0, 0, 0, .12);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .06);--shadow-md: 0 8px 24px rgba(0, 0, 0, .08);--shadow-lg: 0 16px 48px rgba(0, 0, 0, .12);--shadow-xl: 0 24px 64px rgba(0, 0, 0, .16);--glass-surface: rgba(255, 255, 255, .85);--glass-border: rgba(255, 255, 255, .5);--glass-blur: blur(20px) saturate(180%);--space-xs: 4px;--space-sm: 8px;--space-md: 12px;--space-lg: 16px;--space-xl: 24px;--space-2xl: 32px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .35s cubic-bezier(.4, 0, .2, 1);--transition-spring: .5s cubic-bezier(.34, 1.56, .64, 1);--z-dropdown: 100;--z-sticky: 200;--z-modal-backdrop: 300;--z-modal: 400;--z-toast: 500}:root[data-theme=dark]{--color-primary: #f87171;--color-primary-dark: #ef4444;--color-primary-light: #7f1d1d;--color-accent: #2dd4bf;--color-accent-dark: #14b8a6;--color-accent-light: #134e4a;--color-surface: #0b1220;--color-surface-elevated: #111827;--color-surface-subtle: #1f2937;--color-text-primary: #e5e7eb;--color-text-secondary: #9ca3af;--color-text-tertiary: #6b7280;--color-border: rgba(148, 163, 184, .22);--color-border-hover: rgba(148, 163, 184, .35);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .35);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .4);--shadow-md: 0 8px 24px rgba(0, 0, 0, .5);--shadow-lg: 0 16px 48px rgba(0, 0, 0, .55);--shadow-xl: 0 24px 64px rgba(0, 0, 0, .62);--glass-surface: rgba(15, 23, 42, .78);--glass-border: rgba(30, 41, 59, .75)}*{box-sizing:border-box}html,body,#root{margin:0;width:100%;min-height:100%}body{font-family:var(--font-display);color:var(--color-text-primary);background:var(--color-surface);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button:focus-visible,a:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible,[role=button]:focus-visible,[tabindex]:focus-visible{outline:3px solid #0f766e;outline-offset:2px}.loading-shell,.login-shell,.board-shell{min-height:100vh}.loading-shell,.login-shell{display:grid;place-items:center;padding:var(--space-xl);background:linear-gradient(135deg,#fff5f5,#f0fdfa,#fff7ed)}.board-shell{display:flex;flex-direction:column;background:var(--color-surface);height:100vh;overflow:hidden}.app-error-shell{min-height:100vh;display:grid;place-items:center;padding:var(--space-xl);background:linear-gradient(135deg,#fff5f5,#f0fdfa,#fff7ed)}.app-error-card{width:min(560px,100%);border:1px solid var(--color-border);border-radius:var(--radius-xl);background:var(--color-surface-elevated);box-shadow:var(--shadow-lg);padding:var(--space-2xl);display:flex;flex-direction:column;gap:var(--space-md)}.app-error-card h1{margin:0;font-size:1.35rem}.app-error-card p{margin:0;color:var(--color-text-secondary);line-height:1.45}.app-error-detail{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);border:1px solid rgba(239,68,68,.25);background:#ef444414;color:#991b1b;font-family:var(--font-mono);font-size:.8rem}.app-error-actions{display:flex;gap:var(--space-sm);flex-wrap:wrap}.login-card{width:min(480px,100%);background:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-2xl);box-shadow:var(--shadow-lg);animation:cardReveal var(--transition-slow) ease-out}@keyframes cardReveal{0%{opacity:0;transform:translateY(20px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.login-card h1{margin:0 0 var(--space-sm);font-size:2rem;font-weight:800;letter-spacing:-.03em;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-card h2{margin:0;font-size:.95rem;font-weight:500;color:var(--color-text-secondary)}.login-card p{margin-bottom:var(--space-xl);color:var(--color-text-secondary);line-height:1.6;font-size:.95rem}.error-text{display:flex;align-items:center;gap:var(--space-sm);color:#dc2626;font-weight:500;font-size:.9rem;padding:var(--space-sm) var(--space-md);background:linear-gradient(135deg,#dc26261a,#dc26260d);border:1px solid rgba(220,38,38,.2);border-radius:var(--radius-md)}.error-text:before{content:"⚠";font-size:1.1rem}.google-icon{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;background:#fff;color:#4285f4;border-radius:4px;font-weight:700;font-size:.85rem}.qa-login-form{margin-top:var(--space-xl);border-top:1px solid var(--color-border);padding-top:var(--space-lg);display:grid;gap:var(--space-md)}.qa-form-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-xs)}.qa-form-header h2{margin:0;font-size:1rem;font-weight:700}.qa-badge{padding:var(--space-xs) var(--space-sm);background:linear-gradient(135deg,#fee2e2,#fecaca);color:#991b1b;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;border-radius:var(--radius-full)}.qa-login-form label{font-size:.8rem;font-weight:600;color:var(--color-text-secondary);margin-bottom:var(--space-xs);display:block;letter-spacing:.02em}.qa-login-form input{width:100%;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);font-size:.95rem;font-family:inherit;transition:all var(--transition-fast);background:var(--color-surface)}.qa-login-form input:focus{outline:2px solid transparent;border-color:var(--color-accent);box-shadow:0 0 0 3px #4ecdc426;background:var(--color-surface-elevated)}.qa-login-form input::placeholder{color:var(--color-text-tertiary)}.button{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);border:0;border-radius:var(--radius-lg);padding:var(--space-md) var(--space-lg);font-size:.95rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all var(--transition-base);position:relative;overflow:hidden}.button:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.2) 0%,transparent 100%);opacity:0;transition:opacity var(--transition-fast)}.button:hover:before{opacity:1}.button:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.button-primary{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:#fff;box-shadow:0 4px 12px #ff6b6b4d}.button-primary:hover{transform:translateY(-2px);box-shadow:0 8px 20px #ff6b6b66}.button-primary:active{transform:translateY(0)}.button-secondary{background:var(--color-surface-elevated);color:var(--color-text-primary);border:1px solid var(--color-border);box-shadow:var(--shadow-sm)}.button-secondary:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-md)}.primary-button,.secondary-button{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);border-radius:var(--radius-md);border:1px solid var(--color-border);padding:var(--space-sm) var(--space-md);font-size:.85rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all var(--transition-fast)}.secondary-button{background:var(--color-surface-elevated);color:var(--color-text-primary)}.secondary-button:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-sm)}.primary-button{border-color:transparent;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:#fff;box-shadow:0 4px 12px #ff6b6b4d}.primary-button:hover{transform:translateY(-1px);box-shadow:0 6px 14px #ff6b6b5c}.primary-button:disabled,.secondary-button:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.button-ghost{background:transparent;color:var(--color-text-secondary);padding:var(--space-sm) var(--space-md)}.button-ghost:hover{background:var(--color-surface-subtle);color:var(--color-text-primary)}.button-icon{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border:1px solid var(--color-border);background:var(--color-surface-elevated);color:var(--color-text-primary);padding:0;border-radius:var(--radius-md);cursor:pointer;box-shadow:var(--shadow-xs);transition:border-color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast),background var(--transition-fast),color var(--transition-fast)}.button-icon svg{width:17px;height:17px;stroke-width:2.2}.button-icon:hover:not(:disabled),.button-icon:focus-visible:not(:disabled){border-color:var(--color-border-hover);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.button-icon:disabled{opacity:.45;cursor:not-allowed}.button-icon-text{width:auto;min-width:48px;padding:0 var(--space-sm);font-size:.7rem;letter-spacing:.04em}.button-icon.button-primary{background:var(--color-primary);border-color:transparent;color:#fff;box-shadow:0 2px 8px #ff6b6b40}@media(hover:hover){.with-tooltip{position:relative}.with-tooltip:before{content:attr(data-tooltip);position:absolute;left:50%;bottom:calc(100% + 8px);transform:translate(-50%,4px);background:#0f172af2;color:#f8fafc;padding:6px 8px;border-radius:var(--radius-sm);font-size:.7rem;font-weight:600;letter-spacing:.02em;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity var(--transition-fast),transform var(--transition-fast);z-index:320}.with-tooltip:after{content:"";position:absolute;left:50%;bottom:calc(100% + 2px);transform:translate(-50%,4px);border-left:5px solid transparent;border-right:5px solid transparent;border-top:6px solid rgba(15,23,42,.95);opacity:0;pointer-events:none;transition:opacity var(--transition-fast),transform var(--transition-fast);z-index:319}.with-tooltip:hover:before,.with-tooltip:hover:after,.with-tooltip:focus-visible:before,.with-tooltip:focus-visible:after{opacity:1;transform:translate(-50%)}.with-tooltip.tooltip-bottom:before{top:calc(100% + 8px);bottom:auto;transform:translate(-50%,-4px)}.with-tooltip.tooltip-bottom:after{top:calc(100% + 2px);bottom:auto;transform:translate(-50%,-4px);border-top:0;border-bottom:6px solid rgba(15,23,42,.95)}.with-tooltip.tooltip-bottom:hover:before,.with-tooltip.tooltip-bottom:hover:after,.with-tooltip.tooltip-bottom:focus-visible:before,.with-tooltip.tooltip-bottom:focus-visible:after{transform:translate(-50%)}}.board-header{min-height:64px;display:flex;align-items:center;justify-content:space-between;gap:var(--space-lg);padding:0 var(--space-xl);border-bottom:1px solid var(--color-border);background:var(--glass-surface);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);position:sticky;top:0;z-index:var(--z-sticky)}.board-header:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,rgba(0,0,0,.08) 20%,rgba(0,0,0,.08) 80%,transparent 100%)}.board-header-left{display:flex;align-items:center;gap:var(--space-md);min-width:0}.sync-mode-pill{display:inline-flex;align-items:center;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-full);border:1px solid var(--color-border);background:var(--color-surface-elevated);color:var(--color-text-secondary);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.sync-mode-pill-pilot{border-color:#4ecdc466;background:#4ecdc41f;color:#0f766e}.sync-state-pill{display:inline-flex;align-items:center;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-full);border:1px solid var(--color-border);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.sync-state-pill-ok{border-color:#22c55e59;background:#22c55e24;color:#166534}.sync-state-pill-warning{border-color:#f59e0b66;background:#f59e0b1f;color:#92400e}.sync-state-pill-syncing{border-color:#3b82f661;background:#3b82f624;color:#1e3a8a}.board-header h1{margin:0;font-size:1.1rem;font-weight:700;letter-spacing:-.02em}.board-name-pill{display:inline-flex;align-items:center;max-width:240px;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-full);border:1px solid var(--color-border);background:var(--color-surface-elevated);color:var(--color-text-secondary);font-size:.75rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.board-name-pill-editable{cursor:text}.board-name-pill-editable:hover{border-color:var(--color-accent);color:var(--color-text-primary)}.board-name-pill-input{width:min(280px,40vw);border:1px solid var(--color-accent);border-radius:var(--radius-full);background:var(--color-surface-elevated);color:var(--color-text-primary);font:inherit;font-size:.75rem;font-weight:600;padding:6px 10px}.board-name-pill-input:focus{outline:2px solid transparent;border-color:var(--color-accent);box-shadow:0 0 0 2px #4ecdc429}.board-name-rename-error{font-size:.72rem}.board-header p{margin:0;font-size:.8rem;color:var(--color-text-secondary)}.header-actions{display:flex;align-items:center;gap:var(--space-sm);flex-shrink:0}.selection-mode-toggle{display:inline-flex;align-items:center;gap:var(--space-xs)}.header-actions-divider{width:1px;height:24px;background:var(--color-border)}.boards-panel-backdrop{position:fixed;inset:0;z-index:var(--z-modal-backdrop);display:grid;place-items:center;padding:var(--space-xl);background:#02061759;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.boards-panel{width:min(780px,100%);max-height:min(84vh,760px);display:flex;flex-direction:column;border:1px solid var(--color-border);border-radius:var(--radius-xl);background:var(--color-surface-elevated);box-shadow:var(--shadow-xl);overflow:hidden}.boards-panel-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border)}.boards-panel-header h3{margin:0}.boards-panel-body{display:grid;grid-template-columns:minmax(0,1fr) minmax(260px,320px);flex:1 1 auto;min-height:0;overflow:hidden}.boards-list{padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-sm);border-right:1px solid var(--color-border);overflow-y:auto}.boards-side{padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-md);min-height:0;overflow-y:auto}.board-list-section{display:flex;flex-direction:column;gap:var(--space-sm)}.board-list-section-title{margin:0;font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-tertiary)}.board-list-item{display:flex;gap:var(--space-sm);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);padding:var(--space-sm)}.board-list-item.active{border-color:var(--color-accent);box-shadow:0 0 0 1px #4ecdc433}.board-list-link{flex:1;border:0;background:transparent;color:inherit;text-align:left;display:flex;flex-direction:column;gap:2px;cursor:default}.board-list-name{font-size:.9rem;font-weight:700;color:var(--color-text-primary)}.board-list-name-editable{cursor:text}.board-list-name-editable:hover{color:var(--color-accent-dark);text-decoration:underline}.board-list-rename-input{width:100%;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface-elevated);color:var(--color-text-primary);font:inherit;font-size:.86rem;font-weight:700;padding:6px 8px}.board-list-rename-input:focus{outline:2px solid transparent;border-color:var(--color-accent);box-shadow:0 0 0 2px #4ecdc429}.board-list-description{font-size:.8rem;color:var(--color-text-secondary);line-height:1.35}.board-list-meta{font-size:.72rem;color:var(--color-text-tertiary);line-height:1.3}.board-list-actions{display:inline-flex;align-items:center;gap:6px;align-self:flex-start}.board-list-action-button{width:30px;height:30px;border-radius:var(--radius-sm)}.board-list-action-button svg{width:14px;height:14px}.board-create-icon-button{align-self:flex-start}.share-dialog-card{margin:0;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-sm);display:flex;flex-direction:column;gap:var(--space-sm);background:#ffffffe6}.share-dialog-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm)}.share-dialog-header h4{margin:0;font-size:.9rem;color:var(--color-text-primary)}.share-form{display:flex;flex-direction:column;gap:var(--space-sm)}.share-collaborators{display:flex;flex-direction:column;gap:6px}.share-collaborators h5{margin:0;font-size:.78rem;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.08em}.share-collaborator-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm);padding:6px 8px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface-elevated)}.share-collaborator-meta{display:flex;flex-direction:column;gap:4px;min-width:0}.share-collaborator-id{font-size:.72rem;color:var(--color-text-secondary);font-family:var(--font-mono);overflow-wrap:anywhere}.share-collaborator-role{font-size:.7rem;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.08em}.board-create-form{padding:0;display:flex;flex-direction:column;gap:var(--space-sm)}.board-create-form h4{margin:0 0 2px;font-size:.9rem}.board-field{display:flex;flex-direction:column;gap:6px;font-size:.78rem;font-weight:600;color:var(--color-text-secondary)}.board-field input,.board-field textarea,.board-field select{width:100%;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text-primary);font:inherit;font-size:.86rem;padding:8px 10px}.board-field textarea{resize:vertical}.timer-widget{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-full);font-family:var(--font-mono);font-size:.9rem;font-weight:600;box-shadow:var(--shadow-sm)}.timer-widget.running{border-color:var(--color-primary);background:#ff6b6b0d}.timer-display{cursor:pointer;padding:2px 6px;border-radius:4px;transition:background .15s}.timer-display:hover{background:#0000000d}:root[data-theme=dark] .timer-display:hover{background:#ffffff1a}.timer-edit-input{width:50px;font-size:.9rem;font-weight:600;font-family:inherit;padding:2px 6px;border:1px solid var(--color-primary);border-radius:4px;background:var(--color-surface-elevated);color:var(--color-text-primary);text-align:center}.timer-icon{width:20px;height:20px;color:var(--color-primary)}.floating-toolbar{position:fixed;bottom:var(--space-xl);left:50%;transform:translate(-50%);display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm);background:var(--glass-surface);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);z-index:var(--z-sticky);animation:toolbarReveal var(--transition-slow) cubic-bezier(.34,1.56,.64,1)}@keyframes toolbarReveal{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.toolbar-divider{width:1px;height:24px;background:var(--color-border);margin:0 var(--space-xs)}.tool-group{display:flex;align-items:center;gap:var(--space-xs);padding:0 var(--space-sm)}.tool-group.compact{padding:0;gap:2px}.tool-launcher{position:relative;display:inline-flex}.toolbar-popover{position:absolute;left:50%;bottom:calc(100% + 10px);transform:translate(-50%);min-width:220px;max-width:min(300px,calc(100vw - 24px));display:flex;flex-direction:column;gap:var(--space-sm);padding:var(--space-sm);border:1px solid var(--color-border);border-radius:var(--radius-md);background:#fffffffa;box-shadow:var(--shadow-md);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:var(--z-dropdown)}.toolbar-popover-section{display:flex;align-items:center;flex-wrap:wrap;gap:4px}.toolbar-popover-swatches .swatch-button{width:26px;height:26px}.toolbar-popover-input{width:100%;border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:7px 9px;font:inherit;font-size:.85rem;color:var(--color-text-primary);background:var(--color-surface-elevated)}.toolbar-popover-textarea{resize:vertical;min-height:68px}.toolbar-popover-field{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm);font-size:.78rem;color:var(--color-text-secondary)}.toolbar-popover-field input{width:78px;border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:5px 7px;font:inherit;font-size:.8rem}.toolbar-popover-submit{width:100%}.tool-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-tertiary);padding-right:var(--space-sm)}.swatch-button{width:28px;height:28px;border-radius:var(--radius-sm);border:2px solid transparent;padding:0;cursor:pointer;transition:all var(--transition-fast);position:relative}.swatch-button:after{content:"";position:absolute;inset:0;border-radius:6px;border:2px solid transparent;transition:border-color var(--transition-fast)}.swatch-button:hover{transform:scale(1.1)}.swatch-button.active{transform:scale(1.15)}.swatch-button.active:after{border-color:var(--color-text-primary)}.object-context-menu{position:absolute;display:flex;flex-direction:column;gap:6px;padding:8px;background:#fffffff2;border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);z-index:30;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.object-context-row{display:flex;align-items:center;flex-wrap:wrap;gap:6px}.shape-option{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;padding:0;background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast)}.shape-option:hover{background:var(--color-surface-subtle);color:var(--color-text-primary)}.shape-option.active{background:#4ecdc41a;border-color:var(--color-accent);color:var(--color-accent-dark)}.shape-icon{width:16px;height:16px;display:flex;align-items:center;justify-content:center}.board-content{display:grid;grid-template-columns:minmax(0,1fr) 340px;min-height:0;height:calc(100vh - 64px)}.canvas-column{position:relative;overflow:hidden;background:var(--color-surface);min-height:0}.presence-strip{position:absolute;top:var(--space-md);left:var(--space-md);right:var(--space-md);display:flex;gap:var(--space-sm);z-index:10;pointer-events:none;flex-wrap:wrap}.presence-pill{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-md);border-radius:var(--radius-full);background:#000000bf;color:#fff;font-size:.8rem;font-weight:500;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:presencePop var(--transition-spring) ease-out}@keyframes presencePop{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.presence-dot{width:8px;height:8px;border-radius:50%;background:#22c55e;box-shadow:0 0 8px #22c55e80}.presence-dot.away{background:#f59e0b;box-shadow:0 0 8px #f59e0b73}.board-stage{background-image:radial-gradient(circle,rgba(0,0,0,.03) 1px,transparent 1px);background-size:24px 24px;cursor:grab}.board-stage:active{cursor:grabbing}.board-stage.board-stage-area,.board-stage.board-stage-area:active{cursor:crosshair}.inline-editor-layer{position:absolute;inset:0;pointer-events:none;z-index:16}.inline-editor{position:absolute;margin:0;border:1px solid transparent;border-radius:10px;background:transparent;color:var(--color-text-primary);font-family:var(--font-display);font-weight:500;line-height:1.35;padding:8px 10px;box-shadow:none;pointer-events:auto;caret-color:currentColor;transition:border-color var(--transition-fast),box-shadow var(--transition-fast),background-color var(--transition-fast)}.inline-editor::placeholder{color:#64748bbf}.inline-editor:focus{outline:none;border-color:#0f766e8c;box-shadow:0 0 0 2px #0f766e2e}.inline-editor-textarea{resize:none;overflow:hidden}.inline-editor-align-left{text-align:left}.inline-editor-align-center{text-align:center}.inline-editor-pill{border-radius:999px}.inline-editor-text-object{padding:0;border-radius:0;border-color:transparent;box-shadow:none;line-height:1.2}.inline-editor-text-object:focus{border-color:transparent;box-shadow:0 0 0 1px #0f766e59}.inline-editor-frame{font-weight:700;padding:4px 8px}.zoom-controls{position:absolute;right:var(--space-md);bottom:calc(var(--space-md) + 118px);display:flex;flex-direction:column;gap:var(--space-xs);align-items:center;padding:var(--space-sm);background:var(--glass-surface);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);z-index:21}.zoom-button,.zoom-fit-button,.zoom-percentage{width:44px;height:34px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface-elevated);color:var(--color-text-primary);font-family:var(--font-mono);font-size:.8rem;font-weight:600;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast)}.zoom-button{font-size:1.1rem}.zoom-button:hover:not(:disabled),.zoom-fit-button:hover,.zoom-percentage:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-sm)}.zoom-button:disabled{opacity:.5;cursor:not-allowed}.zoom-percentage{width:54px}.right-column{border-left:1px solid var(--color-border);background:var(--glass-surface);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;flex-direction:column;min-height:0;overflow:hidden;position:relative;z-index:5}.side-panel{border-top:1px solid var(--color-border);padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-sm);min-height:0;flex:1;overflow:hidden}.side-panel-content{display:flex;flex-direction:column;gap:var(--space-sm);min-height:0;flex:1}.side-tabs{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-xs);padding:var(--space-sm);border-bottom:1px solid var(--color-border)}.side-tab-button{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface-elevated);color:var(--color-text-secondary);font-size:.75rem;font-weight:600;font-family:inherit;padding:var(--space-xs) var(--space-sm);cursor:pointer;transition:all var(--transition-fast)}.side-tab-button.active,.side-tab-button[aria-pressed=true]{color:var(--color-text-primary);border-color:var(--color-accent);background:#4ecdc414}.side-panel-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md)}.side-panel-header h3{margin:0;font-size:.95rem;font-weight:700;letter-spacing:-.01em}.value-badge{display:inline-flex;align-items:center;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-full);background:linear-gradient(135deg,var(--color-accent) 0%,var(--color-accent-dark) 100%);color:#fff;font-size:.75rem;font-weight:700}.comments-list,.timeline-list{display:flex;flex-direction:column;gap:var(--space-md);max-height:none;overflow-y:auto;padding-right:var(--space-xs);min-height:0;flex:1}.comments-list::-webkit-scrollbar,.timeline-list::-webkit-scrollbar{width:4px}.comments-list::-webkit-scrollbar-track,.timeline-list::-webkit-scrollbar-track{background:transparent}.comments-list::-webkit-scrollbar-thumb,.timeline-list::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}.comment-item,.timeline-item{padding:var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface-elevated);transition:all var(--transition-fast)}.timeline-item{width:100%;display:flex;flex-direction:column;align-items:flex-start;gap:4px;text-align:left;cursor:pointer}.timeline-item:hover{border-color:var(--color-accent);box-shadow:var(--shadow-sm)}.timeline-item.active{border-color:var(--color-accent);background:#4ecdc41a;box-shadow:var(--shadow-sm)}.timeline-item-actor{font-size:.83rem;font-weight:700;color:var(--color-text-primary)}.timeline-item-action{font-size:.84rem;line-height:1.35;color:var(--color-text-secondary)}.timeline-item-time{margin-top:2px;font-size:.72rem;font-family:var(--font-mono);color:var(--color-text-tertiary)}.side-panel-empty{justify-content:center}.comment-item p{margin:var(--space-xs) 0 0;font-size:.85rem;line-height:1.5;color:var(--color-text-primary)}.comment-author{font-size:.8rem;font-weight:600;color:var(--color-text-primary)}.comment-time{font-size:.7rem;color:var(--color-text-tertiary);font-family:var(--font-mono)}.ai-panel{background:var(--color-surface-elevated);padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-sm);border-bottom:0;flex:1 1 auto;min-height:0;overflow-y:auto}.ai-panel-sidebar{border-bottom:0;flex:1;overflow:hidden;min-height:0;padding:0}.ai-panel::-webkit-scrollbar{width:4px}.ai-panel::-webkit-scrollbar-track{background:transparent}.ai-panel::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}.ai-panel-header{display:flex;justify-content:space-between;align-items:center}.ai-panel-header h3{margin:0;font-size:1rem;font-weight:700;display:flex;align-items:center;gap:var(--space-sm)}.ai-panel-header h3:before{content:"✨";font-size:1.1rem}.status-pill{display:inline-flex;align-items:center;padding:var(--space-xs) var(--space-md);border-radius:var(--radius-full);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;background:var(--color-surface-subtle);color:var(--color-text-secondary)}.status-pill.running{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e}.status-pill.running:before{content:"";width:8px;height:8px;border-radius:50%;background:#f59e0b;margin-right:var(--space-xs);animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.status-pill.success{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#065f46}.status-pill.warning{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e}.status-pill.error{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#991b1b}.ai-input{min-height:96px;border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-md);font:inherit;font-size:.95rem;resize:vertical;transition:all var(--transition-fast);background:var(--color-surface);color:var(--color-text-primary)}.comment-input{min-height:72px}.ai-input:focus{outline:2px solid transparent;border-color:var(--color-accent);box-shadow:0 0 0 3px #4ecdc41a;background:var(--color-surface-elevated)}.ai-input::placeholder{color:var(--color-text-tertiary)}.ai-quick-actions{display:flex;gap:var(--space-xs);flex-wrap:wrap;padding:var(--space-sm);background:var(--color-surface);border-radius:var(--radius-md)}.ai-quick-actions .button-ghost{padding:var(--space-sm) var(--space-md);font-size:.8rem;font-weight:600;border-radius:var(--radius-sm)}.quick-action-icon{font-size:1rem;opacity:.7}.ai-tools-row{display:flex;gap:var(--space-sm);flex-wrap:wrap;align-items:center}.ai-tool-icon-button{width:34px;height:34px}.spinner{animation:spin 1s linear infinite;display:inline-block}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.ai-upload-input{display:none}.ai-message{display:flex;align-items:flex-start;gap:var(--space-sm);padding:var(--space-md);border-radius:var(--radius-md);font-size:.9rem;line-height:1.5;animation:messageSlide var(--transition-base) ease-out}@keyframes messageSlide{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.ai-message.success{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#065f46}.ai-message.error{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#991b1b}.ai-message.warning,.ai-message.running{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e}.message-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;flex-shrink:0;font-weight:700}.ai-message.success .message-icon{background:#065f46;color:#fff}.ai-message.error .message-icon{background:#991b1b;color:#fff}.ai-message.warning .message-icon{background:#92400e;color:#fff}.ai-history{display:flex;flex-direction:column;gap:var(--space-xs);border-top:1px solid var(--color-border);padding-top:var(--space-sm);flex:1;min-height:0}.ai-history-header{display:flex;align-items:center;justify-content:space-between}.ai-history-header h4{margin:0;font-size:.82rem;letter-spacing:.02em;text-transform:uppercase;color:var(--color-text-tertiary)}.ai-history-list{display:flex;flex-direction:column;gap:var(--space-xs);max-height:none;min-height:0;flex:1;overflow-y:auto;padding-right:2px}.send-command-button{position:sticky;bottom:0;z-index:1}.ai-history-item{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);padding:8px 10px}.ai-history-item p{margin:6px 0 0;font-size:.8rem;color:var(--color-text-secondary)}.ai-history-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm)}.ai-history-time{font-size:.72rem;color:var(--color-text-tertiary);font-family:var(--font-mono)}.panel-note{margin:0;font-size:.85rem;color:var(--color-text-secondary);line-height:1.5}.panel-note strong{color:var(--color-text-primary)}.minimap{position:absolute;right:var(--space-md);bottom:var(--space-md);z-index:20;padding:var(--space-sm);background:var(--glass-surface);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);cursor:pointer;transition:all var(--transition-fast)}.minimap:hover{box-shadow:var(--shadow-lg)}.minimap-title{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-tertiary);margin-bottom:var(--space-xs)}.minimap-canvas{position:relative;width:140px;height:100px;background:var(--color-surface-subtle);border-radius:var(--radius-sm);overflow:hidden}.minimap-object{position:absolute;background:#4ecdc44d;border:1px solid rgba(78,205,196,.6);border-radius:2px}.minimap-object.selected{background:#ff6b6b66;border-color:#ff6b6bcc}.minimap-viewport{position:absolute;border:2px solid var(--color-text-primary);background:#0000000d;border-radius:2px}.command-palette-backdrop{position:fixed;inset:0;background:#02061747;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:grid;place-items:start center;padding-top:max(72px,10vh);z-index:var(--z-modal-backdrop)}.command-palette{width:min(620px,calc(100vw - 24px));max-height:min(72vh,560px);display:flex;flex-direction:column;gap:var(--space-sm);padding:var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius-lg);background:#fffffffa;box-shadow:var(--shadow-xl)}.command-palette-input{width:100%;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface-elevated);color:var(--color-text-primary);font:inherit;font-size:.95rem;padding:10px 12px}.command-palette-input:focus{outline:2px solid transparent;border-color:var(--color-accent);box-shadow:0 0 0 2px #4ecdc42e}.command-palette-list{display:flex;flex-direction:column;gap:6px;min-height:120px;max-height:360px;overflow-y:auto}.command-palette-item{width:100%;display:grid;grid-template-columns:minmax(0,1fr) auto;grid-template-rows:auto auto;row-gap:2px;column-gap:var(--space-sm);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface-elevated);color:inherit;text-align:left;padding:9px 10px;cursor:pointer;transition:all var(--transition-fast)}.command-palette-item:hover,.command-palette-item.active{border-color:var(--color-accent);background:#4ecdc41a}.command-palette-item-label{grid-column:1;grid-row:1;font-size:.88rem;font-weight:700;color:var(--color-text-primary)}.command-palette-item-description{grid-column:1;grid-row:2;font-size:.76rem;color:var(--color-text-secondary)}.command-palette-item-shortcut{grid-column:2;grid-row:1 / span 2;align-self:center;justify-self:end;border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:2px 7px;font-family:var(--font-mono);font-size:.72rem;color:var(--color-text-secondary);background:var(--color-surface)}.command-palette-hint{margin:0;font-size:.74rem;color:var(--color-text-tertiary)}.template-chooser-backdrop{position:fixed;inset:0;background:#02061752;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:grid;place-items:center;padding:var(--space-xl);z-index:var(--z-modal-backdrop)}.template-chooser-modal{width:min(760px,calc(100vw - 32px));border:1px solid var(--color-border);border-radius:var(--radius-lg);background:#fffffffa;box-shadow:var(--shadow-xl);padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-sm)}.template-chooser-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm)}.template-chooser-header h3{margin:0;font-size:1rem}.template-chooser-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--space-sm)}.template-card{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface-elevated);color:inherit;text-align:left;padding:var(--space-md);display:flex;flex-direction:column;gap:6px;cursor:pointer;transition:border-color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast)}.template-card strong{font-size:.9rem}.template-card span{color:var(--color-text-secondary);font-size:.78rem;line-height:1.35}.template-card:hover:not(:disabled),.template-card:focus-visible:not(:disabled){border-color:var(--color-accent);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.template-card:disabled{opacity:.55;cursor:not-allowed}:root[data-theme=dark] .toolbar-popover,:root[data-theme=dark] .command-palette,:root[data-theme=dark] .template-chooser-modal,:root[data-theme=dark] .share-dialog-card,:root[data-theme=dark] .shortcut-modal{background:#111827f5}:root[data-theme=dark] .command-palette-item:hover,:root[data-theme=dark] .command-palette-item.active{background:#2dd4bf2e}:root[data-theme=dark] .template-card{background:#0f172ae6}.shortcut-modal-backdrop{position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:grid;place-items:center;padding:var(--space-xl);z-index:var(--z-modal-backdrop);animation:fadeIn var(--transition-base) ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.shortcut-modal{width:min(560px,100%);max-height:80vh;overflow-y:auto;background:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-xl);box-shadow:var(--shadow-xl);animation:modalReveal var(--transition-slow) cubic-bezier(.34,1.56,.64,1)}@keyframes modalReveal{0%{opacity:0;transform:scale(.92) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.shortcut-modal h3{margin:0 0 var(--space-md);font-size:1.25rem;font-weight:700}.shortcut-modal ul{margin:0;padding:0;list-style:none;display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-sm)}.shortcut-modal li{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-md);background:var(--color-surface);border-radius:var(--radius-md);font-size:.9rem}.shortcut-modal kbd{display:inline-flex;align-items:center;gap:2px;padding:2px 6px;background:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:6px;font-family:var(--font-mono);font-size:.75rem;font-weight:500;box-shadow:var(--shadow-xs)}.setup-warning{margin:var(--space-2xl) auto;max-width:640px;background:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-xl);box-shadow:var(--shadow-md)}.setup-warning h2{margin:0 0 var(--space-md);font-size:1.1rem;color:#dc2626}.board-access-denied-card{background:linear-gradient(135deg,#0f172a,#1e293b);border-color:#94a3b873;color:#fff;display:flex;flex-direction:column;gap:var(--space-sm)}.board-access-denied-card h2,.board-access-denied-card p,.board-access-denied-card .panel-note,.board-access-denied-card .error-text,.board-access-denied-card .error-text:before,.board-access-denied-card .primary-button{color:#fff}@media(max-width:1024px){.board-content{grid-template-columns:1fr}.boards-panel{max-height:min(92vh,760px)}.boards-panel-body{grid-template-columns:1fr}.boards-list{border-right:0;border-bottom:1px solid var(--color-border);max-height:44vh}.boards-side{border-top:1px solid var(--color-border)}.right-column{border-left:0;border-top:1px solid var(--color-border);order:1}.minimap{right:var(--space-sm);bottom:var(--space-sm)}.zoom-controls{right:var(--space-sm);bottom:calc(var(--space-sm) + 110px)}.floating-toolbar{bottom:var(--space-md);width:calc(100% - var(--space-lg) * 2);justify-content:center;flex-wrap:wrap}.shortcut-modal ul{grid-template-columns:1fr}.template-chooser-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-height:980px){.board-header{min-height:56px;padding:0 var(--space-lg)}.board-content{height:calc(100vh - 56px)}.floating-toolbar{bottom:var(--space-sm);padding:var(--space-xs)}.tool-group{gap:6px;padding:0 var(--space-xs)}.button-icon{width:36px;height:36px}.button-icon-text{min-width:44px;font-size:.66rem}.zoom-controls{right:var(--space-sm);bottom:calc(var(--space-sm) + 102px)}.minimap{right:var(--space-sm);bottom:var(--space-sm);padding:var(--space-xs)}.ai-chat-widget{right:calc(var(--space-sm) + 56px);bottom:calc(var(--space-sm) + 98px)}.ai-chat-widget-panel{width:min(320px,calc(100vw - 24px));height:min(440px,calc(100vh - 176px))}.minimap-canvas{width:124px;height:88px}.ai-panel{padding:var(--space-sm)}.ai-input{min-height:72px}.comment-input{min-height:60px}.side-tabs{padding:var(--space-xs)}.side-panel{padding:var(--space-sm)}.ai-panel-sidebar{padding:0}}@media(max-height:860px){.ai-quick-actions{display:none}}@media(max-width:640px){.board-header{padding:0 var(--space-md)}.floating-toolbar{border-radius:var(--radius-lg)}.login-card{padding:var(--space-lg)}.template-chooser-grid{grid-template-columns:1fr}}
