:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;padding:0;min-width:320px;width:100%;height:100vh;overflow:hidden}#root{width:100%;height:100%;overflow:hidden}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.auth-container{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);overflow:hidden}.auth-background{position:absolute;inset:0;overflow:hidden;pointer-events:none}.bg-shape{position:absolute;border-radius:50%;opacity:.1;background:#fff;animation:float 20s infinite ease-in-out}.bg-shape.shape-1{width:300px;height:300px;top:-100px;left:-100px;animation-delay:0s}.bg-shape.shape-2{width:200px;height:200px;bottom:-50px;right:-50px;animation-delay:5s}.bg-shape.shape-3{width:150px;height:150px;top:50%;right:10%;animation-delay:10s}@keyframes float{0%,to{transform:translate(0) scale(1)}33%{transform:translate(30px,-30px) scale(1.1)}66%{transform:translate(-20px,20px) scale(.9)}}.auth-card{position:relative;z-index:1;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;width:100%;max-width:420px;padding:2.5rem;margin:1rem;animation:slideUp .4s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.auth-header{text-align:center;margin-bottom:2rem}.auth-header h1{font-size:2rem;font-weight:700;color:#1a1a1a;margin:0 0 .5rem;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-subtitle{color:#666;font-size:.95rem;margin:0}.auth-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;background:#f5f5f5;border-radius:8px;padding:.25rem}.auth-tab{flex:1;padding:.75rem;border:none;background:transparent;color:#666;font-size:.95rem;font-weight:600;border-radius:6px;cursor:pointer;transition:all .2s ease}.auth-tab:hover{color:#333}.auth-tab.active{background:#fff;color:#667eea;box-shadow:0 2px 4px #0000001a}.auth-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.9rem;font-weight:600;color:#333}.form-group input{padding:.875rem 1rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:all .2s ease;font-family:inherit}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled{background:#f5f5f5;cursor:not-allowed}.form-group input::placeholder{color:#999}.auth-error{display:flex;align-items:center;gap:.5rem;padding:.875rem 1rem;background:#fee;border:1px solid #fcc;border-radius:8px;color:#c33;font-size:.9rem;animation:shake .4s ease}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.error-icon{font-size:1.2rem}.auth-button{padding:.875rem 1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:.5rem}.auth-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.auth-button:active:not(:disabled){transform:translateY(0)}.auth-button:disabled{opacity:.7;cursor:not-allowed}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.auth-footer{margin-top:1.5rem;text-align:center}.auth-footer p{color:#666;font-size:.9rem;margin:0}.auth-link{background:none;border:none;color:#667eea;font-weight:600;cursor:pointer;padding:0;font-size:inherit;text-decoration:none;transition:color .2s ease}.auth-link:hover:not(:disabled){color:#764ba2;text-decoration:underline}.auth-link:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 480px){.auth-card{padding:2rem 1.5rem;margin:.5rem}.auth-header h1{font-size:1.75rem}.auth-subtitle{font-size:.875rem}}@media (prefers-color-scheme: dark){.auth-card{background:#1e1e1e}.auth-header h1{color:#e0e0e0}.auth-subtitle{color:#999}.auth-tabs{background:#2a2a2a}.auth-tab{color:#999}.auth-tab:hover{color:#e0e0e0}.auth-tab.active{background:#333;color:#667eea}.form-group label{color:#e0e0e0}.form-group input{background:#2a2a2a;border-color:#444;color:#e0e0e0}.form-group input:focus{border-color:#667eea;background:#333}.form-group input:disabled{background:#1a1a1a}.auth-footer p{color:#999}}.color-picker{position:relative;display:flex;align-items:center}.color-picker-button{width:40px;height:40px;padding:4px;background:#fff;border:1px solid #e0e0e0;border-radius:6px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.color-picker-button:hover:not(:disabled){background:#f5f5f5;border-color:#667eea;transform:translateY(-1px)}.color-picker-button:active:not(:disabled){transform:translateY(0) scale(.95)}.color-picker-button:disabled{opacity:.4;cursor:not-allowed;background:#f5f5f5}.color-preview{width:28px;height:28px;border-radius:4px;border:2px solid #ffffff;box-shadow:0 0 0 1px #0000001a,0 2px 4px #0000001a}.color-input-hidden{position:absolute;top:50px;left:0;opacity:0;width:1px;height:1px;pointer-events:none}@media (prefers-color-scheme: dark){.color-picker-button{background:#2a2a2a;border-color:#444}.color-picker-button:hover:not(:disabled){background:#333;border-color:#667eea}.color-picker-button:disabled{background:#1a1a1a}}.canvas-wrapper{position:relative;width:100%;height:100%;overflow:hidden;background:#f5f5f5;cursor:grab}.canvas-wrapper.dragging{cursor:grabbing}.toolbar{position:absolute;top:1rem;left:1rem;z-index:10;display:flex;flex-direction:column;gap:.25rem;align-items:center;background:#fff;border-radius:8px;padding:.5rem;box-shadow:0 2px 8px #0000001a}.toolbar-button{width:40px;height:40px;padding:0;background:#fff;border:1px solid #e0e0e0;border-radius:6px;font-size:1.25rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;color:#333}.toolbar-button:hover:not(:disabled){background:#f5f5f5;border-color:#667eea;transform:translateY(-1px)}.toolbar-button:active:not(:disabled){transform:translateY(0) scale(.95)}.toolbar-button.active{background:#667eea;color:#fff;border-color:#667eea}.toolbar-button.active:hover{background:#5568d3}.toolbar-button:disabled{opacity:.4;cursor:not-allowed;background:#f5f5f5}.toolbar-shapes-menu{position:relative;display:flex;align-items:center}.shapes-dropdown{position:absolute;left:42px;top:-4px;display:flex;flex-direction:column;gap:.25rem;background:#fff;border-radius:8px;padding:.5rem .5rem .5rem .75rem;box-shadow:0 4px 12px #00000026;z-index:100;animation:slideInLeft .2s ease-out}.shapes-dropdown:before{content:"";position:absolute;right:100%;top:0;width:10px;height:100%;background:transparent}.toolbar-divider{width:30px;height:1px;background:#e0e0e0;margin:.25rem 0}.toolbar-info{display:flex;align-items:center;justify-content:center;padding:.25rem 0;font-size:.85rem}.zoom-value{color:#667eea;font-weight:600;min-width:40px;text-align:center}.toolbar-status{display:flex;align-items:center;justify-content:center;padding:0 .25rem;font-size:1rem}.toolbar-status.loading{color:#667eea}.toolbar-status.error{color:#f44336}.canvas-instructions{position:absolute;bottom:1rem;left:50%;transform:translate(-50%);z-index:10;background:#ffffffe6;color:#000;padding:.75rem 1.5rem;border-radius:20px;font-size:.9rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 12px #0003;pointer-events:none}.canvas-instructions p{margin:0;font-weight:500}.shape-count{position:absolute;top:1rem;right:340px;z-index:10;background:#fff;border-radius:8px;padding:.5rem 1rem;box-shadow:0 2px 8px #0000001a;font-size:.9rem;color:#666;font-weight:500;transition:right .3s ease}.cursor-count{margin-left:.5rem;color:#667eea;font-weight:600}.konvajs-content{background:#f5f5f5}.canvas-wrapper.dragging canvas{cursor:grabbing!important}@media (max-width: 1400px){.shape-count{right:300px}}@media (max-width: 1024px){.shape-count{right:280px}}@media (max-width: 768px){.toolbar{top:.5rem;left:.5rem;padding:.4rem}.toolbar-button{width:36px;height:36px;font-size:1.1rem}.toolbar-divider{width:24px}.canvas-instructions{bottom:.5rem;font-size:.8rem;padding:.5rem 1rem}.shape-count{top:.5rem;right:.5rem;font-size:.8rem;padding:.4rem .8rem}}@media (prefers-color-scheme: dark){.canvas-wrapper{background:#1a1a1a}.toolbar{background:#2a2a2a;box-shadow:0 2px 8px #0000004d}.toolbar-button{background:#2a2a2a;border-color:#444;color:#e0e0e0}.toolbar-button:hover:not(:disabled){background:#333;border-color:#667eea}.toolbar-button.active{background:#667eea;color:#fff}.toolbar-button:disabled{background:#1a1a1a}.toolbar-divider{background:#444}.shapes-dropdown{background:#2a2a2a;box-shadow:0 4px 12px #00000080}.canvas-instructions{background:#ffffff1a}.shape-count{background:#2a2a2a;color:#999}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.toolbar,.canvas-instructions{animation:fadeIn .4s ease-out}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.keyboard-shortcuts-container{position:relative;display:flex;align-items:center}.shortcuts-dropdown{position:absolute;left:42px;top:-4px;min-width:280px;background:#fff;border-radius:8px;padding:0;box-shadow:0 4px 12px #00000026;z-index:100;animation:slideInLeft .2s ease-out;overflow:hidden}.shortcuts-dropdown:before{content:"";position:absolute;right:100%;top:0;width:10px;height:100%;background:transparent}.shortcuts-header{padding:.75rem 1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-weight:600;font-size:.9rem;border-bottom:1px solid rgba(0,0,0,.1)}.shortcuts-list{padding:.5rem;max-height:400px;overflow-y:auto}.shortcut-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem;gap:1rem;border-bottom:1px solid #f0f0f0}.shortcut-item:last-child{border-bottom:none}.shortcut-key{font-family:Courier New,monospace;font-size:.75rem;font-weight:600;color:#667eea;background:#f5f5f5;padding:.25rem .5rem;border-radius:4px;white-space:nowrap;flex-shrink:0}.shortcut-action{font-size:.85rem;color:#666;text-align:right;flex:1}@keyframes slideInLeft{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}@media (prefers-color-scheme: dark){.shortcuts-dropdown{background:#2a2a2a;box-shadow:0 4px 12px #00000080}.shortcuts-header{border-bottom-color:#444}.shortcut-item{border-bottom-color:#333}.shortcut-key{color:#85a5ff;background:#1a1a1a}.shortcut-action{color:#999}}.shortcuts-list::-webkit-scrollbar{width:6px}.shortcuts-list::-webkit-scrollbar-track{background:transparent}.shortcuts-list::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}.shortcuts-list::-webkit-scrollbar-thumb:hover{background:#999}@media (prefers-color-scheme: dark){.shortcuts-list::-webkit-scrollbar-thumb{background:#444}.shortcuts-list::-webkit-scrollbar-thumb:hover{background:#555}}.ai-agent-panel{position:fixed;bottom:20px;right:20px;z-index:1000;font-family:Inter,system-ui,sans-serif}.ai-agent-toggle{display:flex;align-items:center;gap:8px;padding:12px 16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:24px;font-size:14px;font-weight:600;cursor:pointer;box-shadow:0 4px 12px #667eea66;transition:all .2s ease}.ai-agent-toggle:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea80}.ai-agent-toggle:active{transform:translateY(0)}.ai-icon{font-size:20px}.ai-label{font-size:14px}.ai-agent-panel.expanded{bottom:20px;right:20px;width:400px;max-height:600px}.ai-agent-panel.expanded .ai-agent-toggle{display:none}.ai-agent-content{display:flex;flex-direction:column;background:#fff;border-radius:16px;box-shadow:0 8px 32px #00000026;overflow:hidden;max-height:600px}.ai-agent-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.ai-agent-header h3{margin:0;font-size:18px;font-weight:600}.ai-agent-close{background:none;border:none;color:#fff;font-size:28px;line-height:1;cursor:pointer;padding:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s ease}.ai-agent-close:hover{background:#fff3}.ai-agent-history{flex:1;overflow-y:auto;padding:16px;background:#f8f9fa;min-height:200px;max-height:350px}.ai-agent-empty{color:#666;text-align:center;padding:20px}.ai-agent-empty p{margin:8px 0}.ai-agent-empty ul{list-style:none;padding:0;text-align:left;max-width:280px;margin:12px auto 0}.ai-agent-empty li{padding:6px 0;color:#888;font-size:13px;font-style:italic}.ai-message{margin-bottom:12px;padding:10px 14px;border-radius:12px;font-size:14px;line-height:1.5;animation:slideIn .2s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.ai-message-user{background:#667eea;color:#fff;margin-left:20px}.ai-message-agent{background:#fff;color:#333;margin-right:20px;border:1px solid #e1e4e8}.ai-message-error{background:#fee;border-color:#fcc;color:#c33}.ai-message-content{word-wrap:break-word}.ai-message-details{margin-top:8px;padding-top:8px;border-top:1px solid rgba(0,0,0,.1);font-size:12px;opacity:.8}.ai-detail{display:flex;flex-direction:column;gap:4px;margin-top:4px}.ai-detail code{background:#0000000d;padding:2px 6px;border-radius:4px;font-size:11px}.ai-detail-args{padding-left:12px;color:#666;font-family:Courier New,monospace;font-size:11px;word-break:break-all;opacity:.8}.ai-detail-result{font-size:11px;opacity:.7}.ai-message-loading{background:#fff;border:1px solid #e1e4e8;margin-right:20px}.ai-loading-dots{display:flex;gap:4px}.ai-loading-dots span{animation:blink 1.4s infinite both}.ai-loading-dots span:nth-child(2){animation-delay:.2s}.ai-loading-dots span:nth-child(3){animation-delay:.4s}@keyframes blink{0%,80%,to{opacity:.3}40%{opacity:1}}.ai-agent-examples{padding:12px 16px;background:#fff;border-top:1px solid #e1e4e8}.ai-examples-title{margin:0 0 8px;font-size:12px;color:#666;font-weight:500}.ai-examples-list{display:flex;flex-direction:column;gap:6px}.ai-example-button{padding:8px 12px;background:#f8f9fa;border:1px solid #e1e4e8;border-radius:8px;font-size:12px;color:#333;cursor:pointer;text-align:left;transition:all .2s ease}.ai-example-button:hover:not(:disabled){background:#e9ecef;border-color:#667eea;color:#667eea}.ai-example-button:disabled{opacity:.5;cursor:not-allowed}.ai-agent-input-form{display:flex;gap:8px;padding:16px;background:#fff;border-top:1px solid #e1e4e8}.ai-agent-input{flex:1;padding:10px 14px;border:2px solid #e1e4e8;border-radius:8px;font-size:14px;font-family:inherit;transition:border-color .2s ease}.ai-agent-input:focus{outline:none;border-color:#667eea}.ai-agent-input:disabled{background:#f8f9fa;cursor:not-allowed}.ai-agent-submit{padding:10px 16px;background:#667eea;color:#fff;border:none;border-radius:8px;font-size:16px;cursor:pointer;transition:all .2s ease;min-width:48px}.ai-agent-submit:hover:not(:disabled){background:#5568d3}.ai-agent-submit:disabled{opacity:.5;cursor:not-allowed}.ai-agent-actions{padding:8px 16px 12px;background:#fff;border-top:1px solid #e1e4e8}.ai-agent-clear{padding:6px 12px;background:transparent;border:1px solid #e1e4e8;border-radius:6px;font-size:12px;color:#666;cursor:pointer;transition:all .2s ease}.ai-agent-clear:hover:not(:disabled){background:#f8f9fa;border-color:#c33;color:#c33}.ai-agent-clear:disabled{opacity:.5;cursor:not-allowed}.ai-agent-status{padding:8px 16px;background:#f8f9fa;border-top:1px solid #e1e4e8;font-size:11px;color:#888;text-align:center}.ai-agent-history::-webkit-scrollbar{width:6px}.ai-agent-history::-webkit-scrollbar-track{background:#f1f1f1}.ai-agent-history::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}.ai-agent-history::-webkit-scrollbar-thumb:hover{background:#999}@media (max-width: 768px){.ai-agent-panel.expanded{width:calc(100vw - 40px);max-width:400px}}@media (max-height: 700px){.ai-agent-content{max-height:500px}.ai-agent-history{max-height:250px}}.ai-message-streaming .ai-cursor{margin-left:2px;animation:cursorBlink 1s infinite}@keyframes cursorBlink{0%,49%{opacity:1}50%,to{opacity:0}}.properties-panel{position:absolute;top:0;right:0;width:320px;height:100%;background:#fff;border-left:1px solid #e0e0e0;display:flex;flex-direction:column;overflow:hidden;box-shadow:-2px 0 8px #0000000d;z-index:10}.properties-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.25rem 1rem;border-bottom:1px solid #e0e0e0;background:#fafafa}.properties-header h3{font-size:1rem;font-weight:700;margin:0;color:#333}.shape-type-badge{display:inline-flex;align-items:center;justify-content:center;padding:4px 12px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:12px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.selection-badge{display:inline-flex;align-items:center;justify-content:center;padding:4px 12px;background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;border-radius:12px;font-size:.7rem;font-weight:700}.properties-warning{padding:.75rem 1.25rem;background:#fff3cd;border-bottom:1px solid #ffeaa7;color:#856404;font-size:.85rem;text-align:center}.properties-content{flex:1;overflow-y:auto;padding:1rem 0}.properties-content::-webkit-scrollbar{width:6px}.properties-content::-webkit-scrollbar-track{background:transparent}.properties-content::-webkit-scrollbar-thumb{background:#ddd;border-radius:3px}.properties-content::-webkit-scrollbar-thumb:hover{background:#ccc}.property-section{margin-bottom:1.5rem;padding:0 1.25rem}.section-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#999;margin:0 0 .75rem}.property-group{margin-bottom:1rem}.property-label{display:block;font-size:.85rem;font-weight:600;color:#666;margin-bottom:.5rem}.property-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.property-row label{flex:0 0 80px;font-size:.85rem;font-weight:500;color:#666}.property-input{flex:1;padding:.5rem .75rem;border:1px solid #ddd;border-radius:6px;font-size:.85rem;font-family:Inter,system-ui,sans-serif;background:#fff;transition:all .2s ease}.property-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.property-input:disabled{background:#f5f5f5;color:#999;cursor:not-allowed}.property-unit{flex:0 0 auto;font-size:.8rem;color:#999;font-weight:500}.property-textarea{width:100%;padding:.5rem .75rem;border:1px solid #ddd;border-radius:6px;font-size:.85rem;font-family:Inter,system-ui,sans-serif;background:#fff;resize:vertical;min-height:60px;transition:all .2s ease}.property-textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.property-textarea:disabled{background:#f5f5f5;color:#999;cursor:not-allowed}.color-picker-container{display:flex;align-items:center;gap:.75rem;flex:1}.color-input{width:50px;height:36px;border:1px solid #ddd;border-radius:6px;cursor:pointer;padding:2px;background:#fff;transition:all .2s ease}.color-input:hover{border-color:#667eea}.color-input:disabled{cursor:not-allowed;opacity:.5}.color-value{font-size:.8rem;color:#666;font-family:Monaco,Courier New,monospace;text-transform:uppercase}.color-swatches{display:grid;grid-template-columns:repeat(5,1fr);gap:.5rem;margin-top:.5rem}.color-swatch{width:100%;aspect-ratio:1;border:2px solid transparent;border-radius:6px;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #0000001a}.color-swatch:hover{transform:scale(1.1);box-shadow:0 3px 8px #0003}.color-swatch.active{border-color:#333;box-shadow:0 0 0 2px #fff,0 0 0 4px #667eea}.color-swatch:disabled{cursor:not-allowed;opacity:.5}.shapes-list{margin-top:1rem}.shape-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:#f8f8f8;border-radius:6px;margin-bottom:.5rem;font-size:.85rem}.shape-color-indicator{width:12px;height:12px;border-radius:50%;flex-shrink:0;border:2px solid white;box-shadow:0 0 0 1px #0000001a}.shape-type{font-weight:600;color:#333;text-transform:capitalize}.shape-position{margin-left:auto;color:#999;font-size:.8rem;font-family:Monaco,Courier New,monospace}.property-info{background:#f8f8f8;border-radius:6px;padding:.75rem}.info-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid #eee;font-size:.85rem}.info-item:last-child{border-bottom:none}.info-label{font-weight:600;color:#666}.info-value{color:#333;font-family:Monaco,Courier New,monospace;font-size:.8rem}.properties-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1.5rem;text-align:center;height:100%}.empty-icon{font-size:3rem;margin-bottom:1rem}@media (max-width: 1400px){.properties-panel{width:280px}}@media (max-width: 1024px){.properties-panel{width:260px}.color-swatches{grid-template-columns:repeat(4,1fr)}}@media (max-width: 768px){.properties-panel{display:none}}@media (prefers-color-scheme: dark){.properties-panel{background:#2a2a2a;border-left-color:#444}.properties-header{background:#1a1a1a;border-bottom-color:#444}.properties-header h3{color:#e0e0e0}.properties-warning{background:#664d03;border-bottom-color:#997404;color:#ffecb3}.section-title{color:#888}.property-row label,.property-label{color:#bbb}.property-input,.property-textarea{background:#333;border-color:#555;color:#e0e0e0}.property-input:focus,.property-textarea:focus{border-color:#667eea;background:#3a3a3a}.property-input:disabled,.property-textarea:disabled{background:#222;color:#666}.color-input{background:#333;border-color:#555}.color-value{color:#bbb}.color-swatch.active{border-color:#ddd}.shape-item{background:#333}.shape-type{color:#e0e0e0}.shape-position{color:#888}.property-info{background:#333}.info-item{border-bottom-color:#444}.info-label{color:#bbb}.info-value,.empty-title{color:#e0e0e0}.empty-subtitle{color:#888}}.presence-panel{width:280px;height:100%;background:#fff;border-left:1px solid #e0e0e0;display:flex;flex-direction:column;overflow:hidden;box-shadow:-2px 0 8px #0000000d}.presence-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.25rem 1rem;border-bottom:1px solid #e0e0e0;background:#fafafa}.presence-header h3{font-size:1rem;font-weight:700;margin:0;color:#333}.user-count-badge{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 8px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:12px;font-size:.75rem;font-weight:700}.presence-list{flex:1;overflow-y:auto;padding:1rem 0}.presence-list::-webkit-scrollbar{width:6px}.presence-list::-webkit-scrollbar-track{background:transparent}.presence-list::-webkit-scrollbar-thumb{background:#ddd;border-radius:3px}.presence-list::-webkit-scrollbar-thumb:hover{background:#ccc}.presence-section{margin-bottom:1.5rem}.section-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#999;margin:0 0 .75rem;padding:0 1.25rem}.presence-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.25rem;transition:background .15s ease;cursor:default}.presence-item:hover{background:#f8f8f8}.presence-item.others-count{background:#f8f8f8;border:1px solid #e0e0e0;border-radius:8px;margin:0 1.25rem;padding:.75rem 1rem;cursor:default}.users-stack{display:flex;align-items:center;position:relative}.stack-circle{width:12px;height:12px;border-radius:50%;border:2px solid white;box-shadow:0 0 0 1px #0000001a;flex-shrink:0}.presence-item.offline{opacity:.6}.presence-item.current-user{background:linear-gradient(135deg,#667eea14,#764ba214)}.presence-item.current-user:hover{background:linear-gradient(135deg,#667eea1f,#764ba21f)}.status-indicator{width:12px;height:12px;border-radius:50%;flex-shrink:0;position:relative}.status-indicator.online{box-shadow:0 0 0 2px #fff,0 0 8px #00000026}.status-indicator.online:after{content:"";position:absolute;inset:-4px;border:2px solid currentColor;border-radius:50%;opacity:0;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:0}50%{transform:scale(1.5);opacity:.3}}.status-indicator.offline{background:#999!important;box-shadow:none}.user-details{display:flex;flex-direction:column;gap:.15rem;flex:1;min-width:0}.user-name{font-size:.9rem;font-weight:600;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-badge{display:inline-block;font-size:.7rem;font-weight:700;color:#667eea;text-transform:uppercase;letter-spacing:.3px}.user-status-text{font-size:.75rem;color:#999}.presence-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1.25rem;color:#999}.presence-spinner{width:32px;height:32px;border:3px solid #f0f0f0;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite;margin-bottom:.75rem}.presence-loading p{font-size:.85rem;margin:0}.presence-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1.25rem;text-align:center}.presence-error .error-icon{font-size:2rem;margin-bottom:.5rem}.presence-error p{font-size:.85rem;color:#666;margin:0}.presence-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1.5rem;text-align:center}.empty-icon{font-size:3rem;margin-bottom:1rem;animation:wave 2s ease-in-out infinite}@keyframes wave{0%,to{transform:rotate(0)}10%,30%{transform:rotate(14deg)}20%{transform:rotate(-8deg)}40%{transform:rotate(-4deg)}50%{transform:rotate(10deg)}60%{transform:rotate(0)}}.empty-title{font-size:.95rem;font-weight:600;color:#333;margin:0 0 .5rem}.empty-subtitle{font-size:.8rem;color:#999;line-height:1.4;margin:0}@media (max-width: 1024px){.presence-panel{width:240px}}@media (max-width: 768px){.presence-panel{display:none}}@media (prefers-color-scheme: dark){.presence-panel{background:#2a2a2a;border-left-color:#444}.presence-header{background:#1a1a1a;border-bottom-color:#444}.presence-header h3{color:#e0e0e0}.presence-item:hover{background:#333}.presence-item.current-user{background:linear-gradient(135deg,#667eea26,#764ba226)}.presence-item.current-user:hover{background:linear-gradient(135deg,#667eea33,#764ba233)}.presence-item.others-count{background:#333;border-color:#555}.stack-circle{border-color:#2a2a2a}.section-title{color:#888}.user-name{color:#e0e0e0}.user-status-text,.presence-loading{color:#888}.presence-spinner{border-color:#444;border-top-color:#667eea}.presence-error p{color:#999}.empty-title{color:#e0e0e0}.empty-subtitle{color:#888}}.app-container{display:flex;flex-direction:column;width:100%;height:100vh;background:#f5f5f5;overflow:hidden;position:relative}.connection-banner{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;z-index:1000;font-size:.9rem;font-weight:600;animation:slideDown .3s ease-out}.connection-banner.offline{background:linear-gradient(135deg,#ff6b6b,#ee5a6f);color:#fff;box-shadow:0 2px 8px #ff6b6b4d}.connection-banner .banner-icon{font-size:1.1rem;animation:pulse 2s ease-in-out infinite}.connection-banner .banner-text{letter-spacing:.3px}.connection-toast{position:fixed;top:1rem;right:1rem;display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;border-radius:8px;font-size:.9rem;font-weight:600;z-index:1000;box-shadow:0 4px 12px #00000026;animation:slideInRight .3s ease-out,fadeOut .3s ease-in 2.7s forwards}.connection-toast.connected{background:linear-gradient(135deg,#52b788,#40916c);color:#fff}.connection-toast .toast-icon{font-size:1.1rem;font-weight:700}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes slideInRight{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0;transform:translate(400px)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.app-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.loading-spinner{width:48px;height:48px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite;margin-bottom:1rem}@keyframes spin{to{transform:rotate(360deg)}}.app-loading p{font-size:1.1rem;font-weight:500;margin:0}.app-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 2rem;background:#fff;border-bottom:1px solid #e0e0e0;box-shadow:0 2px 4px #0000000d;flex-wrap:wrap}.online-users{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.user-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.9rem;font-weight:600;box-shadow:0 2px 6px #00000026;border:2px solid white;cursor:pointer;transition:all .2s ease;position:relative}.user-avatar:hover{transform:scale(1.1);box-shadow:0 3px 8px #0003;z-index:10}.user-avatar.current-user-avatar{border:2px solid #667eea;box-shadow:0 2px 6px #667eea4d}.user-avatar-more{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#666;color:#fff;font-size:.75rem;font-weight:700;box-shadow:0 2px 6px #00000026;border:2px solid white;cursor:pointer;transition:all .2s ease;position:relative}.user-avatar-more:hover{transform:scale(1.1);box-shadow:0 3px 8px #0003;background:#555}.more-users-tooltip{background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;padding:.5rem;min-width:200px;max-width:300px;z-index:9999;border:1px solid #e0e0e0;position:fixed;pointer-events:auto}.tooltip-arrow{position:absolute;top:-6px;left:50%;transform:translate(-50%);width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-bottom:6px solid white;z-index:1}.tooltip-arrow:after{content:"";position:absolute;top:2px;left:-5px;width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-bottom:5px solid #e0e0e0}.tooltip-user{display:flex;align-items:center;gap:.5rem;padding:.25rem .5rem;border-radius:4px;transition:background .15s ease}.tooltip-user:hover{background:#f5f5f5}.tooltip-user-avatar{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.7rem;font-weight:600;flex-shrink:0}.tooltip-user-name{font-size:.85rem;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-header h1{font-size:1.5rem;font-weight:700;margin:0;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.user-info{display:flex;align-items:center;gap:1rem}.username{font-size:.95rem;font-weight:500;color:#333}.logout-button{padding:.5rem 1rem;background:#fff;border:2px solid #667eea;color:#667eea;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease}.logout-button:hover{background:#667eea;color:#fff}.logout-button:active{transform:scale(.98)}.app-content{flex:1;display:flex;overflow:hidden;min-height:0}.app-main{flex:1;display:flex;align-items:center;justify-content:center;overflow:hidden;min-height:0}.app-main.has-padding{padding:2rem}.canvas-placeholder{text-align:center;max-width:600px;padding:3rem;background:#fff;border-radius:16px;box-shadow:0 4px 12px #0000001a}.canvas-placeholder h2{font-size:2rem;font-weight:700;margin:0 0 1rem;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.canvas-placeholder p{font-size:1.1rem;color:#666;margin:.5rem 0}.placeholder-text{margin-top:1.5rem;padding:1rem;background:#f5f5f5;border-radius:8px;font-size:.95rem!important;color:#999!important}@media (max-width: 768px){.app-header{padding:.75rem 1rem;gap:.5rem;align-items:center}.app-header h1{font-size:1.25rem;flex:1;order:1}.online-users{order:2;gap:.3rem}.user-avatar{width:32px;height:32px;font-size:.8rem}.user-avatar-more{width:32px;height:32px;font-size:.7rem}.more-users-tooltip{min-width:180px;max-width:250px;font-size:.9rem}.tooltip-user-avatar{width:20px;height:20px;font-size:.65rem}.user-info{order:3;gap:.5rem}.username{font-size:.85rem}.logout-button{font-size:.85rem;padding:.4rem .8rem}.app-main.has-padding{padding:1rem}.canvas-placeholder{padding:2rem 1.5rem}.canvas-placeholder h2{font-size:1.5rem}}@media (prefers-color-scheme: dark){.app-container{background:#1a1a1a}.app-header{background:#2a2a2a;border-bottom-color:#444}.user-avatar,.user-avatar-more{border-color:#2a2a2a}.more-users-tooltip{background:#2a2a2a;border-color:#444}.tooltip-arrow{border-bottom-color:#2a2a2a}.tooltip-arrow:after{border-bottom-color:#444}.tooltip-user:hover{background:#333}.tooltip-user-name,.username{color:#e0e0e0}.logout-button{background:#2a2a2a}.logout-button:hover{background:#667eea;color:#fff}.canvas-placeholder{background:#2a2a2a;color:#e0e0e0}.canvas-placeholder p{color:#999}.placeholder-text{background:#1a1a1a!important}}
