*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,SF Pro,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;display:flex;justify-content:center;align-items:center;background:radial-gradient(ellipse 200% 50% at 50% 100%,#ea6433,#e9966c 38%,#a2a7bc);height:100dvh;overflow:hidden}#app{width:100%;max-width:430px;height:100dvh;max-height:932px;position:relative}.page-container{display:flex;flex-direction:column;width:100%;height:100%;overflow:hidden}@media(max-width:430px){#app{max-width:100%;max-height:100dvh}.page-header{font-size:clamp(48px,12vw,64px)}.mystery-song-bar{margin-left:20px;margin-right:20px}.song-tile{width:clamp(250px,85vw,297px)}.media-player{margin-left:16px;margin-right:16px}}.page-header{margin-top:19px;margin-bottom:13px;min-height:102px;display:flex;align-items:center;justify-content:center;font-size:64px;font-weight:400;line-height:normal;color:#000;text-align:center}.page-content{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;flex:1;gap:12px}.content-label{font-size:17px;font-weight:400;line-height:22px;letter-spacing:-.43px;color:#000;text-align:center;margin-top:64px}.page-footer-button{margin-bottom:44px;width:175px;height:44px;padding:14px 20px;background:#00000026;border-radius:12px;border:none;font-size:17px;font-weight:400;line-height:22px;letter-spacing:-.43px;color:#000;cursor:pointer;display:flex;align-items:center;justify-content:center;align-self:center;flex-shrink:0}.page-footer-button:hover{background:#00000040}.song-tile{width:297px;height:62px;padding:14px 20px;background:#00000026;border-radius:12px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:background .2s ease;user-select:none;-webkit-user-select:none}.song-tile:hover{background:#00000040}.song-tile-item{display:flex;gap:18px;align-items:center;justify-content:flex-start;width:100%}.song-tile-year{font-size:28px;font-weight:700;line-height:34px;letter-spacing:.38px;color:#000;flex-shrink:0;width:60px}.song-tile-info{display:flex;flex-direction:column;align-items:flex-start;justify-content:center;flex:1;min-width:0}.song-tile-song{font-size:13px;font-weight:400;font-style:italic;line-height:18px;letter-spacing:-.08px;color:#000;width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.song-tile-artist{font-size:13px;font-weight:400;line-height:18px;letter-spacing:-.08px;color:#000;width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.song-tile.incorrect-placement{background:#ff000026;animation:fadeIn .5s ease-in}.song-tile.incorrect-placement:hover{background:#ff000026}@keyframes fadeIn{0%{opacity:.3}to{opacity:1}}.game-over-popup{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#00000080;display:flex;align-items:center;justify-content:center;animation:fadeIn .3s ease-in;z-index:1000}.popup-content{background:#fff;border-radius:16px;padding:32px 48px;text-align:center;box-shadow:0 4px 12px #00000026}.popup-title{font-size:24px;font-weight:700;color:#000;margin:0 0 16px}.popup-score{font-size:18px;font-weight:400;color:#000;margin:0 0 24px}.popup-login-button{background:#ea6433;color:#fff;border:none;border-radius:8px;padding:12px 24px;font-size:16px;font-weight:500;cursor:pointer;transition:background .2s}.popup-login-button:hover{background:#d65a2c}.mystery-song-bar{padding:10px;background:#00000026;border-radius:12px;margin:19px 38px 13px;min-height:102px;display:flex;align-items:center;justify-content:center;opacity:0;animation:fadeIn .5s ease forwards;animation-delay:.3s}.mystery-song{background:#ffffff4d;cursor:grab;touch-action:none}.mystery-song:active{cursor:grabbing}.mystery-song.dragging{opacity:.5}.mystery-song .song-tile-year,.mystery-song .song-tile-song,.mystery-song .song-tile-artist{color:#fff}.timeline-wrapper{display:flex;flex-direction:column;height:100%;min-height:0}.timeline-wrapper.fade-in{opacity:0;animation:fadeIn .5s ease forwards;animation-delay:.3s}.timeline-content{overflow-y:auto;overflow-x:hidden;padding:0 20px;flex:1;scrollbar-width:none;-ms-overflow-style:none;display:flex;flex-direction:column;justify-content:center}.timeline-content::-webkit-scrollbar{display:none}.timeline{display:flex;flex-direction:column;align-items:center;gap:0;width:297px;margin:0 auto;padding:20px 0;height:100%}.timeline-label{font-size:17px;font-weight:400;line-height:22px;letter-spacing:-.43px;color:#000;text-align:center;padding:16px 0;flex-shrink:0}.timeline-label.fade-in{opacity:0;animation:fadeIn .5s ease forwards;animation-delay:.3s}.timeline-divider{height:2px;background:#00000026;border-radius:2px;opacity:0;animation:fadeIn .5s ease forwards;animation-delay:.3s;margin:10px}.timeline-divider-small{width:90px}.timeline-divider-medium{width:160px}.timeline-divider-big{width:230px}.timeline-song{cursor:default}.drop-zone{width:100%;min-height:12px;position:relative;transition:all .2s ease}.drop-zone.drag-over{min-height:62px;background:#ffffff40;border:2px dashed rgba(0,0,0,.4);border-radius:12px;margin:8px 0}.placed-mystery-tile{background:#ffffff4d;cursor:default;margin:0}.drop-zone:has(.placed-mystery-tile){display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:62px;background:#ffffff40;border:2px dashed rgba(0,0,0,.4);border-radius:12px;margin:8px 0}.confirm-button-inline{padding:8px 16px;background:#6478c8cc;color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:500;cursor:pointer;transition:background .2s ease}.confirm-button-inline:hover{background:#6478c8}.media-player{position:relative;height:72px;margin:0 32px 16px;opacity:0;animation:fadeIn .5s ease forwards;animation-delay:.3s}.media-player-play{width:100%;height:100%;background:#00000026;border-radius:12px;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:17px;font-weight:600;line-height:22px;letter-spacing:-.43px;color:#000;transition:background .2s ease}.media-player-play:hover{background:#00000040}.media-player-play:active{background:#0000004d}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideOutTop{0%{transform:translateY(0);opacity:1}to{transform:translateY(-100%);opacity:0}}@keyframes slideOutBottom{0%{transform:translateY(0);opacity:1}to{transform:translateY(100%);opacity:0}}.page-container.transitioning .page-header{animation:slideOutTop .3s ease forwards}.page-container.transitioning .page-footer-button{animation:slideOutBottom .3s ease forwards}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:#fff;border-radius:16px;padding:32px 24px;width:100%;max-width:400px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.modal-content h2{font-size:24px;font-weight:600;margin-bottom:8px;color:#000}.modal-subtitle{font-size:14px;color:#666;margin-bottom:24px}.form-group{margin-bottom:20px}.form-group label{display:block;font-size:14px;font-weight:500;margin-bottom:8px;color:#333}.modal-input{width:100%;padding:12px 16px;border:2px solid #e5e7eb;border-radius:8px;font-size:16px;transition:border-color .2s}.modal-input:focus{outline:none;border-color:#ea6433}.modal-error{background:#fee2e2;border:1px solid #fecaca;color:#dc2626;padding:12px;border-radius:8px;font-size:14px;margin-bottom:20px}.modal-buttons{display:flex;gap:12px;justify-content:flex-end}.modal-button{padding:12px 24px;border-radius:8px;font-size:16px;font-weight:500;border:none;cursor:pointer;transition:all .2s}.modal-button.primary{background:#ea6433;color:#fff}.modal-button.primary:hover:not(:disabled){background:#d65a2c}.modal-button.primary:disabled{background:#fca5a5;cursor:not-allowed}.modal-button.secondary{background:#f3f4f6;color:#374151}.modal-button.secondary:hover{background:#e5e7eb}.admin-dashboard{overflow-y:auto}.admin-header{flex-shrink:0}.admin-content{padding:0 20px;overflow-y:auto;gap:32px;align-items:stretch}.admin-section{background:#0000001a;border-radius:12px;padding:20px;margin-bottom:20px}.admin-section-title{font-size:20px;font-weight:600;margin-bottom:16px;color:#000}.admin-table{width:100%;border-collapse:collapse;background:#ffffff4d;border-radius:8px;overflow:hidden}.admin-table thead{background:#00000026}.admin-table th{padding:12px;text-align:left;font-size:14px;font-weight:600;color:#000}.admin-table td{padding:12px;font-size:14px;border-top:1px solid rgba(0,0,0,.1);color:#000}.admin-table tbody tr:hover{background:#fff3}.admin-btn{padding:6px 12px;background:#00000026;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;color:#000;margin-right:8px;transition:background .2s ease}.admin-btn:hover{background:#00000040}.admin-btn:last-child{margin-right:0}.display-name-input,.year-input{padding:6px 10px;border:1px solid rgba(0,0,0,.2);border-radius:4px;font-size:14px;background:#ffffff80}.admin-error{background:#ff000026;border:1px solid rgba(255,0,0,.3);color:#8b0000;padding:12px;border-radius:8px;margin:16px 0;font-size:14px}.no-session-text{color:#666;font-style:italic;font-size:13px}.admin-link-btn{margin:0 20px 16px;padding:12px 20px;background:#0003;border:none;border-radius:12px;font-size:16px;font-weight:500;color:#000;cursor:pointer;transition:background .2s ease}.admin-link-btn:hover{background:#0000004d}
