*{margin:0;padding:0;box-sizing:border-box}:root{--bg: #1a1a1a;--surface: #2a2a2a;--text: #e0e0e0;--text-dim: #888;--accent: #9500ff;--link: #4A96FF;--safe-top: 0px;--safe-bottom: 0px;--safe-left: 0px;--safe-right: 0px}body{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Inter,Helvetica Neue,Arial,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;overflow:hidden}.app{display:flex;flex-direction:column;height:100vh;height:100dvh;padding:calc(16px + var(--safe-top)) calc(16px + var(--safe-right)) calc(16px + var(--safe-bottom)) calc(16px + var(--safe-left))}.effects-layer{width:100%;height:120px;flex:none;z-index:-1;pointer-events:none}header{display:flex;flex-direction:column;gap:8px}main{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center}footer{padding-bottom:24px}.header-message{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 16px;border-radius:8px}.header-message-error{background:#ff646426}.header-message-announcement{background:#ede8d026}.header-message-text{font-size:13px;color:var(--text);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-message-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}.header-message-close,.header-message-expand{background:none;border:none;padding:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}.header-message-action-btn{background:none;border:none;padding:4px 8px;cursor:pointer;font-size:13px;font-weight:500;color:var(--text-dim);flex-shrink:0}.header-message-close svg,.header-message-expand svg{width:16px;height:16px;fill:var(--text-dim)}.header-message-expand svg{transform:rotate(0)}.announcement-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100;padding:24px}.announcement-modal{background:var(--surface);border-radius:8px;padding:10px 16px;max-width:100%;position:relative}.announcement-modal-close{position:absolute;top:8px;right:8px;background:none;border:none;padding:4px;cursor:pointer;display:flex;align-items:center;justify-content:center}.announcement-modal-close svg{width:16px;height:16px;fill:var(--text-dim)}.announcement-modal-content{color:var(--text);font-size:13px;line-height:1.5;padding-right:24px;white-space:pre-wrap}.announcement-modal-content a{color:var(--link);text-decoration:none}.announcement-modal .modal-actions{border-top:none;padding:16px 0 4px;gap:12px;align-items:stretch}.announcement-modal .modal-actions .modal-btn{flex:1;font-size:13px;font-weight:500;line-height:1.2;background:none;border:none;border-radius:0;padding:10px 16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.announcement-modal .modal-actions .ghost-btn{color:var(--text-dim)}.announcement-modal .modal-actions .apply-btn{color:var(--link)}.header-toolbar{display:flex;align-items:center;justify-content:space-between}.playlist-trigger{display:flex;align-items:center;gap:8px;background:none;border:none;cursor:pointer;font:inherit;padding:8px 0;color:var(--text);text-align:left}.playlist-trigger-icon{width:20px;height:20px}.playlist-name{font-size:16px;font-weight:500}.playlist-arrow{width:20px;height:20px;color:var(--text-dim)}.header-right{display:flex;align-items:center;gap:8px}.profile{background:none;border:none;cursor:pointer;display:flex;align-items:center;font:inherit;padding:8px}.favourites-btn,.player-settings-btn,.web-btn{background:none;border:none;padding:8px;cursor:pointer;display:flex;align-items:center;justify-content:center}.favourites-btn svg{width:22px;height:22px;fill:var(--text)}.web-btn svg{width:22px;height:22px;stroke:var(--text)}.player-settings-btn svg{width:24px;height:24px;fill:var(--text)}.profile img,.avatar-placeholder{width:24px;height:24px;border-radius:50%;object-fit:cover;outline:2px solid #d9d9d9}.avatar-placeholder{background:var(--surface);display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--text-dim)}.dropdown{position:absolute;top:calc(60px + var(--safe-top));background:var(--surface);border-radius:8px;padding:8px;z-index:10}.playlist-dropdown{left:calc(16px + var(--safe-left));min-width:160px}.profile-dropdown{right:calc(16px + var(--safe-right));min-width:140px}.profile-action{width:100%;margin-top:4px;padding:10px 12px;background:var(--surface);color:var(--text);border:none;border-radius:6px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;font-size:14px}.profile-action:hover{background:#ffffff1a}.profile-action .chevron{color:var(--text-dim);font-size:16px}.stat-item{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;gap:16px}.stat-label{font-size:13px;color:var(--text-dim)}.stat-value{font-size:14px;font-weight:600;color:var(--accent)}.dropdown .option{padding:10px 12px;cursor:pointer;border-radius:4px}.dropdown .option:hover{background:#ffffff1a}.dropdown .option.selected{color:var(--accent)}.timer-wrapper{display:flex;flex-direction:column;align-items:center;margin-top:110px}.timer-subtitle{font-size:12px;text-transform:uppercase;color:var(--text-dim);margin-bottom:10px}.timer{font-size:80px;font-variant-numeric:tabular-nums;letter-spacing:-1px;line-height:1}@media (aspect-ratio < 1/1) and (max-width: 360px){.timer{font-size:56px}}.now-playing-bar{display:flex;flex-direction:column;gap:8px}@media (aspect-ratio > 1.2){.now-playing-bar{display:grid;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);align-items:center;gap:24px;padding:0 16px}}.track-widget{display:flex;align-items:center;gap:10px;width:100%;height:60px;cursor:pointer}@media (aspect-ratio > 1.2){.track-widget{width:100%;min-width:0}}.track-cover{width:60px;height:60px;flex-shrink:0;border-radius:6px;overflow:hidden}.track-cover img{width:100%;height:100%;object-fit:cover}.cover-placeholder{width:100%;height:100%;background:var(--surface);display:flex;align-items:center;justify-content:center;font-size:24px;color:var(--text-dim)}.track-info{min-width:0;overflow:hidden}.track-fav-btn,.track-blacklist-btn{background:none;border:none;color:var(--text);cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center}.track-fav-btn svg,.track-blacklist-btn svg{width:20px;height:20px}.track-fav-btn:disabled,.track-blacklist-btn:disabled{opacity:.3;cursor:default}.track-name{font-size:15px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-meta{font-size:12px;color:var(--text-dim);font-stretch:condensed;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-controls{display:flex;align-items:center;justify-content:center;gap:16px;max-width:400px;margin:0 auto}@media (aspect-ratio > 1.2){.player-controls{flex:1;max-width:none;margin:0;justify-content:center;justify-self:center}}.center-controls{display:flex;align-items:center}.skip-btn{background:none;border:none;color:#fff;cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center}.skip-btn svg{width:36px;height:36px}.play-btn{background:transparent;color:#fff;border:2px solid #fff;cursor:pointer;padding:8px;border-radius:50%;margin:0 20px;display:flex;align-items:center;justify-content:center}.play-btn svg{width:42px;height:42px}.player-aux-controls{display:flex;justify-content:space-between;align-items:center;padding:0 24px}@media (aspect-ratio > .75){.player-aux-controls{justify-content:center;padding:0}}@media (aspect-ratio > 1.2){.player-aux-controls{flex-shrink:0;justify-self:end}}.aux-btn{background:none;border:none;color:var(--text-dim);cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center}.aux-btn svg{width:20px;height:20px}.aux-btn.active{color:#fff}.player-controls .repeat-btn,.player-controls .shuffle-btn{display:none}@media (aspect-ratio > .75){.player-controls .repeat-btn,.player-controls .shuffle-btn{display:flex}.player-aux-controls .repeat-btn,.player-aux-controls .shuffle-btn{display:none}}.volume-slider{width:130px;height:32px;display:flex;align-items:center;cursor:pointer;touch-action:none}.volume-track{position:relative;width:100%;height:2px;background:var(--text-dim);border-radius:1px}.volume-fill{position:absolute;left:0;top:0;height:100%;background:#fff;border-radius:1px}.volume-thumb{position:absolute;top:50%;width:8px;height:8px;background:#fff;border-radius:50%;transform:translate(-50%,-50%)}.volume-thumb:before{content:"";position:absolute;top:50%;left:50%;width:24px;height:24px;transform:translate(-50%,-50%)}@media (aspect-ratio < 1/1){.track-widget{min-width:0}}@media (aspect-ratio < 1/1) and (max-width: 360px){.track-widget{height:50px}.track-name{font-size:13px}.track-meta{font-size:11px}}.modal-actions{display:flex;padding:8px 20px;border-top:1px solid rgba(255,255,255,.1);gap:12px;align-items:stretch}.modal-actions .modal-btn{display:inline-flex;align-items:center;justify-content:center;min-height:36px;line-height:1.2;text-align:center}.modal-actions .ghost-btn,.modal-actions .apply-btn{flex:1;text-align:center;background:none;border:none;padding:8px 16px;font-family:inherit;font-size:16px;font-weight:500;cursor:pointer}.modal-actions .ghost-btn{color:var(--text)}.modal-actions .apply-btn{color:var(--text);border:1px solid var(--text);border-radius:20px}.ghost-btn{background:transparent;border:1px solid rgba(255,255,255,.25);color:var(--text);padding:10px 14px;border-radius:6px;cursor:pointer}@media (max-width: 360px){.modal-actions{flex-direction:column;gap:8px}.modal-actions .modal-btn{width:100%}.announcement-modal .modal-actions .modal-btn{white-space:normal}}.playlist-modal-overlay,.track-list-modal-overlay,.settings-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:30;display:flex;align-items:flex-end;justify-content:center}@media (aspect-ratio > 1.2){.playlist-modal-overlay,.track-list-modal-overlay,.settings-modal-overlay{align-items:center}}.playlist-modal,.track-list-modal,.settings-modal{background:var(--surface);border-radius:16px 16px 0 0;width:100%;max-width:500px;max-height:60vh;display:flex;flex-direction:column;padding-top:8px;padding-bottom:calc(16px + var(--safe-bottom))}.settings-modal{max-height:95vh}@media (aspect-ratio > 1.2){.playlist-modal,.track-list-modal,.settings-modal{border-radius:16px;max-height:80vh;padding-bottom:16px}}.modal-header{font-size:14px;font-weight:600;color:var(--text);text-align:center;padding:8px 20px 16px}.modal-tabs{display:flex;gap:0;padding:0 20px 12px;border-bottom:1px solid rgba(255,255,255,.1)}.modal-tab{flex:1;background:none;border:none;padding:10px 16px;font-family:inherit;font-size:14px;font-weight:500;color:var(--text-dim);cursor:pointer;border-bottom:2px solid transparent;transition:color .2s,border-color .2s}.modal-tab.active{color:var(--text);border-bottom-color:var(--text)}.playlist-modal-list{height:300px;overflow-y:auto;padding:0 12px}.playlist-item{display:flex;align-items:center;gap:16px;padding:12px 12px 4px;border-radius:8px;cursor:pointer}.playlist-item:hover{background:none}.playlist-item-icon{width:20px;height:20px;color:var(--text);flex-shrink:0}.playlist-item-icon svg{width:100%;height:100%}.playlist-item-title{flex:1;font-size:16px;font-weight:500;color:var(--text)}.playlist-item-check{width:20px;height:20px;color:var(--text);flex-shrink:0}.playlist-item-wrapper{display:flex;flex-direction:column}.playlist-item-desc{min-height:32px;padding:0 12px 8px 52px;font-size:12px;line-height:1.3;color:var(--text-dim)}.genre-modal-item{display:flex;align-items:center;padding:10px 12px;cursor:pointer;border-radius:8px;border:1px solid transparent}.genre-modal-item:last-child{margin-bottom:0}.genre-modal-item.selected{border-color:#ffffff4d}.genre-modal-item-icon{width:18px;height:18px;color:var(--text);flex-shrink:0;margin-right:12px}.genre-modal-item-name{flex:1;font-family:inherit;font-size:16px;font-weight:500;color:var(--text)}.genre-modal-item-check{width:20px;height:20px;color:var(--text);opacity:0}.genre-modal-item.selected .genre-modal-item-check{opacity:1}.track-list-modal-list{flex:1;overflow-y:auto;padding:0 12px}.track-list-empty{text-align:center;color:var(--text-dim);font-size:14px;padding:40px 20px}.track-list-item{display:flex;align-items:center;justify-content:space-between;padding:12px;border-radius:8px;min-height:58px;box-sizing:border-box}.track-list-info{flex:1;min-width:0}.track-list-name{font-size:15px;line-height:18px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-list-meta{font-size:12px;line-height:14px;color:var(--text-dim);margin-top:2px}.track-list-item.loading{animation:pulse 1.2s ease-in-out infinite}.track-list-item.clickable{cursor:pointer}.favourite-trash-btn{background:none;border:none;color:var(--text-dim);cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.favourite-trash-btn svg{width:18px;height:18px}.favourite-trash-btn:disabled{opacity:.3;cursor:default}.track-list-item.current{background:#ffffff1a;border-radius:8px}.settings-body{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:32px;padding:0 16px 80px}.settings-section{display:flex;flex-direction:column;gap:8px}.section-header{display:flex;align-items:center;gap:8px;margin-bottom:8px;position:relative}.section-label{font-size:16px;font-weight:600;color:var(--text)}.hint-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9}.hint-icon{background:none;border:none;padding:8px;margin:-8px;cursor:pointer;color:var(--text-dim);display:flex;align-items:center}.hint-icon svg{width:14px;height:14px}.hint-tooltip{position:absolute;left:0;top:100%;margin-top:8px;padding:8px 12px;background:#2a2a2a;border:1px solid rgba(255,255,255,.15);border-radius:8px;font-size:13px;color:var(--text-dim);white-space:normal;max-width:250px;z-index:10}.select-all{margin-left:auto;font-size:14px;font-family:inherit;color:var(--text);cursor:pointer;background:none;border:none}.genre-list{border:1px solid rgba(255,255,255,.1);border-radius:12px;overflow:hidden}.genre-item{display:flex;align-items:center;gap:12px;padding:14px 16px;cursor:pointer;border-bottom:1px solid rgba(255,255,255,.08)}.genre-item:last-child{border-bottom:none}.genre-item-icon{width:18px;height:18px;color:var(--text);flex-shrink:0}.genre-item-icon svg{width:100%;height:100%}.genre-item-name{flex:1;font-size:14px;color:var(--text)}.genre-item-check{width:20px;height:20px;color:var(--text);opacity:0}.genre-item.selected .genre-item-check{opacity:1}.empty-state{color:var(--text-dim);font-size:13px}.loading-row{color:var(--text-dim);font-size:14px;padding:8px}.bpm-row{display:flex;align-items:center;gap:12px}.bpm-inputs{display:flex;gap:8px}.bpm-reset{font-size:14px;font-family:inherit;color:var(--text);background:none;border:none;cursor:pointer}.bpm-field{display:flex;align-items:center;gap:8px;padding:10px 12px;background:transparent;border:1px solid rgba(255,255,255,.1);border-radius:8px}.bpm-field:focus-within{border-color:#ffffff4d}.bpm-label{font-size:14px;color:var(--text-dim);flex-shrink:0}.bpm-input{width:48px;padding:0;font-size:14px;font-family:inherit;color:var(--text);background:transparent;border:none;outline:none;-moz-appearance:textfield}.bpm-input::-webkit-outer-spin-button,.bpm-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.track-length-options{display:flex;gap:8px}.track-length-option{flex:1;padding:10px;font-size:14px;font-family:inherit;color:var(--text-dim);background:none;border:1px solid rgba(255,255,255,.1);border-radius:8px;cursor:pointer}.track-length-option.selected{color:var(--text);border-color:var(--text)}@keyframes pulse{0%,to{opacity:.4}50%{opacity:.8}}.track-widget.loading,.playlist-trigger.loading{animation:pulse 1.2s ease-in-out infinite}.cover-skeleton{width:100%;height:100%;background:linear-gradient(90deg,var(--surface) 25%,#3a3a3a 50%,var(--surface) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}.skeleton-text{background:linear-gradient(90deg,var(--surface) 25%,#3a3a3a 50%,var(--surface) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:4px}.skeleton-title{height:18px;width:120px;margin-bottom:2px}.skeleton-meta{height:14px;width:80px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.timer-loading .dot{opacity:.3;animation:dot-pulse 1.2s ease-in-out infinite}.timer-loading .dot:nth-child(1){animation-delay:0s}.timer-loading .dot:nth-child(2){animation-delay:.4s}.timer-loading .dot:nth-child(3){animation-delay:.8s}@keyframes dot-pulse{0%,to{opacity:.3}33%{opacity:1}}.intro-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg);z-index:100;display:flex;flex-direction:column;padding:calc(40px + var(--safe-top)) 24px calc(12px + var(--safe-bottom))}.intro-slides-container{flex:1;position:relative;overflow:hidden}.intro-slides-track{display:flex;height:100%;transition:transform .4s cubic-bezier(.4,0,.2,1)}.intro-slide{flex:0 0 100%;display:flex;flex-direction:column;align-items:center;text-align:center}.intro-title{font-size:36px;font-weight:500;color:var(--text);margin-bottom:20px;line-height:1.2;height:86px}.intro-graphic{flex:1;display:flex;align-items:center;justify-content:center;width:100%;max-height:260px;margin-bottom:20px}.intro-image{max-width:100%;max-height:100%;object-fit:contain}.intro-subtitle{font-size:16px;font-weight:200;color:var(--text);line-height:1.5;max-width:300px;text-align:left}.intro-dots{display:flex;justify-content:center;gap:12px;padding:24px 0}.intro-dot{width:32px;height:4px;border-radius:2px;background:#fff3;border:none;cursor:pointer;padding:0;transition:background .2s ease}.intro-dot.active{background:var(--text)}.intro-footer{display:flex;justify-content:flex-end;padding-top:16px}.intro-skip-btn{background:transparent;border:none;color:var(--text);padding:12px 24px;font-family:inherit;font-size:16px;font-weight:500;cursor:pointer}.intro-skip-btn:active{background:#ffffff1a}.onboarding-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg);z-index:100;display:flex;flex-direction:column;padding:calc(40px + var(--safe-top)) 24px calc(24px + var(--safe-bottom))}.onboarding-step-counter{position:absolute;top:calc(16px + var(--safe-top));right:24px;font-size:14px;color:var(--text-dim)}.onboarding-container{flex:1;display:flex;flex-direction:column;overflow-y:auto}.onboarding-question{font-size:28px;font-weight:500;color:var(--text);margin-bottom:24px;line-height:1.3}.onboarding-options{display:flex;flex-wrap:wrap;gap:10px}.onboarding-options.vertical{flex-direction:column;gap:8px}.onboarding-option{display:flex;align-items:center;gap:8px;background:transparent;border:1px solid rgba(255,255,255,.2);border-radius:20px;padding:10px 16px;color:var(--text);font-family:inherit;font-size:15px;font-weight:400;cursor:pointer}.onboarding-options.vertical .onboarding-option{flex-direction:column;align-items:flex-start;gap:2px;border-radius:12px;padding:12px 16px}.onboarding-option-label{font-size:15px}.onboarding-option-hint{font-size:13px;color:var(--text-dim)}.onboarding-genre-icon{width:18px;height:18px;color:var(--text);flex-shrink:0}.onboarding-option.selected{border-color:var(--accent)}.onboarding-footer{display:flex;justify-content:space-between;padding-top:16px}.onboarding-back-btn{background:transparent;border:none;color:var(--text);padding:12px 24px;font-family:inherit;font-size:16px;font-weight:500;cursor:pointer}.onboarding-next-btn{background:transparent;border:none;color:var(--text);padding:12px 24px;font-family:inherit;font-size:16px;font-weight:500;cursor:pointer;margin-left:auto}.onboarding-next-btn:disabled{opacity:.3;cursor:not-allowed}.personalization-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg);z-index:100;display:flex;align-items:center;justify-content:center}.personalization-content{display:flex;flex-direction:column;align-items:center;gap:40px}.personalization-title{font-size:22px;font-weight:500;color:var(--text);text-align:center}.personalization-circle-container{position:relative;width:140px;height:140px}.personalization-circle-container.ready{animation:breathe 6s ease-in-out .4s infinite;cursor:pointer}.personalization-circle{width:100%;height:100%;transform:rotate(-90deg)}.personalization-circle-bg{fill:none;stroke:#ffffff1a;stroke-width:2}.personalization-circle-progress{fill:none;stroke:var(--accent);stroke-width:2;stroke-linecap:round}.personalization-play-btn{position:absolute;top:50%;left:52%;transform:translate(-50%,-50%) scale(0);width:76px;height:76px;color:var(--text);opacity:0;pointer-events:none}.personalization-play-btn svg{width:100%;height:100%}.personalization-play-btn.visible{opacity:1;transform:translate(-50%,-50%) scale(1);pointer-events:auto;animation:playBtnAppear .8s ease-out forwards}@keyframes playBtnAppear{0%{opacity:0;transform:translate(-50%,-50%) scale(.3)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@keyframes breathe{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}
