.home-modes{display:flex;flex-direction:column;gap:1rem}.home-col-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);padding-left:.1rem;margin-bottom:.5rem}.home-mode-card{display:flex;align-items:flex-start;gap:1.25rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.75rem;text-decoration:none;color:var(--text);transition:border-color .15s,background .15s;position:relative}.home-mode-card__notifier{position:absolute;top:.75rem;right:.75rem;font-size:.7rem;pointer-events:none}.home-mode-card:hover{border-color:var(--accent);background:var(--surface2);text-decoration:none}.home-mode-card__icon{font-size:2.5rem;line-height:1;flex-shrink:0}.home-mode-card__title{font-size:1.3rem;font-weight:700;margin-bottom:.4rem}.home-mode-card__desc{font-size:.95rem;line-height:1.5}.home-mode-card__cta{margin-top:1rem;display:inline-flex}.home-challenges-col,.home-weekly-col{display:flex;flex-direction:column;gap:.75rem}@media (min-width: 500px){.home-modes{flex-direction:row;align-items:stretch;min-height:clamp(400px,58vh,540px)}.home-mode-card__icon{font-size:3rem}.home-multiplayer-col{flex:1;display:flex;flex-direction:column}.home-multiplayer-col .home-mode-card{flex:1;flex-direction:column;padding:2.25rem 2rem}.home-challenges-col{flex:1}.home-challenges-col .home-mode-card{flex:1;flex-direction:column;padding:1.5rem 1.75rem}.home-weekly-col{flex:1;display:flex;flex-direction:column}.home-weekly-col .home-mode-card{flex:1;flex-direction:column;padding:1.5rem 1.75rem}}.playlist-picker{width:100%;max-width:580px;max-height:80vh;display:flex;flex-direction:column}.playlist-picker__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.playlist-picker__tabs{display:flex;gap:.25rem;margin-bottom:.5rem}.playlist-picker__tab{padding:.35rem .8rem;border-radius:6px;font-weight:600;font-size:.88rem;border:none;cursor:pointer;background:transparent;color:var(--text-dim);transition:background .15s,color .15s}.playlist-picker__tab:hover{color:var(--text)}.playlist-picker__tab--active{background:#6c63ff1f;color:var(--accent)}.playlist-picker__search{margin-bottom:.5rem;font-size:.85rem}.playlist-picker__body{flex:1;overflow-y:auto;margin:0 -.25rem;padding:0 .25rem}.playlist-picker__row{display:flex;align-items:center;gap:.6rem;padding:.55rem .6rem;border-radius:6px;cursor:pointer;border:1px solid transparent;transition:background .12s}.playlist-picker__row:hover{background:var(--surface2)}.playlist-picker__row--selected{border-color:#6c63ff66;background:#6c63ff14}.playlist-picker__name-block{flex:1;min-width:0}.playlist-picker__name{font-weight:600}.playlist-picker__meta{font-size:.8rem;color:var(--text-dim);margin-top:.1rem}.playlist-picker__right{display:flex;align-items:center;gap:.4rem;flex-shrink:0}.playlist-picker__count{font-size:.8rem;color:var(--text-dim);white-space:nowrap}.playlist-picker__expand{background:none;border:none;cursor:pointer;color:var(--text-dim);padding:0 .2rem;font-size:.8rem;line-height:1}.playlist-picker__expand:hover{color:var(--text)}.playlist-picker__desc-row{padding:.2rem .6rem .5rem;font-size:.82rem;color:var(--text-dim)}.playlist-picker-trigger{width:100%;text-align:left;justify-content:space-between;margin-top:.25rem}.playlist-picker__footer{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border);display:flex;justify-content:flex-end}.preset-list{display:flex;flex-direction:column;gap:.5rem;margin-top:.25rem}.preset-option{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem;border-radius:8px;border:1px solid var(--border);background:var(--surface2);cursor:pointer;transition:border-color .15s,background .15s}.preset-option--active{border-color:var(--accent);background:#6c63ff1a}.preset-option__name{font-weight:600}.preset-option__desc{font-size:.82rem;color:var(--text-dim)}.records-row{margin-top:.4rem;display:flex;align-items:center;gap:.75rem}.records-row__note{font-size:.82rem;color:var(--text-dim);margin-top:.4rem}.join-code-input{letter-spacing:.2em;font-family:monospace;font-size:1.2rem;text-align:center}.room-code{font-family:monospace;font-size:1.6rem;font-weight:700;letter-spacing:.15em;color:var(--accent)}.room-info-row{color:var(--text-dim);font-size:.85rem}.room-info-row+.room-info-row{margin-top:.25rem}.room-records-row{margin-top:.25rem;font-size:.82rem}.player-list{display:flex;flex-direction:column;gap:.4rem}.player-row{display:flex;align-items:center;gap:.5rem;padding:.4rem 0}.player-row__name--me{font-weight:700}.player-row__you-label{color:var(--text-dim);font-weight:400}.player-host{font-size:.75rem;color:var(--accent);font-weight:600}.settings-form-row{display:flex;gap:1rem}.start-hint{color:var(--text-dim);font-size:.82rem;text-align:center;margin-top:.5rem}.hint-display{margin-bottom:.75rem}.hint-display__label{margin-bottom:.35rem}.hint-display__words{display:flex;flex-wrap:wrap;gap:.6rem;font-family:monospace;font-size:1.4rem;line-height:1.3}.hint-display__word{display:inline-flex;gap:0;align-items:flex-end}.hint-display__blank{display:inline-block;width:.8em;height:1em;border-bottom:2px solid var(--accent);margin-right:3px}.hint-display__char{color:var(--text);margin-right:1px}.answer-input{margin-top:1rem}.answer-input--done{opacity:.45;pointer-events:none}.answer-input__badges{display:flex;gap:.5rem;margin-bottom:.4rem}.answer-input__form{display:flex;gap:.5rem}.answer-badge{padding:.25rem .6rem;border-radius:6px;font-size:.78rem;font-weight:700;border:1px solid}.answer-badge--got{background:#4caf7233;color:var(--green);border-color:var(--green)}.answer-badge--pending{background:var(--surface2);color:var(--text-dim);border-color:var(--border)}.scoreboard-wrap{display:flex;flex-direction:column}.card.scoreboard{padding:.8rem}.sb-col-t{width:44px;flex-shrink:0;text-align:center}.sb-col-a{width:48px;flex-shrink:0;text-align:center}.sb-col-time{width:4rem;flex-shrink:0;text-align:center;margin-left:.75rem}.sb-col-score{width:3rem;flex-shrink:0;text-align:right;margin-left:.75rem}.sb-col--center{display:inline-flex;justify-content:center}.scoreboard__header-row{display:flex;align-items:baseline;padding:0 1.35rem 0 0;gap:.5rem;margin-bottom:.5rem}.scoreboard__title{flex:1;font-size:1rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text)}.scoreboard__col-labels{display:flex;align-items:center;font-size:.72rem;margin-right:.1rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em}.scoreboard__list{display:flex;flex-direction:column;gap:.4rem}.scoreboard__row{display:flex;align-items:center;justify-content:space-between;padding:.4rem .6rem .4rem .15rem;border-radius:6px;border:1px solid transparent;gap:.5rem}.scoreboard__row--me{background:#6c63ff26;border-color:#6c63ff4d}.scoreboard__player{display:flex;align-items:center;gap:.4rem;min-width:0;flex:1}.scoreboard__rank{color:var(--text-dim);font-size:.95rem;font-weight:700;width:1.2rem;text-align:right;flex-shrink:0;padding-right:.75rem}.scoreboard__avatar{width:24px;height:24px;border-radius:50%;object-fit:cover;flex-shrink:0}.scoreboard__name{font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.scoreboard__name--me{font-weight:700}.scoreboard__name--dc{opacity:.5}.scoreboard__dc-dot{font-size:.55rem;color:var(--text-dim);margin-left:.25rem}.scoreboard__flag{width:18px;height:auto;border-radius:2px;flex-shrink:0;opacity:.85}.scoreboard__right{display:flex;align-items:center;flex-shrink:0}.scoreboard__time{font-size:.9rem;font-weight:500;color:var(--text);font-variant-numeric:tabular-nums}.scoreboard__score{font-weight:700;font-size:.95rem}.tiny-badge{width:20px;height:20px;border-radius:4px;font-size:.7rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.tiny-badge--got{background:var(--green);color:#fff}.tiny-badge--blank{background:var(--surface2);color:var(--text-dim)}.round-header__bar-track{background:var(--surface2);border-radius:4px;height:6px;overflow:hidden}.round-header__bar-fill{height:100%;border-radius:4px;transition:width .2s linear,background .3s}.report-modal__code-box{margin-bottom:1rem}.report-modal__code-label{font-size:.75rem;color:var(--text-dim);margin-bottom:.2rem}.report-modal__code{font-family:monospace;font-weight:700;letter-spacing:.1em}.report-modal__hint{font-size:.82rem;color:var(--text-dim);margin-bottom:1rem}.report-modal__btn-row{display:flex;gap:.5rem;margin-bottom:1rem}.report-modal__footer{display:flex;align-items:center;gap:.75rem;margin-bottom:.4rem}.report-modal__id-label{font-size:.75rem;color:var(--text-dim)}.report-modal__id-value{font-family:monospace;font-weight:700;letter-spacing:.08em;font-size:.9rem}.report-modal__footer-hint{font-size:.78rem;color:var(--text-dim);margin:0}.report-modal__song-value{padding:.5rem 0;color:var(--text-dim);font-size:.9rem}.starting-timer{text-align:center;margin-top:1.25rem}.starting-timer__number{font-size:2.5rem;font-weight:700;line-height:1;color:var(--text)}.starting-timer__bar-track{margin:.5rem auto 0;width:200px;height:4px;background:var(--border);border-radius:2px;overflow:hidden}.starting-timer__bar-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .2s linear}.unmute-banner{position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%);background:var(--surface, #222);border:1px solid var(--border, #444);border-radius:2rem;padding:.5rem 1.25rem;font-size:.9rem;cursor:pointer;z-index:100;white-space:nowrap}.game-layout{display:grid;grid-template-columns:1fr 260px;gap:.5rem 1rem;align-items:start}.game-round-info{display:flex;align-items:center;gap:.6rem}.game-round-info__label{font-weight:700;font-size:1rem}.game-round-info__total{color:var(--text-dim);font-weight:400}.game-timerbar{grid-column:1 / -1}.game-scoreboard{grid-column:1}.game-section-label{font-size:1rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text);margin-bottom:.4rem}.game-timer-number{align-self:stretch;display:flex;align-items:center;justify-content:center;font-size:3rem;font-weight:700;font-variant-numeric:tabular-nums;line-height:1;transition:color .3s}.game-answer-col{display:flex;flex-direction:column}.game-songinfo-slot{align-self:start}.game-songinfo-slot .song-info-card{padding:.6rem .8rem .8rem}.game-controls{display:flex;flex-direction:row;align-items:center;gap:.5rem;width:100%}.game-between-header{display:flex;justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.75rem}.game-between-header__right{display:flex;align-items:center;gap:.5rem}.vol-disconnect-btn{font-size:.72rem!important;padding:.2rem .55rem!important}.game-report-btn{text-align:right;margin-top:.5rem}.song-info-card{display:flex;flex-direction:column;gap:.35rem;padding:.55rem .75rem}.song-info-card__correct{font-size:.7rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em}.song-info-card__main{display:flex;gap:.65rem;align-items:flex-start}.song-info-card__img{width:48px;height:48px;border-radius:6px;object-fit:cover;flex-shrink:0}.song-info-card__body{flex:1;display:flex;flex-direction:column;justify-content:center}.song-info-card__title{font-weight:700;font-size:.95rem;margin-bottom:.15rem;line-height:1.2}.song-info-card__artist{color:var(--text-dim);font-size:.85rem;line-height:1.2}.song-info-card__record{font-size:.75rem;color:var(--accent);margin-top:.25rem}.round-answer__label{font-size:.8rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem}.round-answer__body{display:flex;gap:1rem;align-items:flex-start}.round-answer__img{width:80px;height:80px;border-radius:8px;object-fit:cover;flex-shrink:0}.round-answer__info{flex:1}.round-answer__title{font-size:1.15rem;margin-bottom:.3rem}.round-answer__artist{color:var(--text-dim);font-size:.95rem;margin-bottom:.3rem}.round-answer__album{font-size:.82rem;color:var(--text-dim);margin-bottom:.3rem}.round-answer__record{font-size:.8rem;color:var(--accent);margin-top:.2rem}.results-list{margin-bottom:1.5rem}.results-row{display:flex;align-items:center;gap:.75rem;padding:.75rem .5rem;border-radius:6px}.results-row--me{background:#6c63ff12}.results-row__medal{font-size:1.4rem;width:2rem;text-align:center}.results-row__name{flex:1;font-size:1rem}.results-row__name--me{font-weight:700}.results-row__you-label{color:var(--text-dim);font-weight:400;font-size:.85rem}.results-row__score{font-weight:700;font-size:1.2rem}.results-row__score--first{color:var(--yellow)}.results-actions{text-align:center}.results-actions__buttons{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}.stats-player-cell{display:inline-flex;align-items:center;gap:.5rem;text-decoration:none;color:inherit}.stats-player-cell:hover .stats-player-name{text-decoration:underline}.stats-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover;flex-shrink:0}.stats-flag{width:20px;height:15px;object-fit:cover;border-radius:2px;flex-shrink:0}.stats-search-row{display:flex;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}.stats-search-input{flex:1 1 200px;padding:.4rem .6rem;background:var(--bg);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:.9rem;font-family:var(--font);outline:none;transition:border-color .15s}.stats-search-input:focus{border-color:var(--accent)}.stats-search-input--narrow{flex:1 1 160px}.song-header{display:flex;gap:1.25rem;align-items:center;margin-bottom:2rem}.song-header__img{width:100px;height:100px;object-fit:cover;border-radius:8px;flex-shrink:0}.song-header__artist{font-size:1rem;font-weight:600;color:var(--text-dim);margin-bottom:.2rem}.song-header__title-row{display:flex;align-items:baseline;gap:.6rem}.song-header__title{font-size:1.5rem;font-weight:700}.song-header__duration{font-size:.78rem;font-weight:500;color:var(--text-dim)}.song-header__meta{font-size:.9rem;font-weight:500;color:var(--text-dim);margin-top:.25rem}.pe-modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:min(640px,calc(100vw - 2rem));max-height:calc(100vh - 2rem);display:flex;flex-direction:column;overflow:hidden}.pe-modal__header{flex-shrink:0;padding:.75rem 1.25rem .6rem;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:.35rem}.pe-modal__header-top{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.pe-modal__title{font-size:1rem;font-weight:600;margin:0}.pe-modal__header-input{font-size:.8rem!important;padding:.25rem .5rem!important}.pe-modal__close{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:1.25rem;line-height:1;padding:.2rem .4rem;border-radius:4px}.pe-modal__close:hover{color:var(--text);background:var(--surface2)}.pe-modal__body{flex:1;display:flex;flex-direction:column;overflow-y:auto;min-height:0}.pe-playlist-section{flex-shrink:0}.pe-playlist-header{display:flex;align-items:center;gap:.5rem;width:100%;background:none;border:none;cursor:pointer;padding:.75rem 1rem;color:var(--text);font-size:.82rem;font-weight:600;text-align:left;border-bottom:1px solid var(--border)}.pe-playlist-header:hover{background:var(--surface2)}.pe-playlist-header__chevron{font-size:.75rem;color:var(--text-dim);width:12px;flex-shrink:0}.pe-playlist-header__count{font-weight:400;font-size:.78rem;margin-left:auto}.pe-playlist-inner{display:flex;gap:0;border-bottom:1px solid var(--border)}.pe-playlist-col{flex:1;max-height:200px;overflow-y:auto;padding:.6rem .75rem;min-width:0;scrollbar-gutter:stable}.pe-playlist-col+.pe-playlist-col{border-left:1px solid var(--border)}.pe-playlist-col__title{font-size:.68rem;text-transform:uppercase;letter-spacing:.07em;color:var(--text-dim);margin-bottom:.4rem;padding-bottom:.25rem;border-bottom:1px solid var(--border)}.pe-divider{height:0;flex-shrink:0}.pe-add-section{flex:1;display:flex;flex-direction:column;min-height:300px;padding:.75rem 1rem 0}.pe-add-section__title{font-size:.68rem;text-transform:uppercase;letter-spacing:.07em;color:var(--text-dim);margin-bottom:.6rem}.pe-add-hint{font-size:.7rem;margin-bottom:.4rem;flex-shrink:0}.pe-add-scroll{flex:1;overflow-y:auto;min-height:0;padding-bottom:.5rem;scrollbar-gutter:stable}.pe-song-row{display:flex;align-items:center;gap:.5rem;padding:.3rem .4rem;border-radius:5px;cursor:pointer;border-left:2px solid transparent;-webkit-user-select:none;user-select:none}.pe-song-row:hover{background:var(--surface2)}.pe-song-row--compact{cursor:default;padding:.2rem .3rem}.pe-song-row--in-playlist{background:#4caf7212;border-left-color:var(--green)}.pe-song-row--in-playlist:hover{background:#4caf7221}.pe-song-row--pending-add{background:#6c63ff14;border-left-color:var(--accent)}.pe-song-row--pending-add:hover{background:#6c63ff24}.pe-song-row--pending-remove{opacity:.55;border-left-color:var(--red)}.pe-song-row--pending-remove .pe-song-row__title{text-decoration:line-through}.pe-song-row__info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.1rem}.pe-song-row__title{font-size:.86rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pe-song-row__meta{display:flex;gap:.4rem;font-size:.73rem;color:var(--text-dim);flex-wrap:wrap}.pe-song-row__action{flex-shrink:0;background:none;border:1px solid var(--border);color:var(--text-dim);cursor:pointer;font-size:.9rem;line-height:1;width:22px;height:22px;border-radius:4px;display:flex;align-items:center;justify-content:center;padding:0;margin-right:.35rem}.pe-song-row__action:hover{background:var(--surface2);color:var(--text)}.pe-song-row__action--add:hover{border-color:var(--green);color:var(--green)}.pe-song-row__action--remove:hover{border-color:var(--red);color:var(--red)}.pe-song-row__action--undo:hover{border-color:var(--accent);color:var(--accent)}.pe-search-fields{display:flex;flex-direction:column;gap:.4rem;margin-bottom:.5rem;flex-shrink:0}.pe-search-row{display:flex;gap:.4rem}.pe-search-fields .input,.pe-search-row .input{font-size:.82rem;padding:.3rem .5rem}.pe-range-row{display:flex;align-items:center;gap:.4rem;margin-bottom:.35rem;flex-shrink:0}.pe-range-row__label{font-size:.7rem;width:2.2rem;flex-shrink:0}.pe-range-row__input{width:58px!important;font-size:.78rem!important;padding:.2rem .3rem!important;flex-shrink:0}.pe-range-wrap{position:relative;height:20px;flex:1;min-width:0}.pe-range-track{position:absolute;top:50%;left:0;right:0;transform:translateY(-50%);height:4px;background:var(--border);border-radius:2px;pointer-events:none}.pe-range-fill{position:absolute;height:100%;background:var(--accent);border-radius:2px}.pe-range-wrap input[type=range]{position:absolute;width:100%;top:50%;transform:translateY(-50%);pointer-events:none;background:transparent;-webkit-appearance:none;-moz-appearance:none;appearance:none;height:4px;margin:0;padding:0}.pe-range-wrap input[type=range]::-webkit-slider-thumb{pointer-events:auto;-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent);cursor:pointer;border:2px solid var(--bg);box-shadow:0 0 0 1px var(--accent)}.pe-range-wrap input[type=range]::-moz-range-thumb{pointer-events:auto;width:14px;height:14px;border-radius:50%;background:var(--accent);cursor:pointer;border:2px solid var(--bg)}.pe-modal__footer{flex-shrink:0;border-top:1px solid var(--border);padding:.45rem 1rem;display:flex;align-items:center;justify-content:flex-end;gap:.4rem}.pe-modal__footer .btn{font-size:.8rem;padding:.3rem .75rem}.pe-save-error{flex:1;color:var(--red);font-size:.83rem}.pe-save-success{flex:1;color:var(--green);font-size:.83rem;font-weight:500}.pe-json-btn{font-size:.82rem}.pe-json-panel{flex:1;display:flex;flex-direction:column;gap:.75rem;padding:1.25rem 1.5rem;overflow-y:auto;min-height:0;border-bottom:1px solid var(--border)}.pe-json-panel__header{display:flex;justify-content:space-between;align-items:center;font-weight:600;font-size:.95rem}.pe-json-panel__desc{font-size:.8rem;line-height:1.5;margin:0}.pe-json-panel__desc code{background:var(--surface2);border:1px solid var(--border);border-radius:3px;padding:.05em .3em;font-size:.85em}.pe-json-textarea{width:100%;min-height:140px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:monospace;font-size:.82rem;padding:.5rem .75rem;resize:vertical;box-sizing:border-box}.pe-json-textarea:focus{outline:none;border-color:var(--accent)}.pe-json-actions{display:flex;gap:.5rem}.pe-json-error{color:var(--red);font-size:.82rem}.pe-json-results{display:flex;flex-direction:column;gap:.25rem}.pe-json-results__summary{font-size:.83rem;font-weight:500;margin-bottom:.2rem}.pe-json-issue{font-size:.78rem;padding:.1rem 0}.pe-json-issue--not_found{color:var(--red)}.pe-json-issue--mismatch{color:var(--yellow)}.pe-json-issue--skipped{color:var(--text-dim)}.pe-genre-filter{display:flex;flex-direction:column;gap:.2rem}.pe-genre-select{font-size:.8rem!important;padding:.15rem .3rem!important;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);width:100%;cursor:pointer}.pe-genre-select option{padding:.15rem .2rem}.pe-genre-select option:checked{background:var(--accent);color:#fff}.pe-genre-clear{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:.7rem;padding:0;text-decoration:underline;align-self:flex-start}.pe-genre-clear:hover{color:var(--text)}.pe-sort-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem;flex-shrink:0}.pe-sort-label{font-size:.72rem;white-space:nowrap}.pe-sort-select{font-size:.8rem!important;padding:.25rem .5rem!important;flex:1}.pe-advanced-toggle{display:flex;align-items:center;gap:.35rem;font-size:.78rem;color:var(--text-dim);cursor:pointer;padding:.2rem 0;-webkit-user-select:none;user-select:none}.pe-advanced-toggle:hover{color:var(--text)}.pe-advanced-section{display:flex;flex-direction:column;gap:.4rem;padding:.5rem .6rem;background:var(--surface2);border-radius:6px;border:1px solid var(--border)}.pe-advanced-warning{font-size:.72rem;color:var(--yellow);margin-bottom:.1rem}.pe-empty{color:var(--text-dim);font-size:.8rem;padding:.3rem 0}.playlist-item{margin-bottom:.75rem;border:1px solid var(--border);border-radius:8px;overflow:hidden}.playlist-item__header{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--surface2);flex-wrap:wrap}.playlist-item__body{padding:.75rem 1rem}.playlist-item__info{flex:1;min-width:0}.playlist-item__title-row{display:flex;align-items:center;gap:.5rem}.playlist-item__name{font-weight:600}.playlist-item__desc{font-size:.8rem;color:var(--text-dim);margin-top:.15rem}.playlist-item__creator{font-size:.75rem;color:var(--text-dim);margin-top:.1rem}.playlist-records-note{font-size:.72rem;color:var(--text-dim)}.edit-form{flex:1;display:flex;flex-direction:column;gap:.4rem}.edit-form__row{display:flex;gap:.5rem}.edit-error{color:var(--red);font-size:.82rem}.profile-header{display:flex;gap:1.5rem;align-items:center;margin-bottom:1.5rem}.profile-avatar{flex-shrink:0;text-align:center}.profile-avatar__img{width:120px;height:120px;border-radius:50%;object-fit:cover;border:2px solid var(--border);display:block}.profile-avatar__change{margin-top:.4rem}.profile-info{display:flex;flex-direction:column;justify-content:center;flex:1;min-width:0}.profile-info__name{font-size:1.9rem;font-weight:700;margin-bottom:.2rem;display:flex;align-items:center}.profile-info__joined{font-size:.85rem}.profile-stats-multiplayer-wrapper{line-height:1.75em}.profile-stats{display:flex;gap:2.5rem}.profile-main-stats{display:flex;gap:.85rem;flex-wrap:wrap}.profile-trophy-card{position:relative;overflow:hidden;padding:1.1rem 1.4rem .9rem;border-radius:.65rem;display:flex;flex-direction:column;align-items:center;gap:.15rem;width:110px;border:2px solid;background:linear-gradient(160deg,#1c1f32,#161827);transition:transform .18s ease,box-shadow .18s ease;cursor:default}.profile-trophy-card:hover{transform:translateY(-2px)}.profile-trophy-card:before{content:"";position:absolute;top:-15px;left:50%;transform:translate(-50%);width:90px;height:90px;border-radius:50%;filter:blur(28px);opacity:.25;pointer-events:none}.profile-trophy-card:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,rgba(255,255,255,.045) 0%,transparent 55%);pointer-events:none}.profile-trophy-card--gold{border-color:#f0b42847}.profile-trophy-card--gold:hover{box-shadow:0 6px 24px #f0b4281f}.profile-trophy-card--gold:before{background:#e8a020}.profile-trophy-card--gold .profile-trophy-card__icon{color:#f0b830}.profile-trophy-card--gold .profile-trophy-card__value{color:#f2c040}.profile-trophy-card--green{border-color:#34d39947}.profile-trophy-card--green:hover{box-shadow:0 6px 24px #34d39924}.profile-trophy-card--green:before{background:#22c55e}.profile-trophy-card--green .profile-trophy-card__icon,.profile-trophy-card--green .profile-trophy-card__value{color:#4ade80}.profile-trophy-card--gauntlet{border-color:#c084fc47}.profile-trophy-card--gauntlet:hover{box-shadow:0 6px 24px #c084fc24}.profile-trophy-card--gauntlet:before{background:#a855f7}.profile-trophy-card--gauntlet .profile-trophy-card__icon,.profile-trophy-card--gauntlet .profile-trophy-card__value{color:#c084fc}.profile-trophy-card--blue{border-color:#60a5fa47}.profile-trophy-card--blue:hover{box-shadow:0 6px 24px #60a5fa24}.profile-trophy-card--blue:before{background:#3b82f6}.profile-trophy-card--blue .profile-trophy-card__icon,.profile-trophy-card--blue .profile-trophy-card__value{color:#60a5fa}.profile-trophy-card--lightning{border-color:#fb923c47}.profile-trophy-card--lightning:hover{box-shadow:0 6px 24px #fb923c24}.profile-trophy-card--lightning:before{background:#f97316}.profile-trophy-card--lightning .profile-trophy-card__icon,.profile-trophy-card--lightning .profile-trophy-card__value{color:#fb923c}.profile-trophy-card__icon{position:relative;z-index:1;margin-bottom:.35rem;line-height:0}.profile-trophy-card__value{position:relative;z-index:1;font-size:1.85rem;font-weight:800;line-height:1;letter-spacing:-.02em}.profile-trophy-card__label{position:relative;z-index:1;font-size:.72rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.07em;font-weight:500;margin-top:.15rem;text-align:center;line-height:1.3}.profile-stat__value{font-size:1.4rem;font-weight:700}.profile-stat__label{font-size:.8rem;margin-top:.1rem}.header{font-size:1.3rem;font-weight:700;margin-top:1.5rem;margin-bottom:.8rem}.profile-xp{margin-top:.6rem;width:100%;max-width:480px}.profile-xp__label{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:.3rem}.profile-xp__level{font-size:.9rem;font-weight:700;color:var(--accent)}.profile-xp__bar-track{height:6px;background:var(--border);border-radius:3px;overflow:hidden}.profile-xp__bar-fill{height:100%;background:var(--accent);border-radius:3px;transition:width .4s ease}.profile-flag{height:.65em;width:auto;margin-right:.4rem;border-radius:2px;flex-shrink:0}.profile-country-selector{margin-top:.5rem}.profile-country-selector select{font-size:.85rem}.profile-edit-btn{position:absolute;top:1rem;right:1rem}.profile-edit-actions{display:flex;gap:.5rem;margin-top:.75rem}.profile-preset-picker{margin-top:.75rem}.profile-preset-grid{display:flex;flex-wrap:wrap;gap:.4rem}.profile-preset-option{width:52px;height:52px;padding:2px;border-radius:50%;border:2px solid var(--border);background:none;cursor:pointer;transition:border-color .15s}.profile-preset-option img{width:100%;height:100%;border-radius:50%;object-fit:cover;display:block}.profile-preset-option--selected{border-color:var(--accent)}.profile-preset-option:hover:not(:disabled){border-color:var(--accent);opacity:.9}.daily-status-card{display:flex;flex-direction:column;align-items:flex-start;position:relative}.daily-status-streak{position:absolute;top:1.25rem;right:1.5rem;text-align:center}.daily-status-streak__count{font-size:1.4rem;font-weight:700;line-height:1.2}.daily-status-streak__label{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-dim);margin-top:.1rem}.daily-status-card__result{margin-bottom:.5rem}.daily-status-big{font-size:2rem;font-weight:700;color:var(--yellow);font-variant-numeric:tabular-nums}.daily-columns{display:flex;flex-direction:column;gap:1rem;margin-bottom:1rem}.daily-col{flex:1}.daily-leaderboard{display:flex;flex-direction:column;gap:.35rem}.daily-lb-row{display:flex;align-items:center;gap:.75rem;padding:.4rem .5rem;border-radius:6px}.daily-lb-row--me{background:#6c63ff14}.daily-lb-rank{min-width:2rem;font-weight:700;font-size:.9rem}.daily-lb-name{flex:1;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.daily-lb-time{font-variant-numeric:tabular-nums;font-size:.9rem;font-weight:600}@media (min-width: 600px){.daily-columns{flex-direction:row;align-items:flex-start}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:200}.modal-box{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1.5rem;min-width:260px;max-width:360px;width:90%}.audio-gate{flex-direction:column;gap:.5rem;text-align:center}.audio-gate__icon{font-size:3rem;margin-bottom:.75rem}.audio-gate__volume{display:flex;justify-content:center;margin-top:1.25rem}.audio-gate__volume .vol-control{width:280px;flex:none}.audio-gate__volume .vol-slider{flex:1}.daily-game-header{display:flex;align-items:center;gap:1rem}.daily-game-round{display:flex;flex-direction:column;align-items:center;min-width:3.5rem}.daily-game-round__num{font-size:1.5rem;font-weight:700;line-height:1}.daily-game-timer{flex:1}.daily-game-timer__bar{background:var(--surface2);border-radius:4px;height:6px;overflow:hidden;margin-bottom:.3rem}.daily-game-timer__fill{height:100%;border-radius:4px}.daily-game-timer__text{font-size:.85rem;font-weight:700;font-variant-numeric:tabular-nums}.daily-game-volume .vol-control{width:200px;flex:none}.daily-game-volume .vol-slider{flex:1}.vol-control{display:flex;align-items:center;gap:.45rem;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:.3rem .65rem;flex:1}.vol-icon{font-size:.85rem;width:1.1em;text-align:center;color:var(--text-dim);flex-shrink:0}.vol-pct{font-size:.72rem;color:var(--text-dim);min-width:2.2em;font-variant-numeric:tabular-nums;flex-shrink:0}.vol-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:88px;flex:1;height:4px;border-radius:4px;outline:none;cursor:pointer;background:linear-gradient(to right,var(--accent) var(--fill, 100%),var(--surface2) var(--fill, 100%))}.vol-slider::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:radial-gradient(circle at 35% 35%,#9b96ff,var(--accent) 55%,#4a44b5);border:1.5px solid rgba(255,255,255,.15);box-shadow:0 0 0 2px #6c63ff33,0 0 8px #6c63ff73,inset 0 1px 1px #fff3;cursor:pointer;transition:box-shadow .15s}.vol-slider::-webkit-slider-thumb:hover{box-shadow:0 0 0 3px #6c63ff4d,0 0 12px #6c63ff99,inset 0 1px 1px #fff3}.vol-slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:radial-gradient(circle at 35% 35%,#9b96ff,var(--accent) 55%,#4a44b5);border:1.5px solid rgba(255,255,255,.15);box-shadow:0 0 0 2px #6c63ff33,0 0 8px #6c63ff73,inset 0 1px 1px #fff3;cursor:pointer}.daily-game-done{text-align:center}.daily-game-badges,.daily-game-form{display:flex;gap:.5rem}.daily-game-form .input{flex:1}.answer-badge{display:inline-flex;align-items:center;padding:.2rem .6rem;border-radius:999px;font-size:.8rem;font-weight:600;border:1px solid}.answer-badge--pending{color:var(--text-dim);border-color:var(--border);background:var(--surface2)}.answer-badge--got{color:var(--green);border-color:var(--green);background:#4caf721a}.daily-game-progress{display:flex;gap:.5rem;justify-content:center;margin-top:1rem}.daily-game-progress__step{display:flex;flex-direction:column;align-items:center;gap:.2rem;flex:1;padding:.5rem .25rem;border-radius:8px;background:var(--surface2);border:1px solid var(--border)}.daily-game-progress__step.current{border-color:var(--accent);background:#6c63ff1a}.daily-game-progress__step.done{border-color:var(--green);background:#4caf7214}.daily-game-progress__num{font-size:.8rem;font-weight:700;color:var(--text-dim)}.daily-game-progress__step.current .daily-game-progress__num{color:var(--accent)}.daily-game-progress__step.done .daily-game-progress__num{color:var(--green)}.daily-game-progress__time{font-size:.7rem;color:var(--green);font-variant-numeric:tabular-nums}.daily-results-header-card{margin:0}.daily-results-header-top{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.daily-results-summary{display:flex;gap:.75rem;align-items:stretch}.daily-results-time-box{flex:3;text-align:center;margin:0}.daily-results-streak-box{flex:1;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;margin:0}.daily-results-total{font-size:3rem;font-weight:700;color:var(--yellow);font-variant-numeric:tabular-nums;line-height:1.1;margin-bottom:.35rem}.daily-results-streak-count{font-size:2rem;font-weight:700;line-height:1.1;margin-bottom:.35rem}.daily-lb-me td{background:#6c63ff14}.lightning-game{max-width:480px;margin:0 auto;padding:1.5rem 1rem 2rem;display:flex;flex-direction:column;gap:.75rem}.lg-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.25rem}.lg-header__title{display:flex;align-items:center;gap:.4rem;font-size:1.2rem;font-weight:700}.lg-header__bolt{font-size:1.4rem}.lg-header__points{font-size:1.1rem;font-weight:700;color:var(--accent);font-variant-numeric:tabular-nums}.lg-rounds{display:flex;gap:.75rem;justify-content:center}.lg-round-dot{width:2.25rem;height:2.25rem;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;color:var(--text2);transition:all .2s}.lg-round-dot.active{border-color:var(--accent);color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 20%,transparent)}.lg-round-dot.done{background:var(--accent);border-color:var(--accent);color:#fff}.lg-round-label{text-align:center;color:var(--text2);font-size:.85rem;margin:0}.lg-samples{display:flex;gap:.5rem;justify-content:center}.lg-sample-pip{padding:.25rem .6rem;border-radius:1rem;border:1px solid var(--border);font-size:.75rem;font-weight:600;color:var(--text3);background:transparent;transition:all .2s}.lg-sample-pip.active{border-color:var(--accent);color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,transparent)}.lg-sample-pip.past{background:var(--surface2);color:var(--text3);border-color:var(--surface2)}.lg-content{min-height:180px;display:flex;flex-direction:column}.lg-state-card{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem 1.5rem;background:var(--surface1);border:1px solid var(--border);border-radius:12px;text-align:center}.lg-sample-label{color:var(--text2);font-size:.95rem;margin:0}.lg-play-btn{font-size:1.05rem;padding:.6rem 2rem}.lg-timer-bar{width:100%;max-width:260px;height:6px;background:var(--surface2);border-radius:4px;overflow:hidden}.lg-timer-fill{height:100%;background:var(--accent);border-radius:4px;transition:width .05s linear}.lg-spinner{width:2rem;height:2rem;border:3px solid var(--surface2);border-top-color:var(--accent);border-radius:50%;animation:lg-spin .8s linear infinite}@keyframes lg-spin{to{transform:rotate(360deg)}}.lg-guess-area{display:flex;flex-direction:column;gap:.75rem;padding:1.5rem;background:var(--surface1);border:1px solid var(--border);border-radius:12px}.lg-search-wrap{position:relative}.lg-search-input{width:100%;padding:.6rem .75rem;border:1px solid var(--border);border-radius:8px;background:var(--surface2);color:var(--text1);font-size:.95rem;outline:none;box-sizing:border-box}.lg-search-input:focus{border-color:var(--accent)}.lg-search-spinner{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);width:1rem;height:1rem;border:2px solid var(--surface2);border-top-color:var(--accent);border-radius:50%;animation:lg-spin .8s linear infinite}.lg-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--surface2);border:1px solid var(--border);border-radius:8px;max-height:220px;overflow-y:auto;z-index:100;box-shadow:0 4px 16px #0003}.lg-dropdown-item{display:flex;flex-direction:column;align-items:flex-start;gap:.1rem;width:100%;padding:.5rem .75rem;background:transparent;border:none;cursor:pointer;text-align:left;color:var(--text1);transition:background .1s}.lg-dropdown-item:hover{background:var(--surface2)}.lg-dropdown-title{font-size:.9rem;font-weight:600}.lg-dropdown-artist{font-size:.8rem;color:var(--text2)}.lg-guess-actions{display:flex;gap:.75rem;align-items:center}.lg-result-card{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.5rem;background:var(--surface1);border:1px solid var(--border);border-radius:12px;text-align:center}.lg-result-correct,.lg-result-artist,.lg-result-wrong{display:flex;align-items:center;gap:.5rem;font-size:1.1rem;font-weight:700}.lg-result-correct{color:#4caf50}.lg-result-artist{color:#ff9800}.lg-result-wrong{color:var(--text2)}.lg-result-icon{font-size:1.3rem;font-weight:900}.lg-song-reveal{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--surface2);border-radius:8px;text-align:left;width:100%;box-sizing:border-box}.lg-song-thumb{width:52px;height:52px;border-radius:6px;object-fit:cover;flex-shrink:0}.lg-song-info{flex:1;min-width:0}.lg-song-title{font-weight:700;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lg-song-artist{font-size:.85rem;color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lg-volume{display:flex;justify-content:center;margin-top:.5rem}.lg-volume .vol-control{width:200px;flex:none}.lg-volume .vol-slider{flex:1}.vol-control{display:flex;align-items:center;gap:.5rem}.vol-icon{font-size:1rem;cursor:pointer}.vol-pct{font-size:.75rem;color:var(--text2);min-width:2.5rem;text-align:right;font-variant-numeric:tabular-nums}.vol-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;height:4px;border-radius:2px;background:linear-gradient(to right,var(--accent) var(--fill),var(--surface2) var(--fill));outline:none;cursor:pointer}.vol-slider::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent);cursor:pointer}.vol-slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--accent);cursor:pointer;border:none}.lb-page{display:flex;gap:1rem;align-items:flex-start}.lb-sidebar{width:210px;flex-shrink:0}.lb-sidebar-list{overflow-y:auto;max-height:calc(100vh - 220px)}.lb-sidebar-item{padding:.45rem .75rem;cursor:pointer;border-radius:6px;font-size:.85rem;line-height:1.3;transition:background .1s}.lb-sidebar-item:hover{background:#ffffff0a}.lb-sidebar-item.active{background:#6c63ff26;color:var(--accent, #6c63ff)}.lb-sidebar-item .lb-sidebar-num{font-weight:600;display:block}.lb-sidebar-item .lb-sidebar-label{color:var(--text-dim, #888);font-size:.78rem}.lb-sidebar-divider{border:none;border-top:1px solid rgba(255,255,255,.08);margin:.4rem 0}.lb-main{flex:1;min-width:0}.lb-expand-btn{background:none;border:none;cursor:pointer;color:var(--text-dim, #888);font-size:.7rem;padding:.2rem .4rem;line-height:1;border-radius:4px;transition:background .1s}.lb-expand-btn:hover{background:#ffffff0f;color:var(--text, #eee)}.lb-expand-row td{padding:0!important;background:#ffffff05}.lb-round-details{padding:.5rem 1rem .6rem 2.5rem;display:flex;flex-direction:column;gap:.25rem}.lb-round-row{display:flex;align-items:center;gap:1rem;font-size:.82rem}.lb-round-num{width:4rem;flex-shrink:0}.lb-round-cell{min-width:5rem}.lb-round-time{margin-left:auto;font-variant-numeric:tabular-nums}@media (max-width: 600px){.lb-page{flex-direction:column}.lb-sidebar{width:100%}.lb-sidebar-list{max-height:140px}.lb-round-details{padding-left:.75rem}}.as-page{max-width:1200px}.as-layout{display:flex;gap:1.5rem;align-items:flex-start}.as-search-panel{flex:1;min-width:0}.as-search-form{margin-bottom:1rem}.as-search-mode{display:flex;gap:.5rem;margin-bottom:.5rem}.as-mode-btn{display:flex;align-items:center;gap:.4rem;padding:.3rem .8rem;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface2);color:var(--text-dim);cursor:pointer;font-size:.875rem;transition:background .15s,color .15s,border-color .15s}.as-mode-btn input[type=radio]{display:none}.as-mode-btn--active{border-color:var(--accent);background:#6c63ff26;color:var(--text)}.as-search-row{display:flex;gap:.5rem}.as-search-row .input{flex:1}.as-hint{font-size:.8rem;color:var(--text-dim);padding:.5rem 0;border-top:1px solid var(--border);margin-bottom:.75rem}.as-results{margin-top:.5rem}.as-loading{color:var(--text-dim);padding:1rem 0}.as-empty{color:var(--text-dim);padding:1rem 0;text-align:center}.as-breadcrumb{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.as-breadcrumb-title{font-weight:600;color:var(--text)}.as-toolbar{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.as-count-note{font-size:.8rem;color:var(--text-dim)}.as-track-row{display:flex;align-items:center;gap:.75rem;padding:.5rem .6rem;border-bottom:1px solid var(--border);transition:background .1s}.as-track-row:hover{background:var(--surface2)}.as-track-row--in-cart{opacity:.6}.as-track-art{width:40px;height:40px;border-radius:4px;object-fit:cover;flex-shrink:0}.as-track-art--empty{background:var(--surface2)}.as-track-meta{flex:1;min-width:0}.as-track-title{display:block;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.as-track-sub{font-size:.8rem;color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.as-track-dur{color:var(--text-dim)}.as-sep{color:var(--border)}.as-link{background:none;border:none;padding:0;color:var(--accent);cursor:pointer;font-size:inherit;font-family:inherit;text-decoration:underline;text-underline-offset:2px}.as-link:hover{color:var(--text)}.as-artist-row{display:flex;align-items:center;gap:.75rem;padding:.6rem;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s}.as-artist-row:hover{background:var(--surface2)}.as-artist-name{font-weight:500;color:var(--text);flex:1}.as-artist-genre{font-size:.78rem;color:var(--text-dim);background:var(--surface2);padding:.15rem .5rem;border-radius:4px}.as-album-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.75rem}.as-album-card{cursor:pointer;border-radius:var(--radius);overflow:hidden;background:var(--surface2);border:1px solid var(--border);transition:border-color .15s}.as-album-card:hover{border-color:var(--accent)}.as-album-art{width:100%;aspect-ratio:1;object-fit:cover;display:block}.as-album-info{padding:.4rem .5rem}.as-album-name{font-size:.8rem;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.as-album-year{font-size:.75rem;color:var(--text-dim)}.as-cart-panel{width:300px;flex-shrink:0;position:sticky;top:1rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);display:flex;flex-direction:column;max-height:calc(100vh - 6rem)}.as-cart-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;border-bottom:1px solid var(--border)}.as-cart-title{font-weight:600;color:var(--text)}.as-cart-count{font-size:.8rem;color:var(--text-dim)}.as-cart-list{flex:1;overflow-y:auto;padding:.5rem 0}.as-cart-item{display:flex;align-items:center;gap:.5rem;padding:.35rem .75rem}.as-cart-item:hover{background:var(--surface2)}.as-cart-item-info{flex:1;min-width:0}.as-cart-item-title{display:block;font-size:.85rem;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.as-cart-item-artist{display:block;font-size:.75rem;color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.as-cart-remove{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:1.1rem;line-height:1;padding:0 .2rem;border-radius:3px;flex-shrink:0}.as-cart-remove:hover{color:var(--red);background:#e05c5c1a}.as-cart-footer{padding:.75rem;border-top:1px solid var(--border)}.dup-badge{display:inline-block;font-size:.72rem;font-weight:700;padding:.15rem .5rem;border-radius:4px;text-transform:uppercase;letter-spacing:.03em}.dup-badge--ok{background:#4caf7226;color:var(--green);border:1px solid rgba(76,175,114,.3)}.dup-badge--possible{background:#f0c04026;color:var(--yellow);border:1px solid rgba(240,192,64,.3)}.dup-badge--likely{background:#e05c5c26;color:var(--red);border:1px solid rgba(224,92,92,.3)}.as-review-banner{background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:var(--radius);padding:.75rem 1rem;margin-bottom:1rem;font-size:.9rem;color:var(--text-dim)}.as-review-flag-count{color:var(--yellow);font-weight:600}.as-review-row{border-bottom:1px solid var(--border)}.as-review-row--likely_duplicate{background:#e05c5c0a}.as-review-row--possible_duplicate{background:#f0c0400a}.as-review-row-main{display:flex;align-items:center;gap:.75rem;padding:.6rem}.as-review-art{width:36px;height:36px;border-radius:4px;object-fit:cover;flex-shrink:0}.as-review-meta{flex:1;min-width:0}.as-review-title{display:block;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.as-review-artist{font-size:.8rem;color:var(--text-dim)}.as-review-album{font-size:.78rem;color:var(--text-dim)}.as-review-album:before{content:" · "}.as-review-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.as-match-detail{padding:.5rem .6rem .6rem 52px;font-size:.8rem;color:var(--text-dim);background:var(--surface2);border-top:1px solid var(--border)}.as-match-row{display:flex;gap:.75rem;padding:.2rem 0}.as-match-name{color:var(--text)}.as-match-reason{color:var(--text-dim);font-style:italic}.as-review-footer{display:flex;justify-content:space-between;align-items:center;padding:1rem 0;color:var(--text-dim);font-size:.9rem}.as-import-errors{margin-top:.75rem;font-size:.85rem;color:var(--text-dim)}.as-import-error-row{padding:.2rem 0;color:var(--red)}.admin-nav{display:flex;flex-direction:column;gap:.25rem;margin-bottom:1.5rem}.admin-nav__categories{display:flex;gap:.5rem;flex-wrap:wrap}.admin-nav__category{padding:.35rem .9rem;border-radius:6px;font-weight:700;font-size:.85rem;color:var(--text-dim);text-decoration:none;transition:background .15s,color .15s}.admin-nav__category:hover{color:var(--text);text-decoration:none}.admin-nav__category--active{color:var(--text);background:#6c63ff33}.admin-nav__links{display:flex;gap:.5rem;flex-wrap:wrap;padding-left:.25rem}.admin-nav__link{padding:.4rem .8rem;border-radius:6px;font-weight:600;font-size:.9rem;color:var(--text-dim);text-decoration:none;transition:background .15s,color .15s}.admin-nav__link:hover{color:var(--text);text-decoration:none}.admin-nav__link--active{color:var(--accent);background:#6c63ff1f}.admin-nav__subgroups{display:flex;gap:.35rem;padding-left:.25rem;margin-top:.1rem}.admin-nav__subgroup{padding:.25rem .75rem;border-radius:4px;font-weight:600;font-size:.8rem;color:var(--text-dim);background:transparent;border:1px solid var(--border);cursor:pointer;transition:background .15s,color .15s,border-color .15s}.admin-nav__subgroup:hover{color:var(--text);border-color:var(--accent)}.admin-nav__subgroup--active{color:var(--accent);background:#6c63ff1f;border-color:var(--accent)}.admin-panel{width:100%}.admin-list{display:flex;flex-direction:column;gap:0}.admin-list-item{display:flex;align-items:center;gap:.75rem;padding:.65rem 0;border-bottom:1px solid var(--border)}.admin-list-item:last-child{border-bottom:none}.songs-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.songs-search-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.5rem;margin-bottom:.75rem}.songs-action-bar{display:flex;gap:.75rem;margin-bottom:1.25rem}.import-result{padding:.75rem;background:var(--surface2);border-radius:8px;margin-top:.5rem}.import-result__added{font-weight:600}.import-result__errors{margin-top:.5rem}.import-result__error-label{font-weight:600;margin-bottom:.25rem}.import-result__error-row{font-size:.82rem;color:var(--text-dim)}.songs-table-input{background:var(--surface2);border:1px solid var(--accent);border-radius:4px;color:inherit;font:inherit;padding:.15rem .4rem;width:100%;min-width:0}.song-form-modal{max-width:680px;width:100%;max-height:85vh;display:flex;flex-direction:column;margin:0;overflow:hidden}.song-form-modal__body{overflow-y:auto;flex:1;padding-right:.25rem}.song-form-section-divider{border:none;border-top:1px solid var(--border);margin:1.25rem 0 1rem}.blog-header-media{width:100%;max-height:380px;object-fit:cover;border-radius:8px;margin-bottom:1.25rem;display:block}.blog-body{line-height:1.75}.blog-body p{margin-bottom:1.1em}.blog-body h1,.blog-body h2,.blog-body h3,.blog-body h4{margin-top:1.5em;margin-bottom:.5em}.blog-body ul,.blog-body ol{padding-left:1.5em;margin-bottom:1em}.blog-body li{margin-bottom:.3em}.blog-body a{color:var(--accent)}.blog-body code{font-family:monospace;background:#ffffff12;padding:.1em .35em;border-radius:3px;font-size:.9em}.blog-body pre{background:#ffffff0d;padding:1em;border-radius:6px;overflow-x:auto;margin-bottom:1em}.blog-body pre code{background:none;padding:0}.blog-body blockquote{border-left:3px solid var(--accent);margin-left:0;padding-left:1em;color:var(--text-dim)}.blog-body hr{border:none;border-top:1px solid var(--border);margin:1.5em 0}.notif-page{max-width:720px;margin:0 auto;padding:2rem 1rem}.notif-page h1{margin-bottom:.5rem}.notif-count{color:var(--text-muted, #888);font-size:.85rem;margin-bottom:1.25rem}.notif-empty{color:var(--text-muted, #888);margin-top:2rem;text-align:center}.notif-list{display:flex;flex-direction:column;gap:.75rem}.notif-card{display:flex;align-items:center;gap:.85rem;padding:.85rem 1rem;border-radius:8px;background:var(--card-bg, #1e1e1e);border:1px solid var(--border, #333);position:relative}.notif-card--new{border-color:var(--accent, #7c6ff7)}.notif-badge-new{position:absolute;top:.5rem;right:.75rem;font-size:.7rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--accent, #7c6ff7)}.notif-song-thumb{flex-shrink:0}.notif-song-thumb img{width:52px;height:52px;border-radius:6px;object-fit:cover;display:block}.notif-thumb-placeholder{width:52px;height:52px;border-radius:6px;background:var(--border, #333)}.notif-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:.2rem}.notif-song-title{font-weight:600;color:inherit;text-decoration:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.notif-song-title:hover{text-decoration:underline}.notif-song-artist{font-weight:400;color:var(--text-muted, #888)}.notif-detail{display:flex;align-items:center;gap:.4rem;font-size:.88rem}.notif-thief{display:flex;align-items:center;gap:.35rem;color:inherit;text-decoration:none;font-weight:600}.notif-thief:hover{text-decoration:underline}.notif-thief-avatar{width:20px;height:20px;border-radius:50%;object-fit:cover}.notif-thief-unknown{font-weight:600;color:var(--text-muted, #888)}.notif-stole-label{color:var(--text-muted, #888)}.notif-times{display:flex;gap:.75rem;font-size:.8rem;color:var(--text-muted, #888);flex-wrap:wrap}.notif-new-time{color:var(--danger, #e55)}.notif-meta{flex-shrink:0;font-size:.8rem;color:var(--text-muted, #888);align-self:flex-start;padding-top:.1rem}.notif-load-more{display:block;margin:1.5rem auto 0;padding:.6rem 1.5rem;border-radius:6px;background:var(--card-bg, #1e1e1e);border:1px solid var(--border, #333);color:inherit;cursor:pointer;font-size:.9rem}.notif-load-more:hover:not(:disabled){border-color:var(--accent, #7c6ff7)}.notif-load-more:disabled{opacity:.5;cursor:default}.nav-notif-bell{position:relative;display:flex;align-items:center;line-height:1}.nav-notif-badge{position:absolute;top:-6px;right:-8px;background:var(--accent, #7c6ff7);color:#fff;font-size:.65rem;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 3px;line-height:1}.mc-page{display:flex;justify-content:center;align-items:flex-start;padding:2rem 1rem;min-height:100%}.mc-card{background:var(--card-bg, #1e1e2e);border-radius:12px;padding:2rem;width:100%;max-width:480px;display:flex;flex-direction:column;gap:1.2rem}.mc-card h2{margin:0;font-size:1.4rem}.mc-label{display:flex;flex-direction:column;gap:.4rem;font-size:.9rem;color:var(--text-muted, #aaa)}.mc-select,.mc-input{background:var(--input-bg, #2a2a3e);border:1px solid var(--border, #444);border-radius:6px;color:inherit;padding:.5rem .75rem;font-size:1rem;width:100%}.mc-toggle{display:flex;gap:.5rem;margin-top:.2rem}.mc-toggle-btn{flex:1;padding:.5rem;border-radius:6px;border:1px solid var(--border, #444);background:var(--input-bg, #2a2a3e);color:inherit;cursor:pointer;font-size:.9rem;transition:background .15s,border-color .15s}.mc-toggle-btn.active{background:var(--accent, #7c6af7);border-color:var(--accent, #7c6af7);color:#fff}.mc-toggle-btn:disabled{opacity:.4;cursor:default}.mc-btn-primary{padding:.75rem 1.5rem;border-radius:8px;border:none;background:var(--accent, #7c6af7);color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:opacity .15s}.mc-btn-primary:disabled{opacity:.5;cursor:default}.mc-error{color:#e55;margin:0;font-size:.9rem}.mc-gate{align-items:center;text-align:center}.mc-game{width:100%;max-width:560px;display:flex;flex-direction:column;gap:1rem}.mc-header{display:flex;align-items:center;justify-content:space-between}.mc-round-label{font-weight:600;font-size:1rem}.mc-vol{display:flex;align-items:center;gap:.4rem;font-size:.85rem}.vol-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:80px;height:4px;border-radius:4px;outline:none;cursor:pointer;background:linear-gradient(to right,var(--accent) var(--fill, 100%),var(--surface2) var(--fill, 100%))}.vol-slider::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:radial-gradient(circle at 35% 35%,#9b96ff,var(--accent) 55%,#4a44b5);border:1.5px solid rgba(255,255,255,.15);cursor:pointer}.vol-slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:radial-gradient(circle at 35% 35%,#9b96ff,var(--accent) 55%,#4a44b5);border:1.5px solid rgba(255,255,255,.15);cursor:pointer}.mc-timer-bar{height:6px;background:var(--border, #333);border-radius:3px;overflow:hidden}.mc-timer-fill{height:100%;background:var(--accent, #7c6af7);transition:width .1s linear,background-color .3s}.mc-options{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.mc-option{display:flex;flex-direction:column;align-items:flex-start;gap:.25rem;padding:.9rem 1rem;border-radius:10px;border:1px solid var(--border, #444);background:var(--card-bg, #1e1e2e);color:inherit;cursor:pointer;text-align:left;transition:border-color .15s,background .15s,opacity .2s}.mc-option:hover:not(:disabled){border-color:var(--accent, #7c6af7);background:var(--input-bg, #2a2a3e)}.mc-option:disabled{cursor:default}.mc-option.correct{border-color:#4caf50;background:#4caf5026}.mc-option.wrong{border-color:#e55;background:#ee555526}.mc-option.faded{opacity:.35}.mc-option-title{font-weight:600;font-size:.95rem}.mc-option-artist{font-size:.82rem;color:var(--text-muted, #aaa)}.mc-answer-card{border-radius:10px;border:1px solid var(--border, #444);padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:.5rem}.mc-answer-card.correct{border-color:#4caf50;background:#4caf501a}.mc-answer-card.wrong{border-color:#e55;background:#ee55551a}.mc-answer-card.timeout{border-color:#888;background:#8080801a}.mc-answer-verdict{font-weight:700;font-size:1.1rem}.mc-answer-card.correct .mc-answer-verdict{color:#4caf50}.mc-answer-card.wrong .mc-answer-verdict{color:#e55}.mc-answer-card.timeout .mc-answer-verdict{color:#aaa}.mc-answer-song{display:flex;flex-direction:column;gap:.15rem}.mc-answer-selected{font-size:.82rem;color:var(--text-muted, #aaa);margin-top:.25rem}.mc-results h2{font-size:1.6rem}.mc-results-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.4rem;max-height:60vh;overflow-y:auto}.mc-result-row{display:flex;align-items:center;gap:.6rem;font-size:.9rem}.mc-result-row.correct .mc-result-dot{color:#4caf50}.mc-result-row.wrong .mc-result-dot{color:#e55}.mc-result-song{color:var(--text-muted, #aaa)}.gauntlet-status-card{position:relative}.gauntlet-status-result{margin:.75rem 0}.gauntlet-status-big{font-size:2.2rem;font-weight:700;line-height:1.1}.gauntlet-hearts{display:inline-flex;gap:.2rem;font-size:1.1rem}.gauntlet-lives-row{display:flex;gap:.5rem;align-items:center;background:#ffffff0a;border:1px solid var(--border, #333);border-radius:8px;padding:.6rem 1rem;margin-bottom:.75rem;width:fit-content}.gauntlet-heart-big{font-size:1.75rem;line-height:1}.badge-red{background:#e5555526;color:#e55;border:1px solid rgba(229,85,85,.3);display:inline-block;padding:.2rem .6rem;border-radius:4px;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.gs-stage{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;overflow:hidden;background:radial-gradient(ellipse at 50% 55%,#0f0f22,#07070d 55%,#000);isolation:isolate;color:#e9e8ff}.gs-shake-wrap{position:absolute;top:0;right:0;bottom:0;left:0;will-change:transform}.gs-shake-wrap.shaking{animation:gs-shake .55s cubic-bezier(.36,.07,.19,.97) both}.gs-shake-wrap.shaking-hard{animation:gs-shakeHard .7s cubic-bezier(.36,.07,.19,.97) both}@keyframes gs-shake{0%,to{transform:translateZ(0)}10%{transform:translate3d(-6px,3px,0)}20%{transform:translate3d(5px,-4px,0)}30%{transform:translate3d(-4px,2px,0)}40%{transform:translate3d(3px,-2px,0)}55%{transform:translate3d(-2px,1px,0)}70%{transform:translate3d(1px,-1px,0)}}@keyframes gs-shakeHard{0%,to{transform:translateZ(0) rotate(0)}8%{transform:translate3d(-14px,6px,0) rotate(-.6deg)}16%{transform:translate3d(12px,-8px,0) rotate(.5deg)}24%{transform:translate3d(-10px,4px,0) rotate(-.3deg)}34%{transform:translate3d(7px,-3px,0) rotate(.2deg)}45%{transform:translate3d(-5px,2px,0)}60%{transform:translate3d(3px,-1px,0)}75%{transform:translate3d(-1px,1px,0)}}.gs-layer{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;pointer-events:none}.gs-vignette{background:radial-gradient(ellipse at 50% 50%,transparent 30%,rgba(71,62,216,.18) 70%,rgba(0,0,0,.8) 100%);opacity:0;transition:opacity .6s ease}.gs-vignette.on{opacity:1}.gs-layer canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.gs-rune-ring{width:min(78vh,78vw);aspect-ratio:1;position:relative;opacity:0;transform:scale(.6);transition:opacity .5s ease,transform .8s cubic-bezier(.2,.9,.2,1)}.gs-rune-ring.on{opacity:1;transform:scale(1)}.gs-rune-ring>svg{width:100%;height:100%;animation:gs-spin 30s linear infinite;filter:drop-shadow(0 0 14px rgba(138,131,255,.6))}.gs-inner{position:absolute;top:16%;right:16%;bottom:16%;left:16%;animation:gs-spinBack 45s linear infinite}.gs-inner svg{width:100%;height:100%}.gs-rune-ring.gs-far{width:min(180vh,180vw);position:absolute;top:-28%;left:50%;transform:translate(-50%) scale(.85);opacity:0;transition:opacity 1.4s ease,transform 1.4s cubic-bezier(.2,.9,.2,1)}.gs-rune-ring.gs-far.on{opacity:.55;transform:translate(-50%) scale(1)}.gs-rune-ring.gs-far>svg{animation:gs-spin 110s linear infinite;filter:drop-shadow(0 0 22px rgba(138,131,255,.3));opacity:.7}.gs-rune-ring.gs-far .gs-inner{top:12%;right:12%;bottom:12%;left:12%;animation:gs-spinBack 160s linear infinite}@keyframes gs-spin{to{transform:rotate(360deg)}}@keyframes gs-spinBack{to{transform:rotate(-360deg)}}.gs-shock{position:absolute;left:50%;top:50%;width:10px;height:10px;border-radius:50%;transform:translate(-50%,-50%) scale(0);border:2px solid rgba(138,131,255,.9);box-shadow:0 0 40px #8a83ffcc,inset 0 0 40px #8a83ff66;opacity:0;pointer-events:none}.gs-shock.fire{animation:gs-shockwave 1.1s cubic-bezier(.2,.8,.2,1) forwards}.gs-shock.gold{border-color:#ffd772d9;box-shadow:0 0 60px #ffa723b3,inset 0 0 40px #ffd7724d}@keyframes gs-shockwave{0%{transform:translate(-50%,-50%) scale(0);opacity:0;border-width:3px}15%{opacity:1}to{transform:translate(-50%,-50%) scale(140);opacity:0;border-width:.5px}}.gs-rays{width:140vmax;height:140vmax;background:conic-gradient(from 0deg,transparent 0deg,rgba(138,131,255,.12) 3deg,transparent 6deg,transparent 30deg,rgba(255,215,114,.08) 33deg,transparent 36deg,transparent 60deg,rgba(138,131,255,.1) 63deg,transparent 66deg,transparent 90deg,rgba(255,215,114,.06) 93deg,transparent 96deg,transparent 120deg,rgba(138,131,255,.12) 123deg,transparent 126deg,transparent 180deg);opacity:0;transform:scale(.6);mix-blend-mode:screen;animation:gs-raysSpin 60s linear infinite;transition:opacity 1.2s ease,transform 1.2s ease;-webkit-mask-image:radial-gradient(circle,black 0%,black 30%,transparent 70%);mask-image:radial-gradient(circle,black 0%,black 30%,transparent 70%)}.gs-rays.on{opacity:1;transform:scale(1)}@keyframes gs-raysSpin{to{transform:scale(1) rotate(360deg)}}.gs-gauntlet-stage{width:min(58vh,58vw);aspect-ratio:1;position:relative;opacity:0;transform:scale(.1) rotate(-18deg);filter:brightness(.4);transition:none}.gs-gauntlet-stage.crashing{animation:gs-gauntletCrash .75s cubic-bezier(.2,1.4,.3,1) forwards}.gs-gauntlet-stage.settled{opacity:1!important;filter:brightness(1)!important;animation:gs-gauntletBreathe 4s ease-in-out infinite}@keyframes gs-gauntletCrash{0%{opacity:0;transform:scale(.1) rotate(-18deg);filter:brightness(.2) blur(6px)}35%{opacity:1;transform:scale(2.2) rotate(6deg);filter:brightness(1.6) blur(2px)}60%{transform:scale(.86) rotate(-2deg);filter:brightness(1.2) blur(0)}80%{transform:scale(1.06) rotate(1deg)}to{opacity:1;transform:scale(1) rotate(0);filter:brightness(1) blur(0)}}@keyframes gs-gauntletBreathe{0%,to{transform:scale(1) translateY(0)}50%{transform:scale(1.018) translateY(-4px)}}.gs-gauntlet-stage>svg{width:100%;height:100%;overflow:visible}.gs-gauntlet-glow{position:absolute;top:-20%;right:-20%;bottom:-20%;left:-20%;border-radius:50%;--glow-inner: 244, 163, 255;--glow-mid: 148, 160, 255;--glow-outer: 90, 60, 180;--glow-strength: .3;background:radial-gradient(circle at 50% 55%,rgba(var(--glow-inner),calc(.55 * var(--glow-strength))) 0%,rgba(var(--glow-mid),calc(.32 * var(--glow-strength))) 28%,rgba(var(--glow-outer),calc(.14 * var(--glow-strength))) 55%,transparent 75%);filter:blur(34px);opacity:0;transition:opacity .8s ease;z-index:-1}.gs-gauntlet-stage.settled .gs-gauntlet-glow{opacity:1;animation:gs-glowPulse 4.5s ease-in-out infinite}@keyframes gs-glowPulse{0%,to{opacity:.55;transform:scale(1)}50%{opacity:.78;transform:scale(1.04)}}.gs-flash{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 50% 50%,rgba(255,236,170,.95) 0%,rgba(255,200,110,.75) 22%,rgba(230,150,70,.45) 45%,rgba(120,80,40,.12) 70%,transparent 85%);opacity:0;mix-blend-mode:screen;pointer-events:none}.gs-flash.fire{animation:gs-flashBoom .75s ease-out forwards}@keyframes gs-flashBoom{0%{opacity:0}8%{opacity:.85}25%{opacity:.55}to{opacity:0}}.gs-band{position:absolute;left:0;right:0;height:80px;opacity:0;transition:opacity 1.2s ease;pointer-events:none}.gs-band.gs-top{top:0;background:linear-gradient(180deg,rgba(0,0,0,.55),transparent)}.gs-band.gs-bottom{bottom:0;background:linear-gradient(0deg,rgba(0,0,0,.55),transparent)}.gs-band.on{opacity:1}.gs-text-layer{z-index:10;flex-direction:column;pointer-events:none}.gs-kicker{position:absolute;top:7%;left:50%;transform:translate(-50%) translateY(6px);width:clamp(36px,4.5vw,64px);aspect-ratio:210.49 / 196.77;opacity:0;transition:opacity .9s ease .1s,transform .9s ease;filter:drop-shadow(0 0 16px rgba(138,131,255,.4))}.gs-kicker svg{width:100%;height:100%;display:block}.gs-kicker.on{opacity:1;transform:translate(-50%) translateY(0)}.gs-headline{position:absolute;bottom:10%;left:50%;transform:translate(-50%);text-align:center;width:100%;display:flex;flex-direction:column;align-items:center}.gs-eyebrow{order:1;font-family:var(--font, "Segoe UI", system-ui, sans-serif);font-weight:700;font-size:clamp(16px,2vw,32px);letter-spacing:.18em;color:#f2efff;text-transform:uppercase;margin-top:28px;opacity:0;transform:translateY(10px);transition:opacity .6s ease,transform .6s ease;text-shadow:0 0 24px rgba(200,195,255,.25)}.gs-eyebrow.on{opacity:1;transform:translateY(0)}.gs-title{order:2;font-family:Playfair Display,serif;font-weight:775;font-optical-sizing:auto;font-size:clamp(42px,7.5vw,118px);line-height:.95;letter-spacing:.08em;text-transform:uppercase;background:linear-gradient(180deg,#fff,#e6e2ff 40%,#bbb7ff 75%,#7c76da);-webkit-background-clip:text;background-clip:text;color:transparent}.gs-letter{display:inline-block;opacity:0;transform:translateY(.4em) scale(.8);filter:blur(12px);transition:opacity .55s cubic-bezier(.2,.9,.2,1),transform .55s cubic-bezier(.2,.9,.2,1),filter .55s ease}.gs-letter.on{opacity:1;transform:translateY(0) scale(1);filter:blur(0)}.gs-space{display:inline-block;width:.35em}.gs-subtitle{order:3;margin-top:14px;font-family:var(--font, "Segoe UI", system-ui, sans-serif);font-weight:500;font-size:clamp(12px,1.2vw,16px);letter-spacing:.32em;text-transform:uppercase;color:#9a97c8;opacity:0;transform:translateY(6px);transition:opacity .7s ease,transform .7s ease}.gs-subtitle.on{opacity:1;transform:translateY(0)}.gs-cta{order:4;margin-top:40px;font-family:var(--font, "Segoe UI", system-ui, sans-serif);font-size:clamp(11px,1vw,13px);font-weight:600;letter-spacing:.28em;text-transform:uppercase;color:#f6f4ff;background:linear-gradient(180deg,#6c63ff47,#3c3cba38);border:1px solid rgba(138,131,255,.55);padding:16px 34px;cursor:pointer;pointer-events:auto;border-radius:10px;opacity:0;transform:translateY(12px);transition:opacity .7s ease,transform .7s ease,background .25s ease,border-color .25s ease,box-shadow .25s ease,color .25s ease;box-shadow:0 0 0 1px #8a83ff14 inset,0 10px 40px #6c63ff1f;position:relative}.gs-cta.on{opacity:1;transform:translateY(0)}.gs-cta:before{content:"";position:absolute;top:-1px;right:-1px;bottom:-1px;left:-1px;pointer-events:none;background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.14) 50%,transparent 70%);opacity:0;transition:opacity .3s ease;mix-blend-mode:screen}.gs-cta:hover{background:linear-gradient(180deg,#6c63ff6b,#3c3cba52);border-color:#8a83ff;color:#fff;box-shadow:0 0 0 1px #8a83ff33 inset,0 14px 54px #6c63ff59}.gs-cta:hover:before{opacity:1}.gs-cta:active{transform:translateY(1px)}.gs-arrow{display:inline-block;margin-left:12px;transition:transform .25s ease}.gs-cta:hover .gs-arrow{transform:translate(4px)}.gg-page{display:flex;align-items:flex-start;justify-content:center;padding:2rem 1rem;min-height:calc(100vh - 60px)}.gg-card{background:var(--card-bg, #1a1a1a);border:1px solid var(--border, #333);border-radius:10px;padding:2rem;width:100%;max-width:540px;text-align:center}.gg-gate{margin-top:4rem}.gg-btn-primary{background:var(--accent, #6c63ff);color:#fff;border:none;border-radius:8px;padding:.75rem 2rem;font-size:1rem;font-weight:600;cursor:pointer;transition:opacity .15s}.gg-btn-primary:hover{opacity:.85}.gg-btn-primary:disabled{opacity:.4;cursor:default}.gg-game{width:100%;max-width:600px}.gg-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem;flex-wrap:wrap}.gg-round-label{font-size:.9rem;color:var(--text2, #aaa);flex:1}.gg-hearts{display:flex;gap:.15rem;font-size:1.15rem}.gg-vol{display:flex;align-items:center;gap:.4rem;font-size:.85rem;color:var(--text2, #aaa)}.vol-slider{-webkit-appearance:none;width:80px;height:4px;border-radius:2px;outline:none;background:linear-gradient(to right,var(--accent, #6c63ff) var(--fill, 100%),var(--border, #444) var(--fill, 100%))}.vol-slider::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent, #6c63ff);cursor:pointer}.gg-timer-bar{height:6px;background:var(--border, #333);border-radius:3px;overflow:hidden;margin-bottom:.75rem}.gg-timer-fill{height:100%;transition:width .1s linear,background-color .3s;border-radius:3px}.gg-timer-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.gg-timer-seconds{font-size:1rem;font-weight:700;font-variant-numeric:tabular-nums;min-width:2rem;transition:color .3s}.gg-lifelines{display:flex;gap:.5rem}.gg-lifeline-btn{background:var(--card-bg, #1a1a1a);border:1px solid var(--border, #444);color:var(--text1, #eee);border-radius:6px;padding:.3rem .75rem;font-size:.8rem;cursor:pointer;transition:background .15s,opacity .15s}.gg-lifeline-btn:hover:not(:disabled){background:var(--hover-bg, #2a2a2a)}.gg-lifeline-btn:disabled{opacity:.35;cursor:default}.gg-options{display:grid;grid-template-columns:1fr 1fr;gap:.6rem;margin-bottom:1rem}.gg-option{background:var(--card-bg, #1a1a1a);border:1px solid var(--border, #444);border-radius:8px;padding:.75rem 1rem;text-align:left;cursor:pointer;transition:background .15s,border-color .15s;display:flex;flex-direction:column;gap:.2rem}.gg-option:hover:not(:disabled){border-color:var(--accent, #6c63ff);background:var(--hover-bg, #222)}.gg-option:disabled{cursor:default}.gg-option.correct{border-color:#4caf50;background:#4caf501f}.gg-option.wrong{border-color:#e55;background:#e555551f}.gg-option.faded{opacity:.35}.gg-option-title{font-size:.9rem;font-weight:600;color:var(--text1, #eee);line-height:1.3}.gg-option-artist{font-size:.78rem;color:var(--text2, #aaa)}.gg-answer-card{border-radius:10px;border:1px solid var(--border, #333);padding:1.25rem;margin-bottom:1rem}.gg-answer-card.correct{border-color:#4caf50;background:#4caf5014}.gg-answer-card.wrong{border-color:#e55;background:#e5555514}.gg-answer-card.neutral{border-color:var(--text3, #555);background:#ffffff08}.gg-answer-verdict{font-size:1.2rem;font-weight:700;margin-bottom:.75rem}.gg-answer-song{display:flex;gap:.75rem;align-items:center;margin-bottom:.75rem}.gg-answer-art{width:64px;height:64px;border-radius:6px;object-fit:cover;flex-shrink:0}.gg-answer-info{display:flex;flex-direction:column;gap:.15rem}.gg-answer-album{font-size:.75rem;color:var(--text3, #666)}.gg-answer-selected{font-size:.8rem;color:var(--text2, #aaa);margin-bottom:.75rem}.gg-answer-health{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.gg-lifeline-counts{font-size:.8rem;color:var(--text2, #aaa)}.gg-btn-pause{display:block;width:100%;background:none;border:1px solid var(--border, #444);color:var(--text2, #aaa);border-radius:8px;padding:.5rem 1rem;font-size:.85rem;cursor:pointer;margin-bottom:.5rem;transition:background .15s,color .15s;text-align:center}.gg-btn-pause:hover{background:var(--hover-bg, #222);color:var(--text1, #eee)}.gg-next-btn{width:100%;margin-bottom:.4rem}.gg-hint{text-align:center;font-size:.75rem;color:var(--text3, #555);margin:0}@media (max-width: 480px){.gg-options{grid-template-columns:1fr}.gg-page{padding:1rem .5rem}}.gr-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.gr-stat-box{text-align:center;padding:1rem}.gr-stat-big{font-size:1.6rem;font-weight:700;line-height:1.2;margin-bottom:.25rem}.gr-rank{font-size:2.4rem;font-weight:700;margin-bottom:.25rem}.gr-hearts{display:inline-flex;gap:.15rem;font-size:1.2rem}.heart-full{color:#e55}.heart-empty{color:var(--text3, #555)}.gr-rounds{display:flex;flex-direction:column;gap:.4rem}.gr-round-row{display:flex;align-items:center;gap:.65rem;padding:.5rem .6rem;border-radius:6px;border-left:3px solid transparent}.gr-round-row.correct{border-left-color:#4caf50;background:#4caf500d}.gr-round-row.wrong{border-left-color:#e55;background:#e555550d}.gr-round-num{font-size:.75rem;color:var(--text3, #666);min-width:1.5rem;text-align:right;flex-shrink:0}.gr-round-art{width:40px;height:40px;border-radius:4px;object-fit:cover;flex-shrink:0}.gr-round-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.1rem}.gr-round-title{font-size:.9rem;font-weight:600;color:var(--text1, #eee);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gr-round-artist{font-size:.78rem;color:var(--text2, #aaa)}.gr-round-verdict{font-size:1rem;font-weight:700;flex-shrink:0}.gr-round-row.correct .gr-round-verdict{color:#4caf50}.gr-round-row.wrong .gr-round-verdict{color:#e55}@media (max-width: 480px){.gr-stats{grid-template-columns:1fr 1fr}}.dev-panel{position:fixed;bottom:1.25rem;right:1.25rem;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:.75rem 1rem;display:flex;flex-direction:column;gap:.55rem;z-index:200;min-width:220px;box-shadow:0 4px 20px #0006}.dev-panel__title{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);margin-bottom:.1rem}.dev-panel__row{display:flex;align-items:center;gap:.5rem}.dev-toggle{display:flex;align-items:center;gap:.35rem;font-size:.82rem;cursor:pointer;-webkit-user-select:none;user-select:none}.dev-slider-row{display:flex;flex-direction:column;gap:.2rem}.dev-slider-label{font-size:.8rem;color:var(--text-dim)}.dev-slider-row input[type=range]{width:100%}.dev-hint-btn{font-size:.75rem;padding:.15rem .5rem}.dev-hint-btn--active{background:var(--accent);color:#fff;border-color:var(--accent)}input[type=date],input[type=time]{color-scheme:dark}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}@keyframes winner-shimmer{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.winner-card{background:linear-gradient(135deg,#1c1400,#2d2000,#1a1600,#2d2300,#1c1400);background-size:300% 300%;animation:winner-shimmer 6s ease infinite;border-color:#b8860b!important;box-shadow:0 0 24px #f0c0402e,0 0 6px #f0c04014 inset}:root{--bg: #0f1117;--surface: #1a1d27;--surface2: #242736;--border: #2e3248;--accent: #6c63ff;--accent-dim: #4a44b5;--green: #4caf72;--red: #e05c5c;--yellow: #f0c040;--text: #e8eaf0;--text-dim: #8a8fa8;--radius: 10px;--font: "Segoe UI", system-ui, sans-serif}body{background:var(--bg);color:var(--text);font-family:var(--font);min-height:100vh}#root{display:flex;flex-direction:column;min-height:100vh}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;font-family:var(--font)}input,textarea,select{font-family:var(--font)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.6rem 1.2rem;border-radius:8px;border:none;font-size:.95rem;font-weight:600;transition:opacity .15s,transform .1s}.btn:hover{opacity:.88}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-danger{background:var(--red);color:#fff}.btn-ghost{background:transparent;color:var(--text-dim);border:1px solid var(--border)}.btn-success{background:var(--green);color:#fff}.btn-sm{padding:.35rem .8rem;font-size:.85rem}.input{background:var(--surface2);border:1px solid var(--border);border-radius:8px;color:var(--text);padding:.6rem .9rem;font-size:1rem;outline:none;width:100%;transition:border-color .15s}.input:focus{border-color:var(--accent)}.form-group{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1rem}.form-group label{font-size:.85rem;color:var(--text-dim);font-weight:600;text-transform:uppercase;letter-spacing:.04em}.error-msg{background:#e05c5c26;border:1px solid var(--red);border-radius:8px;color:var(--red);padding:.6rem 1rem;font-size:.9rem;margin-bottom:1rem}.warning-msg{background:#f0c0401f;border:1px solid var(--yellow);border-radius:6px;color:var(--yellow);padding:.4rem .75rem;font-size:.85rem}.page-center{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:1rem}.page{max-width:900px;margin:0 auto;padding:2rem 1rem}nav{background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:stretch;justify-content:flex-start;min-height:3rem}.nav-left{display:flex;align-items:center;gap:.25rem;padding:0 .75rem}.nav-right{display:flex;align-items:center;gap:.25rem;padding:0 1rem;margin-left:auto}nav .logo-block{display:flex;align-items:center;padding:0 1.1rem;background:linear-gradient(135deg,#1a1730,#2a2460);text-decoration:none;flex-shrink:0}nav .logo-block:hover{background:linear-gradient(135deg,#1f1c3a,#312b72);text-decoration:none}nav .logo-img{height:1.7rem;width:auto;display:block}nav .nav-link{color:var(--text-dim);font-size:.9rem;font-weight:650;padding:.35rem .6rem;border-radius:6px;transition:color .15s,background .15s}nav .nav-link:hover{color:var(--text);background:var(--surface2);text-decoration:none}nav .nav-username{font-weight:700;color:var(--text);display:flex;align-items:center;gap:.55rem}nav .nav-username:hover{color:var(--text)}nav .nav-avatar{width:24px;height:24px;border-radius:50%;object-fit:cover;flex-shrink:0}nav .nav-link--return{color:var(--green);font-weight:700}nav .nav-link--return:hover{color:var(--green);background:#4caf721a}.nav-dropdown-wrap{position:relative}.nav-dropdown-wrap:after{content:"";position:absolute;top:100%;left:0;right:0;height:4px}.nav-dropdown{display:none;position:absolute;top:calc(100% + 4px);left:0;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);min-width:160px;padding:.35rem;z-index:100;box-shadow:0 4px 16px #0000004d}.nav-dropdown-right{left:auto;right:0}.nav-dropdown-wrap:hover .nav-dropdown{display:flex;flex-direction:column}.nav-dropdown a,.nav-dropdown button{color:var(--text-dim);font-size:.875rem;font-weight:600;padding:.45rem .75rem;border-radius:6px;background:none;border:none;text-align:left;cursor:pointer;width:100%}.nav-dropdown a:hover,.nav-dropdown button:hover{color:var(--text);background:var(--border);text-decoration:none}h1{font-size:1.8rem;font-weight:700;margin-bottom:1rem}h2{font-size:1.3rem;font-weight:700;margin-bottom:.75rem}h3{font-size:1.1rem;font-weight:600;margin-bottom:.5rem}table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:.6rem .8rem;border-bottom:1px solid var(--border)}th{font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-dim)}tr:last-child td{border-bottom:none}.record-popup{position:fixed;top:1.5rem;left:50%;z-index:1000;background:var(--surface);border:1px solid var(--yellow);border-radius:10px;padding:.85rem 1.4rem;min-width:280px;max-width:420px;text-align:center;box-shadow:0 4px 24px #00000059;pointer-events:none}.record-popup--in{animation:record-popup-in .35s ease forwards}.record-popup--out{animation:record-popup-out .4s ease forwards}.record-popup__title{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--yellow);margin-bottom:.3rem}.record-popup__main{font-weight:700;font-size:1rem;margin-bottom:.25rem}.record-popup__times{font-size:.82rem;color:var(--text-dim)}@keyframes record-popup-in{0%{opacity:0;transform:translate(-50%) translateY(-12px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes record-popup-out{0%{opacity:1;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(-12px)}}.embed-error-toast{position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%);background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:.6rem 1.1rem;font-size:.85rem;color:var(--text-dim);box-shadow:0 4px 16px #0000004d;pointer-events:none;animation:embed-error-in .3s ease forwards;z-index:200;white-space:nowrap}@keyframes embed-error-in{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.text-dim{color:var(--text-dim)}.text-accent{color:var(--accent)}.text-green{color:var(--green)}.text-yellow{color:var(--yellow)}.text-red{color:var(--red)}.text-sm{font-size:.85rem}.text-xs{font-size:.75rem}.text-lg{font-size:1.2rem}.font-mono{font-family:monospace}.tabular-nums{font-variant-numeric:tabular-nums}.text-center{text-align:center}.fw-normal{font-weight:400}.fw-semi{font-weight:600}.fw-bold{font-weight:700}.label{font-size:.75rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.06em}.flex-row{display:flex;align-items:center}.flex-col{display:flex;flex-direction:column}.flex-between{display:flex;align-items:center;justify-content:space-between}.flex-center{display:flex;align-items:center;justify-content:center}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}.gap-xs{gap:.35rem}.gap-sm{gap:.5rem}.gap-md{gap:.75rem}.gap-lg{gap:1rem}.gap-xl{gap:1.5rem}.min-w-0{min-width:0}.mb-xs{margin-bottom:.25rem}.mb-sm{margin-bottom:.5rem}.mb-md{margin-bottom:1rem}.mb-lg{margin-bottom:1.5rem}.mt-sm{margin-top:.5rem}.mt-md{margin-top:1rem}.btn-full{width:100%}.badge{display:inline-flex;align-items:center;justify-content:center;padding:.15rem .5rem;border-radius:4px;font-size:.75rem;font-weight:700;border:1px solid}.badge-green{background:#4caf7233;color:var(--green);border-color:var(--green)}.badge-red{background:#e05c5c26;color:var(--red);border-color:var(--red)}.badge-dim{background:var(--surface2);color:var(--text-dim);border-color:var(--border)}.badge-official{background:#22c55e33;color:#22c55e;border-color:#22c55e66}.badge-accent{background:#6c63ff26;color:var(--accent);border-color:#6c63ff4d}.badge-warn{background:#f0c04033;color:var(--yellow);border-color:var(--yellow)}.badge-silver{background:#c0c0c026;color:#b0b0b0;border-color:#888}.badge-bronze{background:#b4783c33;color:#c87f3e;border-color:#a0622a}.info-box{background:var(--surface2);border-radius:6px;padding:.6rem .75rem}.success-box{background:#4caf721a;border:1px solid var(--green);border-radius:8px;padding:.75rem}.code-chip{background:var(--surface2);padding:.25rem .6rem;border-radius:6px;font-family:monospace;font-size:1rem;letter-spacing:.1em;font-weight:700}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.online-dot{width:8px;height:8px;border-radius:50%;background:var(--green);flex-shrink:0}.divider-top{border-top:1px solid var(--border);padding-top:.75rem}
