*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #09090b;--bg-secondary: #0f0f12;--bg-tertiary: #18181b;--bg-elevated: #1f1f23;--bg-hover: #27272a;--accent-primary: #8b5cf6;--accent-secondary: #a78bfa;--accent-highlight: #06b6d4;--accent-glow: rgba(139, 92, 246, .4);--text-primary: #fafafa;--text-secondary: #a1a1aa;--text-muted: #71717a;--border-color: rgba(255, 255, 255, .08);--border-light: rgba(255, 255, 255, .12);--border-accent: rgba(139, 92, 246, .3);--success-color: #22c55e;--danger-color: #ef4444;--warning-color: #eab308;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);--shadow-md: 0 4px 12px rgba(0, 0, 0, .5);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .6);--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:var(--bg-primary);color:var(--text-primary);overflow:hidden}#app{display:flex;flex-direction:column;height:100vh}.toolbar{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);gap:12px;overflow:visible;position:relative;z-index:100}.hearts-container{position:absolute;top:-10px;left:0;width:280px;height:50px;pointer-events:none;z-index:-1;overflow:visible}.floating-heart{position:absolute;bottom:0;animation:heart-rise linear infinite;filter:drop-shadow(0 0 4px rgba(255,105,180,.6));will-change:transform,opacity}@keyframes heart-rise{0%{transform:translateY(0) translate(0) scale(1) rotate(0);opacity:0}5%{opacity:.8}50%{opacity:.6}85%{opacity:.3}to{transform:translateY(-45px) translate(var(--drift)) scale(.5) rotate(var(--spin));opacity:0}}.toolbar-left,.toolbar-right{display:flex;align-items:center;gap:8px}.title-group{display:flex;align-items:center;gap:12px}.app-title{font-size:22px;font-weight:700;margin:0;letter-spacing:-.8px;background:linear-gradient(135deg,#ff69b4,#fff 35%,#ff1493 65%,#ff69b4);background-size:200% 100%;animation:valentine-shimmer 3s ease-in-out infinite;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:drop-shadow(0 2px 8px rgba(255,105,180,.5)) drop-shadow(0 0 12px rgba(255,20,147,.4));cursor:pointer;-webkit-user-select:none;user-select:none}@keyframes valentine-shimmer{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.app-title.wiggle{animation:wiggle .3s ease-in-out}@keyframes wiggle{0%,to{transform:rotate(0)}25%{transform:rotate(-5deg)}75%{transform:rotate(5deg)}}.version-badge{font-size:11px;font-weight:600;padding:4px 8px;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff;border-radius:12px;letter-spacing:.5px;text-transform:uppercase;box-shadow:0 2px 6px #6366f14d}.stats{display:flex;gap:20px;font-size:13px}.stat-item{display:flex;flex-direction:column;gap:1px;padding:5px 10px;background:#191923e6;border:1px solid rgba(99,102,241,.12);border-radius:10px;transition:all .25s;cursor:help}.stat-item:hover{border-color:#6366f14d;background:#1e1e2af2}.stat-label{font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);font-weight:600}.stat-value{font-size:16px;font-weight:700;color:var(--accent-primary);font-variant-numeric:tabular-nums}.main-container{display:flex;flex:1;overflow:hidden}.sidebar{width:310px;background:var(--bg-secondary);border-right:1px solid var(--border-color);overflow-y:auto;overflow-x:hidden;padding:12px;display:flex;flex-direction:column;gap:12px}.sidebar-right{width:320px;border-right:none;border-left:1px solid var(--border-color)}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-track{background:transparent}.sidebar::-webkit-scrollbar-thumb{background:#6366f14d;border-radius:3px}.sidebar::-webkit-scrollbar-thumb:hover{background:#6366f180}.panel{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:14px}.panel:hover{border-color:var(--border-light)}.panel-title{font-size:11px;font-weight:600;margin:0;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.panel-description{font-size:12px;color:var(--text-muted);margin:4px 0 12px;line-height:1.4}.panel-title-row{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.sidebar-left .panel:first-child .panel-title-row{flex-direction:row;justify-content:space-between;align-items:center}#presets-content{max-height:2000px;overflow:hidden;transition:max-height .4s cubic-bezier(.4,0,.2,1),opacity .3s ease;opacity:1;width:100%;box-sizing:border-box}.emitter-controls{display:flex;gap:6px;align-items:center;width:100%}.emitter-controls .emitter-select{flex:1;min-width:0}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;background:#2d2d3ce6;border:1px solid rgba(99,102,241,.25);border-radius:12px;color:var(--text-primary);cursor:pointer;transition:all .2s}.btn-icon i{width:14px;height:14px}.btn-icon:hover{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff;box-shadow:0 0 16px #6366f180,0 4px 12px #6366f14d,0 0 0 1px #fff3 inset}.btn-icon:active{transform:scale(.95)}.preset-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px}.preset-btn{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--bg-elevated);border:1px solid transparent;border-radius:var(--radius-md);color:var(--text-secondary);font-size:12px;font-weight:500;cursor:pointer;transition:all .15s ease;min-width:0;width:100%}.preset-btn i{width:14px;height:14px;flex-shrink:0;opacity:.5}.preset-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.preset-btn:hover i{opacity:.8}.preset-btn.active{background:var(--accent-primary);border-color:transparent;color:#fff;font-weight:600}.preset-btn.active i{opacity:1}.preset-btn span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.btn-view-more-presets{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:8px 12px;margin-top:8px;background:#8b5cf626;border:1px dashed rgba(139,92,246,.4);border-radius:8px;color:#a78bfa;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-view-more-presets:hover{background:#8b5cf640;border-color:#8b5cf699;color:#c4b5fd}.btn-view-more-presets i{width:14px;height:14px}#layers-content{max-height:2000px;overflow:hidden;transition:max-height .4s cubic-bezier(.4,0,.2,1),opacity .3s ease;opacity:1;width:100%;box-sizing:border-box}.layers-list{display:flex;flex-direction:column;gap:6px;max-height:300px;overflow-y:auto}.layers-list::-webkit-scrollbar{width:5px}.layers-list::-webkit-scrollbar-track{background:transparent}.layers-list::-webkit-scrollbar-thumb{background:#6366f14d;border-radius:3px}.layers-list::-webkit-scrollbar-thumb:hover{background:#6366f180}.layer-item{background:#232330d9;border:1px solid rgba(99,102,241,.12);border-radius:10px;padding:8px 10px;cursor:pointer;transition:all .2s;-webkit-user-select:none;user-select:none}.layer-item:hover{border-color:#6366f140;background:#2a2a3af2;box-shadow:0 2px 8px #00000040}.layer-item.selected{background:#6366f11f;border-color:#6366f166;box-shadow:0 0 12px #6366f126}.layer-item.disabled{background:#281e1ee6;border-color:#ef44444d;opacity:.7}.layer-item.disabled:hover{border-color:#ef444480;background:#2d2323f2;box-shadow:0 4px 16px #ef444426,0 2px 8px #0006,0 0 0 1px #ef444426 inset;transform:translateY(-1px);position:relative;z-index:10}.layer-item.disabled .layer-name{color:#ef4444cc}.layer-header{display:flex;align-items:center;gap:8px}.layer-visibility{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;transition:all .2s;border-radius:12px}.layer-visibility:hover{background:#6366f11a;color:var(--accent-primary);box-shadow:0 0 12px #6366f14d}.layer-visibility i{width:16px;height:16px}.layer-visibility.hidden{color:var(--text-secondary);opacity:.4}.layer-name{flex:1;font-size:13px;font-weight:500;color:var(--text-primary);overflow:hidden;white-space:nowrap;display:flex;align-items:center;gap:6px;min-width:0}.layer-name-text{overflow:hidden;text-overflow:ellipsis;flex-shrink:1;min-width:0}.layer-rename-btn{flex-shrink:0;display:none;align-items:center;justify-content:center;width:20px;height:20px;padding:0;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;transition:all .2s;border-radius:12px}.layer-item:hover .layer-rename-btn{display:flex}.layer-rename-btn:hover{background:#6366f133;color:var(--accent-primary);box-shadow:0 0 12px #6366f14d}.layer-rename-btn i{width:11px;height:11px}.layer-name-input{flex:1;padding:2px 6px;background:var(--bg-secondary);border:1px solid var(--accent-primary);border-radius:12px;color:var(--text-primary);font-size:13px;font-weight:500;outline:none;min-width:0}.layer-particle-count{font-size:10px;font-weight:600;color:var(--text-secondary);background:#6366f126;padding:2px 6px;border-radius:12px;flex-shrink:0;font-variant-numeric:tabular-nums}.layer-item.selected .layer-name span:first-child{color:var(--accent-primary);font-weight:600}.layer-item.selected .layer-particle-count{background:#6366f14d;color:var(--accent-primary)}.layer-delete{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;transition:all .2s;border-radius:12px;opacity:0}.layer-item:hover .layer-delete{opacity:1}.layer-delete:hover{background:#ef44441a;color:var(--danger-color);box-shadow:0 0 12px #ef44444d}.layer-delete i{width:14px;height:14px}.layer-item.sprite-layer{border-left:3px solid rgba(59,130,246,.5)}.layer-item.sprite-layer.selected{border-left-color:#3b82f6e6}.sprite-layer-thumbnail{width:20px;height:20px;border-radius:4px;object-fit:cover;margin-right:6px;background:#0000004d;border:1px solid rgba(255,255,255,.1)}.layers-separator{display:flex;align-items:center;padding:8px 12px;font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);opacity:.7}.layers-separator span{background:var(--surface-color);padding:0 8px}.layers-separator:before,.layers-separator:after{content:"";flex:1;height:1px;background:#ffffff1a}.layer-reorder-btns{display:flex;flex-direction:column;gap:0;margin-left:auto;margin-right:4px;opacity:0;transition:opacity .15s}.layer-item:hover .layer-reorder-btns{opacity:1}.layer-reorder-btn{display:flex;align-items:center;justify-content:center;width:18px;height:14px;padding:0;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;border-radius:3px;transition:all .15s}.layer-reorder-btn:hover{background:#6366f133;color:var(--primary-color)}.layer-reorder-btn i{width:12px;height:12px}.layer-item.drop-above{position:relative}.layer-item.drop-above:before{content:"";position:absolute;top:-2px;left:0;right:0;height:3px;background:var(--primary-color);border-radius:2px;box-shadow:0 0 8px var(--primary-color)}.layer-item.drop-below{position:relative}.layer-item.drop-below:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:3px;background:var(--primary-color);border-radius:2px;box-shadow:0 0 8px var(--primary-color)}.layer-attractors{margin-top:6px;margin-left:32px;display:flex;flex-direction:column;gap:4px}.attractor-item{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-secondary);padding:4px 6px;background:#8b5cf614;border-radius:12px;border:1px solid rgba(139,92,246,.2);cursor:pointer;transition:all .2s}.attractor-item:hover{background:#8b5cf626;border-color:#8b5cf666;color:var(--text-primary)}.attractor-item i{width:12px;height:12px;color:var(--accent-secondary)}.attractor-type{font-weight:500}.attractor-strength{margin-left:auto;font-variant-numeric:tabular-nums}.attractor-strength.positive{color:#10b981}.attractor-strength.negative{color:#ef4444}.layer-path{margin-top:6px;margin-left:32px}.path-item{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-secondary);padding:4px 6px;background:#3b82f614;border-radius:12px;border:1px solid rgba(59,130,246,.2);cursor:pointer;transition:all .2s}.path-item:hover{background:#3b82f626;border-color:#3b82f666;color:var(--text-primary)}.path-item i{width:12px;height:12px;color:#3b82f6}.path-type{font-weight:500}.path-name{margin-left:auto;font-style:italic;opacity:.8}.layer-group{margin-bottom:4px}.group-header{display:flex;align-items:center;gap:4px;padding:3px 6px;background:#282837b3;border:1px solid rgba(99,102,241,.2);border-radius:12px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:all .2s ease;position:relative;z-index:1}.group-header:hover{background:#2d2d3cd9;border-color:#6366f14d}.group-header.selected{background:#8b5cf626;border-color:var(--accent-primary)}.group-collapse{padding:2px;background:none;border:none;color:#888;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s ease,color .2s ease}.group-collapse:hover{color:var(--text-primary)}.group-collapse svg{width:12px;height:12px;transition:transform .2s ease}.group-collapsed .group-collapse svg{transform:rotate(-90deg)}.group-drag-handle{padding:2px;color:#555;cursor:grab;display:flex;align-items:center;justify-content:center;transition:color .2s ease}.group-drag-handle:hover{color:#888}.group-drag-handle svg{width:12px;height:12px}.group-header.dragging{opacity:.5}.group-header.drag-over{background:#6366f133;border-color:var(--accent-primary);border-style:dashed}.group-visibility{padding:4px;background:none;border:none;color:#888;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .2s ease}.group-visibility:hover{color:var(--text-primary)}.group-visibility svg{width:12px;height:12px}.group-name{flex:1;display:flex;align-items:center;gap:6px;font-weight:600;color:var(--text-primary);font-size:12px}.group-rename-btn{display:none;padding:2px;background:none;border:none;color:#888;cursor:pointer;opacity:.7;transition:opacity .2s ease;align-items:center;justify-content:center}.group-rename-btn svg{width:11px;height:11px}.group-header:hover .group-rename-btn{display:flex}.group-rename-btn:hover{opacity:1}.group-name-input{flex:1;background:var(--bg-primary);border:1px solid var(--accent-primary);border-radius:12px;padding:4px 6px;color:var(--text-primary);font-size:13px;font-weight:600}.group-delete{padding:4px;background:none;border:none;color:#888;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .2s ease,background .2s ease;opacity:0;border-radius:12px}.group-delete svg{width:12px;height:12px}.group-header:hover .group-delete{opacity:1}.group-delete:hover{color:var(--danger-color)}.group-duplicate{padding:4px;background:none;border:none;color:#888;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .2s ease,background .2s ease;opacity:0;border-radius:12px}.group-duplicate svg{width:12px;height:12px}.group-header:hover .group-duplicate{opacity:1}.group-duplicate:hover{color:var(--accent-primary);background:#ef44441a}.group-content{margin-top:2px;padding-left:16px;transition:max-height .3s ease,opacity .3s ease;overflow:hidden}.group-collapsed .group-content{max-height:0;opacity:0;margin-top:0}.layer-item.grouped{margin-left:0}.layer-group.ungrouped{border-top:1px solid var(--border-color);padding-top:12px;margin-top:12px}.ungrouped-header{background:transparent;border:none;cursor:default;padding:4px 10px}.ungrouped-header:hover{background:transparent;border:none}.ungrouped-label{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:#666;font-weight:600}.btn-create-group{width:100%;padding:6px 8px;background:#6366f11a;border:1px solid rgba(99,102,241,.3);border-radius:12px;color:var(--accent-primary);font-size:12px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .2s ease;margin-bottom:12px}.btn-create-group i{width:14px;height:14px}.btn-create-group:hover{background:#6366f126;border-color:var(--accent-primary)}.drop-indicator{height:2px;background:var(--accent-primary);margin:4px 0;border-radius:1px;opacity:0;transition:opacity .2s ease}.drop-indicator.active{opacity:1;box-shadow:0 0 8px var(--accent-primary)}.layer-item.drag-over{border-color:var(--accent-primary);background:#6366f11a}.layer-group.drag-over{border-color:var(--accent-primary);background:#6366f10d}.layer-item.dragging{opacity:.5;cursor:move}.emitter-select{background:#2d2d3ce6;border:1px solid rgba(99,102,241,.25);border-radius:12px;color:var(--text-primary);padding:4px 8px;font-size:13px;cursor:pointer;transition:all .2s}.emitter-select:hover{border-color:#6366f159;background:#323241f2}.control-tabs{display:flex;gap:2px;margin-bottom:14px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:3px}.tab-btn{flex:1;padding:8px 6px;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-muted);font-size:10px;font-weight:600;cursor:pointer;transition:all .15s ease;white-space:nowrap;min-width:0;overflow:hidden;text-overflow:ellipsis;text-transform:uppercase;letter-spacing:.3px}.tab-btn:hover:not(.active){color:var(--text-secondary);background:var(--bg-elevated)}.tab-btn.active{color:#fff;background:var(--accent-primary)}.tab-content{display:flex;flex-direction:column;gap:12px;max-height:500px;overflow-y:auto;overflow-x:hidden;padding-right:8px;padding-bottom:8px;box-sizing:border-box;width:100%}.tab-content::-webkit-scrollbar{width:5px}.tab-content::-webkit-scrollbar-track{background:transparent}.tab-content::-webkit-scrollbar-thumb{background:#6366f14d;border-radius:3px}.tab-content::-webkit-scrollbar-thumb:hover{background:#6366f180}.form-group{display:flex;flex-direction:column;gap:6px;width:100%;min-width:0;margin-bottom:14px}.form-group label{font-size:10px;color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.6px}.form-group label:has(input[type=checkbox]){display:flex;align-items:center;gap:10px;text-transform:none;font-size:13px;font-weight:500;letter-spacing:0}.input,.slider{width:100%;padding:8px 12px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:13px;font-weight:500;transition:all .15s ease}.input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px #8b5cf633}.input:hover:not(:focus){border-color:var(--border-light)}select.input,.input[type=select],select{-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238b9dc3' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:32px;cursor:pointer}select.input:hover,select:hover{border-color:#6366f159}select.input:focus,select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px #6366f11f}select option{background:#1e1e2e;color:var(--text-primary);padding:8px}.pcr-button{width:40px!important;height:40px!important;border-radius:6px!important;border:1.5px solid rgba(99,102,241,.3)!important;cursor:pointer;transition:border-color .2s ease}.pcr-button:hover{border-color:#6366f199!important}.pcr-button:focus{border-color:var(--accent-primary)!important;box-shadow:0 0 0 2px #6366f11f!important}.pickr{display:inline-block}input[type=checkbox],.input[type=checkbox]{width:18px;height:18px;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#191923e6;border:1.5px solid rgba(99,102,241,.3);border-radius:5px;position:relative;transition:all .2s cubic-bezier(.4,0,.2,1);flex-shrink:0}input[type=checkbox]:hover,.input[type=checkbox]:hover{border-color:#6366f180;background:#232330f2}input[type=checkbox]:checked,.input[type=checkbox]:checked{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));border-color:transparent;box-shadow:0 2px 6px #6366f166}input[type=checkbox]:checked:after,.input[type=checkbox]:checked:after{content:"";position:absolute;left:5px;top:2px;width:4px;height:8px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}#export-filter{background:linear-gradient(135deg,#6366f11f,#8b5cf61f);border:2px solid rgba(99,102,241,.35);font-weight:600;color:var(--text-primary);box-shadow:0 2px 8px #6366f126,0 0 0 1px #6366f11a inset}#export-filter:hover{border-color:#6366f199;background:linear-gradient(135deg,#6366f12e,#8b5cf62e);box-shadow:0 4px 12px #6366f140,0 0 20px #6366f11a,0 0 0 1px #6366f126 inset}#export-filter:focus{border-color:var(--accent-primary);background:linear-gradient(135deg,#6366f133,#8b5cf633);box-shadow:0 0 0 3px #6366f133,0 4px 16px #6366f14d,0 0 0 1px #6366f133 inset}#export-filter option{background:#2d2d3cf2;color:var(--text-primary)}#filter-preview-option label{display:flex;align-items:center;gap:8px;cursor:pointer;padding:8px;border-radius:12px;transition:background .2s;font-weight:500}#filter-preview-option label:hover{background:#6366f11a}#filter-preview-option label i{width:16px;height:16px;color:var(--accent-primary)}#filter-preview-option input[type=checkbox]:checked+i{color:var(--accent-secondary)}#filter-params{padding:12px;margin-top:12px;border:1px solid rgba(99,102,241,.25);border-radius:12px;background:linear-gradient(135deg,#6366f10a,#8b5cf60a);box-shadow:0 2px 8px #6366f114,0 0 0 1px #6366f10d inset}#filter-params .form-group label{color:#6366f1f2;font-weight:600;text-shadow:0 0 10px rgba(99,102,241,.3)}.shape-select-container{position:relative;width:100%}.shape-select-button{display:flex!important;align-items:center;gap:8px;width:100%;text-align:left;cursor:pointer}.shape-preview-icon{flex-shrink:0;border-radius:12px;background:#6366f11a;padding:2px}.shape-name{flex:1}.shape-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:12px;max-height:300px;overflow-y:auto;z-index:1000;box-shadow:var(--shadow-lg)}.shape-option{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;background:transparent;border:none;color:var(--text-primary);font-size:13px;cursor:pointer;transition:all .2s;text-align:left}.shape-option:hover{background:#6366f11a}.shape-option.selected{background:#6366f133;color:var(--accent-primary)}.shape-option .shape-preview-icon{background:#6366f126}.slider{padding:8px 0;height:8px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;cursor:pointer}.slider::-webkit-slider-runnable-track{width:100%;height:8px;background:linear-gradient(to right,rgba(99,102,241,.5) 0%,rgba(99,102,241,.4) var(--fill-percent, 0%),rgba(30,30,40,.9) var(--fill-percent, 0%),rgba(30,30,40,.9) 100%);border:1px solid rgba(99,102,241,.3);border-radius:12px;box-shadow:inset 0 1px 3px #0000004d}.slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-highlight) 100%);border:2px solid rgba(255,255,255,.3);border-radius:50%;cursor:grab;margin-top:-7px;box-shadow:0 2px 8px #6366f180,0 0 0 1px #0003;transition:all .2s}.slider::-webkit-slider-thumb:hover{background:linear-gradient(135deg,var(--accent-secondary) 0%,var(--accent-highlight) 100%);transform:scale(1.2);cursor:grabbing;box-shadow:0 4px 12px #6366f1b3,0 0 12px #22d3ee80,0 0 0 1px #fff6}.slider::-webkit-slider-thumb:active{cursor:grabbing}.slider::-moz-range-track{width:100%;height:8px;background:linear-gradient(to right,rgba(99,102,241,.5) 0%,rgba(99,102,241,.4) var(--fill-percent, 0%),rgba(30,30,40,.9) var(--fill-percent, 0%),rgba(30,30,40,.9) 100%);border:1px solid rgba(99,102,241,.3);border-radius:12px;box-shadow:inset 0 1px 3px #0000004d}.slider::-moz-range-thumb{width:20px;height:20px;background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-highlight) 100%);border:2px solid rgba(255,255,255,.3);border-radius:50%;cursor:grab;box-shadow:0 2px 8px #6366f180,0 0 0 1px #0003;transition:all .2s}.slider::-moz-range-thumb:hover{background:linear-gradient(135deg,var(--accent-secondary) 0%,var(--accent-highlight) 100%);transform:scale(1.2);cursor:grabbing;box-shadow:0 4px 12px #6366f1b3,0 0 12px #22d3ee80,0 0 0 1px #fff6}.slider::-moz-range-thumb:active{cursor:grabbing}.slider-value{display:inline-block;min-width:40px;font-size:12px;color:var(--accent-primary);font-weight:600;text-align:right;flex-shrink:0;padding-left:8px}input.slider-value{background:transparent;border:1px solid rgba(255,255,255,.2);border-radius:4px;padding:2px 6px;color:inherit;font-size:12px}.form-group>div[style*="display: flex"]{align-items:center;gap:8px;flex-wrap:nowrap;width:100%}.form-group>div[style*="display: flex"] label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.input-group{display:flex;align-items:center;gap:8px}.input-group input{flex:1}.input-group span{color:var(--text-secondary);font-size:13px}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:12px;font-weight:500;cursor:pointer;transition:all .15s ease;white-space:nowrap}.btn i{width:14px;height:14px;opacity:.7}.btn-icon-only{padding:8px;min-width:34px;justify-content:center}#reset-btn:hover{border-color:var(--danger-color);color:var(--danger-color)}.btn:hover{background:var(--bg-hover);border-color:var(--border-light)}.btn:active{transform:scale(.98)}.btn:disabled,.btn.loading{opacity:.5;cursor:not-allowed;pointer-events:none}.btn.loading i{animation:spin 1s linear infinite}.btn-primary{background:var(--accent-primary);border:none;color:#fff;font-weight:600}.btn-primary:hover{background:var(--accent-secondary)}.btn-block{width:100%}.btn-preview{background:var(--success-color);border:none;color:#fff;font-weight:600}.btn-preview:hover{background:#16a34a}.btn-stop{background:linear-gradient(135deg,#ef4444,#dc2626);border-color:#ef4444;color:#fff}.btn-stop:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);border-color:#dc2626}.btn-save{background:var(--success-color);border:none;color:#fff;font-weight:600}.btn-save:hover{background:#16a34a}.btn-load{background:#3b82f6;border:none;color:#fff;font-weight:600}.btn-load:hover{background:#2563eb}.btn-share{background:linear-gradient(135deg,#a855f7,#9333ea);border-color:#a855f7;color:#fff;font-weight:600;box-shadow:0 2px 8px #a855f74d,0 0 20px #a855f733;animation:pulse-glow 2s ease-in-out infinite}.btn-share:hover{background:linear-gradient(135deg,#9333ea,#7e22ce);border-color:#9333ea;box-shadow:0 4px 12px #a855f780,0 0 30px #a855f766}@keyframes pulse-glow{0%,to{box-shadow:0 2px 8px #a855f74d,0 0 20px #a855f733}50%{box-shadow:0 2px 8px #a855f766,0 0 25px #a855f74d}}.btn-coffee{background:var(--bg-secondary);border:2px solid #f59e0b;color:#fbbf24;font-weight:600;box-shadow:0 0 10px #fbbf2433}.btn-coffee:hover{background:#f59e0b1a;border-color:#fbbf24;color:#fbbf24;box-shadow:0 0 15px #fbbf2466}.btn-contact{background:linear-gradient(135deg,#f59e0b,#d97706);border-color:#f59e0b;color:#fff;font-weight:600;box-shadow:0 2px 8px #f59e0b4d}.btn-contact:hover{background:linear-gradient(135deg,#d97706,#b45309);border-color:#d97706;box-shadow:0 4px 12px #f59e0b80}.btn-discord{background:linear-gradient(135deg,#5865f2,#4752c4);border:2px solid #5865F2;color:#fff;font-weight:600;text-decoration:none;box-shadow:0 2px 8px #5865f24d,0 0 20px #5865f233;animation:discord-pulse 3s ease-in-out infinite;transition:all .2s ease}.btn-discord:hover{background:linear-gradient(135deg,#4752c4,#3c45a5);border-color:#7289da;box-shadow:0 4px 12px #5865f280,0 0 30px #5865f266;transform:translateY(-1px)}.discord-icon{width:18px;height:18px;filter:drop-shadow(0 0 4px rgba(255,255,255,.3))}@keyframes discord-pulse{0%,to{box-shadow:0 2px 8px #5865f24d,0 0 20px #5865f233}50%{box-shadow:0 2px 8px #5865f280,0 0 30px #5865f266}}.btn-transparent{padding:8px 10px;background:var(--bg-tertiary);border:1px solid var(--border-color);opacity:.6;transition:all .2s}.btn-transparent:hover{opacity:1;background:var(--bg-secondary)}.btn-transparent.active{opacity:1;background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.btn-transparent.active:hover{background:var(--accent-secondary);border-color:var(--accent-secondary)}.btn-upload-image{background:linear-gradient(135deg,#8b5cf6,#7c3aed);border-color:#8b5cf6;color:#fff;font-weight:500;box-shadow:0 2px 6px #8b5cf640;padding:8px 14px;font-size:13px}.btn-upload-image:hover{background:linear-gradient(135deg,#7c3aed,#6d28d9);border-color:#7c3aed;box-shadow:0 3px 10px #8b5cf666;transform:translateY(-1px)}.btn-upload-image:active{transform:translateY(0) scale(.98)}.btn-clear-image{background:linear-gradient(135deg,#ef4444,#dc2626);border-color:#ef4444;color:#fff;padding:6px 8px;min-width:32px;box-shadow:0 2px 6px #ef444440}.btn-clear-image:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);border-color:#dc2626;box-shadow:0 3px 10px #ef444466;transform:translateY(-1px)}.btn-clear-image:active{transform:translateY(0) scale(.95)}.toolbar-divider{width:1px;height:32px;background:var(--border-color);margin:0 4px}.toolbar-dropdown{position:relative}.btn-more{background:#2d2d3ce6;border:1px solid var(--border-color);color:var(--text-primary);font-weight:500;padding:8px 12px;gap:6px}.btn-more:hover{background:#6366f126;border-color:var(--accent-primary);color:var(--accent-primary)}.btn-more .dropdown-chevron{width:14px;height:14px;transition:transform .2s ease}.toolbar-dropdown.open .btn-more .dropdown-chevron{transform:rotate(180deg)}.toolbar-dropdown-menu{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;background:#1e1e28fa;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(99,102,241,.3);border-radius:12px;padding:8px;box-shadow:0 8px 32px #00000080,0 0 0 1px #ffffff0d inset;opacity:0;visibility:hidden;transform:translateY(-8px);transition:all .2s ease;z-index:1000}.toolbar-dropdown.open .toolbar-dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}.dropdown-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;background:transparent;border:none;border-radius:8px;color:var(--text-primary);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s ease;text-decoration:none}.dropdown-item i,.dropdown-item svg{width:18px;height:18px;flex-shrink:0}.dropdown-item:hover{background:#6366f126;color:var(--accent-primary)}.dropdown-item-highlight{color:#fbbf24}.dropdown-item-highlight:hover{background:#fbbf2426;color:#fbbf24}.dropdown-item-discord{color:#7289da}.dropdown-item-discord:hover{background:#5865f226;color:#7289da}.dropdown-divider{height:1px;background:linear-gradient(90deg,transparent,var(--border-color),transparent);margin:6px 0}.panel-collapsible .panel-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;padding-bottom:12px;margin-bottom:0;border-bottom:1px solid rgba(99,102,241,.1);transition:all .2s ease}.panel-collapsible .panel-header:hover{border-bottom-color:#6366f133}.panel-collapsible .panel-header .panel-title{margin:0}.panel-toggle-btn{display:flex;align-items:center;justify-content:center;width:22px;height:22px;padding:0;background:transparent;border:none;color:var(--text-muted);cursor:pointer;transition:all .2s ease;border-radius:6px}.panel-toggle-btn:hover{background:#6366f11f;color:var(--accent-primary)}.panel-toggle-btn i,.panel-toggle-btn svg{width:14px;height:14px;transition:transform .3s cubic-bezier(.4,0,.2,1)}.panel-collapsible.collapsed .panel-toggle-btn i,.panel-collapsible.collapsed .panel-toggle-btn svg{transform:rotate(-90deg)}.panel-collapsible.collapsed .panel-header{margin-bottom:0;padding-bottom:0;border-bottom:none}.panel-content{max-height:2000px;overflow:hidden;opacity:1;transition:max-height .4s cubic-bezier(.4,0,.2,1),opacity .3s ease,margin-top .3s ease;margin-top:14px}.panel-collapsible.collapsed .panel-content{max-height:0!important;opacity:0!important;margin-top:0!important;padding-top:0!important;padding-bottom:0!important;transition:max-height .3s cubic-bezier(.4,0,.2,1),opacity .2s ease,margin-top .2s ease,padding .2s ease}.button-group{display:flex;flex-direction:column;gap:8px}.modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:10000;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease}.modal-content{background:#1e1e2df2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(99,102,241,.25);border-radius:12px;padding:0;max-width:500px;width:90%;box-shadow:0 8px 32px #00000080,0 0 0 1px #6366f11a inset;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid rgba(99,102,241,.15);background:#6366f10d}.modal-header h2{margin:0;font-size:20px;color:var(--text-primary)}.modal-close{background:#28283799;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(99,102,241,.15);color:var(--text-secondary);cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;border-radius:12px;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #0003,0 0 0 1px #6366f114 inset}.modal-close:hover{background:#323241d9;border-color:#6366f14d;color:var(--text-primary);transform:translateY(-1px);box-shadow:0 4px 12px #6366f133,0 0 0 1px #6366f126 inset}.modal-description{padding:20px 24px;background:#23233299;border-bottom:1px solid rgba(99,102,241,.12)}.modal-description p{margin:0 0 12px;color:var(--text-primary);font-size:14px}.modal-description ul{margin:0;padding-left:20px;color:var(--text-secondary);font-size:13px;line-height:1.8}.modal-description li{margin-bottom:6px}.modal-description strong{color:var(--text-primary);font-weight:600}.modal-content form{padding:24px}.modal-content textarea{resize:vertical;font-family:inherit}.optional-label{font-size:12px;color:var(--text-secondary);font-weight:400}.modal-large{max-width:700px}.help-content{padding:24px;max-height:70vh;overflow-y:auto}.help-section{margin-bottom:32px}.help-section:last-child{margin-bottom:0}.help-section h3{font-size:18px;font-weight:600;color:var(--accent-primary);margin-bottom:12px;display:flex;align-items:center;gap:8px}.help-section h3 i{width:20px;height:20px}.help-section h3 .new-badge{font-size:11px;font-weight:600;color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);padding:2px 8px;border-radius:12px;margin-left:8px;letter-spacing:.5px}.help-section p{font-size:14px;line-height:1.6;color:var(--text-secondary);margin-bottom:12px}.help-section ul{list-style:none;padding:0;margin:8px 0}.help-section li{font-size:14px;line-height:1.6;color:var(--text-secondary);padding:6px 0 6px 24px;position:relative}.help-section li:before{content:"•";position:absolute;left:8px;color:var(--accent-primary);font-weight:700}.help-section strong{color:var(--text-primary);font-weight:600}.shortcuts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:12px;margin-top:16px}.shortcut-item{display:flex;align-items:center;gap:12px;padding:10px 12px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:12px}.shortcut-item kbd{display:inline-block;padding:4px 8px;font-size:12px;font-weight:600;line-height:1;color:var(--text-primary);background:var(--bg-secondary);border:2px solid var(--border-light);border-radius:12px;box-shadow:0 2px 0 var(--border-color);font-family:SF Mono,Monaco,Menlo,monospace;white-space:nowrap}.shortcut-item span{font-size:13px;color:var(--text-secondary);flex:1}.shortcut-note{margin-top:16px;font-size:12px;color:var(--text-secondary);font-style:italic;text-align:center}.canvas-container{flex:1;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);position:relative;overflow:hidden}#particle-canvas{border:2px solid var(--border-color);border-radius:12px;cursor:move;box-shadow:var(--shadow-lg),0 0 60px #6366f126;transition:box-shadow .3s;touch-action:none;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}#particle-canvas.transparent-bg{background-image:linear-gradient(45deg,#1a1a28 25%,transparent 25%),linear-gradient(-45deg,#1a1a28 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#1a1a28 75%),linear-gradient(-45deg,transparent 75%,#1a1a28 75%);background-size:20px 20px;background-position:0 0,0 10px,10px -10px,-10px 0px;background-color:#121218}#particle-canvas:hover{box-shadow:var(--shadow-lg),0 0 80px #6366f140}.canvas-overlay{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none}.canvas-info{position:absolute;bottom:24px;left:50%;transform:translate(-50%);background:#0f0f16d9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:10px 18px;border-radius:20px;border:1px solid rgba(99,102,241,.15);font-size:12px;font-weight:500;color:var(--text-secondary);box-shadow:0 4px 20px #0006;animation:fadeInUp .5s ease-out;letter-spacing:.2px}@keyframes fadeInUp{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.progress-bar{position:relative;width:100%;height:36px;background:var(--bg-secondary);border:1.5px solid var(--border-color);border-radius:12px;overflow:hidden;margin-top:12px;box-shadow:inset 0 2px 4px #0000004d}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent-primary),var(--accent-secondary));transition:width .3s ease;width:0%;box-shadow:0 0 20px var(--accent-glow);position:relative;overflow:hidden}.progress-fill:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:13px;font-weight:600;color:var(--text-primary);text-shadow:0 1px 2px rgba(0,0,0,.5);z-index:1}.range-input{display:flex;align-items:center;gap:6px;width:100%}.range-input input[type=number]{flex:1;min-width:0;max-width:80px;padding:6px 8px;font-size:12px;background:#2d2d3ce6;border:1px solid rgba(99,102,241,.25);border-radius:12px;color:var(--text-primary)}.range-input span{color:var(--text-secondary);font-size:12px;flex-shrink:0}.notification{position:fixed;top:80px;left:50%;transform:translate(-50%) translateY(-100px);background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff;padding:14px 28px;border-radius:12px;font-size:14px;font-weight:600;box-shadow:var(--shadow-lg);opacity:0;transition:all .3s cubic-bezier(.4,0,.2,1);z-index:10000;pointer-events:none}.notification.show{opacity:1;transform:translate(-50%) translateY(0)}.notification-error{background:linear-gradient(135deg,#ef4444,#dc2626);max-width:400px;text-align:center;line-height:1.4}.btn[title]:after,.btn-icon[title]:after{content:attr(title);position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%) translateY(-4px);background:var(--bg-tertiary);color:var(--text-primary);padding:6px 10px;border-radius:12px;font-size:11px;font-weight:500;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .2s,transform .2s;border:1px solid var(--border-light);box-shadow:var(--shadow-md);z-index:1000;letter-spacing:.3px}.btn[title]:hover:after,.btn-icon[title]:hover:after{opacity:1;transform:translate(-50%) translateY(0)}.btn,.btn-icon{position:relative}.tutorial-tooltip{position:absolute;top:45px;right:0;left:auto;background:linear-gradient(135deg,#6366f1,#8b5cf6,#a855f7);border:2px solid rgba(255,255,255,.3);border-radius:12px;padding:14px 42px 14px 18px;min-width:240px;max-width:280px;box-shadow:0 8px 32px #6366f199,0 0 0 1px #ffffff1a inset,0 0 20px #8b5cf666;z-index:10001;animation:tooltipFadeInPulse .6s ease-out}.tutorial-tooltip:before{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;border-radius:12px;padding:2px;background:linear-gradient(135deg,#fff6,#ffffff1a);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;animation:tooltipGlow 2s ease-in-out infinite}.tutorial-tooltip-content{display:flex;align-items:flex-start;gap:12px;position:relative}.tutorial-tooltip-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:#ffffff40;border-radius:12px;flex-shrink:0;animation:iconPulse 2s ease-in-out infinite;box-shadow:0 0 15px #ffffff4d}.tutorial-tooltip-icon i{width:20px;height:20px;color:#fff;filter:drop-shadow(0 0 4px rgba(255,255,255,.8))}.tutorial-tooltip-content p{margin:0;padding-top:4px;font-size:14px;line-height:1.5;color:#fff;font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.3)}.tutorial-tooltip-close{position:absolute;top:6px;right:6px;background:#ffffff40;border:none;border-radius:12px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;transition:all .2s;padding:0;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.tutorial-tooltip-close:hover{background:#fff6;transform:scale(1.1)}.tutorial-tooltip-close i{width:16px;height:16px;filter:drop-shadow(0 1px 2px rgba(0,0,0,.3))}.tutorial-tooltip-arrow{position:absolute;top:-10px;right:70px;left:auto;width:0;height:0;border-left:10px solid transparent;border-right:10px solid transparent;border-bottom:10px solid #6366f1;filter:drop-shadow(0 -2px 4px rgba(99,102,241,.4))}@keyframes tooltipFadeInPulse{0%{opacity:0;transform:translateY(-10px) scale(.95)}60%{opacity:1;transform:translateY(0) scale(1.02)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes tooltipGlow{0%,to{opacity:.6}50%{opacity:1}}@keyframes iconPulse{0%,to{transform:scale(1);box-shadow:0 0 15px #ffffff4d}50%{transform:scale(1.1);box-shadow:0 0 25px #fff9}}@media (max-width: 1200px){.sidebar{width:240px}}@media (max-width: 768px){.main-container{flex-direction:column}.sidebar{width:100%;border-right:none;border-bottom:1px solid var(--border-color);max-height:300px}.sidebar-right{border-left:none;border-top:1px solid var(--border-color)}}.coop-panel{position:fixed;top:80px;right:20px;width:320px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;box-shadow:var(--shadow-lg);z-index:1000;transition:all .3s ease}.coop-panel.collapsed{width:auto}.coop-header{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid var(--border-color);cursor:pointer;-webkit-user-select:none;user-select:none}.coop-header h3{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:600;color:var(--text-primary);margin:0}.coop-icon{font-size:20px}.coop-header-actions{display:flex;gap:4px;align-items:center}.coop-toggle-btn,.coop-close-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;transition:all .2s;border-radius:12px}.coop-toggle-btn:hover,.coop-close-btn:hover{color:var(--text-primary);background:var(--bg-tertiary)}.coop-toggle-btn i{transition:transform .3s ease}.coop-panel.collapsed .coop-toggle-btn i{transform:rotate(-90deg)}.coop-content{padding:16px}.coop-panel.collapsed .coop-content{display:none}.coop-state{display:flex;flex-direction:column;gap:12px}.coop-description{font-size:14px;color:var(--text-secondary);line-height:1.5;margin:0}.coop-status-text{font-size:14px;color:var(--text-secondary);text-align:center;margin:0}.coop-error-text{font-size:14px;color:var(--danger-color);text-align:center;margin:0}.coop-error-message{display:flex;align-items:center;gap:8px;padding:12px;background:#ef44441a;border:1px solid var(--danger-color);border-radius:12px;margin-bottom:12px}.coop-error-message i{width:20px;height:20px;color:var(--danger-color);flex-shrink:0}.coop-error-message p{margin:0;font-size:14px;color:var(--danger-color)}.coop-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;border:none;border-radius:12px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;text-align:center}.coop-btn i{width:16px;height:16px}.coop-btn-primary{background:var(--accent-primary);color:#fff}.coop-btn-primary:hover{background:#5558e3;transform:translateY(-1px);box-shadow:0 4px 12px #6366f166}.coop-btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.coop-btn-secondary:hover{background:var(--bg-primary);border-color:var(--border-light)}.coop-btn-small{padding:6px 12px;font-size:12px}.coop-actions{display:flex;gap:8px}.coop-actions .coop-btn{flex:1}.coop-room-info{display:flex;flex-direction:column;gap:8px}.coop-room-info label{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.coop-room-code-container{display:flex;gap:8px;align-items:center}.coop-room-code{flex:1;padding:10px 12px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:12px;font-family:Monaco,Menlo,monospace;font-size:16px;font-weight:600;color:var(--accent-primary);text-align:center;letter-spacing:2px}.coop-participants{display:flex;flex-direction:column;gap:8px}.coop-participants label{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.coop-participants label i{width:14px;height:14px}.coop-participant-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px;max-height:200px;overflow-y:auto}.coop-participant-item{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--bg-tertiary);border-radius:12px;font-size:14px}.coop-participant-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.coop-participant-name{flex:1;color:var(--text-primary)}.coop-host-badge{padding:2px 8px;background:var(--accent-primary);color:#fff;font-size:11px;font-weight:600;border-radius:12px;text-transform:uppercase;letter-spacing:.5px}.coop-connection-status{display:flex;justify-content:center;padding:8px 0}.coop-status-indicator{display:flex;align-items:center;gap:8px;padding:6px 12px;background:var(--bg-tertiary);border-radius:20px;font-size:12px;font-weight:500}.coop-status-dot{width:8px;height:8px;border-radius:50%;animation:pulse 2s infinite}.status-connected .coop-status-dot{background:var(--success-color)}.status-connecting .coop-status-dot,.status-reconnecting .coop-status-dot{background:var(--warning-color)}.status-disconnected .coop-status-dot{background:var(--danger-color)}.coop-spinner{width:40px;height:40px;margin:0 auto;border:3px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.coop-toast{position:fixed;bottom:24px;right:24px;padding:12px 20px;background:var(--bg-secondary);border:1px solid var(--border-color);border-left:4px solid var(--accent-primary);border-radius:12px;color:var(--text-primary);font-size:14px;font-weight:500;box-shadow:var(--shadow-md);z-index:2000;opacity:0;transform:translateY(20px);transition:all .3s ease}.coop-toast.show{opacity:1;transform:translateY(0)}.coop-cursor{position:absolute;pointer-events:none;z-index:10000;transition:all .1s linear}.coop-cursor-dot{width:12px;height:12px;border-radius:50%;border:2px solid white;box-shadow:0 2px 8px #0000004d}.coop-cursor-label{position:absolute;top:-24px;left:14px;padding:4px 8px;background:#000c;color:#fff;font-size:11px;font-weight:500;border-radius:12px;white-space:nowrap;box-shadow:0 2px 8px #0000004d}@media (max-width: 768px){.coop-panel{right:10px;width:calc(100% - 20px);max-width:320px}.coop-toast{right:10px;left:10px;bottom:10px}}.discord-banner{background:linear-gradient(135deg,#5865f2,#4752c4);color:#fff;padding:12px 20px;box-shadow:0 2px 12px #00000026;z-index:10000;position:relative;flex-shrink:0}.discord-banner-content{max-width:1400px;margin:0 auto;display:flex;align-items:center;justify-content:center;gap:20px;position:relative}.discord-banner-text{font-size:14px;font-weight:500;letter-spacing:.2px;display:flex;align-items:center;gap:8px}.discord-banner-link{background:#fff;color:#5865f2;padding:8px 20px;border-radius:12px;text-decoration:none;font-weight:600;font-size:13px;transition:all .2s;box-shadow:0 2px 8px #00000026}.discord-banner-link:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0003}.discord-banner-close{background:none;border:none;color:#fff;font-size:22px;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:12px;transition:all .2s;opacity:.7;position:absolute;right:0;top:50%;transform:translateY(-50%)}.discord-banner-close:hover{background:#ffffff26;opacity:1}@media (max-width: 768px){.discord-banner{padding:12px 50px 12px 16px}.discord-banner-content{flex-direction:column;gap:10px;text-align:center}.discord-banner-text{font-size:13px}.discord-banner-link{font-size:12px;padding:7px 18px}.discord-banner-close{right:12px}}.btn-ai{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none}.btn-ai:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.btn-ai:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-signin{background:#4285f4;color:#fff;border:none}.btn-signin:hover{background:#357ae8}.btn-signout{background:#666;color:#fff;border:none}.btn-signout:hover{background:#555}.user-info{color:#ddd;font-size:13px;padding:0 12px;font-weight:500}.hidden{display:none!important}.ai-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:10001;display:flex;align-items:center;justify-content:center;animation:fadeIn .3s ease-out}.ai-modal-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#000c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.ai-modal-content{position:relative;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;width:90%;max-width:520px;max-height:90vh;overflow:hidden;box-shadow:0 16px 48px #00000080;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(40px) scale(.96);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.ai-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border-color)}.ai-modal-header-content{flex:1}.ai-modal-header h3{margin:0;font-size:16px;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:8px}.ai-modal-header h3 i{width:18px;height:18px;color:var(--accent-primary)}.early-access-badge{display:inline-block;font-size:9px;font-weight:600;letter-spacing:.5px;padding:2px 6px;border-radius:4px;background:var(--accent-primary);color:#fff;vertical-align:middle;margin-left:4px}.ai-modal-subtitle{margin:4px 0 0;font-size:12px;color:var(--text-muted);font-weight:400}.ai-modal-close{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:#fff9;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:12px;transition:all .2s}.ai-modal-close i{width:18px;height:18px}.ai-modal-close:hover{background:#ef444433;border-color:#ef444466;color:#ef4444;transform:scale(1.05)}.ai-disclaimer{display:flex;align-items:center;gap:8px;padding:10px 24px;background:var(--bg-tertiary);border-bottom:1px solid var(--border-color)}.ai-disclaimer-icon{flex-shrink:0;width:14px;height:14px;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.ai-disclaimer-icon i{width:14px;height:14px}.ai-disclaimer-content{font-size:11px;color:var(--text-muted)}.ai-modal-body{padding:20px 24px 24px}.ai-mode-toggle{display:flex;gap:8px;margin-bottom:16px;padding:4px;background:var(--bg-tertiary);border-radius:8px}.ai-mode-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 16px;background:transparent;border:none;border-radius:6px;color:var(--text-muted);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.ai-mode-btn i{width:14px;height:14px}.ai-mode-btn:hover:not(:disabled){color:var(--text-primary);background:#ffffff0d}.ai-mode-btn.active{background:var(--accent-primary);color:#fff}.ai-mode-btn:disabled{opacity:.3;cursor:not-allowed}.ai-input-wrapper{margin-bottom:16px}#ai-prompt-input{width:100%;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);padding:12px 14px;font-size:13px;font-family:inherit;resize:vertical;min-height:100px;transition:border-color .15s;line-height:1.5}#ai-prompt-input:focus{outline:none;border-color:var(--accent-primary)}#ai-prompt-input::placeholder{color:var(--text-muted)}.ai-input-hint{margin-top:6px;font-size:11px;color:var(--text-muted)}.ai-examples{margin-top:16px;padding-top:16px;border-top:1px solid var(--border-color)}.ai-examples-label{font-size:11px;font-weight:500;color:var(--text-muted);margin-bottom:10px}.ai-examples-grid{display:flex;flex-wrap:wrap;gap:6px}.ai-example-btn{background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-secondary);padding:6px 12px;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s}.ai-example-btn:hover{background:var(--bg-hover);border-color:var(--accent-primary);color:var(--text-primary)}.ai-cooldown-info{margin-top:16px;text-align:center}.ai-cooldown-info small{color:var(--text-muted);font-size:11px}.ai-cooldown-info.warning small{color:#f59e0b}.ai-modal-footer{display:flex;gap:10px;padding:16px 24px;border-top:1px solid var(--border-color)}.ai-modal .btn-primary,.ai-modal .btn-secondary{padding:10px 18px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;border:none;display:flex;align-items:center;justify-content:center;transition:all .15s;flex:1}.ai-modal .btn-primary{background:var(--accent-primary);color:#fff}.ai-modal .btn-primary:hover:not(:disabled){background:var(--accent-hover)}.ai-modal .btn-primary:disabled{opacity:.5;cursor:not-allowed}.ai-modal .btn-secondary{background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-secondary)}.ai-modal .btn-secondary:hover{background:var(--bg-hover);color:var(--text-primary)}.ai-modal-content.loading #ai-prompt-input,.ai-modal-content.loading .ai-example-btn{pointer-events:none;opacity:.5}.ai-modal-content.loading #ai-modal-submit{position:relative}.ai-modal-content.loading #ai-modal-submit:after{content:"";position:absolute;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 768px){.ai-modal-content{width:95%;max-width:95%}.ai-modal-header,.ai-modal-body{padding:20px}.ai-modal-footer{padding:16px 20px;flex-direction:column-reverse}.ai-modal-header h3{font-size:17px}.ai-modal-subtitle{font-size:12px}.ai-examples-grid{grid-template-columns:1fr}.ai-modal .btn-primary,.ai-modal .btn-secondary{width:100%}}.ai-generating-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:9999;animation:fadeIn .2s ease}.ai-generating-content{position:relative;background:var(--bg-secondary);border:2px solid var(--border-light);border-radius:16px;padding:32px 48px;display:flex;flex-direction:column;align-items:center;gap:20px;box-shadow:var(--shadow-lg)}.ai-generating-close{position:absolute;top:12px;right:12px;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.ai-generating-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.ai-generating-spinner{width:48px;height:48px;border:4px solid rgba(99,102,241,.2);border-top-color:#6366f1;border-radius:50%;animation:spin .8s linear infinite}.ai-generating-text{font-size:16px;font-weight:600;color:var(--text-primary);text-align:center;transition:color .3s ease}.ai-generating-text.error{color:#ef4444}.ai-progress-bar-container{width:300px;height:8px;background:#6366f133;border-radius:12px;overflow:hidden}.ai-progress-bar{height:100%;background:linear-gradient(90deg,#6366f1,#8b5cf6);border-radius:12px;transition:width .3s ease;width:0%}.ai-progress-bar.error{background:linear-gradient(90deg,#ef4444,#f87171)}.ai-progress-log{max-height:150px;width:350px;overflow-y:auto;font-size:13px;color:var(--text-secondary);background:#0000004d;border-radius:12px;padding:12px;scrollbar-width:thin;scrollbar-color:rgba(99,102,241,.5) transparent}.ai-progress-log::-webkit-scrollbar{width:6px}.ai-progress-log::-webkit-scrollbar-track{background:transparent}.ai-progress-log::-webkit-scrollbar-thumb{background:#6366f180;border-radius:12px}.ai-progress-log-entry{padding:4px 0;opacity:.8;animation:fadeIn .3s ease}.ai-progress-log-entry.error{color:#f87171;opacity:1}button[disabled].btn-generate,button[disabled].btn-modify{opacity:.5;cursor:not-allowed;pointer-events:none}.mobile-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:999;opacity:0;transition:opacity .3s ease}.mobile-backdrop.active{opacity:1}.mobile-nav-bar{display:none;justify-content:space-between;align-items:center;padding:16px 20px;min-height:80px;background:linear-gradient(135deg,#1e1e2dfa,#141423fa);border-bottom:2px solid rgba(99,102,241,.3);box-shadow:0 4px 12px #0000004d;position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.mobile-nav-bar .mobile-menu-btn{width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary),var(--accent-primary));border:2px solid rgba(99,102,241,.5);border-radius:16px;box-shadow:0 4px 12px #6366f14d,0 0 20px #6366f133;transition:all .2s ease;position:relative;overflow:hidden;cursor:pointer;pointer-events:auto;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.mobile-nav-bar .mobile-menu-btn:hover{background:linear-gradient(135deg,var(--accent-primary),var(--primary));border-color:var(--primary);box-shadow:0 6px 16px #6366f166,0 0 30px #6366f14d;transform:translateY(-2px)}.mobile-nav-bar .mobile-menu-btn:active{transform:scale(.95);box-shadow:0 2px 8px #6366f14d}.mobile-nav-bar .mobile-menu-btn i{width:28px!important;height:28px!important;color:#fff!important;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));pointer-events:none}.toast-container{position:fixed;bottom:20px;left:50%;transform:translate(-50%);z-index:10000;display:flex;flex-direction:column;gap:10px;pointer-events:none}.toast{background:#1e1e2df2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--text-primary);padding:12px 20px;border-radius:12px;box-shadow:0 4px 20px #0006,0 0 0 1px #6366f133;font-size:14px;font-weight:500;pointer-events:auto;animation:toastSlideIn .3s cubic-bezier(.4,0,.2,1);max-width:90vw;text-align:center}.toast.success{border-left:3px solid var(--success-color)}.toast.info{border-left:3px solid var(--accent-primary)}.toast.warning{border-left:3px solid var(--warning-color)}.toast.hiding{animation:toastSlideOut .3s cubic-bezier(.4,0,.2,1) forwards}@keyframes toastSlideIn{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes toastSlideOut{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-20px) scale(.95)}}.ripple{position:absolute;border-radius:50%;background:#fff9;transform:scale(0);animation:rippleEffect .6s ease-out;pointer-events:none}@keyframes rippleEffect{to{transform:scale(4);opacity:0}}.mobile-sidebar-close,.mobile-backdrop{display:none}@media (max-width: 768px){html,body,#app{overflow-x:hidden!important;max-width:100vw}.mobile-nav-bar{display:flex!important}.mobile-backdrop{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#0009;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:999;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .3s ease,visibility .3s ease}.mobile-backdrop.active{display:block;opacity:1;visibility:visible;pointer-events:auto}.mobile-sidebar-close{display:flex!important;align-items:center;justify-content:center;position:absolute;top:16px;right:16px;width:44px;height:44px;background:#6366f1e6;border:2px solid rgba(255,255,255,.2);border-radius:50%;color:#fff;cursor:pointer;z-index:10;transition:all .2s ease;box-shadow:0 4px 12px #0000004d}.mobile-sidebar-close:hover{background:#8b5cf6;transform:scale(1.05);box-shadow:0 6px 16px #0006}.mobile-sidebar-close:active{transform:scale(.95)}.mobile-sidebar-close i{width:24px!important;height:24px!important;color:#fff!important}.btn,.btn-icon{position:relative;overflow:hidden}.toolbar .stats{display:none}.toolbar .title-group{flex-shrink:1;min-width:0;overflow:hidden}.toolbar .title-group h1{font-size:16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.toolbar .version-badge{font-size:9px;padding:2px 6px;flex-shrink:0}.toolbar .btn-save,.toolbar .btn-load,.toolbar .btn-share,.toolbar .btn-contact,.toolbar .btn-coffee,.toolbar .btn-discord,.toolbar .btn-signin.hidden,.toolbar .btn-signout.hidden{display:none!important}.toolbar .user-info{font-size:12px;padding:0 8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100px}.toolbar .btn span{display:none}.toolbar{display:grid;grid-template-columns:1fr;grid-template-rows:minmax(min-content,max-content) minmax(min-content,max-content);padding:12px 16px;gap:10px;height:auto;overflow:visible;max-height:none;position:sticky;top:0;z-index:100}.toolbar-left{grid-row:1;display:flex;align-items:flex-start;gap:10px;flex-wrap:wrap;height:auto;overflow:visible}.toolbar-right{grid-row:2;display:flex;align-items:flex-start;justify-content:center;gap:10px;flex-wrap:wrap;height:auto;overflow:visible}.toolbar-divider{display:none}.main-container{height:auto;min-height:calc(100vh - 80px);position:relative}.sidebar{position:fixed!important;top:5vh!important;bottom:5vh!important;left:0!important;right:0!important;height:90vh!important;max-height:90vh!important;min-height:90vh!important;width:100%!important;max-width:100vw!important;padding-top:16px;z-index:1000;transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);overflow-y:auto!important;overflow-x:hidden;border:none!important;box-shadow:2px 0 24px #0006;border-radius:12px 12px 0 0}.sidebar-left{left:0}.sidebar-right{left:auto;right:0;transform:translate(100%);box-shadow:-2px 0 24px #0006}.sidebar-left.mobile-active,.sidebar-right.mobile-active{transform:translate(0)}.canvas-container{width:100%!important;flex:1;padding:8px}#particle-canvas{max-width:100%;max-height:calc(100vh - 100px)}.toolbar .btn,.toolbar .btn-icon,.toolbar .mobile-only{min-height:40px!important;max-height:40px!important;min-width:40px!important;padding:8px!important;font-size:18px!important;display:flex!important;align-items:center!important;justify-content:center!important}.toolbar .btn svg,.toolbar .btn-icon svg,.toolbar .mobile-only svg{width:20px!important;height:20px!important}.btn:not(.toolbar .btn),.btn-icon:not(.toolbar .btn-icon){min-height:44px;min-width:44px;padding:10px 14px;font-size:14px}input[type=range]{height:32px}input[type=range]::-webkit-slider-thumb{width:24px;height:24px}input[type=range]::-moz-range-thumb{width:24px;height:24px}.panel{padding:14px}.panel-title{font-size:16px}.form-group{margin-bottom:14px}.form-group label{font-size:13px;margin-bottom:6px}.input{font-size:14px;padding:10px 12px;min-height:44px}textarea.input{min-height:100px}.preset-grid{grid-template-columns:repeat(2,1fr);gap:8px}.preset-btn{padding:12px 8px;font-size:13px}.layer-item{padding:12px;min-height:56px}.layer-header{gap:10px}.layer-name{font-size:14px}.layer-particle-count{font-size:11px;padding:3px 8px}.layer-visibility,.layer-delete,.layer-duplicate{min-width:36px;min-height:36px;width:36px;height:36px}.layer-visibility i,.layer-delete i,.layer-duplicate i{width:18px!important;height:18px!important}.layer-attractors{margin-left:16px;margin-top:8px;gap:6px}.attractor-item{font-size:13px;padding:8px 10px;min-height:36px;gap:8px}.attractor-item i{width:16px!important;height:16px!important}.layer-path{margin-left:16px;margin-top:8px}.path-item{font-size:13px;padding:8px 10px;min-height:36px;gap:8px}.path-item i{width:16px!important;height:16px!important}.control-tabs{gap:4px}.tab-btn{padding:10px 14px;font-size:13px;min-height:44px}.modal-content{width:95%;max-width:95%;margin:16px}.canvas-info{font-size:11px;padding:8px 14px}.notification{top:70px;font-size:13px;padding:12px 20px}.discord-banner{padding:10px 40px 10px 12px}.discord-banner-text{font-size:12px}.discord-banner-link{padding:6px 14px;font-size:11px}}@media (max-width: 400px){.toolbar{padding:4px 6px;gap:4px}.toolbar-left,.toolbar-right{gap:6px}.toolbar .title-group h1{font-size:13px}.toolbar .version-badge{font-size:8px;padding:2px 4px}.toolbar .btn,.toolbar .btn-icon,.toolbar .mobile-only{min-height:36px!important;max-height:36px!important;min-width:36px!important;padding:6px!important}.toolbar .btn svg,.toolbar .btn-icon svg,.toolbar .mobile-only svg{width:18px!important;height:18px!important}}.context-menu{background:#141418fa;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.1);border-radius:12px;box-shadow:0 8px 32px #00000080,0 0 0 1px #ffffff0d inset;min-width:220px;padding:8px;animation:contextMenuFadeIn .2s cubic-bezier(.16,1,.3,1);overflow:hidden}.context-menu-header{padding:8px 12px 10px;font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid rgba(255,255,255,.06);margin-bottom:8px;-webkit-user-select:none;user-select:none}.context-submenu{margin-left:4px}@keyframes contextMenuFadeIn{0%{opacity:0;transform:scale(.96) translateY(-8px)}to{opacity:1;transform:scale(1) translateY(0)}}.context-menu-item{display:flex;align-items:center;gap:12px;padding:10px 12px;cursor:pointer;color:var(--text-primary);font-size:14px;border-radius:12px;transition:all .15s cubic-bezier(.4,0,.2,1);-webkit-user-select:none;user-select:none;position:relative}.context-menu-item:hover{background:linear-gradient(135deg,#6366f126,#8b5cf626);color:#fff;transform:translate(2px)}.context-menu-item:hover .context-menu-icon{color:var(--accent-primary);transform:scale(1.1)}.context-menu-item:active{transform:translate(2px) scale(.98)}.context-menu-item.disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.context-menu-icon{display:flex;align-items:center;justify-content:center;width:18px;height:18px;flex-shrink:0;color:var(--text-secondary);transition:all .15s cubic-bezier(.4,0,.2,1)}.context-menu-icon i{width:16px;height:16px;stroke-width:2}.context-menu-label{flex:1;white-space:nowrap;font-weight:500}.context-menu-shortcut{color:var(--text-secondary);font-size:11px;font-family:SF Mono,Monaco,Cascadia Code,monospace;background:#ffffff0d;padding:2px 8px;border-radius:12px;border:1px solid rgba(255,255,255,.08);flex-shrink:0}.context-menu-arrow{color:var(--text-secondary);font-size:14px;flex-shrink:0;opacity:.6}.context-menu-separator{height:1px;background:#ffffff0f;margin:6px 0}.sprites-list{display:flex;flex-direction:column;gap:6px;max-height:200px;overflow-y:auto}.sprites-list::-webkit-scrollbar{width:5px}.sprites-list::-webkit-scrollbar-track{background:transparent}.sprites-list::-webkit-scrollbar-thumb{background:#6366f14d;border-radius:3px}.sprites-list::-webkit-scrollbar-thumb:hover{background:#6366f180}.sprites-empty-state{text-align:center;padding:16px;color:var(--text-secondary);font-size:12px}.sprites-empty-state p{margin-bottom:12px;opacity:.7}.sprite-item{background:#232330d9;border:1px solid rgba(99,102,241,.12);border-radius:10px;padding:8px 10px;cursor:pointer;transition:all .2s;-webkit-user-select:none;user-select:none;display:flex;align-items:center;gap:8px}.sprite-item:hover{border-color:#6366f140;background:#2a2a3af2;box-shadow:0 2px 8px #00000040}.sprite-item.selected{background:#6366f11f;border-color:#6366f166;box-shadow:0 0 12px #6366f126}.sprite-thumbnail{width:32px;height:32px;border-radius:6px;object-fit:contain;background:#0000004d;flex-shrink:0}.sprite-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.sprite-item-name{font-size:12px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sprite-item.selected .sprite-item-name{color:var(--accent-primary)}.sprite-item-meta{font-size:10px;color:var(--text-secondary);display:flex;gap:8px}.sprite-item-actions{display:flex;gap:4px;opacity:0;transition:opacity .2s}.sprite-item:hover .sprite-item-actions{opacity:1}.sprite-visibility,.sprite-lock{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:22px;height:22px;padding:0;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;transition:all .2s;border-radius:6px}.sprite-visibility:hover,.sprite-lock:hover{background:#6366f11a;color:var(--accent-primary)}.sprite-visibility.hidden,.sprite-lock.locked{opacity:.5}.sprite-visibility i,.sprite-lock i{width:14px;height:14px}.sprite-controls{margin-top:12px;padding-top:12px;border-top:1px solid var(--border-color)}.sprite-controls-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid rgba(99,102,241,.15)}.sprite-name{font-size:13px;font-weight:600;color:var(--accent-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sprite-controls .form-group{margin-bottom:10px}.sprite-controls .form-group>label:first-child{font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;display:block}.sprite-controls .input-label{font-size:11px;color:var(--text-secondary);min-width:40px}.sprite-controls .input-unit{font-size:11px;color:var(--text-secondary);margin-left:4px}.sprite-controls .opacity-value{font-size:11px;color:var(--text-secondary);min-width:40px;text-align:right}.flip-buttons{display:flex;gap:8px}.flip-buttons .btn{flex:1;display:flex;align-items:center;justify-content:center;gap:4px;padding:6px 10px}.flip-buttons .btn.active{background:#6366f133;border-color:#6366f166;color:var(--accent-primary)}.flip-buttons .btn i{width:14px;height:14px}.sprite-actions{display:flex;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid var(--border-color)}.sprite-actions .btn{flex:1;display:flex;align-items:center;justify-content:center;gap:4px;padding:6px 10px;font-size:12px}.sprite-actions .btn i{width:14px;height:14px}.sprite-actions .btn-danger{background:#ef44441a;border-color:#ef44444d;color:var(--danger-color)}.sprite-actions .btn-danger:hover{background:#ef444433;border-color:#ef444480}.cloud-sync-status{position:absolute;top:12px;right:12px;display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:6px;font-size:12px;background:#18181be6;border:1px solid var(--border-color);transition:all .2s ease;z-index:100;pointer-events:auto;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.cloud-sync-status.hidden{display:none}.cloud-sync-status .sync-icon{width:14px;height:14px}.cloud-sync-status .sync-text{white-space:nowrap}.cloud-sync-status.idle{background:#18181bd9;border-color:#71717a4d;color:var(--text-secondary)}.cloud-sync-status.syncing{background:#8b5cf626;border-color:var(--accent-primary);color:var(--accent-primary)}.cloud-sync-status.syncing .sync-icon{animation:cloud-pulse 1s infinite}.cloud-sync-status.synced{background:#22c55e1a;border-color:var(--success-color);color:var(--success-color)}.cloud-sync-status.error{background:#ef44441a;border-color:var(--danger-color);color:var(--danger-color)}.cloud-sync-status.offline{background:#71717a1a;border-color:var(--text-muted);color:var(--text-muted)}@keyframes cloud-pulse{0%,to{opacity:1}50%{opacity:.4}}.btn-new,.btn-projects{background:#3b82f61a;border:1px solid rgba(59,130,246,.3);color:#93c5fd}.btn-new:hover,.btn-projects:hover{background:#3b82f633;border-color:#3b82f6;color:#fff}.btn-marketplace{background:#22c55e1a;border:1px solid rgba(34,197,94,.3);color:#86efac}.btn-marketplace:hover{background:#22c55e33;border-color:#22c55e;color:#fff}.modal-xlarge{max-width:900px;width:95%}.projects-toolbar{padding:20px 24px;border-bottom:1px solid var(--border-color);display:flex;gap:16px;align-items:center;flex-wrap:wrap;background:#0003}.projects-search{flex:1;min-width:240px;position:relative}.projects-search .search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--text-muted);pointer-events:none;transition:color .2s}.projects-search input{width:100%;padding:12px 14px 12px 42px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);color:var(--text-primary);font-size:14px;font-weight:500;transition:all .2s ease;box-shadow:0 2px 4px #0000000d}.projects-search input:focus{outline:none;border-color:var(--accent-primary);background:var(--bg-secondary);box-shadow:0 0 0 3px #8b5cf626}.projects-search input:focus+.search-icon{color:var(--accent-primary)}.projects-toolbar-actions{display:flex;gap:12px;align-items:center}.projects-sort{padding:12px 16px;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-lg);color:var(--text-primary);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.projects-sort:hover{background:var(--bg-hover);border-color:var(--border-light)}.projects-sort:focus{outline:none;border-color:var(--accent-primary)}.projects-view-toggle{display:flex;gap:4px;background:var(--bg-elevated);padding:4px;border-radius:var(--radius-lg);border:1px solid var(--border-color)}.view-btn{width:36px;height:36px;padding:0;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-md);color:var(--text-muted);cursor:pointer;transition:all .2s ease}.view-btn:hover{color:var(--text-primary);background:var(--bg-hover)}.view-btn.active{color:#fff;background:var(--accent-primary);box-shadow:0 2px 4px #0003}.view-btn svg{width:18px;height:18px}.projects-actions-bar{padding:12px 24px;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center;background:#0000001a;font-size:13px}.projects-count{font-weight:500;color:var(--text-secondary)}.projects-actions-right{display:flex;gap:12px}.projects-container{padding:24px;max-height:60vh;overflow-y:auto;background:radial-gradient(circle at top right,rgba(139,92,246,.03),transparent 40%)}.projects-list.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:20px}.projects-grid .project-item{flex-direction:column;padding:0;overflow:hidden;position:relative;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-xl, 16px);transition:all .25s cubic-bezier(.4,0,.2,1)}.projects-grid .project-item:hover{transform:translateY(-4px);box-shadow:0 12px 24px -8px #00000080;border-color:var(--border-light)}.projects-grid .project-thumbnail{width:100%;aspect-ratio:16/10;height:auto;border-radius:0;background:var(--bg-primary);border-bottom:1px solid var(--border-color);position:relative}.projects-grid .project-thumbnail:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#0006;opacity:0;transition:opacity .2s;pointer-events:none;z-index:10}.projects-grid .project-item:hover .project-thumbnail:before{opacity:1}.projects-grid .project-info{padding:16px;width:100%}.projects-grid .project-name{font-size:15px;margin-bottom:6px;color:var(--text-primary)}.projects-grid .project-meta{flex-wrap:wrap;gap:8px}.projects-grid .project-actions{position:absolute;top:10px;right:10px;opacity:0;display:flex;gap:6px;z-index:20;transform:translateY(-5px);transition:all .2s ease}.projects-grid .project-item:hover .project-actions{opacity:1;transform:translateY(0)}.projects-grid .project-actions .btn-icon{width:32px;height:32px;background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border-light);box-shadow:0 4px 12px #0000004d}.projects-grid .project-actions .btn-icon:hover{background:var(--bg-primary);transform:scale(1.05)}.projects-list.projects-list-view{display:flex;flex-direction:column;gap:12px}.projects-list-view .project-item{display:grid;grid-template-columns:80px 1fr auto;align-items:center;gap:20px;padding:12px;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:all .2s cubic-bezier(.4,0,.2,1)}.projects-list-view .project-item:hover{background:var(--bg-hover);border-color:var(--border-light);transform:translate(4px);box-shadow:0 4px 12px #0000001a}.projects-list-view .project-thumbnail{width:80px;height:56px;border-radius:6px;background:var(--bg-tertiary);overflow:hidden;border:1px solid var(--border-color)}.projects-list-view .project-thumbnail img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.projects-list-view .project-item:hover .project-thumbnail img{transform:scale(1.1)}.projects-list-view .project-info{display:flex;flex-direction:column;gap:4px;min-width:0}.projects-list-view .project-name{font-size:15px;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:8px}.projects-list-view .project-meta{display:flex;align-items:center;gap:12px;font-size:12px;color:var(--text-secondary)}.projects-list-view .project-user-role{font-size:11px;padding:2px 6px;background:var(--bg-tertiary);border-radius:4px;color:var(--text-muted)}.projects-list-view .project-actions{display:flex;align-items:center;gap:8px;opacity:.8;transition:opacity .2s}.projects-list-view .project-item:hover .project-actions{opacity:1}.projects-list-view .btn-icon{width:32px;height:32px;border-radius:6px;background:transparent;color:var(--text-secondary);border:1px solid transparent;display:flex;align-items:center;justify-content:center;transition:all .2s}.projects-list-view .btn-icon:hover{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-color)}.project-item-current{border:1px solid var(--accent-primary)!important;box-shadow:0 0 0 1px var(--accent-primary),0 4px 12px #8b5cf633!important}.project-thumbnail{position:relative;overflow:hidden;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center}.project-thumbnail img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}.project-item:hover .project-thumbnail img{transform:scale(1.05)}.project-no-thumbnail{color:var(--text-muted);opacity:.3}.project-no-thumbnail svg{width:24px;height:24px;opacity:.5}.project-marketplace-badge{position:absolute;top:8px;right:8px;display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:6px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:5}.project-marketplace-badge.approved{background:#22c55ed9;color:#fff;box-shadow:0 2px 6px #22c55e4d}.project-marketplace-badge.pending{background:#eab308d9;color:#1a1a1a;box-shadow:0 2px 6px #eab3084d}.project-marketplace-badge.rejected{background:#ef4444d9;color:#fff;box-shadow:0 2px 6px #ef44444d}.project-update-marketplace-btn{color:#22d3ee!important;border-color:#22d3ee4d!important}.project-update-marketplace-btn:hover{background:#22d3ee26!important;border-color:#22d3ee80!important;color:#22d3ee!important}.current-badge{font-size:10px;font-weight:700;padding:2px 6px;background:var(--accent-primary);color:#fff;border-radius:4px;flex-shrink:0;text-transform:uppercase;letter-spacing:.02em}.public-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;background:#22c55e26;color:var(--success-color);border-radius:4px;font-size:11px;font-weight:500;flex-shrink:0;border:1px solid rgba(34,197,94,.2)}.public-badge svg{width:12px;height:12px}.projects-empty-state,.projects-loading,.projects-error,.projects-no-results{text-align:center;padding:60px 40px;color:var(--text-secondary);grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-tertiary);border-radius:var(--radius-lg);border:2px dashed var(--border-color);margin:20px}.projects-empty-state svg,.projects-no-results svg{width:48px;height:48px;margin-bottom:16px;opacity:.4;color:var(--text-muted)}.projects-empty-state p,.projects-loading p,.projects-error p,.projects-no-results p{margin:0;font-size:15px;font-weight:500}.projects-empty-hint{margin-top:8px!important;font-size:13px!important;color:var(--text-muted);max-width:300px;line-height:1.5}.projects-error{color:var(--danger-color);background:#ef44440d;border-color:#ef444433}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#050505d9;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);z-index:10000;display:flex;align-items:center;justify-content:center;animation:fadeIn .3s cubic-bezier(.16,1,.3,1)}.marketplace-modal-content{background:linear-gradient(165deg,#1e2029,#12131a);border:1px solid rgba(255,255,255,.08);border-radius:24px;width:95%;max-width:1200px;max-height:90vh;display:flex;flex-direction:column;animation:scaleUp .35s cubic-bezier(.16,1,.3,1);overflow:hidden;box-shadow:0 30px 60px -15px #000000b3,0 0 0 1px #ffffff0a}@keyframes scaleUp{0%{opacity:0;transform:scale(.96) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.marketplace-header{padding:24px 32px;border-bottom:1px solid rgba(255,255,255,.06);background:linear-gradient(180deg,#8b5cf614,#22d3ee05)}.marketplace-header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.marketplace-header-top h2{display:flex;align-items:center;gap:14px;margin:0;font-size:26px;font-weight:700;color:var(--text-primary);letter-spacing:-.02em;text-shadow:0 1px 2px rgba(0,0,0,.5)}.marketplace-header-top h2 svg{color:var(--accent-primary);filter:drop-shadow(0 0 12px rgba(139,92,246,.5))}.marketplace-filters{display:flex;gap:16px;margin-bottom:20px}.marketplace-search{flex:1;position:relative}.marketplace-search svg{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:var(--text-muted);transition:color .2s;width:18px;height:18px}.marketplace-search:focus-within svg{color:var(--accent-primary)}.marketplace-search input{width:100%;padding:14px 16px 14px 46px;background:#0c0d12;border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-xl, 16px);color:var(--text-primary);font-size:15px;transition:all .2s;box-shadow:inset 0 2px 4px #0000004d}.marketplace-search input:focus{outline:none;border-color:var(--accent-primary);background:var(--bg-secondary);box-shadow:0 0 0 3px #8b5cf626}.marketplace-search input::placeholder{color:var(--text-muted)}#marketplace-category{min-width:180px;padding:0 20px;height:48px;border-radius:var(--radius-xl, 16px);background-color:#0c0d12;border:1px solid rgba(255,255,255,.08);color:var(--text-primary);cursor:pointer;transition:all .2s}#marketplace-category:hover{border-color:#ffffff24;background-color:#16171e}#marketplace-category:focus{border-color:var(--accent-primary);outline:none}.marketplace-tag-filters{display:flex;align-items:center;gap:10px;margin-bottom:16px;padding:8px 0}.marketplace-tag-filters.hidden{display:none}.tag-filters-label{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;flex-shrink:0}.tag-filters-label svg{opacity:.6}.tag-filters-chips{display:flex;flex-wrap:wrap;gap:6px;flex:1}.marketplace-tag-chip{padding:5px 12px;border-radius:99px;font-size:12px;font-weight:500;background:#ffffff08;color:var(--text-secondary);border:1px solid rgba(255,255,255,.08);cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.marketplace-tag-chip:hover{border-color:#22d3ee4d;color:#22d3ee;background:#22d3ee0f}.marketplace-tag-chip.active{background:#22d3ee1f;color:#22d3ee;border-color:#22d3ee66;font-weight:600;box-shadow:0 0 12px #22d3ee26}.tag-filters-clear{display:flex;align-items:center;gap:4px;padding:4px 10px;border-radius:99px;font-size:11px;font-weight:600;background:#ef44441a;color:#f87171;border:1px solid rgba(239,68,68,.2);cursor:pointer;transition:all .2s;flex-shrink:0}.tag-filters-clear:hover{background:#ef444433;border-color:#ef444466}.tag-filters-clear.hidden{display:none}.marketplace-tabs{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:6px;background:#0c0d12;padding:6px;border-radius:99px;border:1px solid rgba(255,255,255,.06);width:fit-content;max-width:100%}.marketplace-tabs .tab-btn{flex-shrink:0;padding:8px 20px;background:transparent;border:1px solid transparent;border-radius:99px;color:var(--text-secondary);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;gap:8px;white-space:nowrap}.marketplace-tabs .tab-btn:hover{color:var(--text-primary);background:#1a1b24}.marketplace-tabs .tab-btn.active{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;box-shadow:0 2px 12px #8b5cf659,inset 0 1px #ffffff1a}.marketplace-tabs .tab-admin{color:var(--accent-secondary)}.marketplace-tabs .tab-admin:hover{color:var(--accent-primary);background:#8b5cf61a}.pending-badge{background:var(--danger-color);color:#fff;font-size:11px;font-weight:700;padding:2px 8px;border-radius:10px;min-width:20px;text-align:center;box-shadow:0 2px 4px #0003}.marketplace-body{position:relative;flex:1;overflow-y:auto;padding:32px;background:#0c0d12;background-image:radial-gradient(ellipse at 5% 0%,rgba(139,92,246,.07) 0%,transparent 50%),radial-gradient(ellipse at 95% 100%,rgba(34,211,238,.04) 0%,transparent 50%)}.marketplace-body::-webkit-scrollbar{width:10px}.marketplace-body::-webkit-scrollbar-track{background:transparent}.marketplace-body::-webkit-scrollbar-thumb{background:#262833;border:2px solid #0c0d12;border-radius:20px}.marketplace-body::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.marketplace-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px;padding-bottom:40px}.marketplace-card{background:linear-gradient(165deg,#1e2029,#1a1b24);border:1px solid rgba(255,255,255,.07);border-radius:16px;overflow:hidden;transition:all .3s cubic-bezier(.25,.8,.25,1);position:relative;display:flex;flex-direction:column;animation:cardEntrance .4s cubic-bezier(.16,1,.3,1) backwards}.marketplace-card:nth-child(1){animation-delay:0s}.marketplace-card:nth-child(2){animation-delay:.04s}.marketplace-card:nth-child(3){animation-delay:.08s}.marketplace-card:nth-child(4){animation-delay:.12s}.marketplace-card:nth-child(5){animation-delay:.16s}.marketplace-card:nth-child(6){animation-delay:.2s}.marketplace-card:nth-child(7){animation-delay:.24s}.marketplace-card:nth-child(8){animation-delay:.28s}.marketplace-card:nth-child(n+9){animation-delay:.32s}@keyframes cardEntrance{0%{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.marketplace-card:hover{transform:translateY(-4px) scale(1.02);background:linear-gradient(165deg,#262833,#1e2029);border-color:#8b5cf64d;box-shadow:0 8px 32px -8px #0009,0 0 0 1px #8b5cf61f,0 4px 24px -4px #8b5cf61a;z-index:5}.card-thumbnail{position:relative;aspect-ratio:16/9;background:#12131a;display:flex;align-items:center;justify-content:center;overflow:hidden;border-bottom:1px solid rgba(255,255,255,.05)}.card-thumbnail img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.25,.8,.25,1)}.marketplace-card:hover .card-thumbnail img{transform:scale(1.1)}.card-thumbnail:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,rgba(12,13,18,.8) 0%,rgba(139,92,246,.02) 40%,transparent 70%);opacity:.5;transition:opacity .3s;pointer-events:none}.marketplace-card:hover .card-thumbnail:after{opacity:.7}.card-thumbnail-clickable{cursor:pointer}.card-thumbnail-clickable:before{content:"Import Effect";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.9);padding:10px 24px;background:var(--accent-primary);color:#fff;font-size:13px;font-weight:700;border-radius:30px;opacity:0;transition:all .3s cubic-bezier(.34,1.56,.64,1);z-index:10;box-shadow:0 4px 20px #8b5cf666;letter-spacing:.02em;white-space:nowrap}.card-thumbnail-clickable:hover:before{opacity:1;transform:translate(-50%,-50%) scale(1)}.card-no-thumbnail{color:var(--text-muted);opacity:.5}.card-status-badge{position:absolute;top:12px;right:12px;padding:4px 10px;border-radius:8px;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:5;box-shadow:0 2px 8px #0000004d}.card-status-badge.pending{background:#eab308e6;color:#1a1a1a}.card-status-badge.on-marketplace{background:#22c55ee6;color:#1a1a1a}.card-status-badge.not-published{background:#71717acc;color:#fafafa}.card-content{padding:16px;flex:1;display:flex;flex-direction:column;gap:2px}.card-title{font-size:16px;font-weight:700;color:var(--text-primary);margin-bottom:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.01em}.card-meta{display:flex;justify-content:space-between;align-items:center;font-size:11px;color:var(--text-muted);margin-bottom:8px}.card-creator{color:var(--text-secondary);font-weight:500;display:flex;align-items:center;gap:4px}.card-category{align-self:flex-start;font-size:10px;color:var(--accent-secondary);background:#a78bfa1a;border:1px solid rgba(167,139,250,.15);padding:3px 8px;border-radius:4px;margin-bottom:8px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.card-category[data-category=fire]{color:#fb923c;background:#fb923c1a;border-color:#fb923c26}.card-category[data-category=smoke]{color:#9ca3b4;background:#9ca3b414;border-color:#9ca3b426}.card-category[data-category=magic]{color:#a78bfa;background:#a78bfa1a;border-color:#a78bfa26}.card-category[data-category=nature]{color:#34d399;background:#34d3991a;border-color:#34d39926}.card-category[data-category=scifi]{color:#22d3ee;background:#22d3ee1a;border-color:#22d3ee26}.card-category[data-category=abstract]{color:#f472b6;background:#f472b61a;border-color:#f472b626}.card-category[data-category=ui]{color:#2dd4bf;background:#2dd4bf1a;border-color:#2dd4bf26}.card-category[data-category=other]{color:#60a5fa;background:#60a5fa1a;border-color:#60a5fa26}.card-tags{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:10px}.card-tag{padding:2px 8px;background:#ffffff0a;border-radius:4px;font-size:10px;color:var(--text-muted);border:1px solid rgba(255,255,255,.06);transition:color .15s,background .15s}.card-actions{display:flex;align-items:center;gap:8px;padding-top:10px;border-top:1px solid rgba(255,255,255,.04);margin-top:auto}.card-vote-btn{display:flex;align-items:center;gap:6px;padding:6px 14px;background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:99px;color:var(--text-muted);font-size:12px;cursor:pointer;transition:all .2s;flex:1;justify-content:center}.card-vote-btn:hover{border-color:#fb71854d;color:#fb7185;background:#fb71850f;transform:translateY(-1px)}.card-vote-btn.voted{border-color:#fb718566;background:#fb71851f;color:#fb7185;box-shadow:0 0 16px #fb71851a;animation:heartPop .35s cubic-bezier(.17,.89,.32,1.49)}@keyframes heartPop{0%{transform:scale(1)}40%{transform:scale(1.15)}to{transform:scale(1)}}.vote-count{font-weight:700}.card-approve-btn,.card-reject-btn{width:34px;height:34px;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all .2s;border:1px solid var(--border-color);background:var(--bg-primary)}.card-approve-btn:hover{background:var(--success-color);color:#fff;border-color:var(--success-color)}.card-reject-btn:hover{background:var(--danger-color);color:#fff;border-color:var(--danger-color)}.marketplace-load-more{display:flex;justify-content:center;padding:40px 0}.marketplace-load-more button{padding:14px 40px;font-weight:600;border-radius:30px;background:#1e2029;border:1px solid rgba(255,255,255,.08);color:var(--text-primary);transition:all .2s}.marketplace-load-more button:hover{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;border-color:transparent;box-shadow:0 8px 20px #8b5cf64d;transform:translateY(-2px)}.profile-setup-modal-content{background:linear-gradient(145deg,var(--bg-elevated) 0%,var(--bg-secondary) 100%);border:1px solid var(--border-light);border-radius:24px;width:90%;max-width:440px;animation:scaleUp .3s cubic-bezier(.16,1,.3,1);box-shadow:0 25px 50px -12px #00000080,0 0 0 1px #ffffff0d}.profile-setup-modal-content .modal-header{padding:24px 28px 16px;border-bottom:none}.profile-setup-modal-content .modal-header h2{margin:0 0 10px;font-size:22px;font-weight:700;color:var(--text-primary);letter-spacing:-.01em}.profile-setup-modal-content .modal-subtitle{margin:0;font-size:14px;color:var(--text-secondary);line-height:1.5}.profile-setup-modal-content .modal-body{padding:16px 28px 28px}.profile-setup-modal-content .modal-footer{padding:20px 28px;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:12px;background:#0000001a}.publish-modal-content{background:linear-gradient(145deg,var(--bg-elevated) 0%,var(--bg-secondary) 100%);border:1px solid var(--border-light);border-radius:24px;width:90%;max-width:520px;max-height:90vh;display:flex;flex-direction:column;animation:scaleUp .3s cubic-bezier(.16,1,.3,1);overflow:hidden;box-shadow:0 30px 60px -15px #0009,0 0 0 1px #ffffff0d}.publish-modal-content .modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 28px;border-bottom:1px solid var(--border-color);background:#18181b66;flex-shrink:0}.publish-modal-content .modal-header h2{display:flex;align-items:center;gap:12px;margin:0;font-size:18px;font-weight:600;color:var(--text-primary)}.publish-modal-content .modal-header h2 svg{color:var(--accent-primary)}.publish-modal-content .modal-body{padding:24px 28px;overflow-y:auto;flex:1;min-height:0}.publish-preview{margin-bottom:24px}.publish-thumbnail{width:100%;aspect-ratio:16/9;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;overflow:hidden;color:var(--text-muted);box-shadow:inset 0 2px 4px #0000001a}.publish-thumbnail img{width:100%;height:100%;object-fit:cover}.publish-form{display:flex;flex-direction:column;gap:20px}.publish-notice{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;background:#8b5cf614;border:1px solid rgba(139,92,246,.15);border-radius:var(--radius-lg);font-size:13px;color:var(--text-secondary);margin-top:12px}.publish-notice svg{flex-shrink:0;margin-top:2px;color:var(--accent-primary);width:16px;height:16px}.publish-tags-section{display:flex;flex-direction:column;gap:12px}.publish-auto-tags{display:flex;flex-wrap:wrap;gap:8px}.publish-preset-tags{display:flex;flex-direction:column;gap:10px}.publish-tag{padding:6px 14px;border-radius:99px;font-size:12px;font-weight:500;transition:all .2s cubic-bezier(.4,0,.2,1)}.publish-tag.auto-tag{background:#22c55e1a;color:var(--success-color);border:1px solid rgba(34,197,94,.2)}.publish-tag.preset-tag{background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border-color);cursor:pointer}.publish-tag.preset-tag:hover{border-color:var(--border-light);color:var(--text-primary);background:var(--bg-hover);transform:translateY(-1px)}.publish-tag.preset-tag.selected{background:#3b82f626;color:#60a5fa;border-color:#3b82f666;box-shadow:0 4px 12px #3b82f633}.tag-category{display:flex;flex-direction:column;gap:6px}.tag-category-label{font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);padding-left:2px}.tag-category-tags{display:flex;flex-wrap:wrap;gap:6px}.no-auto-tags{font-size:12px;color:var(--text-muted);font-style:italic;padding:4px}.publish-modal-content .modal-footer{padding:20px 28px;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:12px;background:#0000001a;flex-shrink:0}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:13px;font-weight:600;color:var(--text-primary);margin-left:2px}.input-field{padding:12px 14px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);color:var(--text-primary);font-size:14px;transition:all .2s;box-shadow:inset 0 2px 4px #0000001a}.input-field:focus{outline:none;border-color:var(--accent-primary);background:var(--bg-secondary);box-shadow:0 0 0 3px #8b5cf626}.input-field::placeholder{color:var(--text-muted)}.input-field.input-error{border-color:var(--danger-color);box-shadow:0 0 0 3px #ef444426}.select-field{padding:12px 40px 12px 14px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);color:var(--text-primary);font-size:14px;cursor:pointer;transition:all .2s;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url(data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22%2371717a%22%20stroke-width%3D%222%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%3Cpath%20d%3D%22m6%209%206%206%206-6%22%2F%3E%3C%2Fsvg%3E);background-repeat:no-repeat;background-position:right 14px center;background-size:16px}.select-field:focus{outline:none;border-color:var(--accent-primary)}.form-hint{font-size:12px;color:var(--text-muted);margin-left:2px}.form-error{font-size:13px;color:var(--danger-color);padding:10px 14px;background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-md);display:flex;align-items:center;gap:8px}.form-error:before{content:"⚠️";font-size:14px}.form-error.hidden{display:none}.btn-loading{pointer-events:none;opacity:.8}.btn-spinner{display:flex;align-items:center;justify-content:center}.btn-spinner.hidden{display:none}.btn-spinner .spinner{width:20px;height:20px;animation:spin 1s linear infinite;color:currentColor}.marketplace-toast,.publish-toast,.cloud-toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%) translateY(100px);background:var(--bg-elevated);border:1px solid var(--border-light);border-radius:99px;padding:12px 24px;font-size:14px;font-weight:500;color:var(--text-primary);box-shadow:0 10px 30px #00000080,0 0 0 1px #ffffff0d;z-index:10001;opacity:0;transition:all .4s cubic-bezier(.16,1,.3,1);display:flex;align-items:center;gap:10px}.marketplace-toast:before,.publish-toast:before,.cloud-toast:before{content:"✓";display:flex;align-items:center;justify-content:center;width:18px;height:18px;background:var(--success-color);color:#000;border-radius:50%;font-size:10px;font-weight:900}.marketplace-toast.show,.publish-toast.show,.cloud-toast.show{transform:translate(-50%) translateY(0);opacity:1}.marketplace-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 24px;text-align:center;animation:fadeIn .3s ease}.marketplace-empty.hidden{display:none}.marketplace-empty svg{color:var(--text-muted);opacity:.3;margin-bottom:16px}.marketplace-empty p{font-size:15px;color:var(--text-secondary);margin:0;line-height:1.6}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.signin-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000bf;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:10002;display:flex;align-items:center;justify-content:center;animation:signinFadeIn .25s ease}@keyframes signinFadeIn{0%{opacity:0}to{opacity:1}}@keyframes signinCardIn{0%{opacity:0;transform:translateY(16px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.signin-card{position:relative;background:linear-gradient(165deg,#1e2030fa,#10111afa);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:40px 36px 32px;max-width:380px;width:90%;text-align:center;box-shadow:0 24px 48px -12px #0009,0 0 0 1px #8b5cf614 inset,0 -1px #ffffff0d inset;animation:signinCardIn .35s cubic-bezier(.16,1,.3,1)}.signin-close{position:absolute;top:14px;right:14px;background:#ffffff0f;border:1px solid rgba(255,255,255,.08);color:var(--text-muted);cursor:pointer;padding:6px;display:flex;align-items:center;justify-content:center;border-radius:10px;transition:all .2s ease}.signin-close:hover{background:#ffffff1a;color:var(--text-primary)}.signin-icon{width:56px;height:56px;margin:0 auto 20px;background:linear-gradient(135deg,#8b5cf626,#6366f11a);border:1px solid rgba(139,92,246,.2);border-radius:16px;display:flex;align-items:center;justify-content:center;color:var(--accent-secondary)}.signin-title{margin:0 0 8px;font-size:22px;font-weight:700;color:var(--text-primary);letter-spacing:-.3px}.signin-message{margin:0 0 28px;font-size:14px;color:var(--text-secondary);line-height:1.5}.signin-google-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:12px 20px;background:#fff;color:#3c4043;border:none;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #00000026}.signin-google-btn:hover{background:#f7f8f8;box-shadow:0 4px 16px #0003;transform:translateY(-1px)}.signin-google-btn:active{transform:translateY(0);box-shadow:0 1px 4px #00000026}.signin-subtext{margin:14px 0 0;font-size:12px;color:var(--text-muted)}.signin-cancel{margin-top:8px;background:none;border:none;color:var(--text-muted);font-size:13px;cursor:pointer;padding:8px 16px;transition:color .15s}.signin-cancel:hover{color:var(--text-secondary)}.marketplace-loading{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-primary);z-index:20;gap:16px;animation:fadeIn .2s ease}.marketplace-loading.hidden{display:none}.loading-spinner{width:48px;height:48px;color:var(--accent-primary);animation:spin 1s linear infinite}.loading-spinner svg{width:100%;height:100%;display:block}.marketplace-loading p{font-size:15px;font-weight:500;color:var(--text-secondary);margin:0}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}/*! Pickr 1.9.1 MIT | https://github.com/Simonwep/pickr */.pickr{position:relative;overflow:visible;transform:translateY(0)}.pickr *{box-sizing:border-box;outline:none;border:none;-webkit-appearance:none}.pickr .pcr-button{position:relative;height:2em;width:2em;padding:.5em;cursor:pointer;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;border-radius:.15em;background:url('data:image/svg+xml;utf8, <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 50 50" stroke="%2342445A" stroke-width="5px" stroke-linecap="round"><path d="M45,45L5,5"></path><path d="M45,5L5,45"></path></svg>') no-repeat center;background-size:0;transition:all .3s}.pickr .pcr-button:before{position:absolute;content:"";top:0;left:0;width:100%;height:100%;background:url('data:image/svg+xml;utf8, <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 2 2"><path fill="white" d="M1,0H2V1H1V0ZM0,1H1V2H0V1Z"/><path fill="gray" d="M0,0H1V1H0V0ZM1,1H2V2H1V1Z"/></svg>');background-size:.5em;border-radius:.15em;z-index:-1}.pickr .pcr-button:before{z-index:initial}.pickr .pcr-button:after{position:absolute;content:"";top:0;left:0;height:100%;width:100%;transition:background .3s;background:var(--pcr-color);border-radius:.15em}.pickr .pcr-button.clear{background-size:70%}.pickr .pcr-button.clear:before{opacity:0}.pickr .pcr-button.clear:focus{box-shadow:0 0 0 1px #ffffffd9,0 0 0 3px var(--pcr-color)}.pickr .pcr-button.disabled{cursor:not-allowed}.pickr *,.pcr-app *{box-sizing:border-box;outline:none;border:none;-webkit-appearance:none}.pickr input:focus,.pickr input.pcr-active,.pickr button:focus,.pickr button.pcr-active,.pcr-app input:focus,.pcr-app input.pcr-active,.pcr-app button:focus,.pcr-app button.pcr-active{box-shadow:0 0 0 1px #ffffffd9,0 0 0 3px var(--pcr-color)}.pickr .pcr-palette,.pickr .pcr-slider,.pcr-app .pcr-palette,.pcr-app .pcr-slider{transition:box-shadow .3s}.pickr .pcr-palette:focus,.pickr .pcr-slider:focus,.pcr-app .pcr-palette:focus,.pcr-app .pcr-slider:focus{box-shadow:0 0 0 1px #ffffffd9,0 0 0 3px #00000040}.pcr-app{position:fixed;display:flex;flex-direction:column;z-index:10000;border-radius:.1em;background:#fff;opacity:0;visibility:hidden;transition:opacity .3s,visibility 0s .3s;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;box-shadow:0 .15em 1.5em #0000001a,0 0 1em #00000008;left:0;top:0}.pcr-app.visible{transition:opacity .3s;visibility:visible;opacity:1}.pcr-app .pcr-swatches{display:flex;flex-wrap:wrap;margin-top:.75em}.pcr-app .pcr-swatches.pcr-last{margin:0}@supports (display: grid){.pcr-app .pcr-swatches{display:grid;align-items:center;grid-template-columns:repeat(auto-fit,1.75em)}}.pcr-app .pcr-swatches>button{font-size:1em;position:relative;width:calc(1.75em - 5px);height:calc(1.75em - 5px);border-radius:.15em;cursor:pointer;margin:2.5px;flex-shrink:0;justify-self:center;transition:all .15s;overflow:hidden;background:#0000;z-index:1}.pcr-app .pcr-swatches>button:before{position:absolute;content:"";top:0;left:0;width:100%;height:100%;background:url('data:image/svg+xml;utf8, <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 2 2"><path fill="white" d="M1,0H2V1H1V0ZM0,1H1V2H0V1Z"/><path fill="gray" d="M0,0H1V1H0V0ZM1,1H2V2H1V1Z"/></svg>');background-size:6px;border-radius:.15em;z-index:-1}.pcr-app .pcr-swatches>button:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:var(--pcr-color);border:1px solid rgba(0,0,0,.05);border-radius:.15em;box-sizing:border-box}.pcr-app .pcr-swatches>button:hover{filter:brightness(1.05)}.pcr-app .pcr-swatches>button:not(.pcr-active){box-shadow:none}.pcr-app .pcr-interaction{display:flex;flex-wrap:wrap;align-items:center;margin:0 -.2em}.pcr-app .pcr-interaction>*{margin:0 .2em}.pcr-app .pcr-interaction input{letter-spacing:.07em;font-size:.75em;text-align:center;cursor:pointer;color:#75797e;background:#f1f3f4;border-radius:.15em;transition:all .15s;padding:.45em .5em;margin-top:.75em}.pcr-app .pcr-interaction input:hover{filter:brightness(.975)}.pcr-app .pcr-interaction input:focus{box-shadow:0 0 0 1px #ffffffd9,0 0 0 3px #4285f4bf}.pcr-app .pcr-interaction .pcr-result{color:#75797e;text-align:left;flex:1 1 8em;min-width:8em;transition:all .2s;border-radius:.15em;background:#f1f3f4;cursor:text}.pcr-app .pcr-interaction .pcr-result::-moz-selection{background:#4285f4;color:#fff}.pcr-app .pcr-interaction .pcr-result::selection{background:#4285f4;color:#fff}.pcr-app .pcr-interaction .pcr-type.active{color:#fff;background:#4285f4}.pcr-app .pcr-interaction .pcr-save,.pcr-app .pcr-interaction .pcr-cancel,.pcr-app .pcr-interaction .pcr-clear{color:#fff;width:auto}.pcr-app .pcr-interaction .pcr-save,.pcr-app .pcr-interaction .pcr-cancel,.pcr-app .pcr-interaction .pcr-clear{color:#fff}.pcr-app .pcr-interaction .pcr-save:hover,.pcr-app .pcr-interaction .pcr-cancel:hover,.pcr-app .pcr-interaction .pcr-clear:hover{filter:brightness(.925)}.pcr-app .pcr-interaction .pcr-save{background:#4285f4}.pcr-app .pcr-interaction .pcr-clear,.pcr-app .pcr-interaction .pcr-cancel{background:#f44250}.pcr-app .pcr-interaction .pcr-clear:focus,.pcr-app .pcr-interaction .pcr-cancel:focus{box-shadow:0 0 0 1px #ffffffd9,0 0 0 3px #f44250bf}.pcr-app .pcr-selection .pcr-picker{position:absolute;height:18px;width:18px;border:2px solid #fff;border-radius:100%;-webkit-user-select:none;-moz-user-select:none;user-select:none}.pcr-app .pcr-selection .pcr-color-palette,.pcr-app .pcr-selection .pcr-color-chooser,.pcr-app .pcr-selection .pcr-color-opacity{position:relative;-webkit-user-select:none;-moz-user-select:none;user-select:none;display:flex;flex-direction:column;cursor:grab;cursor:-webkit-grab}.pcr-app .pcr-selection .pcr-color-palette:active,.pcr-app .pcr-selection .pcr-color-chooser:active,.pcr-app .pcr-selection .pcr-color-opacity:active{cursor:grabbing;cursor:-webkit-grabbing}.pcr-app[data-theme=nano]{width:14.25em;max-width:95vw}.pcr-app[data-theme=nano] .pcr-swatches{margin-top:.6em;padding:0 .6em}.pcr-app[data-theme=nano] .pcr-interaction{padding:0 .6em .6em}.pcr-app[data-theme=nano] .pcr-selection{display:grid;grid-gap:.6em;grid-template-columns:1fr 4fr;grid-template-rows:5fr auto auto;align-items:center;height:10.5em;width:100%;align-self:flex-start}.pcr-app[data-theme=nano] .pcr-selection .pcr-color-preview{grid-area:2/1/4/1;height:100%;width:100%;display:flex;flex-direction:row;justify-content:center;margin-left:.6em}.pcr-app[data-theme=nano] .pcr-selection .pcr-color-preview .pcr-last-color{display:none}.pcr-app[data-theme=nano] .pcr-selection .pcr-color-preview .pcr-current-color{position:relative;background:var(--pcr-color);width:2em;height:2em;border-radius:50em;overflow:hidden}.pcr-app[data-theme=nano] .pcr-selection .pcr-color-preview .pcr-current-color:before{position:absolute;content:"";top:0;left:0;width:100%;height:100%;background:url('data:image/svg+xml;utf8, <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 2 2"><path fill="white" d="M1,0H2V1H1V0ZM0,1H1V2H0V1Z"/><path fill="gray" d="M0,0H1V1H0V0ZM1,1H2V2H1V1Z"/></svg>');background-size:.5em;border-radius:.15em;z-index:-1}.pcr-app[data-theme=nano] .pcr-selection .pcr-color-palette{grid-area:1/1/2/3;width:100%;height:100%;z-index:1}.pcr-app[data-theme=nano] .pcr-selection .pcr-color-palette .pcr-palette{border-radius:.15em;width:100%;height:100%}.pcr-app[data-theme=nano] .pcr-selection .pcr-color-palette .pcr-palette:before{position:absolute;content:"";top:0;left:0;width:100%;height:100%;background:url('data:image/svg+xml;utf8, <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 2 2"><path fill="white" d="M1,0H2V1H1V0ZM0,1H1V2H0V1Z"/><path fill="gray" d="M0,0H1V1H0V0ZM1,1H2V2H1V1Z"/></svg>');background-size:.5em;border-radius:.15em;z-index:-1}.pcr-app[data-theme=nano] .pcr-selection .pcr-color-chooser{grid-area:2/2/2/2}.pcr-app[data-theme=nano] .pcr-selection .pcr-color-opacity{grid-area:3/2/3/2}.pcr-app[data-theme=nano] .pcr-selection .pcr-color-chooser,.pcr-app[data-theme=nano] .pcr-selection .pcr-color-opacity{height:.5em;margin:0 .6em}.pcr-app[data-theme=nano] .pcr-selection .pcr-color-chooser .pcr-picker,.pcr-app[data-theme=nano] .pcr-selection .pcr-color-opacity .pcr-picker{top:50%;transform:translateY(-50%)}.pcr-app[data-theme=nano] .pcr-selection .pcr-color-chooser .pcr-slider,.pcr-app[data-theme=nano] .pcr-selection .pcr-color-opacity .pcr-slider{flex-grow:1;border-radius:50em}.pcr-app[data-theme=nano] .pcr-selection .pcr-color-chooser .pcr-slider{background:linear-gradient(to right,red,#ff0,#0f0,#0ff,#00f,#f0f,red)}.pcr-app[data-theme=nano] .pcr-selection .pcr-color-opacity .pcr-slider{background:linear-gradient(to right,transparent,black),url('data:image/svg+xml;utf8, <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 2 2"><path fill="white" d="M1,0H2V1H1V0ZM0,1H1V2H0V1Z"/><path fill="gray" d="M0,0H1V1H0V0ZM1,1H2V2H1V1Z"/></svg>');background-size:100%,.25em}
