body{margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f8f9fa;color:#2c3e50;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.App,body{min-height:100vh}.app-header{background:#fff;box-shadow:0 2px 20px #0000001a;padding:1.5rem 2rem;position:-webkit-sticky;position:sticky;top:0;z-index:100}.header-content{gap:1rem;justify-content:space-between;margin:0 auto;max-width:1200px}.header-content,.logo,.logo-section{align-items:center;display:flex}.logo{font-size:2.5rem;justify-content:center;width:160px}.mobile-logo{display:none}.desktop-logo{display:flex}.header-info{flex:1 1;text-align:center}.header-info h1{align-items:center;color:#2c3e50;display:flex;font-size:2rem;font-weight:700;gap:.5rem;justify-content:center;margin:0}.header-info p{color:#6c757d;font-size:.95rem;margin:.3rem 0 0}.view-switcher,.view-switcher button{display:flex;gap:.5rem}.view-switcher button{align-items:center;background:#f8f9fa;border:2px solid #e9ecef;border-radius:25px;color:#6c757d;cursor:pointer;font-size:.9rem;font-weight:600;padding:.7rem 1.5rem;transition:all .3s ease}.view-switcher button:hover{background:#e9ecef;color:#495057}.view-switcher button.active{background:#59c3c3;border-color:#59c3c3;box-shadow:0 4px 15px #59c3c34d;color:#fff}.button-icon{font-size:1.1rem}.dj-view,.request-view{margin:0 auto;max-width:1200px;padding:2rem}.search-section{margin-bottom:3rem;text-align:center}.search-container{display:flex;justify-content:center;margin-bottom:2rem}.search-wrapper{max-width:500px;width:100%}.input-wrapper{background:#fff;border:2px solid #e9ecef;border-radius:25px;box-shadow:0 4px 20px #0000001a;display:flex;overflow:visible;position:relative;transition:all .3s ease}.input-wrapper:focus-within{border-color:#59c3c3;box-shadow:0 4px 25px #59c3c333}.search-input{background:#0000;border:none;border-radius:25px;color:#2c3e50;flex:1 1;font-size:1.1rem;font-weight:500;outline:none;padding:1rem 3.5rem 1rem 1.5rem}.search-input::placeholder{color:#adb5bd;font-weight:400}.search-icon-button{align-items:center;background:#59c3c3;border:none;border-radius:50%;cursor:pointer;display:flex;height:40px;justify-content:center;padding:0;position:absolute;right:6px;top:50%;transform:translateY(-50%);transition:all .3s ease;width:40px}.search-icon-button:hover{background:#4fb3b3;transform:scale(1.05)}.search-icon{align-items:center;color:#fff;display:flex;font-size:20px;justify-content:center}.results-header{background:#fff;border-radius:20px;box-shadow:0 4px 20px #00000014;margin:3rem 0 2rem;padding:2rem;text-align:center}.results-header h2{color:#2c3e50;font-size:1.8rem;font-weight:700;margin-bottom:.5rem}.results-header p{color:#6c757d;font-size:1rem}.results-section{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));margin-top:2rem}.search-icon-button:disabled{cursor:not-allowed;opacity:.7}.search-icon{font-size:1.1rem}.loading-spinner{animation:spin 1s linear infinite;border:2px solid #59c3c34d;border-radius:50%;border-top-color:#59c3c3;display:inline-block;height:16px;width:16px}.loading-spinner.small{height:14px;width:14px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.track-card{background:#fff;border:1px solid #f1f3f4;border-radius:20px;box-shadow:0 4px 20px #00000014;display:flex;flex-direction:column;gap:1.5rem;padding:1.5rem;transition:all .3s ease}.track-card:hover{box-shadow:0 8px 30px #0000001f}.request-card{background:#fff;border:1px solid #f1f3f4;border-radius:16px;box-shadow:0 2px 12px #00000014;display:flex;flex-direction:column;gap:.8rem;max-width:100%;min-height:auto;padding:.8rem;position:relative;transition:all .3s ease}.request-card:hover{box-shadow:0 4px 20px #0000001f}.request-badge{background:#ff6b6b;border-radius:12px;box-shadow:0 2px 8px #ff6b6b4d;color:#fff;font-size:.75rem;font-weight:700;padding:.2rem .6rem;position:absolute;right:-8px;top:-8px;z-index:2}.request-image-container,.track-image-container{display:flex;flex-shrink:0;justify-content:center;position:relative}.track-image-container{margin-bottom:1rem}.request-image-container{align-self:center;margin-bottom:0}.request-image,.track-image{border-radius:12px;box-shadow:0 4px 15px #0000001a;height:80px;object-fit:cover;transition:transform .3s ease;width:80px}.request-image{border-radius:8px;height:50px;width:50px}.image-overlay{align-items:center;background:#000000b3;border-radius:15px;bottom:0;display:flex;justify-content:center;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s ease}.track-image-container:hover .image-overlay{opacity:1}.no-preview-overlay{align-items:center;background:#000c;border-radius:20px;bottom:.5rem;display:flex;justify-content:center;padding:.3rem .6rem;position:absolute;right:.5rem}.no-preview-icon{color:#adb5bd;font-size:1rem}.play-icon{color:#fff;font-size:2rem;transition:all .3s ease}.play-icon.playing{animation:pulse 1.5s infinite;color:#59c3c3}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.1)}}.track-card:hover .image-overlay{background:#000000b3}.track-card:hover .play-icon{transform:scale(1.1)}.request-info,.track-info{flex:1 1;text-align:center}.request-info{display:flex;flex-direction:column;gap:.2rem;justify-content:center;text-align:center}.request-info h3,.track-info h3{color:#2c3e50;font-size:1.1rem;font-weight:700;line-height:1.3;margin-bottom:.5rem}.request-info h3{font-size:1rem;line-height:1.2;margin-bottom:.2rem}.artist{color:#59c3c3;font-size:.95rem;font-weight:600;margin-bottom:.3rem}.request-card .artist{font-size:.85rem;margin-bottom:.2rem}.album{color:#6c757d;font-size:.85rem;font-weight:400;margin-bottom:1rem}.request-card .album{font-size:.8rem;margin-bottom:.5rem}.audio-preview{margin-top:1rem}.preview{border-radius:20px;height:35px;width:100%}.request-meta{align-items:center;display:flex;flex-direction:column;gap:.3rem;margin-top:.2rem}.request-count,.requester,.timestamp{align-items:center;display:flex;font-size:.8rem;gap:.3rem}.meta-icon{font-size:.9rem}.requester{color:gold;font-weight:600}.request-count{background:#ff6b6b1a;border:1px solid #ff6b6b4d;border-radius:12px;color:#ff6b6b;font-size:.75rem;font-weight:700;padding:.2rem .5rem}.timestamp{color:#6c757d;opacity:.8}.card-actions,.request-actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;position:relative;z-index:10}.request-actions{flex-direction:row;flex-shrink:0;gap:.5rem;width:100%}.request-button{align-items:center;background:linear-gradient(45deg,#4ecdc4,#44a08d);border:none;border-radius:50px;box-shadow:0 4px 15px #4ecdc44d;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;justify-content:center;min-width:150px;overflow:hidden;padding:1rem 2rem;position:relative;transition:all .4s cubic-bezier(.4,0,.2,1);white-space:nowrap}.request-button:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s;width:100%}.request-button:hover:before{left:100%}.request-button:hover:not(:disabled){background:linear-gradient(45deg,#45b7aa,#3d8b7d);box-shadow:0 8px 25px #4ecdc466}.request-button:disabled{cursor:not-allowed;opacity:.6;transform:none}.dj-header{background:#fff;border:1px solid #f1f3f4;border-radius:20px;box-shadow:0 4px 20px #0000001a;margin-bottom:3rem;padding:2rem;text-align:center}.dj-header h2{color:#2c3e50;font-size:2rem;font-weight:700;margin-bottom:.5rem}.dj-header p{color:#6c757d;font-size:1.2rem;margin-bottom:1rem}.requests-counter{align-items:center;display:flex;gap:.5rem;justify-content:center;margin-top:1rem}.counter-badge{background:linear-gradient(45deg,#ff6b6b,#ff8e53);border-radius:20px;box-shadow:0 4px 15px #ff6b6b4d;color:#fff;font-size:1.1rem;font-weight:600;padding:.5rem 1rem}.requests-list{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.empty-state{background:#fff;border:1px solid #f1f3f4;border-radius:20px;box-shadow:0 4px 20px #00000014;padding:4rem 2rem;text-align:center}.empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.7}.empty-state h3{color:#2c3e50;font-size:1.8rem;font-weight:700;margin-bottom:.5rem}.empty-state p{color:#6c757d;font-size:1.1rem}.played-button,.reject-button{align-items:center;border:none;border-radius:16px;box-shadow:0 2px 8px #00000026;cursor:pointer;display:flex;flex:1 1;font-size:.8rem;font-weight:600;gap:.3rem;justify-content:center;min-width:80px;padding:.5rem .8rem;pointer-events:auto;position:relative;transition:all .3s ease;white-space:nowrap;z-index:10}.played-button{background:linear-gradient(45deg,#4caf50,#45a049);color:#fff}.played-button:hover{background:linear-gradient(45deg,#45a049,#3d8b40);box-shadow:0 6px 20px #4caf5066}.reject-button{background:linear-gradient(45deg,#f44336,#d32f2f);color:#fff}.reject-button:hover{background:linear-gradient(45deg,#d32f2f,#b71c1c);box-shadow:0 6px 20px #f4433666}.auth-indicator{font-size:.9rem;margin-left:.5rem}.dj-header-top{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1rem}.logout-button{align-items:center;background:#ff6b6b33;border:1px solid #ff6b6b66;border-radius:25px;color:#ff6b6b;cursor:pointer;display:flex;font-size:.9rem;font-weight:600;gap:.5rem;padding:.6rem 1.2rem;transition:all .3s ease}.logout-button:hover{background:#ff6b6b4d;box-shadow:0 4px 15px #ff6b6b4d}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#0009;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:1000}.modal{animation:modalSlideIn .3s ease-out;background:#fff;border:1px solid #f1f3f4;border-radius:20px;box-shadow:0 20px 40px #0003;max-width:400px;padding:2rem;width:90%}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-30px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{align-items:center;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem}.modal-header h3{color:#2c3e50;font-size:1.4rem;font-weight:700;margin:0}.modal-close{align-items:center;background:none;border:none;border-radius:50%;color:#6c757d;cursor:pointer;display:flex;font-size:1.5rem;height:35px;justify-content:center;padding:.25rem;transition:all .3s ease;width:35px}.modal-close:hover{background:#f8f9fa;color:#2c3e50}.login-form{gap:1.5rem}.form-group,.login-form{display:flex;flex-direction:column}.form-group{gap:.5rem}.form-group label{color:#2c3e50;font-size:.9rem;font-weight:600}.form-group input{background:#f8f9fa;border:2px solid #e9ecef;border-radius:10px;color:#2c3e50;font-size:1rem;padding:.75rem 1rem;transition:all .3s ease}.form-group input:focus{background:#fff;border-color:#59c3c3;box-shadow:0 0 0 3px #59c3c31a;outline:none}.form-group input::placeholder{color:#adb5bd}.login-button{align-items:center;background:linear-gradient(135deg,#59c3c3,#4fb3b3);border:none;border-radius:25px;box-shadow:0 4px 15px #59c3c34d;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:700;gap:.5rem;justify-content:center;margin-top:.5rem;padding:.75rem 1.5rem;transition:all .3s ease}.login-button:hover:not(:disabled){box-shadow:0 8px 25px #59c3c366}.login-button:disabled{cursor:not-allowed;opacity:.7;transform:none}.snackbar{animation:slideInUp .3s ease-out;background:#2c3e50;border-radius:25px;bottom:2rem;box-shadow:0 4px 20px #00000026;color:#fff;font-weight:500;left:50%;max-width:90%;padding:1rem 2rem;position:fixed;text-align:center;transform:translateX(-50%);z-index:1000}.snackbar-success{background:linear-gradient(135deg,#28a745,#20c997)}.snackbar-error{background:linear-gradient(135deg,#dc3545,#fd7e14)}.snackbar-info{background:linear-gradient(135deg,#59c3c3,#4fb3b3)}@keyframes slideInUp{0%{opacity:0;transform:translateX(-50%) translateY(100%)}to{opacity:1;transform:translateX(-50%) translateY(0)}}@media (max-width:768px){.snackbar{bottom:1rem;font-size:.9rem;margin:0 1rem;max-width:95%;padding:.8rem 1.5rem}}@media (max-width:480px){.search-input{font-size:1rem;padding:1rem 3.5rem 1rem 1.5rem}.search-icon-button{height:36px;right:6px;width:36px}.search-icon{font-size:18px}.dj-header h2{font-size:2rem}.view-switcher{gap:1rem}.view-switcher button{font-size:1rem;padding:.8rem 1.5rem}.results-header{margin:2rem 0 1.5rem;padding:1.5rem}.results-header h2{font-size:1.6rem}}@media (max-width:768px){.app-header{padding:1rem}.header-content{flex-direction:column;gap:1rem;padding-bottom:1rem;text-align:center}.logo-section{order:1}.logo{font-size:2rem;height:50px;width:50px}.mobile-logo{display:flex}.desktop-logo{display:none}.header-info{order:2}.header-info h1{font-size:1.6rem}.header-info p{font-size:.85rem;margin:.2rem 0 0}.view-switcher{gap:.5rem;justify-content:center;order:3;width:100%}.view-switcher button{flex:1 1;font-size:.85rem;max-width:150px;min-width:120px;padding:.6rem 1rem}.view-switcher button .button-icon{font-size:1rem}.auth-indicator{font-size:.8rem}.dj-view,.request-view{padding:2rem 1rem}.search-wrapper{flex-direction:column;gap:1rem}.search-wrapper .input-wrapper{min-width:100%}.results-section{gap:1.5rem;grid-template-columns:1fr}.request-card,.track-card{padding:1.5rem}.requests-list{grid-template-columns:1fr}.request-card{flex-direction:column;padding:1rem}.request-card,.request-info{text-align:center}.request-actions{flex-direction:row;gap:.5rem;min-width:auto;width:100%}.request-image,.track-image{height:100px;width:100px}.request-image{height:80px;width:80px}.card-actions,.request-actions{flex-direction:column;gap:.8rem}.request-meta{flex-direction:column;gap:.3rem;text-align:center}.counter-badge{font-size:1rem;padding:.4rem .8rem}.modal{margin:1rem;padding:1.5rem}.dj-header-top{align-items:center;flex-direction:column;gap:1rem;text-align:center}.logout-button{align-self:center}}@media (max-width:1024px) and (min-width:769px){.app-header{padding:1.2rem 1.5rem}.logo{font-size:2.2rem}.header-info h1{font-size:1.8rem}.view-switcher button{font-size:.85rem;padding:.6rem 1.2rem}.requests-list{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}}@media (max-width:1024px){.requests-list{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}}
/*# sourceMappingURL=main.a15e55a9.css.map*/