.layout{display:flex;flex-direction:column;height:100vh}.header{display:flex;align-items:center;justify-content:space-between;padding:0 24px;height:64px;background:#fff;border-bottom:1px solid #e0e0e0;box-shadow:0 2px 4px #0000000d}.logo{display:flex;align-items:center;gap:12px}.logo h1{font-size:24px;font-weight:700;color:#2c3e50;margin:0}.tagline{font-size:14px;color:#7f8c8d}.nav{display:flex;gap:8px}.nav-link{padding:8px 16px;border-radius:6px;text-decoration:none;color:#34495e;font-size:14px;font-weight:500;transition:all .2s ease}.nav-link:hover{background:#f5f5f5}.nav-link.active{background:#3498db;color:#fff}.main{flex:1;overflow:hidden}.toolbar{display:flex;align-items:center;gap:24px;padding:12px 24px;background:#fff;border-bottom:1px solid #e0e0e0;flex-wrap:wrap}.toolbar-section{display:flex;flex-direction:column;gap:8px}.toolbar-label{font-size:12px;color:#7f8c8d;font-weight:500}.brush-types{display:flex;gap:8px}.brush-type-btn{width:40px;height:40px;border:2px solid #e0e0e0;border-radius:8px;background:#fff;cursor:pointer;font-size:20px;transition:all .2s ease}.brush-type-btn:hover{border-color:#3498db;background:#f0f8ff}.brush-type-btn.active{border-color:#3498db;background:#3498db;color:#fff}.color-picker{display:flex;gap:6px;align-items:center}.color-btn{width:28px;height:28px;border:2px solid #e0e0e0;border-radius:50%;cursor:pointer;transition:all .2s ease}.color-btn:hover{transform:scale(1.1)}.color-btn.active{border-color:#3498db;box-shadow:0 0 0 2px #3498db}.color-input{width:32px;height:32px;border:2px solid #e0e0e0;border-radius:50%;cursor:pointer;padding:0}.size-slider,.opacity-slider{width:150px;height:6px;border-radius:3px;background:#e0e0e0;outline:none;cursor:pointer}.toolbar-actions{flex-direction:row;align-items:center;margin-left:auto}.action-btn{padding:8px 16px;border:1px solid #e0e0e0;border-radius:6px;background:#fff;color:#34495e;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.action-btn:hover{background:#f5f5f5;border-color:#3498db;color:#3498db}.canvas-settings-panel{position:fixed;top:76px;left:24px;width:360px;background:#fff;border-radius:12px;box-shadow:0 8px 24px #00000026;z-index:1000;overflow:hidden}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #e0e0e0}.panel-header h2{font-size:18px;font-weight:600;color:#2c3e50;margin:0}.panel-header .close-btn{width:28px;height:28px;border:none;background:#f5f5f5;border-radius:50%;cursor:pointer;font-size:16px;color:#7f8c8d;transition:all .2s ease}.panel-header .close-btn:hover{background:#e0e0e0;color:#2c3e50}.panel-content{padding:20px;max-height:calc(100vh - 200px);overflow-y:auto}.settings-group{margin-bottom:24px}.settings-group:last-child{margin-bottom:0}.settings-label{display:block;font-size:14px;font-weight:600;color:#2c3e50;margin-bottom:12px}.size-options{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.size-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:12px 8px;border:2px solid #e0e0e0;border-radius:8px;background:#fff;cursor:pointer;transition:all .2s ease;font-size:14px;font-weight:500;color:#2c3e50}.size-btn:hover{border-color:#3498db;background:#f0f8ff}.size-btn.active{border-color:#3498db;background:#3498db;color:#fff}.size-dimensions{font-size:11px;opacity:.8}.background-types{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.bg-type-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:12px 8px;border:2px solid #e0e0e0;border-radius:8px;background:#fff;cursor:pointer;transition:all .2s ease;font-size:14px;font-weight:500;color:#2c3e50}.bg-type-btn:hover{border-color:#3498db;background:#f0f8ff}.bg-type-btn.active{border-color:#3498db;background:#3498db;color:#fff}.background-colors{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.bg-color-btn{width:32px;height:32px;border:2px solid #e0e0e0;border-radius:50%;cursor:pointer;transition:all .2s ease}.bg-color-btn:hover{transform:scale(1.1)}.bg-color-btn.active{border-color:#3498db;box-shadow:0 0 0 2px #3498db}.color-input{width:36px;height:36px;border:2px solid #e0e0e0;border-radius:50%;cursor:pointer;padding:0}.materials-panel{position:fixed;top:76px;left:24px;width:360px;background:#fff;border-radius:12px;box-shadow:0 8px 24px #00000026;z-index:1000;overflow:hidden}.materials-panel .panel-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #e0e0e0}.materials-panel .panel-header h2{font-size:18px;font-weight:600;color:#2c3e50;margin:0}.materials-panel .panel-header .close-btn{width:28px;height:28px;border:none;background:#f5f5f5;border-radius:50%;cursor:pointer;font-size:16px;color:#7f8c8d;transition:all .2s ease}.materials-panel .panel-header .close-btn:hover{background:#e0e0e0;color:#2c3e50}.materials-panel .panel-content{padding:20px;max-height:calc(100vh - 200px);overflow-y:auto}.category-tabs{display:flex;gap:8px;margin-bottom:16px;border-bottom:2px solid #e0e0e0;padding-bottom:8px}.category-tab{flex:1;padding:8px 12px;border:none;background:transparent;cursor:pointer;font-size:14px;font-weight:500;color:#7f8c8d;transition:all .2s ease;border-radius:6px}.category-tab:hover{background:#f5f5f5;color:#2c3e50}.category-tab.active{background:#3498db;color:#fff}.materials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.material-card{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 8px;border:2px solid #e0e0e0;border-radius:8px;background:#fff;transition:all .2s ease}.material-card:hover{border-color:#3498db;background:#f0f8ff;transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.material-icon{font-size:32px;margin-bottom:4px}.material-name{font-size:12px;font-weight:500;color:#2c3e50;text-align:center}.add-btn{padding:6px 16px;border:1px solid #3498db;border-radius:4px;background:#3498db;color:#fff;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease}.add-btn:hover{background:#2980b9;border-color:#2980b9}.collaborators-panel{position:fixed;bottom:24px;left:24px;width:280px;background:#fff;border-radius:12px;box-shadow:0 8px 24px #00000026;z-index:1000;overflow:hidden}.collaborators-panel .panel-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #e0e0e0}.connection-status{display:flex;align-items:center;gap:8px}.status-dot{width:8px;height:8px;border-radius:50%;background:#bdc3c7;transition:all .2s ease}.status-dot.online{background:#27ae60;box-shadow:0 0 0 2px #d4edda}.status-dot.offline{background:#bdc3c7}.status-text{font-size:12px;color:#7f8c8d;font-weight:500}.invite-btn{padding:6px 16px;border:1px solid #3498db;border-radius:6px;background:#3498db;color:#fff;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease}.invite-btn:hover:not(:disabled){background:#2980b9;border-color:#2980b9}.invite-btn:disabled{background:#bdc3c7;border-color:#bdc3c7;cursor:not-allowed}.collaborators-list{padding:12px 20px;max-height:300px;overflow-y:auto}.collaborator-item{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid #f0f0f0}.collaborator-item:last-child{border-bottom:none}.collaborator-item.local-user{background:#f8f9fa;margin:0 -20px;padding:10px 20px}.avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;color:#fff;background:#3498db}.info{flex:1;display:flex;flex-direction:column;gap:2px}.name{font-size:14px;font-weight:600;color:#2c3e50}.role{font-size:11px;color:#7f8c8d}.status{display:flex;align-items:center;gap:8px}.drawing-indicator{font-size:14px;animation:pulse 1s infinite}.collaborator-item.drawing{background:#fff3cd}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.panel-footer{padding:12px 20px;border-top:1px solid #e0e0e0;background:#f8f9fa}.voice-btn{width:100%;padding:10px;border:1px solid #3498db;border-radius:6px;background:#fff;color:#3498db;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.voice-btn:hover{background:#3498db;color:#fff}.version-panel{position:fixed;top:76px;right:24px;width:400px;max-height:calc(100vh - 100px);background:#fff;border-radius:12px;box-shadow:0 8px 24px #00000026;z-index:1000;overflow:hidden;display:flex;flex-direction:column}.version-panel .panel-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #e0e0e0}.version-panel .panel-header h2{font-size:18px;font-weight:600;color:#2c3e50;margin:0}.version-panel .panel-header .close-btn{width:28px;height:28px;border:none;background:#f5f5f5;border-radius:50%;cursor:pointer;font-size:16px;color:#7f8c8d;transition:all .2s ease}.version-panel .panel-header .close-btn:hover{background:#e0e0e0;color:#2c3e50}.version-panel .panel-content{padding:20px;overflow-y:auto;flex:1}.compare-info{margin-bottom:20px;padding:16px;background:#f0f8ff;border-radius:8px;border:2px solid #3498db}.compare-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.compare-header span{font-size:14px;font-weight:600;color:#2c3e50}.exit-compare-btn{padding:6px 12px;border:1px solid #3498db;border-radius:4px;background:#3498db;color:#fff;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease}.exit-compare-btn:hover{background:#2980b9;border-color:#2980b9}.compare-stats{display:flex;gap:16px}.stat-item{display:flex;align-items:center;gap:8px}.stat-label{font-size:12px;color:#7f8c8d}.stat-value{font-size:16px;font-weight:600}.stat-value.added{color:#27ae60}.stat-value.modified{color:#f39c12}.save-version{display:flex;gap:8px;margin-bottom:20px}.version-input{flex:1;padding:10px 14px;border:2px solid #e0e0e0;border-radius:6px;font-size:14px;outline:none;transition:all .2s ease}.version-input:focus{border-color:#3498db}.save-btn{padding:10px 20px;border:none;border-radius:6px;background:#3498db;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.save-btn:hover:not(:disabled){background:#2980b9;transform:translateY(-1px)}.save-btn:disabled{background:#bdc3c7;cursor:not-allowed}.versions-list{display:flex;flex-direction:column;gap:8px}.empty-state{text-align:center;padding:40px 20px;color:#7f8c8d}.empty-icon{font-size:48px;margin-bottom:12px}.empty-state p{margin:8px 0;font-size:14px}.empty-state .empty-hint{font-size:12px;color:#95a5a6}.version-item{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;background:#fff;transition:all .2s ease}.version-item:hover{border-color:#bdc3c7;background:#f8f9fa}.version-item.current{border-color:#3498db;background:#f0f8ff}.version-item.selected{border-color:#f39c12;background:#fef9e7}.version-thumbnail{width:60px;height:60px;border-radius:6px;overflow:hidden;border:1px solid #e0e0e0;margin-right:12px;flex-shrink:0}.version-thumbnail img{width:100%;height:100%;object-fit:cover}.version-info{flex:1;display:flex;flex-direction:column;gap:4px}.version-name{font-size:14px;font-weight:600;color:#2c3e50}.version-time{font-size:12px;color:#7f8c8d}.version-changes{display:flex;gap:8px;margin-top:4px}.change-badge{padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600}.change-badge.added{background:#d4edda;color:#155724}.change-badge.modified{background:#fff3cd;color:#856404}.version-actions{display:flex;gap:8px;align-items:center}.compare-btn,.restore-btn{padding:6px 12px;border:1px solid #3498db;border-radius:4px;background:#fff;color:#3498db;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease}.compare-btn:hover,.restore-btn:hover{background:#3498db;color:#fff}.current-badge{padding:4px 12px;background:#3498db;color:#fff;font-size:11px;font-weight:600;border-radius:4px}.drawing-canvas{display:flex;flex-direction:column;height:100%;background:#f5f5f5}.canvas-container{flex:1;display:flex;align-items:center;justify-content:center;padding:24px;overflow:auto;position:relative}.canvas{background:#fff;box-shadow:0 4px 12px #00000026;cursor:crosshair;max-width:100%;max-height:100%}.collaborator-cursor{position:absolute;width:20px;height:20px;border:2px solid;border-radius:50%;pointer-events:none;transform:translate(-50%,-50%);z-index:100}.cursor-label{position:absolute;top:-24px;left:0;padding:2px 8px;border-radius:4px;color:#fff;font-size:12px;white-space:nowrap}.export-menu{position:fixed;top:76px;right:24px;width:360px;background:#fff;border-radius:12px;box-shadow:0 8px 24px #00000026;z-index:1000;overflow:hidden}.export-menu-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #e0e0e0}.export-menu-header h3{font-size:18px;font-weight:600;color:#2c3e50;margin:0}.export-menu-header .close-btn{width:28px;height:28px;border:none;background:#f5f5f5;border-radius:50%;cursor:pointer;font-size:16px;color:#7f8c8d;transition:all .2s ease}.export-menu-header .close-btn:hover{background:#e0e0e0;color:#2c3e50}.export-menu-content{padding:20px;max-height:calc(100vh - 200px);overflow-y:auto}.export-section{margin-bottom:20px}.export-section:last-child{margin-bottom:0}.export-section h4{font-size:14px;font-weight:600;color:#2c3e50;margin:0 0 12px}.export-buttons,.share-buttons{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.share-buttons{grid-template-columns:repeat(2,1fr)}.export-btn,.share-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:16px 12px;border:2px solid #e0e0e0;border-radius:8px;background:#fff;cursor:pointer;transition:all .2s ease}.export-btn:hover,.share-btn:hover{border-color:#3498db;background:#f0f8ff;transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.export-icon,.share-icon{font-size:24px}.export-btn span,.share-btn span{font-size:13px;font-weight:500;color:#2c3e50}.compare-indicator{position:fixed;bottom:24px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:12px;padding:12px 20px;background:#fff;border-radius:12px;box-shadow:0 4px 12px #00000026;z-index:1000}.compare-badge{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#f8f9fa;border-radius:8px}.badge-item{display:flex;align-items:center;gap:4px;font-size:13px;font-weight:500;color:#2c3e50}.badge-item.added{color:#22c55e}.badge-item.modified{color:#f59e0b}.badge-item.removed{color:#ef4444}.exit-compare-btn{padding:8px 16px;background:#ef4444;color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.exit-compare-btn:hover{background:#dc2626;transform:translateY(-1px);box-shadow:0 2px 8px #ef44444d}.canvas.placing-material{cursor:crosshair}.material-placement-hint{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:12px;padding:20px 30px;background:#000000d9;border-radius:12px;color:#fff;z-index:1000;pointer-events:none}.hint-icon{font-size:48px}.hint-text{font-size:14px;font-weight:500;text-align:center}.save-version-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;width:100%;padding:16px 12px;border:2px solid #10b981;border-radius:8px;background:#fff;cursor:pointer;transition:all .2s ease}.save-version-btn:hover{border-color:#059669;background:#ecfdf5;transform:translateY(-2px);box-shadow:0 4px 8px #10b98133}.save-icon{font-size:24px}.gallery{padding:24px;background:#f5f5f5;min-height:calc(100vh - 64px)}.gallery-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.gallery-header h1{font-size:28px;font-weight:700;color:#2c3e50;margin:0}.new-artwork-btn{padding:10px 24px;border:none;border-radius:8px;background:#3498db;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.new-artwork-btn:hover{background:#2980b9;transform:translateY(-2px);box-shadow:0 4px 8px #3498db4d}.gallery-filters{display:flex;gap:24px;margin-bottom:32px;flex-wrap:wrap}.filter-group{display:flex;align-items:center;gap:12px}.filter-group label{font-size:14px;font-weight:600;color:#2c3e50}.filter-buttons{display:flex;gap:8px}.filter-btn{padding:6px 16px;border:2px solid #e0e0e0;border-radius:6px;background:#fff;color:#34495e;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.filter-btn:hover{border-color:#3498db;background:#f0f8ff}.filter-btn.active{border-color:#3498db;background:#3498db;color:#fff}.artworks-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}.artwork-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000001a;transition:all .3s ease}.artwork-card:hover{transform:translateY(-4px);box-shadow:0 8px 16px #00000026}.artwork-thumbnail{position:relative;width:100%;height:200px;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;overflow:hidden}.thumbnail-icon{font-size:64px;opacity:.9}.artwork-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;opacity:0;transition:opacity .3s ease}.artwork-card:hover .artwork-overlay{opacity:1}.overlay-btn{padding:8px 20px;border:1px solid rgba(255,255,255,.3);border-radius:6px;background:#ffffff1a;color:#fff;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.overlay-btn:hover{background:#fff3;border-color:#ffffff80;transform:scale(1.05)}.overlay-btn.share{background:#3498db4d;border-color:#3498db80}.overlay-btn.share:hover{background:#3498db80}.artwork-info{padding:16px}.artwork-title{font-size:18px;font-weight:600;color:#2c3e50;margin:0 0 8px}.artwork-description{font-size:13px;color:#7f8c8d;margin:0 0 12px;line-height:1.5}.artwork-meta{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.artwork-style{padding:4px 12px;background:#f0f8ff;color:#3498db;font-size:11px;font-weight:600;border-radius:4px}.artwork-tags{display:flex;gap:6px;flex-wrap:wrap}.tag{padding:2px 8px;background:#f8f9fa;color:#6c757d;font-size:11px;border-radius:4px}.artwork-actions{display:flex;gap:8px}.action-btn{flex:1;padding:8px 16px;border:1px solid #e0e0e0;border-radius:6px;background:#fff;color:#34495e;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.action-btn:hover{border-color:#3498db;background:#f0f8ff;color:#3498db}.action-btn.share{background:#3498db;border-color:#3498db;color:#fff}.action-btn.share:hover{background:#2980b9;border-color:#2980b9}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{height:100%}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}
