body{color:#e8e8e8;background:#0a0a0a;margin:0}*{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0a0a0a;--surface:#141414;--surface-hover:#1a1a1a;--border:#2a2a2a;--text:#e8e8e8;--text-dim:#888;--accent:#c8956c;--accent-hover:#d4a57e;--radius:8px}body{background:var(--bg);color:var(--text);height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;overflow:hidden}#root{height:100vh}.app{flex-direction:column;height:100vh;display:flex}.header{border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:16px;padding:12px 24px;display:flex;position:relative}.logo{letter-spacing:.5px;color:var(--accent);font-size:18px;font-weight:600}.file-name{color:var(--text-dim);font-size:13px}.main{flex:1;display:flex;overflow:hidden}.canvas-area{background:var(--bg);flex:1;justify-content:center;align-items:center;transition:background .2s;display:flex;position:relative}.canvas-area.dragging{outline:2px dashed var(--accent);outline-offset:-8px;background:#0f1a14}.canvas-area.empty{cursor:pointer}.preview-canvas{object-fit:contain;width:auto;max-width:100%;height:auto;max-height:100%;display:none}.preview-canvas.visible{display:block}.export-preview{object-fit:contain;max-width:100%;max-height:100%}.drop-prompt{color:var(--text-dim);flex-direction:column;align-items:center;gap:12px;display:flex}.drop-icon{opacity:.4}.drop-prompt p{font-size:16px}.drop-prompt span{opacity:.5;font-size:13px}.sidebar{border-left:1px solid var(--border);flex-direction:column;flex-shrink:0;gap:8px;width:280px;padding:16px;display:flex;overflow-y:auto}.panel{background:var(--surface);border-radius:var(--radius);padding:16px}.panel-title{text-transform:uppercase;letter-spacing:1px;color:var(--text-dim);margin-bottom:12px;font-size:11px;font-weight:500}.btn{cursor:pointer;border:none;border-radius:6px;justify-content:center;align-items:center;padding:8px 16px;font-size:13px;font-weight:500;transition:all .15s;display:inline-flex}.btn-primary{background:var(--accent);color:#000}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:var(--surface-hover);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:#222}.btn:disabled{opacity:.4;cursor:not-allowed}.full-width{width:100%}.preset-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.preset-btn{background:var(--surface-hover);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:6px;padding:10px 8px;font-size:12px;font-weight:500;transition:all .15s}.preset-btn:hover:not(:disabled){background:#222;border-color:#444}.preset-btn.active{border-color:var(--accent);color:var(--accent);background:#c8956c1a}.preset-btn:disabled{opacity:.4;cursor:not-allowed}.slider-row{align-items:center;gap:12px;display:flex}.slider{appearance:none;background:var(--border);border-radius:2px;outline:none;flex:1;height:4px}.slider::-webkit-slider-thumb{-webkit-appearance:none;background:var(--accent);cursor:pointer;border-radius:50%;width:14px;height:14px;transition:transform .15s}.slider::-webkit-slider-thumb:active{transform:scale(1.2)}.slider:disabled{opacity:.4}.slider-value{color:var(--text-dim);text-align:right;font-variant-numeric:tabular-nums;min-width:36px;font-size:12px}.header-actions{gap:8px;margin-left:auto;display:flex}.btn-small{padding:5px 12px;font-size:12px}.btn-ghost{color:var(--text-dim);border:1px solid var(--border);background:0 0}.btn-ghost:hover{background:var(--surface-hover);color:var(--text)}.btn-active{color:var(--accent);border:1px solid var(--accent);background:#c8956c26}.lut-layer{background:var(--bg);border-radius:6px;margin-bottom:8px;padding:10px}.lut-layer-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.lut-layer-name{color:var(--text);font-size:12px;font-weight:500}.lut-layer-actions{gap:4px;display:flex}.btn-icon{border:1px solid var(--border);width:22px;height:22px;color:var(--text-dim);cursor:pointer;background:0 0;border-radius:4px;justify-content:center;align-items:center;padding:0;font-size:10px;transition:all .15s;display:flex}.btn-icon:hover:not(:disabled){background:var(--surface-hover);color:var(--text)}.btn-icon:disabled{opacity:.3;cursor:not-allowed}.btn-icon-danger:hover:not(:disabled){color:#dc3c3c;background:#dc3c3c33;border-color:#dc3c3c66}.mt-8{margin-top:8px}.slider-group{margin-bottom:12px}.slider-group:last-child{margin-bottom:0}.slider-label{color:var(--text-dim);justify-content:space-between;margin-bottom:6px;font-size:12px;display:flex}.split-line{background:var(--accent);cursor:col-resize;z-index:10;width:3px;position:absolute;top:0;bottom:0;transform:translate(-50%)}.split-handle{background:var(--accent);border:2px solid #fff;border-radius:50%;width:28px;height:28px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 2px 8px #0006}.split-line:before,.split-line:after{content:"";border:5px solid #0000;width:0;height:0;position:absolute;left:50%;transform:translate(-50%)}.split-line:before{border-bottom-color:#fff;margin-top:-24px;top:50%}.split-line:after{border-top-color:#fff;margin-top:14px;top:50%}.share-toast{background:var(--accent);color:#000;z-index:20;white-space:nowrap;border-radius:6px;margin-top:4px;padding:6px 14px;font-size:12px;font-weight:500;animation:.2s ease-out toast-in;position:absolute;top:100%;right:24px}@keyframes toast-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.export-format,.mode-toggle{background:var(--bg);border-radius:6px;gap:4px;padding:3px;display:flex}.mode-btn{color:var(--text-dim);cursor:pointer;background:0 0;border:none;border-radius:4px;flex:1;padding:6px 8px;font-size:11px;font-weight:500;transition:all .15s}.mode-btn:hover{color:var(--text)}.mode-btn-active{background:var(--accent);color:#000}.slider-sub{color:var(--text-dim);opacity:.6;margin-left:4px;font-size:10px}.music-search-wrap{align-items:center;display:flex;position:relative}.music-search-input::-webkit-search-cancel-button{appearance:none}.music-search-input::-webkit-search-decoration{appearance:none}.music-search-input{background:var(--bg);border:1px solid var(--border);width:100%;color:var(--text);border-radius:8px;outline:none;padding:10px 32px 10px 12px;font-size:13px;transition:border-color .15s}.music-search-input:focus{border-color:var(--accent)}.music-search-input::placeholder{color:var(--text-dim);font-size:11px}.music-search-clear{width:24px;height:24px;color:var(--text-dim);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:16px;transition:all .15s;display:flex;position:absolute;top:50%;right:6px;transform:translateY(-50%)}.music-search-clear:hover{background:var(--surface-hover);color:var(--text)}.music-status{color:var(--text-dim);align-items:center;gap:6px;padding:8px 0 4px;font-size:11px;display:flex}.spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:12px;height:12px;animation:.6s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.music-results{flex-direction:column;gap:4px;max-height:240px;margin-top:8px;display:flex;overflow-y:auto}.music-result-item{background:var(--bg);border:1px solid var(--border);cursor:pointer;text-align:left;color:var(--text);border-radius:6px;align-items:center;gap:8px;padding:6px 8px;transition:all .15s;display:flex}.music-result-item:hover{background:var(--surface-hover);border-color:#444}.music-result-cover{object-fit:cover;border-radius:4px;flex-shrink:0;width:36px;height:36px}.music-result-info{min-width:0}.music-result-title{white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:500;overflow:hidden}.music-result-artist{color:var(--accent);white-space:nowrap;text-overflow:ellipsis;font-size:11px;font-weight:500;overflow:hidden}.music-track-detail{flex-direction:column;gap:10px;margin-top:12px;display:flex}.music-track-header{gap:10px;display:flex}.music-track-cover{object-fit:cover;border-radius:6px;flex-shrink:0;width:64px;height:64px}.music-track-meta{min-width:0}.music-track-title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.music-track-artist{color:var(--text-dim);font-size:12px}.music-track-album{color:var(--text-dim);opacity:.7;font-size:11px}.music-track-bpm{color:var(--accent);margin-top:2px;font-size:11px}.music-tags{flex-wrap:wrap;gap:4px;display:flex}.music-tag{background:var(--bg);border:1px solid var(--border);color:var(--text-dim);border-radius:10px;padding:2px 6px;font-size:10px}.music-colors{gap:4px;display:flex}.music-color-swatch{border:1px solid var(--border);border-radius:4px;width:20px;height:20px}.music-embed{border-radius:8px;overflow:hidden}.music-embed iframe{border-radius:8px;display:block}.audio-controls{flex-shrink:0;align-items:center;gap:6px;display:flex}.audio-status{align-items:center;display:flex}.audio-status-text{color:var(--text-dim);opacity:.5;font-size:10px}.mute-btn{background:var(--bg);border:1px solid var(--border);width:40px;height:40px;color:var(--text-dim);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:all .2s;display:flex}.mute-btn:hover{background:var(--surface-hover);color:var(--text)}.mute-btn.muted{animation:2s ease-in-out infinite mute-pulse}.mute-btn.unmuted{background:var(--accent);color:#000;border-color:var(--accent)}@keyframes mute-pulse{0%,to{border-color:var(--border)}50%{border-color:var(--accent);box-shadow:0 0 8px #c8956c4d}}.export-label{color:var(--text-dim);justify-content:space-between;align-items:center;margin:10px 0 6px;font-size:11px;display:flex}.export-style-grid{grid-template-columns:repeat(3,1fr);gap:4px;display:grid}.export-style-btn{background:var(--bg);border:1px solid var(--border);color:var(--text-dim);cursor:pointer;border-radius:4px;padding:6px 4px;font-size:10px;font-weight:500;transition:all .15s}.export-style-btn:hover{color:var(--text);border-color:#444}.export-style-active{background:var(--accent);color:#000;border-color:var(--accent)}.export-toggle-label{color:var(--text-dim);cursor:pointer;align-items:center;gap:4px;font-size:10px;display:flex}.export-toggle-label input[type=checkbox]{accent-color:var(--accent)}.exif-inputs{flex-direction:column;gap:4px;margin-top:4px;display:flex}.exif-input{background:var(--bg);border:1px solid var(--border);width:100%;color:var(--text);border-radius:4px;outline:none;padding:5px 8px;font-size:11px}.exif-input:focus{border-color:var(--accent)}.exif-input::placeholder{color:var(--text-dim);opacity:.5}.exif-row{gap:4px;display:flex}.exif-row .exif-input{flex:1}.sheet-handle-area{display:none}@media (width<=768px){.main{flex-direction:column;position:relative}.canvas-area{flex:none;height:60vh;min-height:200px}.sidebar{background:var(--surface);z-index:100;-webkit-overflow-scrolling:touch;border-top:none;border-left:none;border-radius:16px 16px 0 0;width:100%;transition:height .3s,max-height .3s;position:fixed;bottom:0;left:0;right:0;overflow-y:auto;box-shadow:0 -4px 20px #0006}.sidebar.sheet-min{height:60px;max-height:60px;overflow:hidden}.sidebar.sheet-half{height:45vh;max-height:45vh}.sidebar.sheet-full{height:85vh;max-height:85vh}.sheet-handle-area{z-index:10;background:var(--surface);touch-action:none;border-radius:16px 16px 0 0;flex-direction:column;align-items:center;padding:8px 16px 4px;display:flex;position:sticky;top:0}.sheet-handle{background:var(--border);border-radius:2px;width:36px;height:4px;margin-bottom:8px}.sheet-tabs{gap:0;width:100%;display:flex}.sheet-tab{color:var(--text-dim);letter-spacing:.5px;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:8px 4px;font-size:11px;font-weight:600;transition:all .15s}.sheet-tab-active{color:var(--accent);border-bottom-color:var(--accent)}.mode-toggle{display:none}.slider{height:6px}.slider::-webkit-slider-thumb{width:22px;height:22px}.slider-group{flex-direction:column;justify-content:center;min-height:44px;display:flex}.header{padding:8px 16px}.logo{font-size:15px}.btn-small{padding:4px 8px;font-size:11px}.drop-prompt p{font-size:14px}.drop-prompt span{display:none}.music-search-input{padding:12px 36px 12px 14px;font-size:16px}.music-search-clear{width:32px;height:32px;font-size:20px}.music-results{max-height:50vh;overflow-y:auto}.music-result-item{min-height:52px;padding:10px 12px}.music-result-cover{width:44px;height:44px}.sidebar.sheet-full .panel{overflow:visible}.export-style-grid{grid-template-columns:repeat(3,1fr)}.panel{padding:12px}.panel-title{margin-bottom:8px}}
