*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:#f5f5f7;min-height:100vh;overflow-x:hidden}.login-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:20px;background:linear-gradient(135deg,#667eea,#764ba2)}.login-container h1{color:#fff;font-size:3rem;margin-bottom:3rem;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.login-buttons{display:flex;flex-direction:column;gap:1.5rem;width:100%;max-width:300px}.login-btn{padding:1.5rem;font-size:1.5rem;font-weight:700;border:none;border-radius:12px;cursor:pointer;transition:transform .2s,box-shadow .2s;color:#fff}.gary-btn{background:linear-gradient(135deg,#f093fb,#f5576c)}.simon-btn{background:linear-gradient(135deg,#4facfe,#00f2fe)}.login-btn:active{transform:scale(.95)}.completed-container,.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;color:#333;padding:20px}.completed-container button{margin-top:1rem;padding:1rem 2rem;font-size:1.2rem;background:#007aff;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:700}.app-container{display:flex;flex-direction:column;min-height:100vh;background:#f5f5f7}.top-bar{background:#fff;padding:15px 20px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 10px rgba(0,0,0,.05);position:-webkit-sticky;position:sticky;top:0;z-index:100}.deck-name{font-size:1.3rem;font-weight:600;color:#1d1d1f}.top-controls{display:flex;gap:10px}.icon-btn{width:45px;height:45px;border-radius:10px;border:none;background:#f5f5f7;font-size:1.3rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;position:relative}.icon-btn:hover{background:#e5e5e7}.icon-btn.active{background:#007aff}.settings-panel{background:#fff;padding:20px;margin:0 15px 15px;border-radius:15px;box-shadow:0 2px 15px rgba(0,0,0,.08)}.settings-tabs{display:flex;gap:5px;margin-bottom:20px;border-bottom:2px solid #f0f0f0}.settings-tabs .tab{flex:1 1;padding:12px;background:none;font-size:1rem;font-weight:500;color:#86868b;cursor:pointer;border:none;border-bottom:3px solid transparent;transition:all .2s}.settings-tabs .tab.active{color:#007aff;border-bottom-color:#007aff}.setting-row{display:flex;justify-content:space-between;align-items:center;padding:15px 0;border-bottom:1px solid #f0f0f0}.setting-row:last-child{border-bottom:none}.setting-row span{font-size:1rem;color:#333}.toggle{position:relative;display:inline-block;width:51px;height:31px}.toggle input{opacity:0;width:0;height:0}.slider{cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#ccc;border-radius:31px}.slider,.slider:before{position:absolute;transition:.4s}.slider:before{content:"";height:25px;width:25px;left:3px;bottom:3px;background-color:#fff;border-radius:50%}input:checked+.slider{background-color:#007aff}input:checked+.slider:before{transform:translateX(20px)}.text-size-control{display:flex;align-items:center;gap:10px}.text-size-control input[type=range]{width:120px}.decade-filters{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:10px;gap:10px}.decade-btn{padding:15px;border:2px solid #e5e5e7;background:#fff;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;color:#1d1d1f}.decade-btn.active{background:#007aff;border-color:#007aff;color:#fff}.decade-btn:hover:not(.active){background:#f5f5f7}.bpm-filters{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:10px;gap:10px}.bpm-btn{padding:15px;border:2px solid #e5e5e7;background:#fff;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;color:#1d1d1f}.bpm-btn.active{background:#34c759;border-color:#34c759;color:#fff}.bpm-btn:hover:not(.active){background:#f5f5f7}.swiper-container{flex:1 1;display:flex;align-items:center;justify-content:center;padding:20px;-webkit-user-select:none;-moz-user-select:none;user-select:none}.record-card{width:100%;max-width:450px;background:#fff;border-radius:20px;overflow:visible;box-shadow:0 10px 40px rgba(0,0,0,.1);position:relative;cursor:-webkit-grab;cursor:grab}.record-card:active{cursor:-webkit-grabbing;cursor:grabbing}.record-image{width:100%;aspect-ratio:1;object-fit:cover;display:block;border-radius:20px 20px 0 0}.persistent-mute-indicator{top:15px;right:15px;font-size:2rem;background:rgba(0,0,0,.8);width:50px;height:50px;border-radius:50%;justify-content:center;z-index:25;pointer-events:none;box-shadow:0 4px 12px rgba(0,0,0,.3)}.audio-controls-overlay,.persistent-mute-indicator{position:absolute;display:flex;align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.audio-controls-overlay{top:50%;left:50%;transform:translate(-50%,-50%);gap:40px;background:rgba(0,0,0,.75);padding:20px 40px;border-radius:60px;z-index:20}.control-btn{border:none;background:transparent;color:#fff;font-size:2.5rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;padding:0;width:50px;height:50px}.control-btn.play-btn{font-size:3rem;width:60px;height:60px}.control-btn:active{transform:scale(.9)}.control-btn:hover{opacity:.8}.record-info{padding:25px;background:#fff;border-radius:0 0 20px 20px}.info-title{font-weight:700;color:#1d1d1f;margin-bottom:8px;line-height:1.3}.info-artist{color:#86868b;margin-bottom:15px;line-height:1.4}.info-meta-row{display:flex;gap:8px;flex-wrap:wrap}.info-badge{background:#f5f5f7;padding:6px 12px;border-radius:20px;font-size:.85em;font-weight:500;white-space:nowrap}.info-badge.genre{background:#e3f2fd;color:#1976d2}.info-badge.year{background:#f3e5f5;color:#7b1fa2}.info-badge.bpm{background:#e8f5e9;color:#388e3c}.action-buttons{gap:20px;padding:30px 20px;box-shadow:0 -2px 10px rgba(0,0,0,.05)}.action-btn,.action-buttons{display:flex;justify-content:center;align-items:center;background:#fff}.action-btn{width:70px;height:70px;border-radius:50%;border:3px solid;font-size:2rem;cursor:pointer;transition:transform .2s,box-shadow .2s}.undo-btn{width:60px;height:60px;font-size:1.8rem;border-color:orange;color:orange}.dislike-btn{border-color:#ff3b30;color:#ff3b30}.like-btn{border-color:#34c759;color:#34c759}.action-btn:active{transform:scale(.9)}.action-btn:disabled{opacity:.3;cursor:not-allowed}.liked-container{min-height:100vh;background:#f5f5f7}.liked-header{background:#fff;padding:12px 15px;gap:12px;box-shadow:0 2px 10px rgba(0,0,0,.05);position:-webkit-sticky;position:sticky;top:0;z-index:100}.back-btn,.liked-header{display:flex;align-items:center}.back-btn{width:40px;height:40px;border-radius:10px;border:none;background:#f5f5f7;font-size:1.5rem;cursor:pointer;justify-content:center}.liked-header h2{flex:1 1;font-size:1.1rem;font-weight:600;color:#1d1d1f;white-space:nowrap;min-width:0}.liked-header-controls{display:flex;gap:8px;align-items:center}.view-toggles{display:flex;gap:4px;background:#f5f5f7;padding:3px;border-radius:8px}.view-toggle-compact{width:44px;height:44px;border-radius:6px;border:none;background:transparent;font-size:1.4rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.view-toggle-compact.active{background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.1)}.clear-all-compact{width:44px;height:44px;border-radius:8px;border:none;background:transparent;color:#ff3b30;font-size:1.3rem;cursor:pointer;display:flex;align-items:center;justify-content:center}.liked-songs{padding:20px}.liked-songs.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:20px;gap:20px}.liked-songs.list{display:flex;flex-direction:column;gap:12px;max-width:800px;margin:0 auto}.liked-item{background:#fff;border-radius:15px;overflow:hidden;box-shadow:0 2px 15px rgba(0,0,0,.08);transition:transform .2s;cursor:pointer}.liked-songs.grid .liked-item{display:flex;flex-direction:column;position:relative}.liked-songs.list .liked-item{display:flex;flex-direction:row;align-items:center;padding:15px;gap:15px}.liked-item:hover{transform:translateY(-2px);box-shadow:0 4px 20px rgba(0,0,0,.12)}.liked-item:active{transform:scale(.98)}.liked-item.playing{box-shadow:0 4px 20px rgba(0,122,255,.3)}.liked-image-container,.liked-image-container-list{position:relative;cursor:pointer}.liked-image-container-list{flex-shrink:0}.liked-image{width:100%;aspect-ratio:1;object-fit:cover}.liked-songs.list .liked-image{width:80px;height:80px;border-radius:8px;flex-shrink:0}.play-overlay,.playing-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:60px;height:60px;background:rgba(0,0,0,.7);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.8rem;color:#fff;opacity:0;transition:opacity .2s;pointer-events:none;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.liked-image-container:hover .play-overlay,.liked-image-container:hover .playing-overlay{opacity:1}.play-indicator{position:absolute;top:5px;left:5px;width:28px;height:28px;background:rgba(0,0,0,.8);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem;color:#fff;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.liked-info{padding:15px;flex:1 1}.liked-songs.list .liked-info{padding:0}.liked-title{font-weight:600;color:#1d1d1f;margin-bottom:5px;font-size:1rem}.liked-artist{color:#86868b;font-size:.9rem}.delete-liked-btn{padding:8px;border:none;background:none;font-size:1.5rem;cursor:pointer;color:#ff3b30;transition:transform .2s;min-width:40px;min-height:40px;z-index:10}.liked-songs.grid .delete-liked-btn{position:absolute;top:10px;right:10px;background:#fff;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px rgba(0,0,0,.1)}.liked-songs.list .delete-liked-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center}.delete-liked-btn:active{transform:scale(.9)}.no-liked{color:#86868b;padding:60px 20px;font-size:1.1rem}.badge,.no-liked{text-align:center}.badge{position:absolute;top:-5px;right:-5px;background:#ff3b30;color:#fff;font-size:.7rem;padding:2px 6px;border-radius:10px;font-weight:700;min-width:18px}.audio-prompt{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:10000;background:rgba(0,0,0,.9);padding:30px;border-radius:20px}.play-audio-btn{padding:20px 40px;font-size:1.3rem;background:#007aff;color:#fff;border:none;border-radius:15px;cursor:pointer;font-weight:700;box-shadow:0 8px 20px rgba(0,122,255,.4)}.play-audio-btn:active{transform:scale(.95)}.floating-heart,.floating-x{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);font-size:12rem;font-weight:700;pointer-events:none;z-index:9999;animation:floatUp .5s ease-out forwards}.floating-heart{color:#ff6b9d;text-shadow:0 0 40px rgba(255,107,157,.8)}.floating-x{color:#ff3b30;text-shadow:0 0 40px rgba(255,59,48,.8)}@keyframes floatUp{0%{opacity:0;transform:translate(-50%,-50%) scale(.5)}50%{opacity:1;transform:translate(-50%,-60%) scale(1.2)}to{opacity:0;transform:translate(-50%,-80%) scale(1)}}.floating-mute{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);font-size:5rem;pointer-events:none;z-index:9999;animation:fadeInOut .8s ease-out forwards}@keyframes fadeInOut{0%{opacity:0;transform:translate(-50%,-50%) scale(.8)}30%{opacity:1;transform:translate(-50%,-50%) scale(1.1)}70%{opacity:1;transform:translate(-50%,-50%) scale(1)}to{opacity:0;transform:translate(-50%,-50%) scale(.9)}}@media (max-width:480px){.deck-name,.icon-btn{font-size:1.1rem}.icon-btn{width:40px;height:40px}.record-card{max-width:100%}.action-btn{width:60px;height:60px;font-size:1.7rem}.undo-btn{width:50px;height:50px;font-size:1.5rem}.liked-songs.grid{grid-template-columns:1fr}.bpm-filters,.decade-filters{grid-template-columns:repeat(2,1fr)}.persistent-mute-indicator{width:45px;height:45px;font-size:1.7rem}.audio-controls-overlay{gap:30px;padding:15px 30px}.control-btn{font-size:2rem;width:45px;height:45px}.control-btn.play-btn{font-size:2.5rem;width:55px;height:55px}}@media (max-height:600px) and (orientation:landscape){.swiper-container{padding:10px}.record-card{max-width:350px}.action-buttons{padding:15px}}.search-container{min-height:100vh;background:#f5f5f7;display:flex;flex-direction:column}.search-header{background:#fff;padding:12px 15px;display:flex;align-items:center;gap:12px;box-shadow:0 2px 10px rgba(0,0,0,.05);position:-webkit-sticky;position:sticky;top:0;z-index:100}.search-input-wrapper{flex:1 1;position:relative;display:flex;align-items:center;background:#f5f5f7;border-radius:10px;padding:10px 15px}.search-icon{font-size:1.2rem;margin-right:10px;color:#86868b}.search-input{flex:1 1;border:none;background:transparent;font-size:1rem;outline:none;color:#1d1d1f}.clear-search{background:none;border:none;font-size:1.2rem;color:#86868b;cursor:pointer;padding:0 5px}.search-results{flex:1 1;overflow-y:auto;padding:15px}.no-results,.search-loading,.search-prompt{text-align:center;color:#86868b;padding:40px 20px;font-size:1.1rem}.results-header{font-size:.9rem;color:#666;margin-bottom:15px;padding:0 5px}.search-result-item{background:#fff;border-radius:15px;padding:12px;margin-bottom:12px;display:flex;gap:12px;align-items:center;box-shadow:0 2px 10px rgba(0,0,0,.08);transition:transform .2s}.search-result-item:active{transform:scale(.98)}.search-result-item.reviewed{opacity:.6}.result-image-container{position:relative;flex-shrink:0;cursor:pointer}.result-image{width:80px;height:80px;border-radius:10px;object-fit:cover}.play-button-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:rgba(0,0,0,.7);width:35px;height:35px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.2rem;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.result-info{flex:1 1;min-width:0}.result-title{font-weight:600;color:#1d1d1f;margin-bottom:4px;font-size:1rem}.result-artist,.result-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.result-artist{color:#86868b;font-size:.9rem;margin-bottom:8px}.result-meta{display:flex;gap:6px;flex-wrap:wrap}.result-badge{background:#f5f5f7;padding:4px 10px;border-radius:12px;font-size:.75rem;font-weight:500;white-space:nowrap}.result-badge.genre{background:#e3f2fd;color:#1976d2}.result-badge.year{background:#f3e5f5;color:#7b1fa2}.result-badge.bpm{background:#e8f5e9;color:#388e3c}.result-like-btn{width:50px;height:50px;border-radius:50%;border:none;background:#34c759;color:#fff;font-size:1.8rem;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .2s}.result-like-btn:active{transform:scale(.9)}.reviewed-badge{font-size:.85rem;color:#34c759;font-weight:600;white-space:nowrap}@media (max-width:480px){.result-image{width:70px;height:70px}.result-title{font-size:.95rem}.result-like-btn{width:45px;height:45px;font-size:1.6rem}}.result-unreview-btn{padding:8px 16px;border-radius:20px;border:2px solid orange;background:#fff;color:orange;font-size:.9rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .2s}.result-unreview-btn:active{transform:scale(.95);background:orange;color:#fff}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px}.modal-content{background:#fff;border-radius:20px;padding:30px 20px 20px;max-width:400px;width:100%;box-shadow:0 20px 40px rgba(0,0,0,.3)}.modal-title{font-size:1.3rem;font-weight:600;color:#1d1d1f;margin-bottom:15px;text-align:center}.modal-message{color:#666;margin-bottom:25px;text-align:center;line-height:1.4}.modal-buttons{display:flex;flex-direction:column;gap:12px}.modal-btn{padding:15px 20px;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.modal-btn.primary{background:#ff3b30;color:#fff}.modal-btn.secondary{background:orange;color:#fff}.modal-btn.cancel{background:#f5f5f7;color:#333}.modal-btn:active{transform:scale(.98)}@media (max-width:480px){.modal-content{margin:0 15px}}.audio-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.85);display:flex;align-items:center;justify-content:center;z-index:20000;padding:40px}.audio-modal-content{background:#fff;border-radius:25px;padding:40px 30px;max-width:350px;width:100%;text-align:center;box-shadow:0 25px 50px rgba(0,0,0,.4)}.audio-modal-icon{font-size:4rem;margin-bottom:20px}.audio-modal-title{font-size:1.4rem;font-weight:600;color:#1d1d1f;margin-bottom:15px}.audio-modal-message{color:#666;margin-bottom:30px;line-height:1.4}.audio-enable-btn{width:100%;padding:18px;background:#007aff;color:#fff;border:none;border-radius:15px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 8px 20px rgba(0,122,255,.4)}.audio-enable-btn:active{transform:scale(.98)}.db-toggle{display:flex;background:#f5f5f7;border-radius:10px;padding:3px;gap:2px}.db-btn{flex:1 1;padding:10px 16px;border:none;border-radius:8px;background:transparent;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;color:#666}.db-btn.active{background:#007aff;color:#fff;box-shadow:0 2px 8px rgba(0,122,255,.3)}.desktop-audio-banner{position:fixed;top:20px;left:50%;transform:translateX(-50%);background:rgba(0,122,255,.9);color:#fff;padding:12px 24px;border-radius:25px;font-size:.9rem;font-weight:500;z-index:1000;cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 20px rgba(0,122,255,.3);transition:all .3s ease}.desktop-audio-banner.visible{opacity:1;transform:translateX(-50%) translateY(0)}.desktop-audio-banner.hidden{opacity:0;transform:translateX(-50%) translateY(-10px)}.desktop-audio-banner:hover{background:#007aff;transform:translateX(-50%) scale(1.05)}@media (max-width:768px){.desktop-audio-banner{display:none}}