:root{color-scheme:dark;--bg-color: #000000;--panel-bg: #0c0d0f;--border-color: rgba(255, 255, 255, .1);--accent-color: #00ff88;--accent-glow: 0 0 10px rgba(0, 255, 136, .2);--text-primary: #ffffff;--text-secondary: rgba(255, 255, 255, .5);--text-muted: rgba(255, 255, 255, .3);--radius-sm: 2px;--radius-md: 4px;--radius-lg: 8px;--warning-color: #ff3333}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-color);color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,monospace;font-feature-settings:"cv02","cv03","cv04","cv11","tnum";-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;letter-spacing:-.01em;overflow-x:hidden}.app-container{width:100vw;max-width:100vw;margin:0;padding:0;overflow-x:hidden}.transition-hint{margin:.25rem 0;padding:.25rem .5rem;background:#ffffff08;border-radius:4px;font-size:.75rem;opacity:.8;display:flex;align-items:center;gap:.5rem}.top-search-bar{margin:0;padding:1.5rem 2rem;background:transparent;border-bottom:1px solid var(--border-color);border-left:none;border-right:none;border-top:none;border-radius:0;width:100%}.header-content{display:flex;align-items:center;justify-content:space-between;gap:2rem;width:100%}.app-logo{height:42px;width:auto;flex-shrink:0;filter:brightness(0) invert(1)}.search-wrapper{display:flex;align-items:center;gap:1rem;flex:1;max-width:650px;background:transparent;border:none;border-bottom:2px solid rgba(255,255,255,.2);border-radius:0;padding:.75rem .5rem;transition:border-color .2s}.search-wrapper:focus-within{border-color:#fff}.search-input{background:transparent;border:none;color:var(--text-primary);width:100%;font-size:1rem;font-family:Inter,monospace;font-weight:400;outline:none;letter-spacing:.03em}h1,h2,h3,h4,h5,h6{font-family:Outfit,sans-serif;font-weight:600;letter-spacing:-.02em;color:var(--text-primary)}.search-icon{color:var(--text-secondary)}.glass{background:var(--bg-color);border:none;border-radius:0;padding:2rem;color:var(--text-primary)}button{transition:all .2s cubic-bezier(.25,.8,.25,1)}button:active{transform:scale(.96)}.app-container-single{display:none}.app-grid{display:grid;grid-template-columns:minmax(0,1fr) 400px;gap:0;width:100%;max-width:100%}.setlist-sidebar{border-left:1px solid var(--border-color);background:var(--bg-color);height:calc(100vh - 85px);overflow-y:auto}.library-section{height:calc(100vh - 85px);overflow-y:auto;overflow-x:auto}.library-section{min-height:400px}.sidebar-panel{display:flex;flex-direction:column;background:var(--panel-bg);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:0 8px 24px #0009;overflow:hidden;height:fit-content;max-height:calc(100vh - 120px);color:var(--text-primary)}.sidebar-panel-header{padding:1rem 1.25rem;border-bottom:1px solid var(--border-color);background:#0003}.sidebar-panel-content{flex:1;overflow-y:auto;padding:1rem 1.25rem}.setlist-stats-compact{display:flex;gap:.5rem;margin-bottom:1rem;overflow-x:auto}.stat-card-compact{flex:1;min-width:70px;display:flex;flex-direction:column;align-items:center;gap:.25rem;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:6px;padding:.5rem .25rem}.stat-card-compact .stat-icon{opacity:.7}.stat-card-compact .stat-content{display:flex;flex-direction:column;align-items:center;gap:.125rem}.stat-card-compact .stat-value{font-size:.875rem;font-weight:600;color:var(--text-primary)}.stat-card-compact .stat-label{font-size:.625rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px}.collapsible-section{margin-bottom:1rem}.collapsible-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.5rem .75rem;cursor:pointer;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:6px;transition:all .2s;font-size:.875rem;font-weight:500}.collapsible-header:hover{background:#ffffff14;border-color:var(--primary)}.collapsible-header-left{display:flex;align-items:center;gap:.5rem}.collapsible-toggle{font-size:.75rem;transition:transform .2s}.collapsible-toggle.expanded{transform:rotate(90deg)}.collapsible-content{margin-top:.5rem;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 1100px){.app-grid{grid-template-columns:1fr}}.section-header{display:flex;align-items:center;gap:.6rem;margin-bottom:1rem}.section-icon{color:var(--accent-color)}.track-table-container{overflow-x:auto}.track-table{width:100%;border-collapse:collapse}.track-table th{padding:.8rem .75rem;color:var(--text-secondary);font-size:.75rem;font-family:Outfit,sans-serif;font-weight:500;text-transform:uppercase;letter-spacing:.08em;border-bottom:1px solid rgba(255,255,255,.05);text-align:left;white-space:nowrap}.track-table th:nth-child(2),.track-table td:nth-child(2){min-width:140px}.track-table th:nth-child(3),.track-table td:nth-child(3){min-width:120px}.track-table th:nth-child(4),.track-table td:nth-child(4){min-width:100px}.track-table th:nth-child(5),.track-table td:nth-child(5){min-width:120px}.track-table th:nth-child(6),.track-table td:nth-child(6){min-width:110px}.track-table th:nth-child(7),.track-table td:nth-child(7){min-width:60px;text-align:center}.track-table th:nth-child(8),.track-table td:nth-child(8){min-width:100px;text-align:left}.track-table th:nth-child(9),.track-table td:nth-child(9){min-width:100px;text-align:left}.track-table th:nth-child(10),.track-table td:nth-child(10){min-width:60px;text-align:center}.track-table th:nth-child(11),.track-table td:nth-child(11){text-align:center}.track-table th:nth-child(12),.track-table td:nth-child(12){text-align:center}.track-row{border-bottom:1px solid var(--border-color);transition:background-color .1s;background:transparent;color:var(--text-primary)}.track-row:hover{background-color:#ffffff08}.track-row.is-keyboard-focused{background-color:#000;box-shadow:inset 4px 0 0 0 var(--accent-color)}.track-row.is-keyboard-focused td{border-top:1px solid rgba(255,255,255,.05);border-bottom:1px solid rgba(255,255,255,.05)}.track-row td{padding:.6rem .75rem;font-size:.85rem;font-family:Inter,monospace;vertical-align:middle;letter-spacing:.02em}.track-img{width:36px;height:36px;border-radius:var(--radius-sm);box-shadow:none;border:1px solid var(--border-color)}.track-name{font-family:Outfit,sans-serif;font-weight:600;font-size:1.05rem;color:var(--text-primary);transition:color .2s ease}.track-artist{font-size:.85rem;font-weight:400;margin-top:3px;color:var(--text-secondary)}.badge-key{padding:.2rem .5rem;background:transparent;color:var(--text-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-family:Inter,monospace;font-weight:600;font-size:.75rem}.badge-key.has-key{color:var(--accent-color);border-color:var(--accent-color)}.match-score{font-weight:700;font-size:.85rem;font-family:Inter,monospace}.match-score.high{color:var(--accent-color)}.match-score.medium{color:var(--warning-color)}.is-locked,.perfect-match{background-color:#00ff880d}.btn-icon{background:transparent;border:1px solid rgba(0,0,0,.2);color:#444;padding:.4rem;border-radius:0;cursor:pointer;transition:border-color .1s,color .1s;display:flex;align-items:center;justify-content:center}.btn-icon:hover{color:#000;border-color:#000}.btn-icon.active{background:#000;color:#fff;border-color:#000}.btn-add{background:transparent;border:1px solid var(--accent-color);color:var(--accent-color);padding:.4rem;border-radius:0;display:flex;align-items:center;justify-content:center;cursor:pointer}.btn-add:hover{background:var(--accent-color);color:#000}.lock-indicator{background:var(--accent-glow);color:var(--accent-color);padding:.25rem .75rem;border-radius:2rem;font-size:.75rem;font-weight:600;display:flex;align-items:center;gap:.5rem;cursor:pointer}.self-tag{font-size:.7rem;text-transform:uppercase;color:var(--text-secondary);font-weight:800}.import-fab{position:fixed;bottom:2rem;right:2rem}.shift-menu-trigger{background:transparent;border:none;color:var(--text-primary);font-family:Inter,monospace;font-weight:700;font-size:1rem;display:flex;align-items:center;gap:.5rem;cursor:pointer;transition:color .2s;letter-spacing:.05em;padding:.5rem}.shift-menu-trigger:hover{color:var(--accent-color)}.btn-spotify-status{background:transparent;border:1px solid rgba(255,255,255,.1);color:var(--text-primary);padding:.5rem .75rem;border-radius:20px;font-size:.7rem;font-weight:700;display:flex;align-items:center;gap:.5rem;cursor:pointer;letter-spacing:.05em;transition:all .2s ease}.btn-spotify-status:hover{border-color:#ffffff4d;background:#ffffff0d}.btn-spotify-status.connected{color:#1db954;border-color:#1db9544d}.spotify-dot{width:8px;height:8px;border-radius:50%;background:#1db954;box-shadow:0 0 8px #1db95466}.spotify-dot.gray{background:#666;box-shadow:none}.btn-logout{opacity:.7;transition:opacity .2s}.btn-logout:hover{opacity:1}.shift-menu-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9999;display:flex;justify-content:flex-end;animation:fadeInOverlay .2s ease-out}.shift-menu-panel{background:#c2c2c2;width:100%;max-width:650px;height:100vh;box-shadow:-10px 0 30px #00000080;display:flex;flex-direction:column;animation:slideInMenu .3s cubic-bezier(.16,1,.3,1);color:#1a1a1a}.shift-menu-header{padding:2rem;display:flex;justify-content:flex-end}.shift-menu-close{background:transparent;border:none;color:#000;font-family:Inter,monospace;font-weight:700;font-size:.9rem;display:flex;align-items:center;gap:.5rem;cursor:pointer;letter-spacing:.05em;transition:transform .2s}.shift-menu-close:hover{transform:scale(1.05)}.shift-menu-content{flex:1;overflow-y:auto;padding:0 2rem 2rem}.shift-menu-content .sidebar-panel{background:transparent;border:none;box-shadow:none;padding:0}.shift-menu-content .sidebar-tab{font-size:1.1rem;padding:1rem;color:#444}.shift-menu-content .sidebar-tab.active{background:transparent;color:#000}.shift5-massive-tab{font-family:Inter,sans-serif;font-size:3.8rem;font-weight:500;letter-spacing:-.04em;color:#1a1a1a;line-height:1.1;transition:opacity .2s;opacity:.8}.shift5-massive-tab:hover,.shift5-massive-tab.active{opacity:1;color:#000}.tab-superscript{font-size:1.2rem;font-weight:700;vertical-align:top;position:relative;top:-.2em;margin-left:.3rem}.shift-menu-content h3{color:#000}@keyframes fadeInOverlay{0%{opacity:0}to{opacity:1}}@keyframes slideInMenu{0%{transform:translate(100%)}to{transform:translate(0)}}.vault-popup-header{display:flex;justify-content:space-between;align-items:center;padding:2rem;border-bottom:1px solid var(--glass-border);background:linear-gradient(180deg,var(--glass-highlight) 0%,transparent 100%)}.vault-popup-header h3{margin:0;font-size:1.5rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.vault-popup-header .hint{margin:.5rem 0 0;font-size:.85rem}.sidebar-tabs{display:flex;gap:.5rem;flex:1}.sidebar-tab{display:flex;align-items:center;gap:.35rem;padding:.6rem .9rem;background:transparent;border:1px solid transparent;border-radius:.5rem;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;font-size:.85rem;font-weight:500;position:relative;flex:1;justify-content:center}.sidebar-tab:hover{background:var(--glass-highlight);color:var(--text-primary)}.sidebar-tab.active{background:#ffffff1a;border:1px solid var(--glass-border);color:var(--text-primary);box-shadow:0 4px 12px #0000001a}.sidebar-tab .tab-badge{background:var(--text-primary);color:#000;font-size:.7rem;font-weight:700;padding:2px 6px;border-radius:10px;min-width:18px;text-align:center}.vault-popup-content{flex:1;overflow-y:auto;padding:1.5rem}.vault-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;color:var(--text-secondary)}.vault-empty p{margin:.75rem 0;font-size:.95rem}.vault-item{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;margin-bottom:.5rem;border-radius:var(--radius-md);background:var(--glass-bg);border:1px solid var(--glass-border);transition:all .2s ease}.vault-item:hover{background:#ffffff14;border-color:#ffffff26;transform:translateY(-2px);box-shadow:0 4px 12px #0003}.vault-item.is-active{background:linear-gradient(135deg,#1db95433,#1db9540d);border-color:#1db95466;box-shadow:0 0 15px #1db95426}.vault-item.is-active:hover{background:linear-gradient(135deg,#1db95440,#1db9541a)}.vault-item .toggle-btn{background:transparent;border:none;cursor:pointer;display:flex;align-items:center;color:var(--text-secondary);padding:0;transition:all .2s ease}.vault-item .toggle-btn:hover{color:var(--accent-color);transform:scale(1.1)}.vault-item .list-info{flex:1;display:flex;flex-direction:column;gap:.25rem;min-width:0}.vault-item .list-name{font-weight:600;font-size:.85rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.vault-item .list-meta{font-size:.7rem;color:var(--text-secondary)}.vault-item .delete-btn{opacity:.6;transition:all .2s ease;color:#ff4444b3;padding:.35rem;border-radius:4px}.vault-item:hover .delete-btn{opacity:1;background:#ff44441a}.vault-item .delete-btn:hover{transform:scale(1.1);color:#f44;background:#f443}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInFromRight{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.vault-list-compact-grid{display:flex;flex-wrap:wrap;gap:.5rem;padding-bottom:.5rem}.vault-item-compact{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem .6rem;border-radius:0;background:transparent;border:1px solid rgba(0,0,0,.2);transition:all .2s cubic-bezier(.16,1,.3,1);flex-shrink:0;max-width:100%}.vault-item-compact.is-active{background:#000;border-color:#000;box-shadow:none}.vault-item-compact .list-name-compact{color:#000}.vault-item-compact.is-active .list-name-compact{color:#fff}.vault-item-compact .list-meta-compact{color:#00000080}.vault-item-compact.is-active .list-meta-compact{color:#fff9}.vault-item-compact .toggle-btn-compact{color:#0006}.vault-item-compact.is-active .toggle-btn-compact{color:#0f8}.vault-item-compact:hover{border-color:#000;transform:none;background:#0000000d}.vault-item-compact.is-active:hover{background:#1a1a1a}.toggle-btn-compact{background:transparent;border:none;cursor:pointer;display:flex;align-items:center;padding:2px;flex-shrink:0}.toggle-btn-compact:hover{color:var(--accent-color)}.list-info-compact{flex:1;min-width:0;display:flex;flex-direction:column;cursor:pointer}.list-name-compact{font-size:.75rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-primary)}.list-meta-compact{font-size:.6rem;color:var(--text-secondary)}.delete-btn-compact{opacity:.3;background:transparent;border:none;cursor:pointer;color:#f44c;padding:2px;flex-shrink:0;transition:all .2s}.vault-item-compact:hover .delete-btn-compact{opacity:1}.delete-btn-compact:hover{color:#f44}.setlist-stats{margin-bottom:1.5rem;padding:1rem;background:linear-gradient(135deg,#1db95414,#1db95405);border:1px solid rgba(29,185,84,.2);border-radius:var(--radius-md);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}@media (max-width: 600px){.stats-grid{grid-template-columns:repeat(2,1fr)}}.stat-card{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:#ffffff08;border-radius:8px;border:1px solid rgba(255,255,255,.05);transition:all .2s ease}.stat-card:hover{background:#ffffff0d;border-color:#ffffff1a;transform:translateY(-2px)}.stat-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:#ffffff0d;border-radius:6px;color:var(--accent-color)}.stat-content{flex:1;display:flex;flex-direction:column;gap:.25rem}.stat-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);font-weight:600}.stat-value{font-size:1.1rem;font-weight:700;color:var(--text-primary)}.transition-hint{display:flex;align-items:center;justify-content:center;padding:.5rem;margin:.5rem 0;border-radius:8px;border:1px solid transparent;transition:all .2s ease}.transition-hint.good{background:#1db95414;border-color:#1db95433}.transition-hint.moderate{background:#ffaa0014;border-color:#fa03}.transition-hint.risky{background:#ff444414;border-color:#f443}.transition-content{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;justify-content:center}.transition-metric{display:flex;align-items:center;gap:.4rem;font-size:.8rem;font-weight:600;color:var(--text-secondary)}.transition-hint.good .transition-metric{color:#1db954e6}.transition-hint.moderate .transition-metric{color:#ffaa00e6}.transition-hint.risky .transition-metric{color:#ff4444e6}@keyframes modalZoom{0%{opacity:0;transform:translate(-50%,-50%) scale(.9)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.playlist-list{display:flex;flex-direction:column;gap:.75rem}.playlist-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;border-radius:var(--radius-md);background:var(--glass-bg);border:1px solid var(--glass-border);transition:all .2s ease}.playlist-item:hover{background:#ffffff14;border-color:#ffffff26;transform:translateY(-2px);box-shadow:0 4px 12px #0003}.playlist-item .drag-handle{color:var(--text-secondary);cursor:grab;opacity:.5;transition:opacity .2s ease}.playlist-item:hover .drag-handle{opacity:1}.playlist-item .mini-img-wrapper{width:40px;height:40px;border-radius:.375rem;overflow:hidden;flex-shrink:0}.playlist-item .mini-img{width:100%;height:100%;object-fit:cover}.playlist-item-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.25rem}.playlist-item .item-name{margin:0;font-size:.9rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.playlist-item .item-artist{margin:0;font-size:.8rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.playlist-item .item-key{padding:.25rem .5rem;background:#1db95426;border:1px solid rgba(29,185,84,.3);border-radius:.375rem;font-size:.8rem;font-weight:600;color:var(--accent-color);flex-shrink:0}.dropzone{border:2px dashed var(--glass-border);padding:4rem;text-align:center;border-radius:1rem}.btn-primary{background:var(--accent-color);color:#000;border:none;padding:.6rem 1.2rem;border-radius:var(--radius-sm);font-weight:700;text-transform:uppercase;cursor:pointer;transition:background .2s;letter-spacing:.05em;font-family:Inter,monospace}.btn-primary:hover{background:linear-gradient(135deg,#1ed760e6,#14a046)}.btn-danger{background:transparent;color:var(--warning-color);border:1px solid var(--warning-color);padding:.6rem 1.2rem;border-radius:var(--radius-sm);font-weight:600;text-transform:uppercase;cursor:pointer;transition:all .2s;letter-spacing:.05em;font-family:Inter,monospace}.btn-danger:hover{transform:translateY(-2px);box-shadow:0 8px 30px #ff475733,inset 0 1px 1px #ffffff1a;background:linear-gradient(135deg,#ff475740,#ff475726);border-color:#ff475780}.btn-danger:active{transform:scale(.96)}.btn-secondary{background:transparent;color:var(--text-primary);border:1px solid var(--border-color);padding:.6rem 1.2rem;border-radius:var(--radius-sm);font-weight:600;text-transform:uppercase;cursor:pointer;transition:all .2s;letter-spacing:.05em;font-family:Inter,monospace}.btn-secondary:hover{background:#ffffff26;border-color:#ffffff4d;transform:translateY(-2px);box-shadow:0 8px 30px #0000004d,inset 0 1px 1px #ffffff26}.playlist-item{display:flex;align-items:center;gap:.75rem;padding:.5rem;margin-bottom:2px;border-radius:var(--radius-sm);background:transparent;border:1px solid transparent;border-bottom:1px solid var(--border-color);transition:background .1s}.playlist-item:hover{background:#ffffff0f;border-color:#ffffff1a;transform:translate(4px)}.mini-img{width:32px;height:32px;border-radius:6px;box-shadow:0 4px 8px #0006}.playlist-item-info{flex:1}.item-name{font-size:.85rem;font-weight:600;display:block;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;color:var(--text-primary);font-family:Outfit,sans-serif}.item-artist{font-size:.75rem;font-weight:400;color:var(--text-secondary)}.shift-menu-content .vault-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;text-align:center;background:transparent;border:1px dashed rgba(0,0,0,.2);border-radius:0;margin-bottom:2rem;color:#000}.shift-menu-content .vault-empty svg{color:#444}.shift-menu-content .vault-empty a{color:#000;text-decoration:underline}.shift-menu-content .vault-stats{background:transparent!important;border:1px solid rgba(0,0,0,.2)!important;border-radius:0!important;color:#000!important}.shift-menu-content .vault-stats .text-secondary{color:#444!important}.shift-menu-content .vault-stats .key-count{color:#000!important}.shift-menu-content .btn-primary,.shift-menu-content .btn-secondary,.shift-menu-content .btn-danger{border-radius:0;font-weight:700;letter-spacing:.05em;text-transform:uppercase;box-shadow:none}.shift-menu-content .btn-primary{background:#0f8;color:#000;border:none}.shift-menu-content .btn-secondary{background:transparent;color:#000;border:1px solid rgba(0,0,0,.2)}.shift-menu-content .btn-secondary:hover{background:#0000000d;border-color:#000}.shift-menu-content .btn-danger{background:transparent;color:#f33;border:1px solid rgba(255,51,51,.5)}.shift-menu-content .btn-danger:hover{background:#f33;color:#fff}.playlist-item.dragging{opacity:.5;transform:scale(.98)}.playlist-item{cursor:move}.playlist-item .drag-handle{cursor:grab}.playlist-item .drag-handle:active{cursor:grabbing}.mini-img-wrapper{position:relative;cursor:pointer!important}.mini-img-wrapper.is-playing{animation:pulse 1.5s ease-in-out infinite}.play-overlay-mini{position:absolute;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s ease;color:#fff}.mini-img-wrapper:hover .play-overlay-mini,.mini-img-wrapper.is-playing .play-overlay-mini{opacity:1}.setlist-header{display:flex;gap:.5rem;align-items:center;padding:.75rem 0;border-bottom:3px solid #000000;margin-bottom:.75rem}.setlist-selector{flex:1;display:flex;gap:.5rem;align-items:center}.setlist-dropdown{flex:1;background:#fff;border:2px solid #000000;border-radius:0;padding:.5rem .75rem;color:#000;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease}.setlist-dropdown:hover{background:#ffffff14;border-color:var(--accent-color)}.setlist-dropdown:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 2px #1db95433}.setlist-rename-input{flex:1;display:flex;gap:.5rem;align-items:center}.rename-input{flex:1;background:#ffffff1a;border:1px solid var(--accent-color);border-radius:6px;padding:.5rem .75rem;color:#fff;font-size:.9rem}.rename-input:focus{outline:none;box-shadow:0 0 0 2px #1db95433}.btn-sm{padding:.5rem .75rem;font-size:.85rem;white-space:nowrap}.item-key{font-size:.7rem;font-family:monospace;color:var(--accent-color);font-weight:700}.btn-remove{background:transparent;border:none;color:#ff00004d;cursor:pointer}.btn-remove:hover{color:red}.warning-box{margin:1rem;padding:.8rem 1.2rem;background:#ffab001a;border:1px solid rgba(255,171,0,.3);border-radius:8px;display:flex;align-items:center;gap:.8rem;color:#ffab00;font-size:.9rem}.text-warning{color:#ffab00}.img-wrapper{position:relative;width:48px;height:48px;border-radius:4px;overflow:hidden;background:#111}.img-wrapper img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.img-wrapper:hover img{transform:scale(1.1)}.play-overlay{position:absolute;bottom:0;right:0;width:24px;height:24px;background:var(--accent-color);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s ease;color:#000;border-top-left-radius:4px}.img-wrapper:hover .play-overlay,.img-wrapper.is-playing .play-overlay{opacity:1}.is-playing-row{background:#1db9540d!important}.mini-img-wrapper{width:32px;height:32px;border-radius:4px;overflow:hidden;flex-shrink:0}.mini-img{width:100%;height:100%;object-fit:cover}.native-audio-player{position:fixed;bottom:1.5rem;right:1.5rem;width:340px;z-index:1000;background:#0a0a0a;border:1px solid rgba(29,185,84,.4);box-shadow:0 8px 32px #000000b3;animation:slideIn .25s ease-out;overflow:hidden}.nap-header{display:flex;align-items:center;justify-content:space-between;padding:.6rem .75rem;gap:.5rem;border-bottom:1px solid rgba(255,255,255,.08)}.nap-track-info{display:flex;align-items:center;gap:.6rem;min-width:0}.nap-cover{width:36px;height:36px;object-fit:cover;flex-shrink:0}.nap-cover-fallback{background:#1a1a1a;display:flex;align-items:center;justify-content:center;color:#ffffff4d}.nap-meta{display:flex;flex-direction:column;min-width:0}.nap-name{font-size:.8rem;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family:Outfit,sans-serif}.nap-artist{font-size:.7rem;color:#ffffff73;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family:Inter,monospace}.nap-close{flex-shrink:0;background:transparent;border:1px solid rgba(255,255,255,.15);color:#fff9;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:border-color .15s,color .15s;border-radius:0}.nap-close:hover{border-color:#fff;color:#fff}.nap-open-spotify{display:inline-flex;align-items:center;gap:4px;color:#1db954;font-size:.72rem;font-weight:600;font-family:Inter,monospace;text-decoration:none;opacity:.85;transition:opacity .15s}.nap-open-spotify:hover{opacity:1}.native-audio-player audio{display:block;width:100%;height:36px;background:#111;outline:none;filter:invert(1) hue-rotate(90deg)}.spotify-full-player{position:fixed;bottom:1.5rem;right:1.5rem;width:320px;z-index:1000;background:#0a0a0a;border:1px solid rgba(29,185,84,.4);box-shadow:0 12px 40px #000000bf;animation:slideIn .25s ease-out;overflow:hidden}.sfp-header{display:flex;align-items:center;justify-content:space-between;padding:.65rem .75rem;gap:.5rem;border-bottom:1px solid rgba(255,255,255,.07)}.sfp-track-info{display:flex;align-items:center;gap:.6rem;min-width:0;flex:1}.sfp-cover{width:40px;height:40px;object-fit:cover;flex-shrink:0;border:1px solid rgba(255,255,255,.08)}.sfp-cover-fallback{background:#1a1a1a;display:flex;align-items:center;justify-content:center;color:#ffffff40}.sfp-meta{display:flex;flex-direction:column;min-width:0}.sfp-name{font-size:.82rem;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family:Outfit,sans-serif}.sfp-artist{font-size:.71rem;color:#ffffff6b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sfp-close,.sfp-spotify-link{flex-shrink:0;background:transparent;border:1px solid rgba(255,255,255,.12);color:#ffffff80;width:26px;height:26px;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:0;transition:border-color .15s,color .15s;text-decoration:none}.sfp-close:hover,.sfp-spotify-link:hover{border-color:#ffffff80;color:#fff}.sfp-spotify-link{color:#1db954;border-color:#1db95440}.sfp-spotify-link:hover{border-color:#1db954;color:#1db954}.sfp-progress-wrapper{padding:.55rem .75rem .35rem;cursor:pointer}.sfp-progress-bar{height:3px;background:#ffffff1f;position:relative;overflow:hidden}.sfp-progress-fill{height:100%;background:#1db954;transition:width .5s linear}.sfp-progress-wrapper:hover .sfp-progress-bar{height:5px}.sfp-time{display:flex;justify-content:space-between;font-size:.67rem;color:#ffffff4d;margin-top:4px;font-family:Inter,monospace}.sfp-controls{display:flex;align-items:center;justify-content:center;padding:.5rem .75rem .65rem;gap:1rem}.sfp-play-btn{background:#1db954;border:none;color:#000;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:50%;transition:transform .15s,background .15s}.sfp-play-btn:hover{transform:scale(1.1);background:#1ed760}.spotify-preview-player iframe{display:block;border-radius:12px}.close-player-btn{position:absolute;top:.5rem;right:.5rem;z-index:10;background:#000c;border:1px solid rgba(255,255,255,.2);border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;transition:all .2s ease}.close-player-btn:hover{background:#fff3;border-color:var(--accent-color);transform:scale(1.1)}@keyframes slideIn{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.pagination-controls{display:flex;justify-content:center;align-items:center;gap:1.5rem;padding:1.5rem;border-top:1px solid var(--glass-border);margin-top:1rem}.btn-pagination{background:var(--glass-bg);border:1px solid var(--glass-border);color:var(--text-primary);padding:.6rem 1.2rem;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:600;transition:all .2s ease;min-width:100px}.btn-pagination:hover:not(:disabled){background:var(--glass-highlight);border-color:#fff3;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.btn-pagination:disabled{opacity:.4;cursor:not-allowed;background:transparent;border-color:transparent}.pagination-info{font-variant-numeric:tabular-nums;font-size:.95rem;color:var(--text-secondary);font-weight:500;background:#ffffff0d;padding:.4rem 1rem;border-radius:20px}.energy-bar-container{position:relative;width:80px;height:20px;background:#ffffff0d;border-radius:10px;overflow:hidden;border:1px solid rgba(255,255,255,.1)}.energy-bar-fill{position:absolute;left:0;top:0;height:100%;border-radius:10px;transition:width .3s ease,background .3s ease;box-shadow:0 0 8px currentColor;opacity:.9}.energy-label{position:absolute;right:4px;top:50%;transform:translateY(-50%);font-size:.7rem;font-weight:700;color:var(--text-primary);text-shadow:0 1px 2px rgba(0,0,0,.8);pointer-events:none}.energy-na{color:var(--text-secondary);font-size:.85rem}.energy-filter{display:flex;align-items:center;gap:.5rem;margin-left:auto}.custom-dropdown{position:relative;z-index:50}.custom-dropdown-trigger{display:flex;align-items:center;gap:.5rem;background:#ffffff0d;border:1px solid var(--glass-border);color:var(--text-primary);padding:.5rem .85rem;border-radius:8px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .25s cubic-bezier(.25,.8,.25,1);font-family:inherit;white-space:nowrap}.custom-dropdown-trigger:hover{background:#ffffff1a;border-color:#fff3;transform:translateY(-1px);box-shadow:0 4px 12px #0003}.custom-dropdown-trigger.open{border-color:var(--accent-color);box-shadow:0 0 0 2px #1db95426}.dropdown-icon{color:var(--accent-color);flex-shrink:0}.dropdown-label{flex:1}.dropdown-chevron{color:var(--text-secondary);transition:transform .25s ease;flex-shrink:0}.dropdown-chevron.rotated{transform:rotate(180deg)}.energy-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;box-shadow:0 0 8px currentColor}.custom-dropdown-menu{position:absolute;top:calc(100% + 6px);left:0;min-width:100%;background:#141414f2;backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px);border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:.35rem;box-shadow:0 12px 40px #00000080,0 0 0 1px #ffffff0d;animation:dropdownFadeIn .2s cubic-bezier(.25,.8,.25,1);overflow:hidden}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-4px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.custom-dropdown-item{display:flex;align-items:center;gap:.6rem;width:100%;background:transparent;border:none;color:var(--text-secondary);padding:.6rem .85rem;border-radius:7px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .15s ease;font-family:inherit;white-space:nowrap}.custom-dropdown-item:hover{background:#ffffff14;color:var(--text-primary)}.custom-dropdown-item.active{background:#1db9541f;color:var(--accent-color)}.check-mark{margin-left:auto;color:var(--accent-color);font-weight:700;font-size:.9rem}.year-filter{display:flex;align-items:center;gap:.5rem;margin-left:.75rem}.year-input{background:#ffffff0d;border:1px solid var(--glass-border);color:var(--text-primary);padding:.5rem .75rem;border-radius:8px;font-size:.85rem;width:90px;text-align:center;transition:all .2s ease}.year-input::placeholder{color:var(--text-secondary);opacity:.6}.year-input:hover{background:#ffffff1a;border-color:#fff3}.year-input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 2px #1db95433}.year-separator{color:var(--text-secondary);font-weight:600}.login-gate{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem}.login-box{width:100%;max-width:400px;padding:2.5rem;display:flex;flex-direction:column;gap:2rem;animation:loginFadeIn .5s cubic-bezier(.25,.8,.25,1)}@keyframes loginFadeIn{0%{opacity:0;transform:translateY(24px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes shake{0%,to{transform:translate(0)}15%{transform:translate(-10px)}30%{transform:translate(10px)}45%{transform:translate(-8px)}60%{transform:translate(8px)}75%{transform:translate(-5px)}90%{transform:translate(5px)}}.login-box.shake{animation:shake .6s cubic-bezier(.25,.8,.25,1)}.login-logo-area{display:flex;flex-direction:column;align-items:center;gap:.75rem}.login-logo{height:52px;width:auto;filter:brightness(0) invert(1)}.login-subtitle{color:var(--text-secondary);font-size:.9rem;text-align:center}.login-form{display:flex;flex-direction:column;gap:1rem}.login-field{display:flex;align-items:center;gap:.75rem;background:#ffffff0d;border:1px solid var(--glass-border);border-radius:var(--radius-md);padding:.85rem 1rem;transition:border-color .2s,box-shadow .2s}.login-field:focus-within{border-color:var(--accent-color);box-shadow:0 0 0 3px #1db95426}.login-field-icon{color:var(--text-secondary);flex-shrink:0}.login-input{background:transparent;border:none;outline:none;color:var(--text-primary);font-size:1rem;flex:1;font-family:inherit}.login-input::placeholder{color:var(--text-secondary)}.login-pw-toggle{background:none;border:none;padding:0;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;transition:color .2s}.login-pw-toggle:hover{color:var(--text-primary)}.login-error{color:#f44;font-size:.85rem;text-align:center;padding:.5rem;background:#ff444414;border-radius:8px;border:1px solid rgba(255,68,68,.2)}.login-btn{display:flex;align-items:center;justify-content:center;gap:.6rem;background:var(--accent-color);color:#000;border:none;border-radius:var(--radius-md);padding:.9rem 1.5rem;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s ease;margin-top:.5rem;letter-spacing:.02em}.login-btn:hover{background:#22e35e;box-shadow:var(--accent-glow);transform:translateY(-2px)}.login-btn:active{transform:scale(.97) translateY(0)}.btn-logout{background:#ffffff0d;border:1px solid var(--glass-border);color:var(--text-secondary);padding:.5rem;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.btn-logout:hover{background:#ff444426;border-color:#f446;color:#f44}.vault-keys-grid{display:flex;flex-wrap:wrap;gap:.5rem}.vault-key-badge{display:inline-flex;align-items:stretch;background:#14141466;border:1px solid rgba(255,255,255,.08);border-radius:6px;overflow:hidden;transition:all .2s cubic-bezier(.25,.8,.25,1);cursor:default;box-shadow:0 2px 8px #0003}.vault-key-badge:hover{border-color:#1db95466;transform:translateY(-2px);box-shadow:0 4px 12px #1db95433}.vault-key-badge .key-label{background:#1db95426;color:var(--accent-color);padding:.35rem .6rem;font-weight:700;font-size:.75rem;letter-spacing:.05em;display:flex;align-items:center;border-right:1px solid rgba(255,255,255,.05)}.vault-key-badge .key-count{padding:.35rem .6rem;color:var(--text-secondary);font-size:.75rem;font-weight:600;display:flex;align-items:center;background:#0000004d}.key-filter-panel{display:flex;flex-direction:column;gap:1rem}.key-filter-stat{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:8px}.key-filter-stat-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.key-filter-stat-value{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.key-filter-clear{background:#1db9541a;border:1px solid rgba(29,185,84,.3);color:var(--accent-color);border-radius:6px;padding:.4rem .75rem;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s ease;text-align:left}.key-filter-clear:hover{background:#1db95433}.key-filter-grid{display:flex;flex-wrap:wrap;gap:.5rem}.key-filter-badge{display:inline-flex;align-items:stretch;background:#14141466;border:1px solid rgba(255,255,255,.08);border-radius:6px;overflow:hidden;transition:all .2s cubic-bezier(.25,.8,.25,1);cursor:pointer;box-shadow:0 2px 8px #0003;padding:0}.key-filter-badge:hover{border-color:#1db95480;transform:translateY(-2px);box-shadow:0 4px 12px #1db95440}.key-filter-badge.active{border-color:var(--accent-color);background:#1db95426;box-shadow:0 0 12px #1db9544d}.key-filter-badge.active .key-label{background:var(--accent-color);color:#000}.key-filter-badge.harmonic{border-color:#1db95459;background:#1db9540f}.key-filter-badge.dimmed{opacity:.28;filter:grayscale(.7);transform:none!important;box-shadow:none!important}.key-filter-badge .key-label{background:#1db95426;color:var(--accent-color);padding:.35rem .6rem;font-weight:700;font-size:.75rem;letter-spacing:.05em;display:flex;align-items:center;border-right:1px solid rgba(255,255,255,.05);transition:all .2s}.key-filter-badge .key-count{padding:.35rem .6rem;color:var(--text-secondary);font-size:.75rem;font-weight:600;display:flex;align-items:center;background:#0000004d}.harmonic-profile{display:flex;flex-direction:column;gap:1rem}.harmonic-group{display:flex;flex-direction:column;gap:.5rem}.harmonic-group-header{display:flex;flex-direction:column;gap:.1rem;padding-bottom:.4rem;border-bottom:1px solid rgba(255,255,255,.06)}.harmonic-group-title{font-size:.78rem;font-weight:700;letter-spacing:.02em}.harmonic-group-desc{font-size:.67rem;color:var(--text-secondary)}.key-badge-label{font-size:.6rem;color:var(--text-secondary);padding:0 .4rem 0 0;letter-spacing:.03em;white-space:nowrap}.key-filter-badge.key-cat-safety .key-label{background:#1db95433;color:#1db954f2}.key-filter-badge.key-cat-safety:hover{border-color:#1db95480;box-shadow:0 4px 10px #1db95433}.key-filter-badge.key-cat-safety.active{border-color:#1db954e6;box-shadow:0 0 12px #1db95466}.key-filter-badge.key-cat-safety.active .key-label{background:#1db954e6;color:#000}.key-filter-badge.key-cat-pro .key-label{background:#50a0ff26;color:#64b4fff2}.key-filter-badge.key-cat-pro:hover{border-color:#50a0ff80;box-shadow:0 4px 10px #50a0ff33}.key-filter-badge.key-cat-pro.active{border-color:#50a0ffe6;box-shadow:0 0 12px #50a0ff66;background:#50a0ff1a}.key-filter-badge.key-cat-pro.active .key-label{background:#50a0ffe6;color:#000}.key-filter-badge.key-cat-energy .key-label{background:#ff505026;color:#ff6464f2}.key-filter-badge.key-cat-energy:hover{border-color:#ff505080;box-shadow:0 4px 10px #ff505033}.key-filter-badge.key-cat-energy.active{border-color:#ff5050e6;box-shadow:0 0 12px #ff505066;background:#ff50501a}.key-filter-badge.key-cat-energy.active .key-label{background:#ff5050e6;color:#000}.harmonic-lock-bar{display:flex;flex-direction:column;gap:.5rem;padding:.6rem .85rem;background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:8px;margin-top:.25rem}.harmonic-lock-title{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:var(--text-secondary)}.harmonic-lock-title strong{color:var(--text-primary)}.harmonic-lock-title .hlb-key{font-weight:700;color:var(--accent-color);font-size:.78rem;background:#1db9541f;padding:.05rem .35rem;border-radius:4px}.hlb-unlock{margin-left:auto;background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:.8rem;padding:.1rem .3rem;border-radius:3px;transition:color .15s}.hlb-unlock:hover{color:var(--text-primary);background:#ffffff0f}.harmonic-lock-cats{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.hlb-cat{display:flex;align-items:center;gap:.3rem}.hlb-cat-icon{font-size:.75rem}.hlb-keys{display:flex;flex-wrap:wrap;gap:.25rem}.hlb-key-btn{border:1px solid;border-radius:4px;padding:.15rem .45rem;font-size:.72rem;font-weight:700;cursor:pointer;transition:all .15s;letter-spacing:.03em}.hlb-key-btn:hover{opacity:.85;transform:translateY(-1px)}.spotify-importer{display:flex;flex-direction:column;gap:0}.spotify-playlists-list{display:flex;flex-direction:column;gap:0;max-height:400px;overflow-y:auto}.spotify-playlist-item{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.6rem 0;border-bottom:1px solid rgba(0,0,0,.07)}.spotify-playlist-item:last-child{border-bottom:none}.spotify-playlist-info{display:flex;align-items:center;gap:.6rem;min-width:0;flex:1}.spotify-playlist-cover{width:38px;height:38px;object-fit:cover;flex-shrink:0;border-radius:0;background:#222;display:flex;align-items:center;justify-content:center;color:#fff}.spotify-playlist-cover.liked-songs-cover{background:linear-gradient(135deg,#450af5,#c4efd9)}.spotify-playlist-cover.no-image{background:#0000001f;color:#0006}.spotify-playlist-name{font-size:.82rem;font-weight:600;color:#000;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px}.spotify-playlist-meta{font-size:.72rem;color:#00000073;margin-top:1px}.spotify-import-btn{flex-shrink:0;background:#000;color:#fff;border:none;border-radius:0;padding:.35rem .75rem;font-size:.72rem;font-weight:700;font-family:Inter,monospace;letter-spacing:.05em;cursor:pointer;display:flex;align-items:center;gap:.3rem;white-space:nowrap;min-width:90px;justify-content:center;transition:background .15s,color .15s}.spotify-import-btn:hover:not(:disabled){background:#1db954}.spotify-import-btn:disabled{background:#00000026;color:#00000080;cursor:not-allowed}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(1.3)}}.server-sync-spinner{width:36px;height:36px;border:3px solid rgba(255,255,255,.08);border-top-color:var(--accent-color);border-radius:50%;animation:spin .9s linear infinite;margin:0 auto}@keyframes spin{to{transform:rotate(360deg)}}
