:root{--bg-primary: #0a0a0f;--bg-secondary: #12121a;--bg-tertiary: #1a1a2e;--bg-card: #16213e;--text-primary: #ffffff;--text-secondary: rgba(255, 255, 255, .7);--text-muted: rgba(255, 255, 255, .4);--accent-purple: #9333ea;--accent-pink: #ec4899;--accent-blue: #3b82f6;--gradient-primary: linear-gradient(135deg, var(--accent-purple) 0%, var(--accent-pink) 100%);--gradient-bg: linear-gradient(180deg, var(--bg-primary) 0%, var(--bg-secondary) 100%);--border-color: rgba(255, 255, 255, .1);--border-hover: rgba(255, 255, 255, .2);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--font-sans: "Inter", "Segoe UI", system-ui, -apple-system, sans-serif}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%}body{font-family:var(--font-sans);background:var(--gradient-bg);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.app{min-height:100vh;display:flex;flex-direction:column}.container{max-width:1400px;margin:0 auto;padding:0 24px;width:100%}.header{background:#0a0a0fcc;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border-color);padding:16px 0;position:sticky;top:0;z-index:100}.header-content{display:flex;align-items:center;justify-content:space-between}.logo{font-size:1.5rem;font-weight:800;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:2px}.user-info{display:flex;align-items:center;gap:12px}.user-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;border:2px solid var(--accent-purple)}.user-name{font-size:.9rem;color:var(--text-secondary)}.main{flex:1;padding:32px 0}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;font-size:.9rem;font-weight:600;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;text-decoration:none}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-sm),0 0 20px #9333ea4d}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-md),0 0 30px #9333ea66}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--bg-card);border-color:var(--border-hover)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover{background:#ffffff0d;color:var(--text-primary)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.section{margin-bottom:48px}.section-title{font-size:1.25rem;font-weight:600;margin-bottom:20px;color:var(--text-primary)}.section-subtitle{color:var(--text-muted);font-size:.875rem;margin-top:-12px;margin-bottom:20px}.playlist-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.playlist-card{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;transition:all .2s ease}.playlist-card:hover{border-color:var(--accent-purple);transform:translateY(-4px);box-shadow:var(--shadow-md)}.playlist-card.selected{border-color:var(--accent-purple);box-shadow:0 0 0 2px #9333ea4d}.playlist-image{width:100%;aspect-ratio:1;object-fit:cover;background:var(--bg-secondary)}.playlist-info{padding:12px}.playlist-name{font-weight:600;font-size:.9rem;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.playlist-tracks{color:var(--text-muted);font-size:.8rem}.track-list{display:flex;flex-direction:column;gap:8px}.track-item{display:flex;align-items:center;gap:16px;padding:12px 16px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease}.track-item:hover{background:var(--bg-card);border-color:var(--border-hover)}.track-item.selected{border-color:var(--accent-purple);background:#9333ea1a}.track-checkbox{width:20px;height:20px;accent-color:var(--accent-purple)}.track-image{width:48px;height:48px;border-radius:var(--radius-sm);object-fit:cover;background:var(--bg-secondary)}.track-info{flex:1;min-width:0}.track-name{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-artist{color:var(--text-muted);font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-year{color:var(--text-secondary);font-weight:600;font-size:.9rem;min-width:50px;text-align:right}.actions-bar{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background:#0a0a0fe6;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-top:1px solid var(--border-color);position:fixed;bottom:0;left:0;right:0}.selection-info{color:var(--text-secondary);font-size:.9rem}.selection-count{color:var(--accent-purple);font-weight:600}.actions-buttons{display:flex;gap:12px}.login-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;text-align:center;padding:24px}.login-logo{font-size:3rem;font-weight:800;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:16px;letter-spacing:4px}.login-subtitle{color:var(--text-secondary);font-size:1.1rem;margin-bottom:48px;max-width:400px}.spotify-btn{background:#1db954;color:#fff;padding:16px 32px;font-size:1rem;font-weight:600;border-radius:50px;box-shadow:0 4px 20px #1db9544d}.spotify-btn:hover{background:#1ed760;transform:translateY(-2px);box-shadow:0 6px 24px #1db95466}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:64px 24px;text-align:center;color:var(--text-muted)}.empty-icon{font-size:3rem;margin-bottom:16px;opacity:.5}.loading{display:flex;align-items:center;justify-content:center;padding:48px}.spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--accent-purple);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.modal-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px}.modal{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);max-width:800px;max-height:90vh;overflow:auto;width:100%}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border-color)}.modal-title{font-size:1.25rem;font-weight:600}.modal-close{background:none;border:none;color:var(--text-muted);font-size:1.5rem;cursor:pointer;padding:4px;line-height:1}.modal-close:hover{color:var(--text-primary)}.modal-body{padding:24px}@media(max-width:768px){.container{padding:0 16px}.playlist-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.actions-bar{flex-direction:column;gap:16px;padding:16px}.actions-buttons{width:100%}.actions-buttons .btn{flex:1}}.print-only{display:none}@media print{.no-print{display:none!important}.print-only{display:block}}.play-page{min-height:100vh;display:flex;flex-direction:column;background:var(--gradient-bg)}.play-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background:#0a0a0fcc;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border-color)}.play-title{font-size:1.25rem;font-weight:700;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.play-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px}.play-error{display:flex;align-items:center;gap:12px;padding:16px 24px;background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);color:#ef4444;margin-bottom:24px}.scanner-container{display:flex;flex-direction:column;align-items:center;gap:24px}.scanner-frame{position:relative;width:300px;height:300px;border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-tertiary)}.qr-reader{width:100%;height:100%}.qr-reader video{object-fit:cover}.scanner-overlay{position:absolute;inset:0;pointer-events:none}.scanner-corners{position:absolute;inset:40px;border:3px solid var(--accent-purple);border-radius:12px;animation:pulse-border 2s ease-in-out infinite}@keyframes pulse-border{0%,to{opacity:1}50%{opacity:.5}}.scanner-hint{display:flex;align-items:center;gap:8px;color:var(--text-secondary);font-size:.9rem}.scanner-loading{color:var(--accent-purple);font-size:.875rem}.playing-container{display:flex;flex-direction:column;align-items:center;gap:32px;width:100%;max-width:400px}.now-playing-card{width:100%;padding:48px 24px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-xl);text-align:center}.playing-animation{margin-bottom:24px}.sound-bars{display:flex;align-items:flex-end;justify-content:center;gap:6px;height:60px}.sound-bars span{width:8px;background:var(--gradient-primary);border-radius:4px;animation:soundbar .8s ease-in-out infinite}.sound-bars span:nth-child(1){animation-delay:0s;height:20px}.sound-bars span:nth-child(2){animation-delay:.1s;height:35px}.sound-bars span:nth-child(3){animation-delay:.2s;height:50px}.sound-bars span:nth-child(4){animation-delay:.3s;height:35px}.sound-bars span:nth-child(5){animation-delay:.4s;height:20px}@keyframes soundbar{0%,to{transform:scaleY(1)}50%{transform:scaleY(.5)}}.paused-indicator{color:var(--text-muted)}.mystery-text{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin-bottom:8px}.guess-prompt{color:var(--text-muted);font-size:1rem}.playback-controls{display:flex;align-items:center;justify-content:center;gap:16px}.control-btn{display:flex;align-items:center;justify-content:center;width:56px;height:56px;border:none;border-radius:50%;background:var(--bg-tertiary);color:var(--text-primary);cursor:pointer;transition:all .2s ease}.control-btn:hover{background:var(--bg-card);transform:scale(1.05)}.control-btn-primary{width:72px;height:72px;background:var(--gradient-primary);box-shadow:0 0 20px #9333ea66}.control-btn-primary:hover{box-shadow:0 0 30px #9333ea99}.scan-next-btn{width:100%;padding:16px 32px;font-size:1rem}@media(max-width:480px){.play-header{padding:12px 16px}.scanner-frame{width:280px;height:280px}.now-playing-card{padding:32px 16px}.control-btn{width:48px;height:48px}.control-btn-primary{width:64px;height:64px}}@media(max-width:375px){.scanner-frame{width:250px;height:250px}}.challenge-label{display:none}@media(min-width:480px){.challenge-label{display:inline;margin-left:4px}}.challenge-banner{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;background:linear-gradient(135deg,#eab30826,#f9731626);border:1px solid rgba(234,179,8,.3);border-radius:var(--radius-md);color:#fbbf24;font-size:.875rem;font-weight:500;margin-bottom:16px}.timer-display{display:flex;align-items:center;justify-content:center;gap:8px;padding:8px 16px;background:#eab30833;border-radius:var(--radius-full);color:#fbbf24;font-size:1.25rem;font-weight:700;margin-bottom:16px;animation:pulse-timer 1s ease-in-out infinite}@keyframes pulse-timer{0%,to{opacity:1}50%{opacity:.7}}.card{border-radius:16px;display:flex;align-items:center;justify-content:center;font-family:Inter,Segoe UI,system-ui,sans-serif;position:relative;overflow:hidden}.card-back{background:linear-gradient(145deg,#1a1a2e,#16213e,#0f0f23);border:2px solid rgba(255,255,255,.1);box-shadow:0 4px 20px #0006,inset 0 1px #ffffff0d}.card-back:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 20%,rgba(147,51,234,.15) 0%,transparent 50%),radial-gradient(circle at 70% 80%,rgba(236,72,153,.1) 0%,transparent 50%);pointer-events:none}.card-content{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:20px;width:100%;height:100%;position:relative;z-index:1}.card-artist{color:#fffc;font-size:4em;font-weight:600;text-transform:uppercase;letter-spacing:2px;margin-bottom:auto;padding-top:8%;max-width:90%;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-align:center;line-height:1.1;word-break:break-word}.card-year{color:#fff;font-size:10em;font-weight:800;text-shadow:0 0 40px rgba(147,51,234,.5);line-height:1}.card-song{color:#ffffffe6;font-size:4em;font-weight:500;font-style:italic;margin-top:auto;padding-bottom:8%;max-width:90%;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-align:center;line-height:1.1;word-break:break-word}.card-front{background:linear-gradient(145deg,#1a1a2e,#16213e,#0f0f23);border:2px solid rgba(255,255,255,.1);box-shadow:0 4px 20px #0006,inset 0 1px #ffffff0d;flex-direction:column}.card-front:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 20%,rgba(147,51,234,.15) 0%,transparent 50%),radial-gradient(circle at 70% 80%,rgba(236,72,153,.1) 0%,transparent 50%);pointer-events:none}.qr-container{display:flex;align-items:center;justify-content:center;position:relative;z-index:1}.card-logo{position:absolute;bottom:12%;color:#ffffff4d;font-size:.75em;font-weight:700;letter-spacing:4px;text-transform:uppercase}.card-preview{display:flex;gap:24px;align-items:center;justify-content:center;padding:20px}.card-preview-wrapper{display:flex;flex-direction:column;align-items:center;gap:8px}.card-preview-label{color:#ffffff80;font-size:.75em;text-transform:uppercase;letter-spacing:1px}@media print{.card{page-break-inside:avoid;-webkit-print-color-adjust:exact;print-color-adjust:exact}}.card-front.theme-colorful,.card-back.theme-colorful{background:linear-gradient(145deg,#1a0a2e,#2d1b4e,#1e3a5f 60%,#0d4f4f);border-color:#ff64ff4d}.card-front.theme-colorful:before,.card-back.theme-colorful:before{background:radial-gradient(circle at 20% 30%,rgba(0,255,255,.2) 0%,transparent 40%),radial-gradient(circle at 80% 20%,rgba(255,0,255,.2) 0%,transparent 40%),radial-gradient(circle at 50% 80%,rgba(255,255,0,.15) 0%,transparent 40%)}.card-back.theme-colorful .card-year{background:linear-gradient(90deg,#0ff,#f0f,#ff0);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;text-shadow:none;filter:drop-shadow(0 0 20px rgba(255,0,255,.5))}.card-front.theme-icy,.card-back.theme-icy{background:linear-gradient(145deg,#0a1628,#1e3a5f,#2d5a7b);border-color:#a8d5e54d}.card-front.theme-icy:before,.card-back.theme-icy:before{background:radial-gradient(circle at 30% 20%,rgba(168,213,229,.25) 0%,transparent 50%),radial-gradient(circle at 70% 70%,rgba(200,230,255,.2) 0%,transparent 50%),radial-gradient(circle at 20% 80%,rgba(100,200,255,.15) 0%,transparent 40%)}.card-back.theme-icy .card-year{color:#a8d5e5;text-shadow:0 0 30px rgba(168,213,229,.8),0 0 60px rgba(100,200,255,.4)}.card-back.theme-icy .card-artist,.card-back.theme-icy .card-song{color:#c8e6ffe6}.card-front.theme-sunny,.card-back.theme-sunny{background:linear-gradient(145deg,#2d1b06,#5a3000 40%,#8b4500,#6b3500);border-color:#ffb4324d}.card-front.theme-sunny:before,.card-back.theme-sunny:before{background:radial-gradient(circle at 70% 20%,rgba(255,200,50,.3) 0%,transparent 50%),radial-gradient(circle at 30% 70%,rgba(255,140,0,.2) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(255,100,0,.15) 0%,transparent 40%)}.card-back.theme-sunny .card-year{color:gold;text-shadow:0 0 30px rgba(255,200,50,.8),0 0 60px rgba(255,140,0,.5)}.card-back.theme-sunny .card-artist,.card-back.theme-sunny .card-song{color:#ffe6b4e6}.card-front.theme-neon,.card-back.theme-neon{background:linear-gradient(145deg,#0a0a0a,#0d0d1a,#1a0a2e);border-color:#00ff6466;box-shadow:0 4px 20px #0009,inset 0 0 30px #00ff640d,0 0 20px #00ff6433}.card-front.theme-neon:before,.card-back.theme-neon:before{background:radial-gradient(circle at 20% 20%,rgba(0,255,100,.15) 0%,transparent 40%),radial-gradient(circle at 80% 30%,rgba(255,0,128,.15) 0%,transparent 40%),radial-gradient(circle at 50% 80%,rgba(0,200,255,.15) 0%,transparent 40%)}.card-back.theme-neon .card-year{color:#00ff64;text-shadow:0 0 20px rgba(0,255,100,1),0 0 40px rgba(0,255,100,.8),0 0 80px rgba(0,255,100,.4)}.card-back.theme-neon .card-artist{color:#ff00c8e6;text-shadow:0 0 10px rgba(255,0,200,.5)}.card-back.theme-neon .card-song{color:#00c8ffe6;text-shadow:0 0 10px rgba(0,200,255,.5)}.card-front.theme-neon .qr-container svg{filter:drop-shadow(0 0 8px rgba(0,255,100,.6))}.card-front.theme-dutch,.card-back.theme-dutch{background:linear-gradient(145deg,#1a2850,#2a4070 40%,#3a5090,#2a4070);border:2px solid rgba(255,255,255,.15);box-shadow:0 4px 20px #2a4070cc,inset 0 0 40px #ff660014,0 0 15px #f603}.card-front.theme-dutch:before,.card-back.theme-dutch:before{background:radial-gradient(circle at 30% 20%,rgba(255,102,0,.15) 0%,transparent 50%),radial-gradient(circle at 70% 80%,rgba(255,153,51,.1) 0%,transparent 50%),radial-gradient(circle at 20% 70%,rgba(58,80,144,.3) 0%,transparent 40%)}.card-back.theme-dutch .card-year{color:#f60;text-shadow:0 0 30px rgba(255,102,0,.8),0 0 60px rgba(255,153,51,.5)}.card-back.theme-dutch .card-artist{color:#fffffff2;text-shadow:0 0 10px rgba(42,64,112,.7)}.card-back.theme-dutch .card-song{color:#ffdcb4f2;text-shadow:0 0 10px rgba(255,102,0,.3)}.card-front.theme-dutch .qr-container svg{filter:drop-shadow(0 0 8px rgba(255,102,0,.5))}.card-front.theme-dutch-clear,.card-back.theme-dutch-clear{background:#2a4070;border:3px solid #ff6600;box-shadow:0 4px 12px #0006,inset 0 0 0 2px #ffffff1a}.card-front.theme-dutch-clear:before,.card-back.theme-dutch-clear:before{background:none}.card-back.theme-dutch-clear .card-year{color:#f60;text-shadow:2px 2px 0 #1a2850,-1px -1px 0 #1a2850}.card-back.theme-dutch-clear .card-artist{color:#fff;text-shadow:1px 1px 0 rgba(0,0,0,.5)}.card-back.theme-dutch-clear .card-song{color:#fc9;text-shadow:1px 1px 0 rgba(0,0,0,.5)}.card-front.theme-dutch-clear .qr-container svg{filter:none}
