:root{--bg-primary: #0a0a0f;--bg-secondary: #12121a;--bg-tertiary: #1a1a24;--bg-elevated: #22222e;--text-primary: #f0f0f5;--text-secondary: #8888a0;--text-muted: #55556a;--accent-primary: #e53935;--accent-secondary: #ff5252;--accent-glow: rgba(229, 57, 53, .4);--accent-alt: #35d4ff;--accent-alt-glow: rgba(53, 212, 255, .3);--border-subtle: rgba(255, 255, 255, .06);--border-active: rgba(229, 57, 53, .3);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 20px;--radius-xl: 28px;--font-display: "Outfit", sans-serif;--font-mono: "JetBrains Mono", monospace;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-medium: .3s cubic-bezier(.4, 0, .2, 1);--transition-slow: .5s cubic-bezier(.4, 0, .2, 1)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-display);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app{min-height:100vh;display:flex;flex-direction:column;position:relative}.app-layout{display:flex;flex:1;position:relative;z-index:1;overflow:hidden}.left-panel{position:fixed;left:0;top:0;width:400px;height:100vh;display:flex;flex-direction:column;border-right:1px solid var(--border-subtle);background:linear-gradient(135deg,#12121af2,#0a0a0ff2);overflow:hidden;z-index:10}.left-panel-content{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden}.selectors-container{flex:1;overflow-y:auto;overflow-x:hidden;min-height:0;display:flex;flex-direction:column}.right-panel{flex:1;margin-left:400px;display:flex;flex-direction:column;overflow:hidden;background:transparent;height:100vh}.background-effects{position:fixed;top:0;right:0;bottom:0;left:0;overflow:hidden;pointer-events:none;z-index:0}.gradient-orb{position:absolute;border-radius:50%;filter:blur(120px);opacity:.5;animation:float 20s ease-in-out infinite}.orb-1{width:600px;height:600px;background:radial-gradient(circle,var(--accent-primary) 0%,transparent 70%);top:-200px;right:-100px;animation-delay:0s}.orb-2{width:500px;height:500px;background:radial-gradient(circle,var(--accent-alt) 0%,transparent 70%);bottom:-150px;left:-100px;animation-delay:-7s}.orb-3{width:400px;height:400px;background:radial-gradient(circle,#a855f7 0%,transparent 70%);top:50%;left:50%;transform:translate(-50%,-50%);animation-delay:-14s;opacity:.3}@keyframes float{0%,to{transform:translate(0) scale(1)}25%{transform:translate(30px,-30px) scale(1.05)}50%{transform:translate(-20px,20px) scale(.95)}75%{transform:translate(-30px,-20px) scale(1.02)}}.header{padding:2rem;text-align:center;position:relative;z-index:1}.logo{font-size:2rem;font-weight:700;letter-spacing:.2em;color:var(--text-primary);display:flex;align-items:center;justify-content:center;gap:.75rem}.logo-icon{color:var(--accent-primary);font-size:1.5rem;animation:pulse-once 1s ease-out forwards}.logo-icon-svg{color:var(--accent-primary);animation:pulse-once 1s ease-out forwards}@keyframes pulse-once{0%{opacity:0;transform:scale(.8)}50%{opacity:1;transform:scale(1.05)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}.tagline{font-size:.875rem;color:var(--text-muted);letter-spacing:.1em;margin-top:.5rem;font-weight:300}.main-content{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem;position:relative;z-index:1}.audio-player{width:100%;max-width:700px}.file-library{background:linear-gradient(135deg,var(--bg-tertiary) 0%,var(--bg-secondary) 100%);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:1rem 1.25rem;margin-bottom:1.5rem;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.library-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.library-icon{font-size:1rem}.library-title{font-size:.875rem;font-weight:600;color:var(--text-primary);letter-spacing:.02em}.library-count{margin-left:auto;font-family:var(--font-mono);font-size:.7rem;color:var(--text-muted);background:var(--bg-elevated);padding:.2rem .5rem;border-radius:var(--radius-sm)}.library-select-wrapper{display:flex;gap:.5rem;align-items:stretch}.library-select{flex:1;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:.625rem 2.5rem .625rem 1rem;font-family:var(--font-display);font-size:.875rem;color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%238888a0' 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 .75rem center;background-size:1rem}.library-select:hover{border-color:var(--accent-primary);background-color:#e539350d}.library-select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-glow)}.library-select option{background:var(--bg-secondary);color:var(--text-primary);padding:.5rem}.delete-file-button{display:flex;align-items:center;justify-content:center;width:38px;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;font-size:.875rem;transition:all var(--transition-fast)}.delete-file-button:hover{color:#ff4757;border-color:#ff4757;background:#ff47571a}.drop-zone{background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-tertiary) 100%);border:2px dashed var(--border-subtle);border-radius:var(--radius-xl);padding:3rem 2rem;text-align:center;cursor:pointer;transition:all var(--transition-medium);position:relative;overflow:hidden}.drop-zone:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,var(--accent-glow) 0%,transparent 50%);opacity:0;transition:opacity var(--transition-medium)}.drop-zone:not(.has-file):hover,.drop-zone.drag-over{border-color:var(--accent-primary);transform:translateY(-2px);box-shadow:0 20px 40px -20px #00000080,0 0 60px -30px var(--accent-primary)}.drop-zone:not(.has-file):hover:before,.drop-zone.drag-over:before{opacity:1}.drop-zone.has-file{border-style:solid;border-color:var(--border-subtle);cursor:default;padding:1rem}.drop-zone.has-file:hover{transform:none;box-shadow:none}.drop-prompt{position:relative;z-index:1}.drop-icon{width:64px;height:64px;margin:0 auto 1.5rem;color:var(--accent-primary);animation:bounce 2s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.drop-icon svg{width:100%;height:100%}.drop-text{font-size:1.25rem;font-weight:500;color:var(--text-primary);margin-bottom:.5rem}.drop-subtext{font-size:.875rem;color:var(--text-muted)}.file-info-with-waveform{position:relative;z-index:1;width:100%;display:flex;flex-direction:column;gap:1rem}.file-info-header{display:flex;align-items:center;gap:.75rem;padding:0 .25rem}.file-icon-static{font-size:1.5rem;color:var(--accent-primary);flex-shrink:0}.file-details{flex:1;min-width:0;text-align:left}.playback-controls{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.go-to-start-btn{width:32px;height:32px;border-radius:50%;border:1px solid var(--border-subtle);background:var(--bg-elevated);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.go-to-start-btn svg{width:14px;height:14px}.go-to-start-btn:hover{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--text-secondary)}.play-button-compact{width:40px;height:40px;border-radius:50%;border:none;background:var(--accent-primary);color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);flex-shrink:0}.play-button-compact svg{width:18px;height:18px}.play-button-compact:hover{background:var(--accent-secondary);transform:scale(1.05)}.play-button-compact.playing{background:var(--bg-elevated);border:2px solid var(--accent-primary)}.file-name{font-size:1rem;font-weight:500;color:var(--text-primary);margin-bottom:.25rem;word-break:break-all;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-duration{font-family:var(--font-mono);font-size:.75rem;color:var(--accent-primary)}.waveform-container{position:relative;height:100px;background:var(--bg-tertiary);border-radius:var(--radius-sm);overflow:hidden;cursor:pointer}.waveform-container:hover{background:var(--bg-elevated)}.waveform-time-overlay{position:absolute;bottom:0;left:0;right:0;display:flex;justify-content:space-between;padding:.25rem .5rem;font-family:var(--font-mono);font-size:.625rem;color:var(--text-muted);pointer-events:none;z-index:5;background:linear-gradient(transparent,#0000004d)}.time-current{color:var(--text-primary)}.time-total{color:var(--text-secondary)}.sliders-compact{display:flex;flex-direction:column;gap:1rem;margin-top:.75rem;padding-top:1rem;border-top:1px solid var(--border-subtle)}.slider-row{display:grid;grid-template-columns:40px 1fr 55px;align-items:end;gap:.5rem;height:36px;padding-bottom:2px}.slider-row.disabled{opacity:.5}.slider-label-compact{font-size:.65rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;line-height:1;padding-bottom:1px}.slider-track-wrapper{position:relative;height:100%;display:flex;flex-direction:column;justify-content:flex-end}.slider-bounds{position:absolute;top:0;left:0;right:0;display:flex;justify-content:space-between;pointer-events:none}.bound-label{font-family:var(--font-mono);font-size:.6rem;color:var(--text-secondary);line-height:1}.slider-graduations-compact{position:absolute;bottom:8px;left:0;right:0;height:14px;pointer-events:none}.graduation-compact{position:absolute;width:1px;height:5px;background:var(--text-secondary);opacity:.5;transform:translate(-50%);bottom:0}.graduation-compact.major{height:9px;opacity:.7}.graduation-compact.center{height:12px;width:2px;background:var(--accent-primary);opacity:1}.slider-compact{width:100%;height:6px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--bg-elevated);border-radius:3px;cursor:pointer;position:relative;z-index:1;margin:0}.slider-compact::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:12px;height:12px;background:var(--text-primary);border-radius:50%;cursor:pointer;transition:transform var(--transition-fast),background var(--transition-fast)}.slider-compact::-webkit-slider-thumb:hover{background:var(--accent-primary);transform:scale(1.2)}.slider-compact::-moz-range-thumb{width:12px;height:12px;background:var(--text-primary);border:none;border-radius:50%;cursor:pointer}.slider-compact::-moz-range-thumb:hover{background:var(--accent-primary)}.slider-compact:disabled{cursor:not-allowed;opacity:.5}.slider-value-compact{font-family:var(--font-mono);font-size:.7rem;color:var(--text-secondary);text-align:right;line-height:1;padding-bottom:1px}.reset-button-compact{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.8rem;padding:0 0 1px;opacity:.5;transition:opacity var(--transition-fast),color var(--transition-fast);line-height:1}.reset-button-compact:hover{opacity:1;color:var(--text-primary)}.reset-button-compact:disabled{cursor:not-allowed;opacity:.3}.drop-zone.is-loading{cursor:wait;border-color:var(--accent-alt)}.loading-container{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:1.5rem}.loading-spinner{width:64px;height:64px;position:relative}.spinner-svg{width:100%;height:100%;animation:rotate 1.5s linear infinite}.spinner-svg circle{stroke:var(--accent-alt);stroke-linecap:round;stroke-dasharray:90,150;stroke-dashoffset:0;animation:dash 1.5s ease-in-out infinite}@keyframes rotate{to{transform:rotate(360deg)}}@keyframes dash{0%{stroke-dasharray:1,150;stroke-dashoffset:0}50%{stroke-dasharray:90,150;stroke-dashoffset:-35}to{stroke-dasharray:90,150;stroke-dashoffset:-124}}.loading-text{font-size:1rem;font-weight:500;color:var(--text-secondary);letter-spacing:.02em;animation:pulse-text 1.5s ease-in-out infinite}@keyframes pulse-text{0%,to{opacity:.7}50%{opacity:1}}.controls-container{margin-top:2rem;background:var(--bg-secondary);border-radius:var(--radius-lg);padding:1.5rem;border:1px solid var(--border-subtle);animation:slideUp .4s ease-out}.waveform-canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1}.waveform-overlay{z-index:2;clip-path:inset(0 100% 0 0);will-change:clip-path}.waveform-playhead{position:absolute;top:0;left:0;width:2px;height:100%;background:#fff;pointer-events:none;z-index:3;transform:translate(0);will-change:transform;box-shadow:0 0 4px #ffffff80}.waveform-container{container-type:inline-size}.analyzing-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#00000080;color:var(--text-secondary);font-size:.875rem;z-index:2;animation:pulse-text 1.5s ease-in-out infinite}.waveform-container .progress-bar{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;opacity:0;pointer-events:none;z-index:3}.progress-fill{height:100%;position:absolute;top:0;left:0;z-index:2;background:linear-gradient(90deg,#e5393526,#ff52521a);border-radius:var(--radius-sm) 0 0 var(--radius-sm);transition:width .1s linear;pointer-events:none}.progress-playhead{position:absolute;top:0;bottom:0;width:2px;background:var(--accent-primary);z-index:4;pointer-events:none;transition:left .1s linear;box-shadow:0 0 8px var(--accent-glow)}.progress-playhead:before{content:"";position:absolute;top:-4px;left:50%;transform:translate(-50%);width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid var(--accent-primary)}.progress-playhead:after{content:"";position:absolute;bottom:-4px;left:50%;transform:translate(-50%);width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-bottom:6px solid var(--accent-primary)}.play-button{display:flex;align-items:center;justify-content:center;width:72px;height:72px;margin:0 auto 2rem;background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);border:none;border-radius:50%;color:#fff;cursor:pointer;transition:all var(--transition-fast);box-shadow:0 4px 20px var(--accent-glow),inset 0 1px #fff3}.play-button:hover{transform:scale(1.08);box-shadow:0 8px 30px var(--accent-glow),inset 0 1px #fff3}.play-button:active{transform:scale(.98)}.play-button svg{width:28px;height:28px}.sliders-container{display:flex;flex-direction:column;gap:1.25rem}.slider-group{background:var(--bg-tertiary);border-radius:var(--radius-md);padding:1.25rem 1.5rem}.slider-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.slider-label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:500;color:var(--text-primary)}.slider-icon{font-size:1rem}.reset-button{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;font-size:.875rem;transition:all var(--transition-fast)}.reset-button:hover{color:var(--accent-primary);border-color:var(--accent-primary);background:#e539351a}.slider-wrapper{position:relative;height:24px;background:var(--bg-elevated);border-radius:6px;margin-bottom:.75rem;overflow:hidden}.slider-graduations{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;justify-content:space-between;align-items:flex-end;padding:0 2px;pointer-events:none;z-index:1}.graduation{width:1px;height:6px;background:var(--text-secondary);opacity:.6;flex-shrink:0}.graduation.major{height:10px;background:var(--text-primary);opacity:.5}.graduation.center{height:14px;width:2px;background:var(--text-primary);opacity:.9}.slider{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;background:transparent;cursor:pointer;z-index:3;-webkit-appearance:none;-moz-appearance:none;appearance:none}.slider::-webkit-slider-runnable-track{width:100%;height:100%;background:transparent;cursor:pointer}.slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:6px;height:24px;background:var(--text-primary);border-radius:3px;cursor:pointer;box-shadow:0 0 8px #00000080;transition:transform var(--transition-fast),background var(--transition-fast)}.slider::-webkit-slider-thumb:hover{background:var(--accent-primary);transform:scaleX(1.5)}.slider::-moz-range-track{width:100%;height:100%;background:transparent;cursor:pointer}.slider::-moz-range-thumb{width:6px;height:24px;background:var(--text-primary);border:none;border-radius:3px;cursor:pointer;box-shadow:0 0 8px #00000080;transition:transform var(--transition-fast),background var(--transition-fast)}.slider::-moz-range-thumb:hover{background:var(--accent-primary)}.slider-track{position:absolute;bottom:0;left:0;height:8px;background:linear-gradient(90deg,var(--accent-primary),var(--accent-secondary));border-radius:0 0 6px 6px;transition:width .05s linear}.pitch-track{background:linear-gradient(90deg,var(--accent-alt),#67e8f9)}.slider-value{font-family:var(--font-mono);font-size:1.25rem;font-weight:600;color:var(--text-primary);text-align:center;margin-bottom:.5rem}.slider-marks{display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:.625rem;color:var(--text-muted)}.footer{padding:1.5rem;text-align:center;position:relative;z-index:1}.footer p{font-size:.75rem;color:var(--text-muted);letter-spacing:.05em}.slider-group.disabled{opacity:.6;pointer-events:none}.slider-group.disabled .slider{cursor:not-allowed}.loading-badge{margin-left:.5rem;padding:.125rem .5rem;background:#35d4ff33;border-radius:4px;font-size:.625rem;color:var(--accent-alt);animation:pulse-text 1.5s ease-in-out infinite}.marker-handle{position:absolute;top:-4px;transform:translate(-50%);z-index:15;cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none}.marker-handle:active,.marker-handle.dragging{cursor:grabbing}.marker-handle .marker-label{display:flex;align-items:center;justify-content:center;width:22px;height:22px;background:#ffc107;color:#1a1a24;font-family:var(--font-mono);font-weight:700;font-size:.75rem;border-radius:4px 4px 50% 50%;box-shadow:0 2px 8px #0006;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.marker-handle:hover .marker-label,.marker-handle.dragging .marker-label{transform:scale(1.15);box-shadow:0 4px 12px #ffc10766}.marker-handle:after{content:"";position:absolute;top:22px;left:50%;transform:translate(-50%);width:2px;height:82px;background:#ffc107;pointer-events:none}.waveform-container.dragging-marker{cursor:grabbing}.waveform-container.dragging-marker .waveform-canvas,.waveform-container.dragging-marker .progress-bar{pointer-events:none}.loop-controls{display:flex;align-items:center;gap:.5rem;margin-top:.75rem;padding:.5rem 0}.marker-btn-group{display:flex;align-items:stretch;gap:0;position:relative}.marker-btn-group:has(.marker-clear-btn) .loop-marker-btn{border-top-right-radius:0;border-bottom-right-radius:0;border-right:none}.marker-btn-group .marker-clear-btn{border-top-left-radius:0;border-bottom-left-radius:0;border-left:1px solid rgba(255,193,7,.3)}.loop-marker-btn{display:flex;align-items:center;gap:.35rem;padding:.35rem .65rem;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;font-family:var(--font-mono);font-size:.75rem;transition:all var(--transition-fast)}.loop-marker-btn:hover{border-color:#ffc107;color:#ffc107;background:#ffc1071a}.loop-marker-btn.active{border-color:#ffc107;background:#ffc10726;color:#ffc107}.loop-marker-btn .marker-letter{font-weight:700;font-size:.85rem}.loop-marker-btn .marker-time{font-size:.7rem;opacity:.8}.marker-clear-btn{display:flex;align-items:center;justify-content:center;width:24px;padding:0;background:#ffc10714;border:1px solid #ffc107;border-radius:var(--radius-sm);color:#ffc10780;cursor:pointer;font-size:.7rem;font-weight:500;transition:all var(--transition-fast)}.marker-clear-btn:hover{background:#e5393533;border-color:var(--accent-primary);color:var(--accent-primary)}.marker-clear-btn:active{background:#e539354d;transform:scale(.95)}.loop-reset-btn{display:flex;align-items:center;justify-content:center;width:26px;height:26px;padding:0;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;font-size:.75rem;transition:all var(--transition-fast)}.loop-reset-btn:hover{border-color:var(--accent-primary);color:var(--accent-primary);background:#e539351a}.loop-info{margin-left:auto;font-family:var(--font-mono);font-size:.7rem;color:#ffc107;opacity:.8}.player-footer{margin-top:2rem;text-align:center}.player-footer p{font-size:.75rem;color:var(--text-muted);letter-spacing:.05em}.shortcuts-hint{display:inline-flex;align-items:center;gap:.5rem;background:transparent;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:.4rem .75rem;font-size:.7rem;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-display)}.shortcuts-hint:hover{border-color:var(--text-secondary);color:var(--text-secondary);background:#ffffff05}.shortcuts-hint kbd{display:inline-flex;align-items:center;justify-content:center;min-width:1.4rem;height:1.4rem;padding:0 .4rem;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:4px;font-family:var(--font-mono);font-size:.65rem;color:var(--text-secondary)}.shortcuts-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .15s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.shortcuts-modal{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:1.5rem;min-width:500px;max-width:90vw;max-height:85vh;overflow-y:auto;animation:slideUp .2s ease-out;box-shadow:0 20px 50px #00000080}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.shortcuts-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem;padding-bottom:.75rem;border-bottom:1px solid var(--border-subtle)}.shortcuts-header h3{font-family:var(--font-display);font-size:1rem;font-weight:600;color:var(--text-primary);margin:0}.shortcuts-close{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;font-size:.85rem;transition:all var(--transition-fast)}.shortcuts-close:hover{border-color:var(--accent-primary);color:var(--accent-primary);background:#e539351a}.shortcuts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}.shortcut-group h4{font-family:var(--font-display);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--accent-alt);margin:0 0 .75rem}.shortcut-item{display:flex;align-items:center;gap:.5rem;margin-bottom:.6rem}.shortcut-item kbd{display:inline-flex;align-items:center;justify-content:center;min-width:1.75rem;height:1.75rem;padding:0 .5rem;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:5px;font-family:var(--font-mono);font-size:.7rem;color:var(--text-primary);box-shadow:0 2px 0 var(--border-subtle)}.shortcut-item span{font-size:.75rem;color:var(--text-secondary)}@media (max-width: 600px){.shortcuts-modal{min-width:auto;margin:1rem;padding:1rem}.shortcuts-grid{grid-template-columns:1fr;gap:1rem}}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--bg-elevated);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.audio-player-container{flex:1;padding:1.5rem;overflow-y:auto;min-height:0}.column-browser{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden;background:#12121af2}.column-browser-header{display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;border-bottom:1px solid var(--border-subtle);background:var(--bg-tertiary);flex-shrink:0}.column-browser-back{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;padding:0;background:transparent;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.column-browser-back:hover{background:var(--bg-elevated);border-color:var(--border-active);color:var(--accent-primary)}.column-browser-back svg{width:1rem;height:1rem}.column-browser-title{font-size:.9rem;font-weight:600;color:var(--text-primary);margin:0;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.column-browser-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:.75rem 1.5rem 1rem;min-height:0}.column-browser-item{width:100%;padding:.6rem .75rem;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-primary);font-size:.85rem;text-align:left;cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;margin-bottom:.25rem}.column-browser-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.column-browser-item.active{background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);color:#fff;font-weight:500}.column-browser-item-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.column-browser-empty{padding:2rem 1rem;text-align:center;color:var(--text-muted);font-size:.85rem}.app-header{display:flex;align-items:center;justify-content:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-subtle);background:linear-gradient(135deg,#1a1a24f2,#12121af2);flex-shrink:0;position:relative;overflow:hidden}.app-header:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent 0%,rgba(229,57,53,.15) 20%,transparent 40%,rgba(53,212,255,.15) 60%,transparent 80%,rgba(229,57,53,.15) 100%),linear-gradient(135deg,rgba(229,57,53,.1) 0%,transparent 25%,rgba(53,212,255,.1) 50%,transparent 75%,rgba(229,57,53,.1) 100%);filter:blur(40px);opacity:.6;pointer-events:none;z-index:0}.app-header:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,rgba(229,57,53,.4) 20%,rgba(53,212,255,.4) 50%,rgba(229,57,53,.4) 80%,transparent 100%);opacity:.5;z-index:1}.app-header-title-container{display:flex;align-items:center;justify-content:center;flex:1;position:relative;z-index:1;cursor:pointer;transition:opacity var(--transition-fast)}.app-header-title-container:hover{opacity:.8}.app-header-title{font-size:1.35rem;font-weight:600;color:var(--text-primary);margin:0;font-family:var(--font-display);letter-spacing:.03em;text-align:center;line-height:1.2}.app-header-logout{position:absolute;right:1.5rem;display:flex;align-items:center;justify-content:center;width:1.75rem;height:1.75rem;padding:0;background:transparent;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0;z-index:1}.app-header-logout:hover{background:var(--bg-elevated);border-color:var(--border-active);color:var(--accent-primary)}.app-header-logout svg{width:.875rem;height:.875rem}.app-header-spacer{width:1.75rem;flex-shrink:0}.song-header{display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;border-bottom:1px solid var(--border-subtle);background:var(--bg-tertiary);flex-shrink:0}.song-header-back{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;padding:0;background:transparent;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.song-header-back:hover{background:var(--bg-elevated);border-color:var(--border-active);color:var(--accent-primary)}.song-header-back svg{width:1rem;height:1rem}.song-header-content{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden}.song-header-folder{font-size:.7rem;font-weight:400;color:var(--text-muted);margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;opacity:.8}.song-header-title{font-size:.9rem;font-weight:600;color:var(--text-primary);margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.song-selectors{padding:1rem 1.5rem;border-bottom:1px solid var(--border-subtle);background:var(--bg-secondary);display:flex;flex-direction:column;gap:.75rem;flex-shrink:0}.song-selector-group{display:flex;align-items:center;gap:.5rem}.song-selector-group label{font-size:.85rem;color:var(--text-secondary);font-weight:500;min-width:80px}.song-select{flex:1;padding:.5rem .75rem;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.85rem;font-family:var(--font-display);cursor:pointer;transition:all var(--transition-fast)}.song-select:hover{border-color:var(--border-active)}.song-select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px var(--accent-glow)}.recording-selector{padding:0;border-bottom:1px solid var(--border-subtle);background:var(--bg-secondary);flex-shrink:0}.recording-selector-header{padding:.75rem 1.5rem .5rem}.recording-selector-title{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--text-secondary);margin:0}.recording-selector-content{padding:0 1.5rem .75rem;display:flex;flex-direction:column;gap:.25rem;overflow:visible}.recording-selector-item{width:100%;padding:.6rem .75rem;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-primary);font-size:.85rem;text-align:left;cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center}.recording-selector-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.recording-selector-item.active{background:#ffffff0d;color:var(--text-primary);font-weight:400}.recording-selector-item-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.partition-selector{padding:0;border-top:1px solid var(--border-subtle);background:var(--bg-secondary);flex-shrink:0;display:flex;flex-direction:column}.partition-selector-header{padding:.75rem 1.5rem .5rem;flex-shrink:0}.partition-selector-title{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--text-secondary);margin:0}.partition-selector-content{padding:0 1.5rem .75rem;display:flex;flex-direction:column;gap:.25rem;overflow:visible}.partition-selector-item{width:100%;padding:.6rem .75rem;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-primary);font-size:.85rem;text-align:left;cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center}.partition-selector-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.partition-selector-item.active{background:#ffffff0d;color:var(--text-primary);font-weight:400}.partition-selector-item-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pdf-viewer{display:flex;flex-direction:column;height:100%;overflow:hidden;padding:0;margin:0;background:transparent}.pdf-viewer-controls{padding:1rem 1.5rem;border-bottom:1px solid var(--border-subtle);background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-tertiary) 100%);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.pdf-selectors{display:flex;gap:1rem;flex-wrap:wrap}.pdf-selector-group{display:flex;align-items:center;gap:.5rem}.pdf-selector-group label{font-size:.85rem;color:var(--text-secondary);font-weight:500}.pdf-select{padding:.5rem .75rem;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.85rem;font-family:var(--font-display);cursor:pointer;transition:all var(--transition-fast);min-width:200px}.pdf-select:hover{border-color:var(--border-active)}.pdf-select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px var(--accent-glow)}.pdf-navigation{display:flex;align-items:center;gap:1rem}.pdf-nav-button{padding:.5rem 1rem;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.85rem;cursor:pointer;transition:all var(--transition-fast)}.pdf-nav-button:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--border-active)}.pdf-nav-button:disabled{opacity:.5;cursor:not-allowed}.pdf-page-info{font-size:.85rem;color:var(--text-secondary);font-family:var(--font-mono);min-width:80px;text-align:center}.pdf-viewer-content{flex:1;overflow-y:auto;overflow-x:hidden;display:flex;align-items:flex-start;justify-content:center;padding:0;margin:0;background:transparent}.pdf-pages-container{display:flex;flex-direction:column;align-items:center;gap:1rem;width:100%;padding:0;margin:0}.pdf-page-wrapper{position:relative;display:flex;justify-content:center;margin-bottom:1rem}.pdf-canvas{max-width:100%;height:auto;box-shadow:0 4px 20px #0000004d;border-radius:var(--radius-sm);background:#fff;display:block}.pdf-page-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);padding:1rem;background:var(--bg-elevated);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.85rem}.pdf-loading,.pdf-error,.pdf-empty,.pdf-viewer-empty{padding:2rem;text-align:center;color:var(--text-secondary);font-size:.9rem}.pdf-error{color:var(--accent-primary)}@media (max-width: 768px){.app{min-height:auto}.app-layout{flex-direction:column;overflow-y:auto;height:auto}.left-panel{position:relative;width:100%;height:auto;border-right:none;border-bottom:1px solid var(--border-subtle)}.right-panel{margin-left:0;width:100%;height:auto;overflow-y:auto}.audio-player-container{flex:0 0 auto}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;z-index:1}.login-card{background:linear-gradient(135deg,#12121af2,#0a0a0ff2);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:3rem 2.5rem;width:100%;max-width:420px;box-shadow:0 20px 60px #00000080;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.login-header{text-align:center;margin-bottom:2rem}.login-title{font-size:2rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem;font-family:var(--font-display)}.login-subtitle{font-size:.95rem;color:var(--text-secondary);font-family:var(--font-display);margin-bottom:.5rem}.login-debug-hint{margin-top:1rem;padding:.75rem 1rem;background:#35d4ff1a;border:1px solid rgba(53,212,255,.3);border-radius:var(--radius-md);font-size:.85rem;display:flex;flex-direction:column;gap:.25rem}.login-debug-label{color:var(--accent-alt);font-weight:500;font-size:.75rem;text-transform:uppercase;letter-spacing:.5px}.login-debug-password{color:var(--text-primary);font-family:var(--font-mono);font-size:.9rem;word-break:break-all}.login-form{display:flex;flex-direction:column;gap:1.25rem}.login-input-group{display:flex;flex-direction:column}.login-input{width:100%;padding:.875rem 1rem;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-primary);font-size:1rem;font-family:var(--font-display);transition:all var(--transition-fast)}.login-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-glow)}.login-input:disabled{opacity:.6;cursor:not-allowed}.login-input::placeholder{color:var(--text-muted)}.login-error{padding:.75rem 1rem;background:#e539351a;border:1px solid rgba(229,57,53,.3);border-radius:var(--radius-md);color:var(--accent-secondary);font-size:.9rem;text-align:center}.login-button{width:100%;padding:.875rem 1.5rem;background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);border:none;border-radius:var(--radius-md);color:var(--text-primary);font-size:1rem;font-weight:500;font-family:var(--font-display);cursor:pointer;transition:all var(--transition-fast);box-shadow:0 4px 12px #e539354d}.login-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 16px #e5393566}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.about-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:1000;padding:2rem;overflow-y:auto}.about-modal{background:linear-gradient(135deg,#12121afa,#0a0a0ffa);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);width:100%;max-width:800px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000080;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.about-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 2rem;border-bottom:1px solid var(--border-subtle);flex-shrink:0}.about-header-title-container{display:flex;flex-direction:column;gap:.25rem}.about-title{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin:0;font-family:var(--font-display)}.about-version-container{display:flex;flex-direction:column;gap:.125rem}.about-version{font-size:.75rem;font-weight:400;color:var(--text-muted);font-family:var(--font-mono);letter-spacing:.05em;opacity:.7}.about-build-date{font-size:.7rem;font-weight:400;color:var(--text-muted);font-family:var(--font-mono);letter-spacing:.02em;opacity:.6}.about-close{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;padding:0;background:transparent;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.about-close:hover{background:var(--bg-elevated);border-color:var(--border-active);color:var(--accent-primary)}.about-close svg{width:1rem;height:1rem}.about-content{padding:2rem;overflow-y:auto;flex:1;min-height:0}.about-section{margin-bottom:2rem}.about-section:last-child{margin-bottom:0}.about-section h2{font-size:1.2rem;font-weight:600;color:var(--text-primary);margin:0 0 1rem;font-family:var(--font-display);border-bottom:1px solid var(--border-subtle);padding-bottom:.5rem}.about-section h3{font-size:1rem;font-weight:600;color:var(--text-primary);margin:1.5rem 0 .75rem;font-family:var(--font-display)}.about-section p{font-size:.95rem;color:var(--text-secondary);line-height:1.6;margin:0 0 1rem}.about-section ul{list-style:none;padding:0;margin:0}.about-section li{font-size:.9rem;color:var(--text-secondary);line-height:1.6;margin-bottom:.75rem;padding-left:1.5rem;position:relative}.about-section li:before{content:"•";position:absolute;left:.5rem;color:var(--accent-primary);font-weight:700}.about-section li strong{color:var(--text-primary);font-weight:600}.about-section code{background:var(--bg-elevated);padding:.125rem .375rem;border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:.85em;color:var(--accent-alt)}.about-shortcuts{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;margin-top:1rem}.shortcut-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-md)}.shortcut-item kbd{display:inline-flex;align-items:center;justify-content:center;min-width:2rem;padding:.25rem .5rem;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:.75rem;font-weight:600;color:var(--text-primary);box-shadow:0 1px 2px #0000004d}.shortcut-item span{font-size:.9rem;color:var(--text-secondary);flex:1}.about-note{margin-top:1rem;padding:.75rem 1rem;background:#35d4ff1a;border:1px solid rgba(53,212,255,.3);border-radius:var(--radius-md);font-size:.9rem;color:var(--text-secondary)}.about-note strong{color:var(--accent-alt)}.about-footer{margin-top:2rem;padding-top:2rem;border-top:1px solid var(--border-subtle);text-align:center}.about-author{font-size:.85rem;color:var(--text-muted);margin:0}.about-author a{color:var(--text-secondary);text-decoration:none;transition:color var(--transition-fast)}.about-author a:hover{color:var(--accent-primary)}@media (max-width: 768px){.about-overlay{padding:1rem}.about-modal{max-height:95vh}.about-header{padding:1.25rem 1.5rem}.about-content{padding:1.5rem}.about-shortcuts{grid-template-columns:1fr}}
