*{box-sizing:border-box}:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;font-weight:400;color:#1e293b;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;padding:0;min-height:100vh;background:#f8fafc}#root{height:100vh;width:100vw}button{font-family:inherit;font-size:inherit;line-height:inherit;margin:0;padding:0;border:none;background:none;cursor:pointer}input{font-family:inherit;font-size:inherit;line-height:inherit;margin:0;padding:0;border:none;background:none;outline:none}button:focus-visible,input:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:1rem}.login-form{background:#fff;border-radius:16px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;padding:2.5rem;width:100%;max-width:400px;position:relative;overflow:hidden}.login-form:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#3b82f6,#8b5cf6,#ec4899)}.login-form h1{font-size:2rem;font-weight:700;color:#1f2937;text-align:center;margin:0 0 .5rem;background:linear-gradient(135deg,#3b82f6,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-form p{color:#6b7280;text-align:center;margin:0 0 2rem;font-size:.95rem}.auth-tabs{display:flex;background:#f3f4f6;border-radius:8px;padding:4px;margin-bottom:1.5rem}.tab-button{flex:1;padding:.75rem 1rem;border-radius:6px;font-weight:500;font-size:.9rem;transition:all .2s ease;color:#6b7280;background:transparent}.tab-button:hover{color:#374151;background:#ffffff80}.tab-button.active{background:#fff;color:#3b82f6;box-shadow:0 1px 3px #0000001a}.form-group{margin-bottom:1.25rem}.form-group input{width:100%;padding:.875rem 1rem;border:2px solid #e5e7eb;border-radius:8px;font-size:.95rem;transition:all .2s ease;background:#fafafa}.form-group input:focus{outline:none;border-color:#3b82f6;background:#fff;box-shadow:0 0 0 3px #3b82f61a}.form-group input:disabled{background:#f9fafb;color:#9ca3af;cursor:not-allowed}.form-group input::placeholder{color:#9ca3af}.error-message{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:.75rem 1rem;border-radius:8px;font-size:.875rem;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.error-message:before{content:"⚠️";font-size:1rem}.verification-banner{background:#f0fdf4;border:1px solid #bbf7d0;color:#166534;padding:.75rem 1rem;border-radius:8px;font-size:.875rem;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.verification-banner:before{content:"✅";font-size:1rem}.login-button{width:100%;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;padding:.875rem 1.5rem;border-radius:8px;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .2s ease;position:relative;overflow:hidden}.login-button:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-1px);box-shadow:0 10px 15px -3px #3b82f64d}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{background:#9ca3af;cursor:not-allowed;transform:none;box-shadow:none}.login-button:disabled:after{content:"";position:absolute;top:50%;left:50%;width:16px;height:16px;margin:-8px 0 0 -8px;border:2px solid transparent;border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}@media (max-width: 480px){.login-container{padding:.5rem}.login-form{padding:1.5rem}.login-form h1{font-size:1.75rem}}@media (prefers-color-scheme: dark){.login-form{background:#1f2937;color:#f9fafb}.login-form h1{color:#f9fafb}.login-form p{color:#d1d5db}.form-group input{background:#374151;border-color:#4b5563;color:#f9fafb}.form-group input:focus{background:#4b5563;border-color:#3b82f6}.form-group input::placeholder{color:#9ca3af}.auth-tabs{background:#374151}.tab-button{color:#9ca3af}.tab-button:hover{color:#d1d5db;background:#37415180}.tab-button.active{background:#4b5563;color:#60a5fa}}.auth-callback{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:1rem}.auth-callback-content{background:#fff;border-radius:16px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;padding:3rem 2.5rem;text-align:center;max-width:400px;width:100%}.spinner{width:40px;height:40px;border:4px solid #e5e7eb;border-top:4px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1.5rem}.success-icon{font-size:4rem;margin:0 auto 1.5rem}.auth-callback-content h2{font-size:1.5rem;font-weight:600;color:#1f2937;margin:0 0 .5rem}.auth-callback-content p{color:#6b7280;margin:0 0 .5rem;font-size:.95rem}.redirect-text{color:#9ca3af;font-size:.85rem;font-style:italic}@media (prefers-color-scheme: dark){.auth-callback-content{background:#1f2937;color:#f9fafb}.auth-callback-content h2{color:#f9fafb}.auth-callback-content p{color:#d1d5db}.redirect-text{color:#9ca3af}.spinner{border-color:#4b5563;border-top-color:#60a5fa}}.ai-command-overlay{position:fixed;inset:0;background:#0000004d;display:flex;align-items:flex-start;justify-content:center;padding-top:100px;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.ai-command-bar{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;width:100%;max-width:600px;margin:0 20px;overflow:hidden;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.ai-command-header{display:flex;align-items:center;padding:16px 20px;border-bottom:1px solid #e5e7eb;background:#f9fafb}.ai-command-icon{font-size:20px;margin-right:12px}.ai-command-title{font-size:18px;font-weight:600;color:#111827;flex:1}.ai-command-close{background:none;border:none;font-size:24px;color:#6b7280;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s}.ai-command-close:hover:not(:disabled){background:#e5e7eb;color:#374151}.ai-command-close:disabled{opacity:.5;cursor:not-allowed}.ai-command-form{padding:20px}.ai-command-input-container{display:flex;align-items:center;gap:12px;margin-bottom:16px;position:relative}.ai-command-input{flex:1;padding:12px 16px;border:2px solid #e5e7eb;border-radius:8px;font-size:16px;outline:none;transition:border-color .2s}.ai-command-input:focus{border-color:#3b82f6}.ai-command-input:disabled{background:#f9fafb;color:#6b7280}.ai-command-spinner{position:absolute;right:80px;top:50%;transform:translateY(-50%)}.spinner{width:20px;height:20px;border:2px solid #e5e7eb;border-top:2px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite}.ai-command-submit{background:#3b82f6;color:#fff;border:none;padding:12px 20px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s;white-space:nowrap}.ai-command-submit:hover:not(:disabled){background:#2563eb}.ai-command-submit:disabled{background:#9ca3af;cursor:not-allowed}.ai-command-error{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:14px;margin-bottom:16px}.error-icon{font-size:16px}.ai-command-suggestions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:16px}.suggestions-label{font-size:14px;color:#6b7280;font-weight:500}.suggestion-chip{background:#f3f4f6;border:1px solid #d1d5db;color:#374151;padding:6px 12px;border-radius:20px;font-size:12px;cursor:pointer;transition:all .2s}.suggestion-chip:hover:not(:disabled){background:#e5e7eb;border-color:#9ca3af}.suggestion-chip:disabled{opacity:.5;cursor:not-allowed}.ai-command-footer{padding:12px 20px;background:#f9fafb;border-top:1px solid #e5e7eb;text-align:center}.shortcut-hint{font-size:12px;color:#6b7280}@media (max-width: 640px){.ai-command-overlay{padding-top:50px}.ai-command-bar{margin:0 10px}.ai-command-input-container{flex-direction:column;align-items:stretch}.ai-command-submit{width:100%}.ai-command-suggestions{flex-direction:column;align-items:flex-start}}:root{--bg-primary: #f8fafc;--bg-secondary: #ffffff;--bg-tertiary: #f1f5f9;--text-primary: #1f2937;--text-secondary: #6b7280;--text-tertiary: #9ca3af;--border-primary: #e2e8f0;--border-secondary: #d1d5db;--shadow-primary: 0 2px 4px rgba(0, 0, 0, .1);--shadow-secondary: 0 1px 2px 0 rgba(0, 0, 0, .05);--accent-primary: #3b82f6;--accent-hover: #2563eb;--accent-secondary: #ef4444;--accent-secondary-hover: #dc2626}[data-theme=dark]{--bg-primary: #1f2937;--bg-secondary: #374151;--bg-tertiary: #4b5563;--text-primary: #f9fafb;--text-secondary: #d1d5db;--text-tertiary: #9ca3af;--border-primary: #4b5563;--border-secondary: #6b7280;--shadow-primary: 0 2px 4px rgba(0, 0, 0, .3);--shadow-secondary: 0 1px 2px 0 rgba(0, 0, 0, .2);--accent-primary: #3b82f6;--accent-hover: #2563eb;--accent-secondary: #ef4444;--accent-secondary-hover: #dc2626}[data-theme=darker]{--bg-primary: #111827;--bg-secondary: #1f2937;--bg-tertiary: #374151;--text-primary: #ffffff;--text-secondary: #e5e7eb;--text-tertiary: #9ca3af;--border-primary: #374151;--border-secondary: #4b5563;--shadow-primary: 0 2px 4px rgba(0, 0, 0, .5);--shadow-secondary: 0 1px 2px 0 rgba(0, 0, 0, .3);--accent-primary: #60a5fa;--accent-hover: #3b82f6;--accent-secondary: #f87171;--accent-secondary-hover: #ef4444}.app{height:100vh;display:flex;flex-direction:column;background:var(--bg-primary);color:var(--text-primary);transition:background-color .3s ease,color .3s ease}.app-header{background:var(--bg-secondary);border-bottom:1px solid var(--border-primary);padding:0 1rem;z-index:10;transition:background-color .3s ease,border-color .3s ease}.header-content{display:flex;align-items:center;justify-content:space-between;height:60px}.header-content h3{margin:0;color:var(--text-primary);font-size:1.5rem;font-weight:600}.header-content .username{color:var(--text-secondary);font-size:.9rem}.logout-button{background:#ef4444;color:#fff;border:none;padding:.5rem 1rem;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .2s}.logout-button:hover{background:#dc2626}.ai-test-button{background:#3b82f6;color:#fff;border:none;padding:.5rem 1rem;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .2s;margin-right:.5rem}.ai-test-button:hover{background:#2563eb}.app-main{flex:1;display:flex;overflow:hidden}.canvas-wrapper{flex:1;position:relative;background:var(--bg-secondary);transition:background-color .3s ease}.canvas-container{background:var(--bg-secondary);transition:background-color .3s ease}.sidebar{width:300px;background:var(--bg-secondary);border-left:1px solid var(--border-primary);padding:1rem;overflow-y:auto;transition:background-color .3s ease,border-color .3s ease}.loading-container{display:flex;align-items:center;justify-content:center;height:100vh;background:#f8fafc}.loading-spinner{font-size:1.2rem;color:#6b7280;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.connection-status{position:fixed;top:80px;right:20px;padding:.5rem 1rem;border-radius:.375rem;font-size:.875rem;font-weight:500;z-index:50;transition:all .3s ease}.connection-status.connected{background:#d1fae5;color:#065f46;border:1px solid #a7f3d0}.connection-status.disconnected{background:#fee2e2;color:#991b1b;border:1px solid #fca5a5}.connection-status.reconnecting{background:#fef3c7;color:#92400e;border:1px solid #fde68a}.pending-changes{position:fixed;bottom:20px;right:20px;background:#1f2937;color:#fff;padding:.5rem 1rem;border-radius:.375rem;font-size:.875rem;z-index:50;display:flex;align-items:center;gap:.5rem}.pending-changes .spinner{width:16px;height:16px;border:2px solid #374151;border-top:2px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.status-connected{background:#10b981e6!important}.status-disconnected{background:#ef4444e6!important}.status-reconnecting,.status-pending{background:#f59e0be6!important}.canvas-toolbar{position:absolute;top:10px;left:10px;z-index:100;display:flex;align-items:center;gap:1rem;background:var(--bg-secondary);padding:.5rem 1rem;border-radius:8px;box-shadow:var(--shadow-primary);border:1px solid var(--border-primary);transition:background-color .3s ease,border-color .3s ease,box-shadow .3s ease}.shape-buttons{display:flex;gap:.5rem}.z-index-buttons{display:flex;gap:.5rem;margin-left:.5rem;padding-left:.5rem;border-left:1px solid #e2e8f0}.z-index-button{background:#f3f4f6;color:#374151;border:1px solid #d1d5db;padding:.375rem .75rem;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.25rem}.z-index-button:hover{background:#e5e7eb;border-color:#9ca3af}.z-index-button:active{background:#d1d5db;transform:translateY(1px)}.toolbar-button{background:#3b82f6;color:#fff;border:none;padding:.5rem 1rem;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .2s}.toolbar-button:hover{background:#2563eb}.toolbar-button.primary{background:#3b82f6}.toolbar-button.primary:hover{background:#2563eb}.toolbar-button.secondary{background:#6b7280}.toolbar-button.secondary:hover{background:#4b5563}.color-palette{display:flex;gap:.5rem;align-items:center}.color-button{width:32px;height:32px;border:2px solid transparent;border-radius:50%;cursor:pointer;transition:all .2s;position:relative}.color-button:hover{transform:scale(1.1);box-shadow:0 2px 8px #0003}.color-button.selected{border-color:#1f2937;box-shadow:0 0 0 2px #3b82f64d}.color-button.selected:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-weight:700;font-size:14px;text-shadow:0 0 2px rgba(0,0,0,.8)}@media (max-width: 768px){.app-main{flex-direction:column}.sidebar{width:100%;height:200px;border-left:none;border-top:1px solid #e2e8f0}.canvas-toolbar{position:relative;top:auto;left:auto;margin:1rem;box-shadow:none;border:1px solid #e2e8f0}}.ai-command-overlay{position:fixed;inset:0;background:#00000080;z-index:1000;display:flex;align-items:flex-start;justify-content:center;padding-top:100px}.ai-command-bar{background:#fff;padding:20px;border-radius:8px;width:500px;max-width:90vw;box-shadow:0 10px 25px #0003}.ai-command-bar h3{margin:0 0 15px;color:#1f2937;font-size:1.25rem;font-weight:600}.ai-command-bar input{flex:1;padding:10px;border:1px solid #d1d5db;border-radius:4px;font-size:16px;outline:none;transition:border-color .2s}.ai-command-bar input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.ai-command-bar button{padding:10px 20px;background:#3b82f6;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:16px;font-weight:500;transition:background-color .2s}.ai-command-bar button:hover:not(:disabled){background:#2563eb}.ai-command-bar button:disabled{background:#9ca3af;cursor:not-allowed}.ai-command-bar .error{color:#dc2626;margin-bottom:10px;font-size:14px}.ai-command-bar .help-text{color:#6b7280;font-size:12px;margin-top:10px}.hidden{display:none!important}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.focus-visible{outline:2px solid #3b82f6;outline-offset:2px}.fade-in{animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.slide-up{animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.settings-container{position:relative;display:inline-block}.settings-button{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-secondary);padding:8px 12px;border-radius:6px;cursor:pointer;font-size:16px;transition:all .2s ease;margin-right:10px}.settings-button:hover{background:var(--bg-secondary);border-color:var(--border-primary);transform:translateY(-1px)}.settings-dropdown{position:absolute;top:100%;right:0;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:8px;box-shadow:var(--shadow-primary);min-width:280px;z-index:1000;animation:slideUp .2s ease-out}.settings-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border-primary)}.settings-header h4{margin:0;color:var(--text-primary);font-size:1.1rem;font-weight:600}.close-button{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:18px;padding:4px;border-radius:4px;transition:all .2s ease}.close-button:hover{background:var(--bg-tertiary);color:var(--text-primary)}.settings-content{padding:20px}.user-info{margin-bottom:24px}.info-item{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.info-item label{color:var(--text-secondary);font-size:.9rem;font-weight:500}.info-item span{color:var(--text-primary);font-size:.9rem}.theme-section{margin-bottom:24px}.section-label{display:block;color:var(--text-primary);font-size:1rem;font-weight:600;margin-bottom:12px}.theme-options{display:flex;flex-direction:column;gap:8px}.theme-option{display:flex;align-items:center;padding:12px;border:1px solid var(--border-secondary);border-radius:6px;cursor:pointer;transition:all .2s ease}.theme-option:hover{background:var(--bg-tertiary);border-color:var(--border-primary)}.theme-option input[type=radio]{margin-right:12px;accent-color:var(--accent-primary)}.theme-info{display:flex;flex-direction:column;gap:2px}.theme-label{color:var(--text-primary);font-size:.95rem;font-weight:500}.theme-description{color:var(--text-secondary);font-size:.8rem}.shortcuts-section{margin-bottom:0}.shortcuts-list{display:flex;flex-direction:column;gap:16px}.shortcut-category{display:flex;flex-direction:column;gap:8px}.shortcut-category h5{margin:0;color:var(--text-primary);font-size:.9rem;font-weight:600;padding-bottom:4px;border-bottom:1px solid var(--border-secondary)}.shortcut-item{display:flex;justify-content:space-between;align-items:center;padding:6px 0}.shortcut-key{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-secondary);border-radius:4px;padding:4px 8px;font-size:.8rem;font-weight:500;font-family:Courier New,monospace;min-width:60px;text-align:center}.shortcut-description{color:var(--text-secondary);font-size:.85rem;margin-left:12px;flex:1}.users-list{padding:1rem;border-bottom:1px solid var(--border-color)}.users-list h4{margin:0 0 1rem;color:var(--text-primary);font-size:.9rem;font-weight:600}.users{display:flex;flex-direction:column;gap:.5rem}.user-item{display:flex;align-items:center;gap:.5rem;padding:.5rem;border-radius:6px;transition:background-color .2s ease,opacity .2s ease}.user-item:hover{background-color:var(--bg-hover)}.user-item.current-user{background-color:var(--accent-color);color:#fff}.user-item.idle{opacity:.6}.user-color{width:12px;height:12px;border-radius:50%;flex-shrink:0;transition:opacity .2s ease}.user-color.idle{opacity:.5}.username{font-size:.85rem;color:var(--text-primary);font-weight:500}[data-theme=light] .username{color:var(--text-secondary)}.user-item.current-user .username{color:#fff}.user-item.idle .username{color:var(--text-secondary);font-style:italic}
