.album-library{position:fixed;right:0;top:0;width:320px;height:100vh;background:#ffffff1a;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-left:1px solid rgba(255,255,255,.2);box-shadow:-4px 0 24px #0000001a;display:flex;flex-direction:column;z-index:100;overflow:visible;transition:transform .3s ease}.album-library.collapsed{transform:translate(100%)}.album-library:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#ffffff1a,#ffffff0d,#ffffff1a);pointer-events:none;z-index:-1}.album-library-header{padding:24px 20px 16px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;background:#ffffff0d;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.album-library-header-right{display:flex;align-items:center;gap:12px}.album-library-collapse-button{position:absolute;right:100%;top:50%;transform:translateY(-50%);background:#ffffff26;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid rgba(255,255,255,.2);border-right:none;border-radius:8px 0 0 8px;padding:12px 16px;color:#000c;font-size:14px;font-weight:600;cursor:pointer;z-index:101;transition:all .3s ease;box-shadow:-2px 0 12px #0000001a;display:flex;align-items:center;justify-content:center;min-width:40px;height:48px}.album-library-collapse-button:hover{background:#ffffff40;transform:translateY(-50%) translate(-4px);box-shadow:-4px 0 16px #00000026}.album-library-expand-tab{position:fixed;right:0;top:50%;transform:translateY(-50%) rotate(-90deg);transform-origin:center;background:#ffffff26;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid rgba(255,255,255,.2);border-right:none;border-radius:8px 8px 0 0;padding:12px 24px;color:#000c;font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:1px;cursor:pointer;z-index:100;transition:all .3s ease;box-shadow:-2px 0 12px #0000001a;white-space:nowrap}.album-library-expand-tab:hover{background:#ffffff40;transform:translateY(-50%) rotate(-90deg) translate(-4px);box-shadow:-4px 0 16px #00000026}.album-library-header h2{margin:0;font-size:18px;font-weight:600;color:#000c;text-transform:uppercase;letter-spacing:1px}.album-count{background:#0000001a;color:#000000b3;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.album-library-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:12px;scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.2) transparent}.album-library-content::-webkit-scrollbar{width:6px}.album-library-content::-webkit-scrollbar-track{background:transparent}.album-library-content::-webkit-scrollbar-thumb{background:#0003;border-radius:3px}.album-library-content::-webkit-scrollbar-thumb:hover{background:#0000004d}.album-library-empty{display:flex;align-items:center;justify-content:center;height:200px;color:#00000080;font-size:14px}.album-library-item{display:flex;align-items:center;padding:12px;margin-bottom:8px;background:#ffffff26;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:12px;cursor:grab;transition:all .2s ease,opacity .1s ease,transform .1s ease;position:relative;overflow:hidden;touch-action:none;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.album-library-item:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,rgba(255,255,255,.1) 0%,transparent 100%);opacity:0;transition:opacity .2s ease;pointer-events:none}.album-library-item:hover{background:#ffffff40;border-color:#ffffff4d;transform:translate(-4px);box-shadow:0 4px 12px #0000001a}.album-library-item:hover:before{opacity:1}.album-library-item:active{cursor:grabbing;transform:translate(-2px) scale(.98)}.album-library-item.dragging,.album-library-item.is-dragging{opacity:.6;transform:scale(1.05);box-shadow:0 8px 24px #0000004d;z-index:1000;pointer-events:none;transition:none}.album-library-item.dragging:before,.album-library-item.is-dragging:before{opacity:0}.album-library-item-image{width:60px;height:60px;min-width:60px;border-radius:8px;overflow:hidden;margin-right:12px;box-shadow:0 2px 8px #00000026;background:#0000001a}.album-library-item-image img{width:100%;height:100%;object-fit:cover;display:block}.album-library-item-info{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center}.album-library-item-name{font-size:14px;font-weight:600;color:#000000d9;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}.album-library-item-artist{font-size:12px;color:#0009;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}.album-library-item[draggable=true]{user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}@media (max-width: 768px){.album-library{width:280px}}@media (max-width: 480px){.album-library{width:100%;height:40vh;bottom:0;top:auto;border-left:none;border-top:1px solid rgba(255,255,255,.2)}}.genre-library{position:fixed;left:0;top:0;width:200px;height:100vh;background:#ffffff1a;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-right:1px solid rgba(255,255,255,.2);box-shadow:4px 0 24px #0000001a;display:flex;flex-direction:column;z-index:99;overflow:visible;transition:transform .3s ease}.genre-library.collapsed{transform:translate(-100%)}.genre-library:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#ffffff1a,#ffffff0d,#ffffff1a);pointer-events:none;z-index:-1}.genre-library-header{padding:24px 20px 16px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;background:#ffffff0d;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.genre-library-header-right{display:flex;align-items:center;gap:12px}.collapse-button{background:#0000001a;border:none;color:#000000b3;padding:6px 10px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-width:32px;height:28px;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.collapse-button:hover{background:#0003;color:#000000e6;transform:scale(1.05)}.collapse-button:active{transform:scale(.95)}.genre-library-collapse-button{position:absolute;left:100%;top:50%;transform:translateY(-50%);background:#ffffff26;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid rgba(255,255,255,.2);border-left:none;border-radius:0 8px 8px 0;padding:12px 16px;color:#000c;font-size:14px;font-weight:600;cursor:pointer;z-index:100;transition:all .3s ease;box-shadow:2px 0 12px #0000001a;display:flex;align-items:center;justify-content:center;min-width:40px;height:48px}.genre-library-collapse-button:hover{background:#ffffff40;transform:translateY(-50%) translate(4px);box-shadow:4px 0 16px #00000026}.genre-library-expand-tab{position:fixed;left:0;top:50%;transform:translateY(-50%) rotate(90deg);transform-origin:center;background:#ffffff26;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid rgba(255,255,255,.2);border-left:none;border-radius:0 0 8px 8px;padding:12px 24px;color:#000c;font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:1px;cursor:pointer;z-index:99;transition:all .3s ease;box-shadow:2px 0 12px #0000001a;white-space:nowrap}.genre-library-expand-tab:hover{background:#ffffff40;transform:translateY(-50%) rotate(90deg) translate(4px);box-shadow:4px 0 16px #00000026}.genre-library-header h2{margin:0;font-size:16px;font-weight:600;color:#000c;text-transform:uppercase;letter-spacing:1px}.genre-count{background:#0000001a;color:#000000b3;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.genre-library-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:12px;scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.2) transparent}.genre-library-content::-webkit-scrollbar{width:6px}.genre-library-content::-webkit-scrollbar-track{background:transparent}.genre-library-content::-webkit-scrollbar-thumb{background:#0003;border-radius:3px}.genre-library-content::-webkit-scrollbar-thumb:hover{background:#0000004d}.genre-library-empty{display:flex;align-items:center;justify-content:center;height:200px;color:#00000080;font-size:14px}.genre-library-item{display:flex;align-items:center;padding:12px;margin-bottom:8px;background:#ffffff26;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:12px;cursor:grab;transition:all .2s ease,opacity .1s ease,transform .1s ease;position:relative;overflow:hidden;touch-action:none;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.genre-library-item:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,rgba(255,255,255,.1) 0%,transparent 100%);opacity:0;transition:opacity .2s ease;pointer-events:none}.genre-library-item:hover{background:#ffffff40;border-color:#ffffff4d;transform:translate(4px);box-shadow:0 4px 12px #0000001a}.genre-library-item:hover:before{opacity:1}.genre-library-item:active{cursor:grabbing;transform:translate(2px) scale(.98)}.genre-library-item.dragging,.genre-library-item.is-dragging{opacity:.6;transform:scale(1.05);box-shadow:0 8px 24px #0000004d;z-index:1000;pointer-events:none;transition:none}.genre-library-item.dragging:before,.genre-library-item.is-dragging:before{opacity:0}.genre-library-item-name{font-size:14px;font-weight:600;color:#000000d9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3;text-transform:uppercase;letter-spacing:1px}.genre-library-item[draggable=true]{user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}@media (max-width: 1200px){.genre-library{width:180px}}@media (max-width: 768px){.genre-library{width:160px}}@media (max-width: 480px){.genre-library{width:100%;height:30vh;bottom:0;top:auto;left:0;border-right:none;border-top:1px solid rgba(255,255,255,.2)}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{position:relative;background:#fffffff2;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid rgba(255,255,255,.3);border-radius:24px;padding:32px;min-width:320px;max-width:90vw;max-height:90vh;box-shadow:0 8px 32px #0003;animation:slideUp .3s ease;overflow-y:auto}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-close-button{position:absolute;top:16px;right:16px;background:#0000001a;border:none;border-radius:50%;width:32px;height:32px;font-size:24px;line-height:1;color:#000000b3;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:1}.modal-close-button:hover{background:#0003;color:#000000e6;transform:scale(1.1)}.modal-close-button:active{transform:scale(.95)}.modal-body{display:flex;flex-direction:column;gap:20px}.modal-title{font-size:24px;font-weight:700;margin:0 0 8px;background:linear-gradient(to right,#a600ff,#ff00a6,#ff6b35);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.modal-user-info{display:flex;flex-direction:column;gap:12px;padding:16px;background:#0000000d;border-radius:12px;margin-bottom:8px}.modal-user-name{font-size:18px;font-weight:600;color:#000000e6;margin:0}.modal-user-email{font-size:14px;color:#0009;margin:0}.modal-logout-button{padding:12px 24px;background:linear-gradient(135deg,#f50,#ff6b35);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;width:100%;box-shadow:0 4px 12px #ff55004d}.modal-logout-button:hover{background:linear-gradient(135deg,#ff6b35,#ff8533);transform:translateY(-2px);box-shadow:0 6px 16px #f506}.modal-logout-button:active{transform:translateY(0);box-shadow:0 2px 8px #ff55004d}.App{width:100vw;height:100vh;display:flex;flex-direction:column;margin:0;padding:0;overflow:hidden}.logo-container-center{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:1000;pointer-events:auto}.hacksify-logo{font-size:2rem;font-weight:700;margin:0;background:linear-gradient(to right,#a600ff,#ff00a6,#ff6b35);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;transition:all .3s ease}.hacksify-logo.clickable{cursor:pointer;pointer-events:auto}.hacksify-logo.clickable:hover{transform:scale(1.1);filter:brightness(1.2)}.fixed-login-button{position:fixed;top:30px;left:50%;transform:translate(-50%);z-index:1000;pointer-events:auto;display:flex;justify-content:center;align-items:center}.app-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background-color:transparent}.logo{font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,var(--accent-color),#ff6b35);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}nav{display:flex;gap:1rem}.nav-btn{padding:.5rem 1.5rem;background-color:transparent;color:var(--text-secondary);border-radius:20px;transition:all .3s ease}.nav-btn:hover{background-color:#ffffff1a;color:var(--text-primary)}.nav-btn.active{background-color:var(--accent-color);color:var(--text-primary)}.user-profile{display:flex;align-items:center}.avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--accent-color),#ff6b35)}.visualizer-container{flex:1;position:relative;overflow:visible;width:100%;height:100%;margin:0;padding:0;min-width:0;min-height:0}:root{--bg-color: #ffffff;--bg-secondary: #212121;--text-primary: #000000;--text-secondary: #666666;--accent-color: #a600ff;--font-family: "Inter", system-ui, Avenir, Helvetica, Arial, sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background-color:var(--bg-color);color:var(--text-primary);line-height:1.5;font-weight:400;overflow:hidden}#root{width:100vw;height:100vh;display:flex;flex-direction:column}h1,h2,h3{font-weight:700}button{cursor:pointer;border:none;outline:none;font-family:inherit}
