:root{--color-primary: #0969da;--color-primary-hover: #0860ca;--color-danger: #dc2626;--color-success: #16a34a;--color-bg: #ffffff;--color-bg-secondary: #f9fafb;--color-canvas: #f4f4f5;--color-text: #18181b;--color-text-secondary: #71717a;--color-text-tertiary: #a1a1aa;--color-border: #e4e4e7;--color-border-hover: #d4d4d8;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 8px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 16px rgba(0, 0, 0, .12);--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{margin:0;font-family:var(--font-sans);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:var(--color-text);background:var(--color-bg-secondary)}button{font-family:inherit;font-size:inherit}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#d4d4d8;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a1a1aa}::selection{background:#0969da33}.homepage{min-height:100vh;background:linear-gradient(180deg,#fff,#f9fafb);display:flex;align-items:center;justify-content:center;padding:24px}.homepage-container{width:100%;max-width:1200px;display:flex;flex-direction:column;gap:48px}.homepage-header{display:flex;align-items:center;justify-content:space-between;padding:16px 0}.logo{display:flex;align-items:center;gap:12px}.logo-text{font-size:20px;font-weight:700;color:var(--color-text)}.hero{text-align:center;padding:80px 0;display:flex;flex-direction:column;align-items:center;gap:32px}.hero-title{font-size:64px;font-weight:700;line-height:1.1;color:var(--color-text);letter-spacing:-.02em}.hero-subtitle{font-size:20px;line-height:1.6;color:var(--color-text-secondary);max-width:600px}.hero-actions{display:flex;flex-direction:column;align-items:center;gap:16px;width:100%;max-width:480px}.join-canvas{display:flex;gap:8px;width:100%}.join-canvas .input{flex:1}.features{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:32px;padding:48px 0}.feature{display:flex;flex-direction:column;align-items:center;text-align:center;gap:16px;padding:32px;background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);border:1px solid var(--color-border);transition:all .2s ease}.feature:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.feature-icon{width:64px;height:64px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center}.feature h3{font-size:20px;font-weight:600;color:var(--color-text)}.feature p{font-size:15px;line-height:1.5;color:var(--color-text-secondary);max-width:300px}.homepage-footer{padding:32px 0;text-align:center;border-top:1px solid var(--color-border)}.homepage-footer p{font-size:14px;color:var(--color-text-tertiary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border:none;border-radius:var(--radius-md);font-size:15px;font-weight:500;cursor:pointer;transition:all .15s ease;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover)}.btn-secondary{background:#fff;color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover:not(:disabled){background:var(--color-bg-secondary);border-color:var(--color-border-hover)}.btn-lg{padding:14px 32px;font-size:16px;border-radius:10px}.input{padding:10px 16px;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:15px;font-family:inherit;color:var(--color-text);background:#fff;transition:all .15s ease}.input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #0969da1a}.input::placeholder{color:var(--color-text-tertiary)}@media(max-width:768px){.hero-title{font-size:42px}.hero-subtitle{font-size:18px}.features{grid-template-columns:1fr}}.color-picker-container{position:relative}.color-picker-trigger{width:32px;height:32px;border:2px solid #e0e0e0;border-radius:6px;cursor:pointer;transition:all .15s ease;padding:0}.color-picker-trigger:hover{transform:scale(1.1);border-color:var(--color-primary)}.color-picker-dropdown{position:absolute;top:calc(100% + 8px);left:0;min-width:240px;background:#fff;border-radius:12px;box-shadow:0 4px 16px #0000001f,0 0 0 1px #0000000a;padding:12px;z-index:1001}.color-picker-section{margin-bottom:12px}.color-picker-section:last-child{margin-bottom:0}.color-picker-label{font-size:12px;font-weight:600;color:var(--color-text-secondary);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.color-picker-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:6px}.color-preset-btn{width:32px;height:32px;border:2px solid transparent;border-radius:6px;cursor:pointer;transition:all .15s ease;padding:0}.color-preset-btn:hover{transform:scale(1.1)}.color-preset-btn.active{border-color:var(--color-primary);box-shadow:0 0 0 2px #fff,0 0 0 4px var(--color-primary)}.color-picker-custom{display:flex;gap:8px;align-items:center}.color-input{width:40px;height:40px;border:2px solid #e0e0e0;border-radius:6px;cursor:pointer;padding:0}.color-text-input{flex:1;padding:8px 12px;border:1px solid var(--color-border);border-radius:6px;font-size:14px;font-family:Monaco,Courier New,monospace;transition:all .15s ease}.color-text-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #0969da1a}.tooltip-wrapper{position:relative;display:inline-flex}.tooltip-content{position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%);background:#18181b;color:#fff;padding:6px 10px;border-radius:6px;font-size:12px;font-weight:500;white-space:nowrap;pointer-events:none;opacity:0;visibility:hidden;transition:opacity .2s ease,visibility .2s ease,transform .2s ease;z-index:10000;box-shadow:0 2px 8px #0003,0 1px 3px #0000001a;display:flex;align-items:center;gap:8px}.tooltip-content:before{content:"";position:absolute;bottom:100%;left:50%;transform:translate(-50%);border:4px solid transparent;border-bottom-color:#18181b}.tooltip-wrapper:hover .tooltip-content{opacity:1;visibility:visible;transform:translate(-50%) translateY(2px)}.tooltip-shortcut{padding:2px 6px;background:#ffffff26;border-radius:4px;font-size:11px;font-weight:600;font-family:SF Mono,Monaco,Consolas,monospace}.tooltip-wrapper.tooltip-top .tooltip-content{top:auto;bottom:calc(100% + 8px);transform:translate(-50%)}.tooltip-wrapper.tooltip-top .tooltip-content:before{bottom:auto;top:100%;border-bottom-color:transparent;border-top-color:#18181b}.tooltip-wrapper.tooltip-top:hover .tooltip-content{transform:translate(-50%) translateY(-2px)}.opacity-slider-container{display:flex;align-items:center;gap:8px;padding:4px 8px;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;min-width:150px}.opacity-label{display:flex;align-items:center;gap:4px;font-size:13px;font-weight:500;color:#374151;white-space:nowrap}.opacity-label svg{flex-shrink:0}.opacity-slider{flex:1;height:6px;border-radius:3px;background:linear-gradient(to right,transparent 0%,#374151 100%);appearance:none;cursor:pointer;outline:none}.opacity-slider::-webkit-slider-thumb{appearance:none;width:16px;height:16px;border-radius:50%;background:#fff;border:2px solid #0D99FF;cursor:pointer;box-shadow:0 2px 4px #0003}.opacity-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:#fff;border:2px solid #0D99FF;cursor:pointer;box-shadow:0 2px 4px #0003}.opacity-slider::-webkit-slider-thumb:hover{transform:scale(1.1)}.opacity-slider::-moz-range-thumb:hover{transform:scale(1.1)}.stroke-width-picker{position:relative}.stroke-width-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:transparent;border:none;border-radius:8px;cursor:pointer;color:#374151;transition:all .2s ease}.stroke-width-btn:hover{background:#0000000a}.stroke-width-menu{position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%);min-width:180px;background:#fff;border-radius:12px;box-shadow:0 4px 16px #0000001f,0 0 0 1px #0000000a;padding:6px;z-index:1001}.stroke-width-option{display:flex;align-items:center;justify-content:space-between;width:100%;padding:8px 12px;background:transparent;border:none;border-radius:6px;cursor:pointer;font-size:13px;color:#374151;transition:all .15s ease;gap:12px}.stroke-width-option:hover{background:#0000000a}.stroke-width-option.active{background:#0d99ff;color:#fff}.stroke-width-option svg{flex-shrink:0}.stroke-width-label{font-weight:500;white-space:nowrap;min-width:36px;text-align:right}.sticky-color-picker{position:relative}.sticky-color-trigger{width:32px;height:32px;border:2px solid #e0e0e0;border-radius:6px;cursor:pointer;transition:all .15s ease;padding:0;box-shadow:0 2px 4px #0000001a}.sticky-color-trigger:hover{transform:scale(1.1);border-color:#0d99ff}.sticky-color-dropdown{position:absolute;top:calc(100% + 8px);left:0;min-width:220px;background:#fff;border-radius:12px;box-shadow:0 4px 16px #0000001f,0 0 0 1px #0000000a;padding:12px;z-index:1001}.sticky-color-label{font-size:11px;font-weight:600;color:#666;margin-bottom:10px;text-transform:uppercase;letter-spacing:.5px}.sticky-color-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.sticky-color-btn{width:44px;height:44px;border:2px solid transparent;border-radius:8px;cursor:pointer;transition:all .15s ease;padding:0;box-shadow:0 2px 4px #0000001a;display:flex;align-items:center;justify-content:center}.sticky-color-btn:hover{transform:scale(1.1);box-shadow:0 4px 8px #00000026}.sticky-color-btn.active{border-color:#0d99ff;box-shadow:0 0 0 2px #fff,0 0 0 4px #0d99ff,0 4px 8px #00000026}.arrow-style-picker{position:relative}.arrow-style-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:transparent;border:none;border-radius:8px;cursor:pointer;color:#374151;transition:all .2s ease}.arrow-style-btn:hover{background:#0000000a}.arrow-icon{font-size:20px;font-weight:700}.arrow-style-menu{position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%);min-width:200px;background:#fff;border-radius:12px;box-shadow:0 4px 16px #0000001f,0 0 0 1px #0000000a;padding:12px;z-index:1001}.arrow-style-section{margin-bottom:12px}.arrow-style-section:last-child{margin-bottom:0}.arrow-style-label{font-size:11px;font-weight:600;color:#666;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.arrow-style-grid{display:flex;flex-direction:column;gap:4px}.arrow-style-option{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;background:transparent;border:none;border-radius:6px;cursor:pointer;font-size:13px;color:#374151;transition:all .15s ease}.arrow-style-option:hover{background:#0000000a}.arrow-style-option.active{background:#0d99ff;color:#fff}.arrow-option-icon{font-size:18px;font-weight:700;width:24px;text-align:center}.arrow-option-name{font-weight:500}.text-formatting{display:flex;align-items:center;gap:4px;padding:4px 8px;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a}.text-format-btn{display:flex;align-items:center;justify-content:center;min-width:32px;height:32px;padding:0 8px;background:transparent;border:none;border-radius:6px;cursor:pointer;color:#374151;font-size:14px;font-weight:500;transition:all .15s ease}.text-format-btn:hover{background:#0000000a}.text-format-btn.active{background:#0d99ff;color:#fff}.text-format-btn.toggle-btn{font-size:15px;font-weight:600}.text-format-divider{width:1px;height:20px;background:#e0e0e0;margin:0 4px}.text-format-dropdown{position:relative}.dropdown-btn{gap:6px}.font-family-label{max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.size-btn{min-width:56px;justify-content:space-between}.text-format-menu{position:absolute;top:calc(100% + 4px);left:0;min-width:120px;max-height:300px;overflow-y:auto;background:#fff;border-radius:8px;box-shadow:0 4px 16px #0000001f,0 0 0 1px #0000000a;padding:4px;z-index:1001}.text-format-menu-item{display:block;width:100%;padding:8px 12px;background:transparent;border:none;border-radius:4px;cursor:pointer;text-align:left;font-size:14px;color:#374151;transition:all .15s ease}.text-format-menu-item:hover{background:#0000000a}.text-format-menu-item.active{background:#0d99ff;color:#fff}.align-btn svg{opacity:.8}.align-btn.active svg{opacity:1}.toolbar-container{position:fixed;top:20px;left:50%;transform:translate(-50%);z-index:1000;display:flex;flex-direction:column;align-items:center;gap:8px;pointer-events:none}.toolbar{display:flex;align-items:center;gap:4px;padding:8px 12px;background:#fff;border-radius:16px;box-shadow:0 1px 2px #0000000a,0 2px 6px #0000000f,0 4px 12px #00000014,0 0 0 .5px #0000000a;pointer-events:auto;transition:box-shadow .2s ease}.toolbar:hover{box-shadow:0 2px 4px #0000000f,0 4px 8px #00000014,0 8px 16px #0000001a,0 0 0 .5px #0000000a}.toolbar-section{display:flex;align-items:center;gap:4px}.toolbar-section+.toolbar-section{margin-left:4px;padding-left:8px;border-left:1px solid #e0e0e0}.toolbar-btn{display:flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 8px;background:transparent;border:none;border-radius:8px;cursor:pointer;color:#374151;font-size:14px;font-weight:500;transition:all .2s cubic-bezier(.4,0,.2,1);position:relative}.toolbar-btn:hover:not(:disabled):not(.active){background:#0000000a;transform:scale(1.05)}.toolbar-btn:active:not(:disabled){transform:scale(.95)}.toolbar-btn.active{background:#0d99ff;color:#fff;box-shadow:0 1px 3px #0d99ff4d,inset 0 1px #ffffff26}.toolbar-btn.active:hover{background:#0b8ae6;transform:scale(1.02)}.toolbar-btn:disabled{opacity:.3;cursor:not-allowed;transform:none!important}.toolbar-btn.icon-btn{min-width:36px;width:36px}.toolbar-btn.delete-btn:hover:not(:disabled){background:#fee;color:#dc2626}.toolbar-btn.export-btn{background:#0969da;color:#fff}.toolbar-btn.export-btn:hover{background:#0860ca}.color-btn{width:28px;height:28px;border:2px solid transparent;border-radius:6px;cursor:pointer;transition:all .15s ease;position:relative;padding:0}.color-btn:hover{transform:scale(1.1)}.color-btn.active{border-color:#0969da;box-shadow:0 0 0 2px #fff,0 0 0 4px #0969da}.export-dropdown{position:relative}.export-menu{position:absolute;top:calc(100% + 8px);right:0;min-width:180px;background:#fff;border-radius:12px;box-shadow:0 4px 16px #0000001f,0 0 0 1px #0000000a;padding:6px;z-index:1001}.export-menu button{display:block;width:100%;padding:10px 12px;text-align:left;background:transparent;border:none;border-radius:6px;cursor:pointer;font-size:14px;color:#18181b;transition:background .15s ease}.export-menu button:hover{background:#f4f4f5}.export-menu-divider{height:1px;background:#e4e4e7;margin:6px 0}.selection-info{padding:6px 16px;background:#18181b;color:#fff;border-radius:20px;font-size:13px;font-weight:600;box-shadow:0 2px 6px #00000026,0 1px 3px #0000001a;pointer-events:auto;animation:slideInDown .2s cubic-bezier(.4,0,.2,1)}@keyframes slideInDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.toolbar-btn.ai-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.toolbar-btn.ai-btn:hover:not(:disabled){background:linear-gradient(135deg,#5568d3,#63408b);transform:scale(1.05)}.toolbar-divider{width:1px;height:24px;background:#e0e0e0;margin:0 4px}@media(max-width:768px){.toolbar{flex-wrap:wrap;max-width:90vw}.toolbar-section+.toolbar-section{margin-left:0;padding-left:0;border-left:none}}.zoom-controls{position:fixed;bottom:20px;right:20px;display:flex;align-items:center;gap:2px;background:#fff;border-radius:10px;padding:6px;box-shadow:0 2px 8px #00000014,0 0 0 1px #0000000a;z-index:100}.zoom-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:none;border-radius:6px;cursor:pointer;color:var(--color-text);transition:all .15s ease}.zoom-btn:hover{background:var(--color-bg-secondary)}.zoom-level{display:flex;align-items:center;justify-content:center;min-width:52px;height:32px;padding:0 8px;background:transparent;border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;color:var(--color-text-secondary);transition:all .15s ease}.zoom-level:hover{background:var(--color-bg-secondary);color:var(--color-text)}.zoom-divider{width:1px;height:20px;background:var(--color-border);margin:0 2px}.minimap-container{position:fixed;bottom:20px;left:20px;background:#fff;border-radius:10px;padding:8px;box-shadow:0 2px 8px #00000014,0 0 0 1px #0000000a;z-index:100;-webkit-user-select:none;user-select:none}.minimap-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;padding:0 2px}.minimap-title{font-size:11px;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.5px}.minimap-toggle{width:20px;height:20px;border:none;background:#f0f0f0;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#666;transition:all .15s ease}.minimap-toggle:hover{background:#e0e0e0;color:#333}.minimap-toggle:active{transform:scale(.95)}.minimap-canvas{display:block;border-radius:6px;cursor:grab;background:var(--color-canvas, #f8f9fa);transition:box-shadow .15s ease}.minimap-canvas:hover{box-shadow:0 0 0 2px #06f3}.minimap-canvas.dragging{cursor:grabbing;box-shadow:0 0 0 2px #06f6}.context-menu-overlay{position:fixed;inset:0;z-index:999}.context-menu{position:fixed;min-width:180px;background:#fff;border-radius:8px;box-shadow:0 4px 16px #00000026;padding:4px;z-index:1000}.context-menu button{display:flex;align-items:center;justify-content:space-between;width:100%;padding:8px 12px;background:transparent;border:none;border-radius:4px;text-align:left;font-size:14px;color:#374151;cursor:pointer;transition:background .15s}.context-menu button:hover{background:#0000000a}.context-menu button.danger{color:#ef4444}.context-menu button span{font-size:12px;color:#9ca3af;font-family:Monaco,monospace}.context-menu-divider{height:1px;background:#e5e7eb;margin:4px 0}.search-toggle-btn{position:fixed;top:20px;right:20px;background:#fff;border:2px solid #e0e0e0;border-radius:8px;padding:10px 16px;font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:6px;z-index:100;box-shadow:0 2px 8px #0000001a;transition:all .2s ease}.search-toggle-btn:hover{background:#f5f5f5;border-color:#4ecdc4;transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.search-panel{position:fixed;top:20px;right:20px;width:380px;max-height:80vh;background:#fff;border:2px solid #e0e0e0;border-radius:12px;box-shadow:0 8px 32px #00000026;z-index:100;display:flex;flex-direction:column;overflow:hidden}.search-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #e0e0e0;background:#f8f9fa}.search-header h3{margin:0;font-size:16px;font-weight:600;color:#2c3e50}.close-btn{background:none;border:none;font-size:20px;color:#95a5a6;cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .2s ease}.close-btn:hover{background:#e0e0e0;color:#2c3e50}.search-input-container{padding:16px 20px;border-bottom:1px solid #e0e0e0}.search-input{width:100%;padding:10px 12px;border:2px solid #e0e0e0;border-radius:8px;font-size:14px;outline:none;transition:border-color .2s ease}.search-input:focus{border-color:#4ecdc4}.filter-buttons{display:flex;gap:8px;padding:12px 20px;border-bottom:1px solid #e0e0e0;background:#f8f9fa;overflow-x:auto}.filter-btn{padding:6px 12px;border:1px solid #e0e0e0;background:#fff;border-radius:6px;font-size:13px;cursor:pointer;white-space:nowrap;transition:all .2s ease}.filter-btn:hover{background:#f0f0f0}.filter-btn.active{background:#4ecdc4;color:#fff;border-color:#4ecdc4}.search-results{flex:1;overflow-y:auto;padding:12px 0}.search-placeholder,.no-results{text-align:center;padding:40px 20px;color:#95a5a6}.search-placeholder p:first-child{font-size:16px;margin-bottom:8px}.search-placeholder .hint{font-size:13px;color:#b0b0b0}.no-results p{font-size:14px}.results-list{padding:0 12px}.results-count{font-size:12px;color:#95a5a6;margin:0 8px 12px;font-weight:500}.result-item{display:flex;align-items:flex-start;gap:12px;padding:12px;margin-bottom:8px;border-radius:8px;cursor:pointer;transition:all .2s ease;border:1px solid transparent}.result-item:hover{background:#f8f9fa;border-color:#4ecdc4}.result-icon{font-size:20px;flex-shrink:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#f0f0f0;border-radius:6px}.result-content{flex:1;min-width:0}.result-title{font-size:13px;font-weight:600;color:#2c3e50;margin-bottom:4px;text-transform:capitalize}.result-text{font-size:13px;color:#555;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.result-meta{font-size:11px;color:#95a5a6}.search-results::-webkit-scrollbar{width:6px}.search-results::-webkit-scrollbar-track{background:transparent}.search-results::-webkit-scrollbar-thumb{background:#d0d0d0;border-radius:3px}.search-results::-webkit-scrollbar-thumb:hover{background:#b0b0b0}
