.ln{position:relative;min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;background:var(--bg-landing);overflow:hidden;isolation:isolate}.ln:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");opacity:.028;pointer-events:none;z-index:100;mix-blend-mode:overlay}.ln__topbar{position:absolute;top:0;left:0;right:0;display:flex;justify-content:space-between;align-items:center;padding:var(--sp-6) var(--sp-8);z-index:20;animation:ln-fade .8s ease-out .6s both}.ln__login{font-family:inherit;font-size:var(--fs-sm);font-weight:500;color:var(--text-secondary);background:none;border:none;cursor:pointer;padding:0;letter-spacing:.02em;transition:color var(--transition-fast)}.ln__login:hover{color:var(--text-primary)}.ln__hero{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;z-index:2;padding:80px var(--sp-6) 0}.ln__mark{display:block;font-size:clamp(52px,7vw,80px);font-weight:500;color:var(--text-primary);letter-spacing:.04em;text-align:center;animation:ln-fade 1s ease-out .1s both;position:relative}.ln__mark-i{display:inline-block;width:.075em;background:var(--accent-primary);border-radius:1px;vertical-align:baseline;margin-left:.04em;animation:ln-mark-wave 4s ease-in-out infinite;box-shadow:0 0 20px #c4873b40}@keyframes ln-mark-wave{0%{height:.52em}12%{height:.72em}28%{height:.48em}42%{height:.8em}58%{height:.54em}72%{height:.68em}85%{height:.44em}to{height:.52em}}.ln__tagline{font-size:clamp(16px,2.4vw,22px);font-weight:400;color:var(--text-secondary);text-align:center;letter-spacing:.01em;margin-top:var(--sp-5);line-height:1.5;animation:ln-fade 1s ease-out .35s both}.ln__cta{margin-top:clamp(32px,4vw,48px);animation:ln-fade 1s ease-out .6s both;position:relative}.ln__enter{font-family:inherit;font-size:var(--fs-base);font-weight:500;letter-spacing:.06em;color:var(--text-primary);background:transparent;border:1px solid rgba(196,135,59,.3);border-radius:100px;padding:16px 52px;cursor:pointer;position:relative;overflow:hidden;transition:border-color .4s ease,color .3s ease,box-shadow .5s ease,transform .3s ease}.ln__enter:before{content:"";position:absolute;top:-1px;right:-1px;bottom:-1px;left:-1px;border-radius:inherit;background:radial-gradient(ellipse 80% 80% at 50% 50%,rgba(196,135,59,.06),transparent);opacity:1;animation:ln-cta-breathe 3s ease-in-out infinite}.ln__enter:after{content:"";position:absolute;top:-8px;right:-8px;bottom:-8px;left:-8px;border-radius:inherit;border:1px solid rgba(196,135,59,0);transition:border-color .5s ease,inset .5s ease;pointer-events:none}@keyframes ln-cta-breathe{0%,to{opacity:.5}50%{opacity:1}}.ln__enter:hover{border-color:var(--accent-primary);box-shadow:0 0 40px #c4873b1f,inset 0 0 30px #c4873b0f;transform:scale(1.02)}.ln__enter:hover:after{border-color:#c4873b1f;top:-14px;right:-14px;bottom:-14px;left:-14px}.ln__enter:active{background:var(--accent-primary);color:var(--text-on-accent);border-color:var(--accent-primary);transform:scale(.98);box-shadow:0 0 60px #c4873b40}.ln__enter-arrow{display:inline-block;margin-left:10px;opacity:.4;transition:opacity .3s ease,transform .3s ease;font-size:.85em}.ln__enter:hover .ln__enter-arrow{opacity:.8;transform:translate(3px)}.ln__spectrum{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:flex-end;z-index:1;pointer-events:none;mask-image:linear-gradient(to bottom,transparent 0%,black 35%,black 88%,transparent 100%),linear-gradient(to right,transparent 0%,black 6%,black 94%,transparent 100%);mask-composite:intersect;-webkit-mask-image:linear-gradient(to bottom,transparent 0%,black 35%,black 88%,transparent 100%),linear-gradient(to right,transparent 0%,black 6%,black 94%,transparent 100%);-webkit-mask-composite:source-in}.ln__spectrum-inner{display:flex;align-items:flex-end;width:100%;height:100%;gap:3px;padding:0}.ln__bar{flex:1;min-width:2px;border-radius:2px 2px 0 0;background:var(--accent-primary);transform-origin:bottom center;will-change:height,opacity}.ln__spectrum-glow{position:absolute;bottom:20%;left:50%;transform:translate(-50%);width:80%;height:50%;border-radius:50%;background:radial-gradient(ellipse,rgba(196,135,59,.07) 0%,rgba(196,135,59,.025) 40%,transparent 70%);pointer-events:none;z-index:0;animation:ln-glow-pulse 6s ease-in-out infinite}@keyframes ln-glow-pulse{0%,to{opacity:.6;transform:translate(-50%) scale(1)}50%{opacity:1;transform:translate(-50%) scale(1.05)}}.ln__footer{position:relative;z-index:10;text-align:center;padding:var(--sp-8) var(--sp-5) var(--sp-6);display:flex;flex-direction:column;align-items:center;gap:var(--sp-3);animation:ln-fade 1s ease-out 1.2s both}.ln__footer-tagline{font-size:var(--fs-xs);color:var(--text-tertiary);letter-spacing:.05em}.ln__footer-about{font-size:var(--fs-xs);color:var(--text-tertiary);max-width:400px;line-height:1.6;opacity:.7}.ln__footer-links{display:flex;align-items:center;gap:var(--sp-2)}.ln__footer-link{font-size:var(--fs-xs);color:var(--text-secondary);text-decoration:none;transition:color var(--transition-fast)}.ln__footer-link:hover{color:var(--text-primary)}.ln__footer-sep{color:var(--text-tertiary);font-size:var(--fs-xs)}.ln__footer-copy{font-size:var(--fs-xs);color:var(--text-tertiary);opacity:.6}@keyframes ln-fade{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media(max-width:480px){.ln__topbar{padding:var(--sp-4) var(--sp-5)}.ln__hero{padding-top:60px}.ln__spectrum-inner{gap:2px}.ln__bar:nth-child(odd){display:none}.ln__enter{padding:14px 40px;font-size:var(--fs-sm)}.ln__footer-about{display:none}}@media(min-width:1600px){.ln__spectrum-inner{gap:4px}}:root{--bg-app: #0D0B0E;--bg-card: #161218;--bg-card-hover: #1E1820;--bg-current: #1A1520;--bg-filter: #12101A;--bg-filter-btn: #1A1620;--bg-filter-active: #2A1E15;--border-subtle: #2A2530;--border-card: #2E2835;--border-current: #3A2A15;--border-filter-active: #C4873B;--text-primary: #E8E0D8;--text-secondary: #9B928A;--text-tertiary: #5A534E;--text-muted: #3E3832;--text-on-accent: #0D0B0E;--accent-primary: #C4873B;--accent-primary-soft: #D4A86A;--accent-primary-muted: #8B5E29;--accent-primary-glow: rgba(196, 135, 59, .15);--accent-primary-glass: rgba(196, 135, 59, .06);--accent-sage: #6B8F71;--accent-amber: #D4A86A;--accent-tag: #6B5B7B;--accent-score-high: #6B8F71;--accent-score-mid: #D4A86A;--accent-score-low: #A3545B;--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 20px;--sp-6: 24px;--sp-8: 32px;--fs-xs: 11px;--fs-sm: 13px;--fs-base: 15px;--fs-md: 17px;--fs-lg: 20px;--fs-xl: 24px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--bg-landing: #080609;--bg-glass: rgba(22, 18, 24, .85);--border-glass: rgba(196, 135, 59, .08);--transition-fast: .15s ease}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}button,input{font-family:inherit}body{font-family:Satoshi,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-app);color:var(--text-primary);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html{scroll-behavior:smooth}::selection{background:#c4873b33;color:#fff}*:focus-visible{outline:2px solid var(--accent-primary-soft);outline-offset:2px}*:focus:not(:focus-visible){outline:none}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.app{padding:var(--sp-4);padding-bottom:60px}.splash{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;background:var(--bg-landing)}.splash__mark{font-size:clamp(40px,5.5vw,56px);font-weight:500;color:var(--text-primary);letter-spacing:.03em;animation:fade-in .4s ease-out both}.splash__mark-i{display:inline-block;width:.08em;height:.52em;background:var(--accent-primary);border-radius:1px;vertical-align:baseline;margin-left:.04em}.app-topbar{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:var(--sp-3) 0;margin-bottom:var(--sp-3)}.app-topbar__left{justify-self:start}.app-topbar__right{justify-self:end;display:flex;align-items:center;gap:var(--sp-3)}.app-topbar__logout{font-size:var(--fs-sm);font-weight:500;color:var(--text-tertiary);background:none;border:none;padding:var(--sp-1) 0;cursor:pointer;transition:color var(--transition-fast)}.app-topbar__logout:hover{color:var(--text-secondary)}.app-topbar__back{font-size:var(--fs-sm);font-weight:600;color:var(--accent-primary-soft);background:none;border:1px solid var(--accent-primary-muted);border-radius:var(--radius-sm);padding:var(--sp-1) var(--sp-3);cursor:pointer;transition:all var(--transition-fast)}.app-topbar__back:hover{color:var(--accent-primary);border-color:var(--accent-primary-soft)}.lang-toggle{display:flex;align-items:center;gap:2px}.lang-toggle__btn{font-family:inherit;font-size:var(--fs-xs);font-weight:500;color:var(--text-tertiary);background:none;border:none;cursor:pointer;padding:2px 4px;letter-spacing:.03em;transition:color var(--transition-fast)}.lang-toggle__btn--active{color:var(--accent-primary)}.lang-toggle__btn:hover:not(.lang-toggle__btn--active){color:var(--text-secondary)}.lang-toggle__sep{font-size:var(--fs-xs);color:var(--text-muted);-webkit-user-select:none;user-select:none}.app-topbar__mark{font-size:var(--fs-xl);font-weight:500;color:var(--text-primary);letter-spacing:.03em;background:none;border:none;padding:0;cursor:pointer;transition:color var(--transition-fast)}.app-topbar__mark:hover{color:var(--accent-primary-soft)}.app-topbar__mark-i{display:inline-block;width:.08em;background:var(--accent-primary);border-radius:1px;vertical-align:baseline;margin-left:.04em;animation:mark-i-wave 4s ease-in-out infinite}.subtitle{color:var(--text-tertiary);font-size:var(--fs-base);margin-top:var(--sp-1)}.subtitle.error{color:var(--accent-score-low)}.section-heading{font-size:var(--fs-sm);font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--text-tertiary);margin:var(--sp-8) 0 var(--sp-3)}.section-heading__count{color:var(--text-muted);font-weight:400}.library__greeting{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--sp-4);margin-bottom:var(--sp-2);animation:fade-up .4s ease-out both}.library__greeting-name{font-size:var(--fs-xl);font-weight:600;color:#fff;line-height:1.2}.library__greeting-sub{font-size:var(--fs-sm);color:var(--text-secondary);margin-top:var(--sp-1)}.library__greeting-actions{display:flex;align-items:center;gap:var(--sp-2);flex-shrink:0;padding-top:4px}.library__download-btn{font-size:var(--fs-xs);font-weight:500;color:var(--text-secondary);background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--sp-1) var(--sp-3);cursor:pointer;white-space:nowrap;transition:color var(--transition-fast),border-color var(--transition-fast),background var(--transition-fast)}.library__download-btn:hover{color:var(--text-primary);border-color:var(--text-muted);background:var(--bg-card-hover)}.library__download-btn:active{transform:scale(.97)}.library__download-progress{font-size:var(--fs-xs);color:var(--text-secondary);display:flex;align-items:center;gap:var(--sp-2);white-space:nowrap}.library__download-progress--error{color:var(--status-error)}.library__download-cancel{font-size:var(--fs-xs);color:var(--text-muted);background:none;border:none;cursor:pointer;text-decoration:underline;padding:0}.library__download-cancel:hover{color:var(--text-secondary)}.library__cta{display:flex;justify-content:center;margin-bottom:var(--sp-2);animation:fade-up .4s ease-out .1s both}.library__add-btn{font-size:var(--fs-base);font-weight:600;letter-spacing:.3px;color:var(--text-on-accent);background:var(--accent-primary);border:none;border-radius:var(--radius-md);padding:var(--sp-4) var(--sp-8);width:100%;cursor:pointer;transition:background var(--transition-fast),transform var(--transition-fast)}.library__add-btn:hover{background:var(--accent-primary-soft)}.library__add-btn:active{transform:scale(.97)}.library__add-btn--limit{background:var(--bg-card);color:var(--text-muted);cursor:not-allowed;opacity:.7}.library__add-btn--limit:hover{background:var(--bg-card)}.library__add-btn--upgrade{background:transparent;color:var(--accent-primary-soft);border:1px solid var(--accent-primary-muted);cursor:pointer;opacity:1}.library__add-btn--upgrade:hover{border-color:var(--accent-primary-soft);color:var(--accent-primary);background:var(--accent-primary-glass)}@media(min-width:571px){.library__cta{justify-content:flex-start}.library__add-btn{width:auto;padding:var(--sp-2) var(--sp-5);font-size:var(--fs-sm);border-radius:var(--radius-sm)}}.library__live-btn{font-size:var(--fs-sm);font-weight:600;color:var(--text-on-accent);background:var(--accent-primary);border:1px solid var(--accent-primary);border-radius:var(--radius-sm);padding:var(--sp-1) var(--sp-3);cursor:pointer;transition:all var(--transition-fast)}.library__live-btn:hover{background:var(--accent-primary-soft);border-color:var(--accent-primary-soft)}.library__stats{display:flex;align-items:baseline;gap:var(--sp-3);margin-bottom:var(--sp-2);animation:fade-up .4s ease-out .06s both}.library__stat{font-size:var(--fs-xs);color:var(--text-secondary);font-variant-numeric:tabular-nums;white-space:nowrap}.library__stat em{font-style:normal;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--text-tertiary);font-size:10px;margin-left:2px}.library__stat-sep{width:1px;height:10px;background:var(--border-subtle);flex-shrink:0}.pq{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);margin-bottom:var(--sp-4);animation:fade-up .3s ease-out both;overflow:hidden}.pq--complete{animation:pq-complete-exit .6s ease-out 2.5s forwards;pointer-events:none}@keyframes pq-complete-exit{to{opacity:0;transform:translateY(-8px)}}.pq__summary{display:flex;align-items:center;gap:var(--sp-2);width:100%;padding:var(--sp-3) var(--sp-4);background:none;border:none;cursor:pointer;text-align:left;transition:background var(--transition-fast)}.pq__summary:hover{background:#c4873b0a}.pq__dot{width:6px;height:6px;border-radius:50%;background:var(--text-muted);flex-shrink:0}.pq__dot--active{background:var(--accent-primary);animation:status-pulse 2s ease-in-out infinite}.pq__dot--error{background:var(--accent-score-low);animation:status-pulse 2s ease-in-out infinite}.pq__bar-track{width:60px;height:3px;background:var(--border-subtle);border-radius:2px;overflow:hidden;flex-shrink:0}.pq__bar-fill{height:100%;background:var(--accent-primary);border-radius:2px;transition:width .4s cubic-bezier(.22,1,.36,1)}.pq--complete .pq__bar-fill{background:var(--accent-sage)}.pq__text{flex:1;font-size:var(--fs-sm);color:var(--text-secondary);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.pq__text--error{color:var(--accent-score-low)}.pq__sep{color:var(--text-muted);font-weight:400}.pq__chevron{font-size:var(--fs-xs);color:var(--text-muted);flex-shrink:0;margin-left:var(--sp-1)}.pq__list{display:flex;flex-direction:column;border-top:1px solid var(--border-subtle);max-height:200px;overflow-y:auto;animation:fade-up .2s ease-out both}.pq__item{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-4);min-height:32px;transition:background var(--transition-fast)}.pq__item:hover{background:#ffffff05}.pq__item--error{background:#a3545b0a}.pq__item-dot{width:5px;height:5px;border-radius:50%;background:var(--text-muted);flex-shrink:0}.pq__item-dot--active{background:var(--accent-primary);animation:status-pulse 2s ease-in-out infinite}.pq__item-dot--error{background:var(--accent-score-low)}.pq__item-name{flex:1;font-size:var(--fs-xs);color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.pq__item-label{font-size:var(--fs-xs);color:var(--text-tertiary);flex-shrink:0}.pq__item--error .pq__item-label{color:var(--accent-score-low)}.pq__item--duplicate .pq__item-label{color:var(--text-muted)}.pq__item--limit{background:var(--accent-primary-glass)}.pq__item--limit .pq__item-dot{background:var(--accent-primary)}.pq__item--limit .pq__item-label{color:var(--accent-primary-muted)}.pq__item-error{font-size:var(--fs-xs);color:var(--text-muted);flex-shrink:0;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pq__item-actions{display:flex;align-items:center;gap:var(--sp-1);flex-shrink:0}.pq__action{font-size:var(--fs-sm);line-height:1;color:var(--text-muted);background:none;border:none;padding:var(--sp-1);cursor:pointer;flex-shrink:0;transition:color var(--transition-fast)}.pq__action:hover{color:var(--accent-primary-soft)}.pq__action--dismiss:hover,.pq__action--delete:hover{color:var(--accent-score-low)}.pq__action--upgrade{color:var(--accent-primary-soft);font-weight:600;letter-spacing:.3px}.pq__action--upgrade:hover{color:var(--accent-primary)}.library__pending-btn{background:none;border:none;padding:0;font:inherit;color:var(--accent-primary-soft);cursor:pointer;transition:color var(--transition-fast)}.library__pending-btn:hover{color:var(--accent-primary)}.library .section-heading{margin:0 0 var(--sp-2);animation:fade-up .4s ease-out .16s both}.track-list--spacious{gap:var(--sp-3);animation:fade-up .4s ease-out .2s both}.library-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--sp-3) var(--sp-4);display:flex;flex-direction:column;gap:var(--sp-2);transition:opacity .4s ease}.library-card__name{font-size:var(--fs-md);font-weight:500;color:var(--text-primary);line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.library-card__meta{display:flex;align-items:center;gap:var(--sp-2);font-size:var(--fs-sm);color:var(--text-secondary)}.library-card__sep{color:var(--text-muted)}.library-card__character{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-3);margin-top:var(--sp-1)}.library-card__bars{display:flex;flex-direction:column;gap:3px;width:48px;flex-shrink:0}.library-card__bar{height:3px;background:var(--border-subtle);border-radius:2px;overflow:hidden}.library-card__bar-fill{height:100%;border-radius:2px;background:var(--accent-primary-soft);transition:width .8s cubic-bezier(.22,1,.36,1),opacity .4s ease}.library-card__bar-fill--melodic{background:var(--accent-amber)}.library-card__bar-fill--vocal{background:var(--accent-tag)}.library-card__tags{display:flex;gap:var(--sp-1);flex-wrap:wrap;justify-content:flex-end}.library-card__tag{font-size:var(--fs-xs);font-weight:600;color:var(--accent-tag);background:#6b5b7b1a;border-radius:var(--radius-sm);padding:2px var(--sp-2);white-space:nowrap}.library-card--pending{opacity:.7}.library-card__header{display:flex;justify-content:space-between;align-items:center;gap:var(--sp-3)}.library-card__header .library-card__name{flex:1;min-width:0}.library-card__status{font-size:var(--fs-xs);font-weight:700;text-transform:uppercase;letter-spacing:.5px;flex-shrink:0;padding:2px var(--sp-2);border-radius:var(--radius-sm)}.library-card__status--uploaded,.library-card__status--processing{color:var(--accent-amber);background:#d4a85c1a}.library-card__status--error{color:var(--accent-score-low);background:#d45c5c1a}.library-card__delete{font-size:var(--fs-md);line-height:1;color:var(--text-muted);background:none;border:none;padding:var(--sp-1) var(--sp-2);cursor:pointer;border-radius:var(--radius-sm);flex-shrink:0;transition:color var(--transition-fast),background var(--transition-fast)}.library-card__delete:hover{color:var(--accent-score-low);background:#d45c5c1a}.library-card__bar-fill--empty{opacity:0}.library-card--deleting{animation:card-exit .3s ease-out forwards;pointer-events:none}.library-card--new{animation:card-enter .4s ease-out both}.library-card--tappable{cursor:pointer}.library-card--tappable:active{background:var(--bg-card-hover)}.library-card--analyzing .library-card__bar{animation:bar-analyze 1.8s ease-in-out infinite}.library-card--analyzing .library-card__bar:nth-child(2){animation-delay:.15s}.library-card--analyzing .library-card__bar:nth-child(3){animation-delay:.3s}.library-card__status--processing{animation:status-pulse 2s ease-in-out infinite}@keyframes bar-analyze{0%,to{background:var(--border-subtle)}50%{background:#c4873b1f}}@keyframes status-pulse{0%,to{opacity:1}50%{opacity:.5}}.library-card--skeleton{pointer-events:none}.skeleton-line{background:var(--text-primary);border-radius:var(--radius-sm);animation:skeleton-pulse 1.5s ease-in-out infinite}.library--skeleton{animation:fade-in .3s ease-out both}.library--skeleton .library__greeting,.library--skeleton .library__stats,.library--skeleton .library__cta,.library--skeleton .sets-section,.library--skeleton .section-heading-row,.library--skeleton .library .section-heading,.library--skeleton .track-list--spacious{animation:none}@keyframes card-exit{to{opacity:0;transform:translate(-20px) scale(.97)}}@keyframes card-enter{0%{opacity:0;transform:translateY(-8px)}}@keyframes skeleton-pulse{0%,to{opacity:.06}50%{opacity:.12}}.upload-zone{display:flex;align-items:center;justify-content:center;padding:var(--sp-8) var(--sp-5);border:2px dashed var(--border-subtle);border-radius:var(--radius-lg);transition:border-color .2s ease,background .2s ease;animation:fade-up .4s ease-out .1s both}.upload-zone--active{border-color:var(--accent-primary-muted);background:var(--accent-primary-glass)}.upload-zone__content{display:flex;flex-direction:column;align-items:center;gap:var(--sp-3)}.upload-zone__message{font-size:var(--fs-md);font-weight:500;color:var(--text-secondary)}.upload-zone__or{font-size:var(--fs-sm);color:var(--text-muted);text-transform:uppercase;letter-spacing:1px}.upload-zone__actions{display:flex;gap:var(--sp-3)}.upload-zone__btn{font-size:var(--fs-sm);font-weight:600;color:var(--text-on-accent);background:var(--accent-primary);border:none;border-radius:var(--radius-sm);padding:var(--sp-2) var(--sp-4);cursor:pointer;transition:filter var(--transition-fast)}.upload-zone__btn:hover{filter:brightness(1.1)}.upload-zone__btn--secondary{color:var(--accent-primary-soft);background:transparent;border:1px solid var(--accent-primary-muted)}.upload-zone__btn--secondary:hover{filter:none;border-color:var(--accent-primary-soft);color:var(--accent-primary)}.upload-zone__hint{font-size:var(--fs-xs);color:var(--text-muted);text-align:center}@media(max-width:570px){.library__greeting{flex-direction:column;align-items:flex-start;gap:var(--sp-3)}.library__stats{flex-wrap:wrap;gap:var(--sp-2)}}.track-list{display:flex;flex-direction:column;gap:var(--sp-2)}.now-playing-card{background:linear-gradient(160deg,#1a1520,#14101a);border:1px solid var(--border-current);border-left:3px solid var(--accent-primary);border-radius:var(--radius-lg);padding:var(--sp-4) var(--sp-4)}.now-playing-card__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--sp-2)}.now-playing-card__label{font-size:var(--fs-xs);font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--accent-primary)}.now-playing-card__favorite{font-size:var(--fs-lg);line-height:1;color:var(--text-muted);background:none;border:none;padding:0;cursor:pointer;transition:color var(--transition-fast)}.now-playing-card__favorite:hover{color:var(--accent-primary-soft)}.now-playing-card__favorite--active{color:var(--accent-primary)}.now-playing-card__favorite--active:hover{color:var(--accent-primary-soft)}.now-playing-card__back{font-size:var(--fs-sm);font-weight:600;color:var(--text-secondary);background:#ffffff0d;border:1px solid var(--border-card);border-radius:var(--radius-sm);padding:var(--sp-1) var(--sp-3);cursor:pointer;transition:background var(--transition-fast)}.now-playing-card__back:active{background:#ffffff1a}.now-playing-card__name{font-size:var(--fs-lg);font-weight:600;color:#fff;line-height:1.2;margin-bottom:var(--sp-2)}.now-playing-card__stats{display:flex;align-items:baseline;gap:var(--sp-4);flex-wrap:wrap;margin-bottom:0}.now-playing-card__bpm{font-size:var(--fs-lg);font-weight:600;color:var(--text-primary)}.now-playing-card__key{font-size:var(--fs-base);color:var(--text-secondary)}.now-playing-card__bars{display:flex;flex-direction:column;gap:var(--sp-2);margin-top:var(--sp-3);margin-bottom:var(--sp-2)}.stat-bar{display:flex;align-items:center;gap:var(--sp-3)}.stat-bar__label{font-size:var(--fs-xs);font-weight:600;color:var(--text-muted);min-width:52px;text-transform:uppercase;letter-spacing:.5px}.stat-bar__track{flex:1;height:3px;background:var(--border-subtle);border-radius:2px;overflow:hidden}.stat-bar__fill{height:100%;background:var(--accent-primary-soft);border-radius:2px;transition:width .3s ease}.stat-bar__value{font-size:var(--fs-xs);font-weight:600;color:var(--text-tertiary);min-width:22px;text-align:right;font-variant-numeric:tabular-nums}.now-playing-card__secondary{display:flex;justify-content:space-between;align-items:center;margin-top:var(--sp-2)}.now-playing-card__duration{font-size:var(--fs-sm);color:var(--text-muted)}.now-playing-card__footer{display:flex;align-items:center;gap:var(--sp-3);margin-top:var(--sp-3)}.now-playing-card__mini-bars{display:flex;flex-direction:column;gap:3px;width:48px;flex-shrink:0}.now-playing-card__mini-bar{height:3px;background:var(--border-subtle);border-radius:2px;overflow:hidden}.now-playing-card__mini-fill{height:100%;border-radius:2px;background:var(--accent-primary-soft);transition:width .3s ease}.now-playing-card__mini-fill--melodic{background:var(--accent-amber)}.now-playing-card__mini-fill--vocal{background:var(--accent-tag)}.now-playing__nav{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--sp-4)}.now-playing__nav-btn{font-size:var(--fs-sm);font-weight:600;color:var(--accent-primary-soft);background:none;border:1px solid var(--accent-primary-muted);border-radius:var(--radius-sm);padding:var(--sp-1) var(--sp-3);cursor:pointer;transition:all var(--transition-fast)}.now-playing__nav-btn:hover{color:var(--accent-primary);border-color:var(--accent-primary-soft)}.now-playing__nav-btn--reset{color:var(--text-tertiary);border-color:var(--border-subtle)}.now-playing__nav-btn--reset:hover{color:var(--text-secondary);border-color:var(--border-card)}.now-playing .section-heading-row,.now-playing .track-search{animation:none}.track-rec{display:flex;align-items:center;gap:var(--sp-3);background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--sp-3) var(--sp-4);cursor:pointer;transition:background var(--transition-fast)}.track-rec:active{background:var(--bg-card-hover)}.track-rec__info{flex:1;min-width:0}.track-rec__name{font-size:var(--fs-md);font-weight:500;color:var(--text-primary);line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.track-rec__meta{display:flex;align-items:center;gap:var(--sp-2);margin-top:var(--sp-1)}.track-rec__bpm{font-size:var(--fs-sm);color:var(--text-secondary)}.track-rec__sep{font-size:var(--fs-sm);color:var(--text-muted)}.track-rec__camelot{font-size:var(--fs-xs);font-weight:600;color:var(--accent-primary);background:var(--accent-primary-glow);border-radius:var(--radius-sm);padding:var(--sp-1) var(--sp-2);flex-shrink:0}.track-rec__favorite{font-size:var(--fs-md);line-height:1;color:var(--text-muted);background:none;border:none;padding:0;cursor:pointer;flex-shrink:0;transition:color var(--transition-fast)}.track-rec__favorite:hover{color:var(--accent-primary-soft)}.track-rec__favorite--active{color:var(--accent-primary)}.track-rec__favorite--active:hover{color:var(--accent-primary-soft)}.score-ring{flex-shrink:0}.set-history{margin-top:var(--sp-4);border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:var(--bg-card);overflow:hidden}.set-history__toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--sp-3) var(--sp-4);background:none;border:none;cursor:pointer;text-align:left;transition:background var(--transition-fast)}.set-history__toggle:hover{background:#c4873b0a}.set-history__label{font-size:var(--fs-sm);font-weight:600;color:var(--text-tertiary)}.set-history__count{color:var(--text-muted);font-weight:400}.set-history__chevron{font-size:var(--fs-xs);color:var(--text-muted);flex-shrink:0;margin-left:var(--sp-1)}.set-history__list{display:flex;flex-direction:column;border-top:1px solid var(--border-subtle);max-height:240px;overflow-y:auto;animation:fade-up .2s ease-out both}.history-track{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-2) var(--sp-3);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast);border-left:3px solid transparent}.history-track:active{background:var(--bg-card-hover)}.history-track--current{border-left-color:var(--accent-primary);background:var(--accent-primary-glass)}.history-track__step{font-size:var(--fs-sm);font-weight:600;color:var(--text-muted);min-width:20px;text-align:center}.history-track--current .history-track__step{color:var(--accent-primary)}.history-track__name{flex:1;font-size:var(--fs-base);color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.history-track--current .history-track__name{color:var(--text-primary)}.history-track__meta{font-size:var(--fs-sm);color:var(--text-muted);flex-shrink:0}.history-track__favorite{font-size:var(--fs-md);line-height:1;color:var(--text-muted);background:none;border:none;padding:0;cursor:pointer;flex-shrink:0;transition:color var(--transition-fast)}.history-track__favorite:hover{color:var(--accent-primary-soft)}.history-track__favorite--active{color:var(--accent-primary)}.history-track__favorite--active:hover{color:var(--accent-primary-soft)}.history-track__remove{font-size:var(--fs-md);line-height:1;color:var(--text-muted);background:none;border:none;padding:var(--sp-1) var(--sp-2);cursor:pointer;border-radius:var(--radius-sm);flex-shrink:0;transition:color var(--transition-fast),background var(--transition-fast)}.history-track__remove:active{color:var(--accent-score-low);background:#d45c5c1a}.tags-inline{font-size:var(--fs-sm);color:var(--text-tertiary)}.filter-bar{display:flex;gap:var(--sp-2);margin:var(--sp-3) 0 0;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:var(--sp-1)}.filter-bar::-webkit-scrollbar{display:none}.filter-row{display:contents}.filter-group{--tab-radius: 10px;--tab-scoop: 8px;--fg-surface: var(--bg-filter-btn);--fg-void: var(--bg-app);display:flex;flex-direction:column;align-items:center;position:relative;flex-shrink:0}.filter-group__tab{position:relative;z-index:1;background:var(--fg-surface);border-radius:var(--tab-radius) var(--tab-radius) 0 0;margin-bottom:-1px}.filter-group__tab:before{content:"";position:absolute;bottom:0;left:calc(-1 * var(--tab-scoop));width:var(--tab-scoop);height:var(--tab-scoop);background:radial-gradient(circle at 0% 0,transparent calc(var(--tab-scoop) - .5px),var(--fg-surface) var(--tab-scoop))}.filter-group__tab:after{content:"";position:absolute;bottom:0;right:calc(-1 * var(--tab-scoop));width:var(--tab-scoop);height:var(--tab-scoop);background:radial-gradient(circle at 100% 0,transparent calc(var(--tab-scoop) - .5px),var(--fg-surface) var(--tab-scoop))}.filter-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--text-tertiary);text-align:center;padding:8px 14px 4px}.filter-group__buttons{display:flex;background:var(--fg-surface);border-radius:var(--tab-radius)}.filter-group__buttons .filter-btn:first-child{border-top-left-radius:var(--tab-radius);border-bottom-left-radius:var(--tab-radius)}.filter-group__buttons .filter-btn:last-child{border-top-right-radius:var(--tab-radius);border-bottom-right-radius:var(--tab-radius)}.filter-group__buttons .filter-btn:last-child:after{display:none}.filter-btn{font-size:13px;font-weight:600;color:var(--text-muted);background:transparent;border:none;padding:8px 14px;min-height:36px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;position:relative;touch-action:manipulation;transition:color 30ms ease,background-color 30ms ease}.filter-btn:after{content:"";position:absolute;right:0;top:20%;bottom:20%;width:1px;background:var(--border-subtle)}@media(hover:hover){.filter-btn:hover{color:var(--text-secondary);background:#ffffff08}}.filter-btn.active{color:#fff;background:var(--bg-filter-active);box-shadow:inset 0 0 0 1px var(--border-filter-active);z-index:1;transition:color 60ms ease,background-color 60ms ease}.filter-btn.active:after,.filter-btn:has(+.filter-btn.active):after{display:none}.track-search{position:relative;height:40px;max-width:36px;margin-top:0;margin-bottom:var(--sp-2);animation:fade-up .4s ease-out .16s both;transition:max-width .2s ease-out}.track-search--open{max-width:600px;transition:max-width .25s cubic-bezier(.4,0,.2,1)}.track-search__trigger{position:absolute;top:0;left:0;display:flex;align-items:center;justify-content:center;width:36px;height:40px;color:var(--text-muted);background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);cursor:pointer;padding:0;transition:opacity .12s ease .08s,border-color var(--transition-fast),color var(--transition-fast)}.track-search--open .track-search__trigger{opacity:0;pointer-events:none;transition:opacity .12s ease,border-color var(--transition-fast),color var(--transition-fast)}.track-search__trigger:hover{border-color:var(--accent-primary-muted);color:var(--text-secondary)}.track-search__input{position:absolute;top:0;left:0;width:100%;height:40px;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:0 var(--sp-4);padding-right:36px;color:var(--text-primary);font-size:var(--fs-base);outline:none;opacity:0;pointer-events:none;transition:opacity .1s ease,border-color var(--transition-fast),box-shadow var(--transition-fast)}.track-search--open .track-search__input{opacity:1;pointer-events:auto;transition:opacity .2s ease .05s,border-color var(--transition-fast),box-shadow var(--transition-fast)}.track-search__input:focus{border-color:var(--accent-primary-soft);box-shadow:0 0 0 3px var(--accent-primary-glow)}.track-search__input::placeholder{color:var(--text-muted)}.track-search__clear{position:absolute;right:0;top:0;height:100%;width:36px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-muted);font-size:var(--fs-lg);line-height:1;cursor:pointer;padding:0;transition:color var(--transition-fast)}.track-search__clear:hover{color:var(--text-secondary)}.empty{color:var(--text-muted);text-align:center;padding:var(--sp-5);font-size:var(--fs-base)}@keyframes fade-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes modal-backdrop-in{0%{opacity:0}to{opacity:1}}@keyframes modal-panel-in{0%{opacity:0;transform:scale(.97) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.landing{position:relative;min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden;background:var(--bg-landing)}.landing:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 55% 55% at 64% 48%,rgba(196,135,59,.055),transparent 70%),radial-gradient(ellipse 35% 40% at 28% 42%,rgba(107,91,123,.025),transparent 60%);pointer-events:none;z-index:1}.landing:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");opacity:.03;pointer-events:none;z-index:2;mix-blend-mode:overlay}.landing__login{position:absolute;top:var(--sp-6);right:var(--sp-8);font-family:inherit;font-size:var(--fs-sm);font-weight:500;color:var(--text-secondary);background:none;border:none;cursor:pointer;padding:0;z-index:10;transition:color var(--transition-fast);animation:fade-in .8s ease-out .5s both}.landing__login:hover{color:var(--text-primary)}.landing__scene{position:relative;z-index:3;display:flex;align-items:center;gap:clamp(40px,6vw,80px);max-width:1060px;width:100%;padding:0 48px}.landing__text{position:relative;z-index:2;flex:0 1 440px;display:flex;flex-direction:column;align-items:flex-start}.landing__mark{display:block;font-size:clamp(40px,5.5vw,56px);font-weight:500;color:var(--text-primary);letter-spacing:.03em;text-shadow:0 0 80px rgba(196,135,59,.08);margin-bottom:var(--sp-6);animation:fade-in .8s ease-out .15s both}.landing__mark-i{display:inline-block;width:.08em;background:var(--accent-primary);border-radius:1px;vertical-align:baseline;margin-left:.04em;animation:mark-i-wave 4s ease-in-out infinite}@keyframes mark-i-wave{0%{height:.52em}12%{height:.72em}28%{height:.48em}42%{height:.8em}58%{height:.54em}72%{height:.68em}85%{height:.44em}to{height:.52em}}.landing__headline{font-size:clamp(22px,3.2vw,34px);font-weight:500;color:var(--text-primary);line-height:1.3;letter-spacing:-.01em;animation:fade-in 1s ease-out .35s both}.landing__steps{display:flex;flex-direction:column;gap:var(--sp-2);margin-top:var(--sp-8);animation:fade-in 1s ease-out .65s both}.landing__steps p{font-size:var(--fs-base);color:var(--text-secondary);letter-spacing:.02em;line-height:1.6}.landing__vinyl{position:relative;flex:1;display:flex;align-items:center;justify-content:center;min-height:520px;animation:fade-in 1.2s ease-out .3s both}.landing__vinyl:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:240px;height:240px;border-radius:50%;background:radial-gradient(circle,rgba(196,135,59,.14) 0%,rgba(196,135,59,.05) 40%,transparent 70%);pointer-events:none;z-index:0;opacity:.7;transition:opacity .4s ease}.landing__vinyl:hover:after{opacity:1}.landing__groove{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border-radius:50%;border:1px solid var(--accent-primary);pointer-events:none}.landing__groove--1{width:192px;height:192px;animation:groove-1 3.2s ease-in-out infinite}.landing__groove--2{width:238px;height:238px;animation:groove-2 3.8s ease-in-out .4s infinite}.landing__groove--3{width:296px;height:296px;animation:groove-3 4.2s ease-in-out .9s infinite}.landing__groove--4{width:358px;height:358px;animation:groove-4 3.5s ease-in-out .5s infinite}.landing__groove--5{width:428px;height:428px;animation:groove-5 4.5s ease-in-out 1.1s infinite}.landing__groove--6{width:520px;height:520px;animation:groove-6 4s ease-in-out .7s infinite}@keyframes groove-1{0%,to{opacity:.22}50%{opacity:.08}}@keyframes groove-2{0%,to{opacity:.16}50%{opacity:.06}}@keyframes groove-3{0%,to{opacity:.12}50%{opacity:.04}}@keyframes groove-4{0%,to{opacity:.08}50%{opacity:.025}}@keyframes groove-5{0%,to{opacity:.05}50%{opacity:.015}}@keyframes groove-6{0%,to{opacity:.03}50%{opacity:.01}}.landing__label{position:relative;z-index:2;display:flex;align-items:center;justify-content:center;width:140px;height:140px;border-radius:50%;border:1px solid var(--accent-primary);background:#c4873b08;color:var(--text-primary);font-family:inherit;font-size:var(--fs-base);font-weight:500;line-height:1.4;text-align:center;cursor:pointer;transition:background .3s ease,box-shadow .3s ease}.landing__label:hover{background:#c4873b1a;box-shadow:0 0 60px #c4873b1a}.landing__label:active{background:var(--accent-primary);color:var(--text-on-accent)}.landing__footer{position:absolute;bottom:0;left:0;right:0;text-align:center;padding:var(--sp-6) var(--sp-5);z-index:3;animation:fade-in 1s ease-out 1.2s both;display:flex;flex-direction:column;align-items:center;gap:var(--sp-3)}.landing__footer-tagline{font-size:var(--fs-xs);color:var(--text-muted);letter-spacing:.05em}.landing__footer-about{font-size:var(--fs-xs);color:var(--text-muted);max-width:400px;line-height:1.6;opacity:.6}.landing__footer-links{display:flex;align-items:center;gap:var(--sp-2)}.landing__footer-link{font-size:var(--fs-xs);color:var(--text-tertiary);text-decoration:none;transition:color var(--transition-fast)}.landing__footer-link:hover{color:var(--text-secondary)}.landing__footer-sep{color:var(--text-muted);font-size:var(--fs-xs)}.landing__footer-copy{font-size:var(--fs-xs);color:var(--text-muted);opacity:.5}@media(max-width:900px){.landing__scene{flex-direction:column;gap:var(--sp-4);padding:0 var(--sp-6)}.landing__text{flex:none;align-items:center;text-align:center;max-width:none}.landing__vinyl{min-height:380px;flex:none}.landing__label{width:120px;height:120px;font-size:var(--fs-sm)}.landing__groove--1{width:164px;height:164px}.landing__groove--2{width:204px;height:204px}.landing__groove--3{width:252px;height:252px}.landing__groove--4{width:304px;height:304px}.landing__groove--5{width:360px;height:360px}.landing__groove--6{width:420px;height:420px}}@media(max-width:570px){.landing__login{top:var(--sp-4);right:var(--sp-5)}.landing__scene{padding:0 var(--sp-5)}.landing__vinyl{min-height:320px}.landing__label{width:110px;height:110px}.landing__groove--1{width:150px;height:150px}.landing__groove--2{width:188px;height:188px}.landing__groove--3{width:232px;height:232px}.landing__groove--4{width:280px;height:280px}.landing__groove--5{width:330px;height:330px}.landing__groove--6{width:380px;height:380px}.landing__footer-about{display:none}}.legal{min-height:100vh;min-height:100dvh;background:var(--bg-landing);padding:var(--sp-8) var(--sp-6);position:relative}.legal__top{display:flex;justify-content:space-between;align-items:center;position:absolute;top:var(--sp-8);left:var(--sp-6);right:var(--sp-6)}.legal__back{font-size:var(--fs-sm);color:var(--text-tertiary);text-decoration:none;transition:color var(--transition-fast)}.legal__back:hover{color:var(--accent-primary)}.legal__body{max-width:600px;margin:0 auto;padding-top:var(--sp-8)}.legal__mark{display:block;font-size:clamp(28px,4vw,36px);font-weight:500;color:var(--text-primary);letter-spacing:.03em;margin-bottom:var(--sp-8);animation:fade-in .6s ease-out both}.legal__mark-i{display:inline-block;width:.08em;height:.52em;background:var(--accent-primary);border-radius:1px;vertical-align:baseline;margin-left:.04em}.legal__title{font-size:var(--fs-lg);font-weight:500;color:var(--text-primary);margin-bottom:var(--sp-6);animation:fade-in .6s ease-out .1s both}.legal__content{color:var(--text-secondary);font-size:var(--fs-base);line-height:1.7;animation:fade-in .6s ease-out .2s both}.legal__content p{margin-bottom:var(--sp-5)}.legal__content p:last-child{margin-bottom:0}.legal__content a{color:var(--accent-primary);text-decoration:none;transition:color var(--transition-fast)}.legal__content a:hover{color:var(--accent-primary-soft)}.legal__content strong{color:var(--text-primary);font-weight:500}.legal__content h2{font-size:var(--fs-md);font-weight:500;color:var(--text-primary);margin-top:var(--sp-8);margin-bottom:var(--sp-4)}.legal__content h2:first-child{margin-top:0}.legal__content ul{list-style:none;padding:0;margin-bottom:var(--sp-5)}.legal__content li{padding-left:var(--sp-4);position:relative;margin-bottom:var(--sp-2)}.legal__content li:before{content:"—";position:absolute;left:0;color:var(--text-muted)}.legal__updated{font-size:var(--fs-xs);color:var(--text-muted);margin-bottom:var(--sp-8);letter-spacing:.02em}@media(max-width:570px){.legal{padding:var(--sp-6) var(--sp-5)}.legal__top{top:var(--sp-6);left:var(--sp-5);right:var(--sp-5)}}.auth-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;background:#080609e0;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);animation:modal-backdrop-in .2s ease-out both}.auth-modal{position:relative;width:min(420px,calc(100vw - 48px));background:#161218e6;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-glass);border-radius:var(--radius-lg);box-shadow:0 0 80px #c4873b0a,0 24px 48px #00000080;padding:40px;animation:modal-panel-in .25s ease-out both}.auth-modal__close{position:absolute;top:var(--sp-4);right:var(--sp-4);background:none;border:none;color:var(--text-muted);font-size:var(--fs-lg);cursor:pointer;padding:var(--sp-1);line-height:1;transition:color var(--transition-fast)}.auth-modal__close:hover{color:var(--text-secondary)}.auth-modal__title{font-size:var(--fs-xl);font-weight:500;color:var(--text-primary)}.auth-modal__subtitle{font-size:var(--fs-base);color:var(--text-secondary);margin-top:var(--sp-1)}.auth-modal__field{margin-top:var(--sp-5)}.auth-modal__label{display:block;font-size:var(--fs-xs);font-weight:500;letter-spacing:.5px;color:var(--text-tertiary);margin-bottom:var(--sp-2)}.auth-modal__input{width:100%;height:44px;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:0 var(--sp-4);color:var(--text-primary);font-size:var(--fs-base);outline:none;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.auth-modal__input:focus{border-color:var(--accent-primary-soft);box-shadow:0 0 0 3px var(--accent-primary-glow)}.auth-modal__input::placeholder{color:var(--text-muted)}.auth-modal__password-wrap{position:relative}.auth-modal__password-wrap .auth-modal__input{padding-right:40px}.auth-modal__password-toggle{position:absolute;right:0;top:0;height:100%;width:36px;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;padding:0}.auth-modal__password-toggle:hover .auth-modal__eq-bars span{opacity:.55}.auth-modal__eq-bars{display:flex;align-items:flex-end;gap:2px;height:10px}.auth-modal__eq-bars span{display:block;width:2px;background:var(--accent-primary);border-radius:1px;opacity:.35;transition:height .25s ease-out,opacity .2s ease}.auth-modal__eq-bars span:nth-child(1){height:6px}.auth-modal__eq-bars span:nth-child(2){height:8px}.auth-modal__eq-bars span:nth-child(3){height:10px}.auth-modal__eq-bars span:nth-child(4){height:7px}.auth-modal__eq-bars span:nth-child(5){height:5px}.auth-modal__eq-bars.auth-modal__eq-bars--flat span{height:2px}.auth-modal__submit{width:100%;height:48px;margin-top:28px;background:var(--accent-primary);color:var(--text-on-accent);font-weight:500;font-size:var(--fs-base);border:none;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.auth-modal__submit:hover{background:var(--accent-primary-soft)}.auth-modal__submit:disabled{cursor:not-allowed}.auth-modal__submit--loading{animation:auth-pulse 1.6s ease-in-out infinite}@keyframes auth-pulse{0%,to{opacity:.45}50%{opacity:.7}}.auth-modal__toggle{margin-top:var(--sp-5);text-align:center;font-size:var(--fs-sm);color:var(--text-secondary)}.auth-modal__toggle-action{color:var(--accent-primary-soft);cursor:pointer;background:none;border:none;font-size:var(--fs-sm);font-weight:500;padding:0;transition:color var(--transition-fast)}.auth-modal__toggle-action:hover{color:var(--accent-primary)}.app-topbar__settings{background:none;border:none;cursor:pointer;padding:2px;color:var(--text-tertiary);transition:color var(--transition-fast);display:flex;align-items:center}.app-topbar__settings:hover{color:var(--text-secondary)}.app-topbar__settings svg{width:16px;height:16px}.ln__settings{background:none;border:none;cursor:pointer;padding:0;color:var(--text-tertiary);transition:color var(--transition-fast);display:flex;align-items:center}.ln__settings:hover{color:var(--text-secondary)}.ln__settings svg{width:16px;height:16px}.settings-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;background:#080609e0;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);animation:modal-backdrop-in .2s ease-out both}.settings-modal{position:relative;width:min(380px,calc(100vw - 48px));max-height:calc(100dvh - 48px);overflow-y:auto;background:#161218e6;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-glass);border-radius:var(--radius-lg);box-shadow:0 0 80px #c4873b0a,0 24px 48px #00000080;padding:40px;animation:modal-panel-in .25s ease-out both}.settings-modal__close{position:absolute;top:var(--sp-4);right:var(--sp-4);background:none;border:none;color:var(--text-muted);font-size:var(--fs-lg);cursor:pointer;padding:var(--sp-1);line-height:1;transition:color var(--transition-fast)}.settings-modal__close:hover{color:var(--text-secondary)}.settings-modal__title{font-size:var(--fs-xl);font-weight:500;color:var(--text-primary)}.settings-modal__section{margin-top:var(--sp-6)}.settings-modal__label{font-size:var(--fs-xs);font-weight:500;letter-spacing:.5px;color:var(--text-tertiary);margin-bottom:var(--sp-3)}.settings-modal__lang-toggle{display:flex;align-items:center;gap:2px}.settings-modal__lang-btn{font-family:inherit;font-size:var(--fs-sm);font-weight:500;color:var(--text-tertiary);background:none;border:none;cursor:pointer;padding:4px 8px;letter-spacing:.03em;transition:color var(--transition-fast)}.settings-modal__lang-btn--active{color:var(--accent-primary)}.settings-modal__lang-btn:hover:not(.settings-modal__lang-btn--active){color:var(--text-secondary)}.settings-modal__lang-sep{font-size:var(--fs-sm);color:var(--text-muted);-webkit-user-select:none;user-select:none}.settings-modal__coming-soon{font-size:var(--fs-sm);color:var(--text-muted)}.settings-modal__plan-name{font-size:var(--fs-base);font-weight:600;color:var(--text-primary);text-transform:lowercase}.settings-modal__plan-usage{font-size:var(--fs-sm);color:var(--text-secondary);margin-top:var(--sp-1)}.settings-modal__divider{border:none;border-top:1px solid var(--border-subtle);margin:var(--sp-5) 0 0}.settings-modal__plan-interval{font-weight:400;color:var(--text-secondary)}.settings-modal__pending-warning{font-size:var(--fs-sm);color:var(--accent-primary-soft);margin-top:var(--sp-2);padding:var(--sp-2) var(--sp-3);background:var(--accent-primary-glass);border-radius:var(--radius-sm);border:1px solid var(--accent-primary-muted)}.settings-modal__interval-toggle{display:flex;align-items:center;gap:2px;margin-top:var(--sp-4)}.settings-modal__interval-btn{font-family:inherit;font-size:var(--fs-sm);font-weight:500;color:var(--text-tertiary);background:none;border:none;cursor:pointer;padding:4px 8px;letter-spacing:.03em;transition:color var(--transition-fast)}.settings-modal__interval-btn--active{color:var(--accent-primary)}.settings-modal__interval-btn:hover:not(.settings-modal__interval-btn--active){color:var(--text-secondary)}.settings-modal__interval-sep{font-size:var(--fs-sm);color:var(--text-muted);-webkit-user-select:none;user-select:none}.settings-modal__annual-hint{font-size:var(--fs-xs);color:var(--accent-primary-soft);margin-left:var(--sp-2)}.settings-modal__plans{display:flex;flex-direction:column;gap:var(--sp-3);margin-top:var(--sp-4)}.settings-modal__plan-card{display:flex;align-items:center;justify-content:space-between;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--sp-3) var(--sp-4);transition:background var(--transition-fast),border-color var(--transition-fast)}.settings-modal__plan-card:hover{background:var(--bg-card-hover);border-color:var(--accent-primary-muted)}.settings-modal__plan-card-info{display:flex;flex-direction:column;gap:2px}.settings-modal__plan-card-name{font-size:var(--fs-base);font-weight:600;color:var(--text-primary);text-transform:lowercase}.settings-modal__plan-card-limit{font-size:var(--fs-xs);color:var(--text-secondary)}.settings-modal__plan-card-action{display:flex;flex-direction:column;align-items:flex-end;gap:var(--sp-1)}.settings-modal__plan-card-price{font-size:var(--fs-sm);font-weight:500;color:var(--text-primary)}.settings-modal__plan-card-suffix{font-weight:400;color:var(--text-tertiary)}.settings-modal__upgrade-btn{font-family:inherit;font-size:var(--fs-xs);font-weight:600;color:var(--text-on-accent);background:var(--accent-primary);border:none;border-radius:var(--radius-sm);padding:var(--sp-1) var(--sp-3);cursor:pointer;transition:background var(--transition-fast),transform var(--transition-fast)}.settings-modal__upgrade-btn:hover{background:var(--accent-primary-soft)}.settings-modal__upgrade-btn:active{transform:scale(.97)}.settings-modal__upgrade-btn:disabled{opacity:.7;cursor:not-allowed}.settings-modal__upgrade-btn--loading{animation:auth-pulse 1.6s ease-in-out infinite}.settings-modal__best-plan{font-size:var(--fs-sm);color:var(--accent-primary-soft);margin-top:var(--sp-3)}.settings-modal__error{font-size:var(--fs-sm);color:var(--accent-score-low);margin-top:var(--sp-3)}.settings-modal__manage-link{display:inline-block;font-family:inherit;font-size:var(--fs-sm);font-weight:500;color:var(--text-tertiary);background:none;border:none;padding:0;margin-top:var(--sp-4);cursor:pointer;transition:color var(--transition-fast)}.settings-modal__manage-link:hover{color:var(--accent-primary-soft)}.settings-backdrop--closing{animation:modal-backdrop-out .2s ease-in forwards}.settings-modal--closing{animation:modal-panel-out .2s ease-in forwards}@keyframes modal-backdrop-out{0%{opacity:1}to{opacity:0}}@keyframes modal-panel-out{0%{opacity:1;transform:scale(1) translateY(0)}to{opacity:0;transform:scale(.97) translateY(8px)}}@media(min-width:1280px){.filter-bar{overflow-x:visible;flex-wrap:wrap;justify-content:space-evenly;padding-bottom:0}}@media(max-width:640px){.auth-modal,.settings-modal{padding:28px 24px}}.sets-section{margin-bottom:var(--sp-2);animation:fade-up .4s ease-out .12s both}.sets-section__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp-2)}.sets-section__header .section-heading{margin:0}.sets-section__new-btn{font-size:var(--fs-sm);font-weight:600;color:var(--accent-primary);background:none;border:1px solid var(--accent-primary-muted);border-radius:var(--radius-sm);padding:var(--sp-1) var(--sp-3);cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast)}.sets-section__new-btn:hover{background:var(--accent-primary-glass);border-color:var(--accent-primary)}.sets-section__create{display:flex;gap:var(--sp-2);margin-bottom:var(--sp-3)}.sets-section__name-input{flex:1;font-size:var(--fs-base);color:var(--text-primary);background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:var(--sp-2) var(--sp-3);outline:none;transition:border-color var(--transition-fast)}.sets-section__name-input:focus{border-color:var(--accent-primary-muted)}.sets-section__name-input::placeholder{color:var(--text-tertiary)}.sets-section__create-btn{font-size:var(--fs-sm);font-weight:600;color:var(--text-on-accent);background:var(--accent-primary);border:none;border-radius:var(--radius-sm);padding:var(--sp-2) var(--sp-4);cursor:pointer;transition:opacity var(--transition-fast)}.sets-section__create-btn:disabled{opacity:.4;cursor:default}.sets-section__list{display:flex;flex-direction:row;gap:var(--sp-2);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:var(--sp-1)}.sets-section__list::-webkit-scrollbar{display:none}.set-card{display:flex;align-items:center;flex-shrink:0;gap:var(--sp-2);background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--sp-2) var(--sp-3);white-space:nowrap;cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast)}.set-card:hover{background:var(--bg-card-hover);border-color:var(--accent-primary-muted)}.set-card__name{flex:1;font-size:var(--fs-base);font-weight:500;color:var(--text-primary);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.set-card__meta{font-size:var(--fs-sm);color:var(--text-secondary);flex-shrink:0}.set-card__delete{font-size:var(--fs-md);line-height:1;color:var(--text-muted);background:none;border:none;padding:var(--sp-1) var(--sp-2);cursor:pointer;border-radius:var(--radius-sm);flex-shrink:0;transition:color var(--transition-fast)}.set-card__delete:hover{color:var(--accent-score-low)}.set-card__info{display:flex;align-items:center;gap:var(--sp-2);flex:1;min-width:0}.set-card__actions{display:flex;align-items:center;gap:0;flex-shrink:0}.set-card__edit{font-size:var(--fs-sm);line-height:1;color:var(--text-muted);background:none;border:none;padding:var(--sp-1) var(--sp-1);cursor:pointer;border-radius:var(--radius-sm);flex-shrink:0;transition:color var(--transition-fast)}.set-card__edit:hover{color:var(--accent-primary-soft)}.set-card--has-session{border-left:2px solid var(--accent-primary)}.set-card--has-session .set-card__meta{color:var(--accent-primary-soft)}.set-card--deleting{opacity:0;transform:scale(.96);transition:opacity .3s ease,transform .3s ease;pointer-events:none}.set-card__confirm{display:flex;align-items:center;gap:var(--sp-3);width:100%}.set-card__confirm-text{flex:1;font-size:var(--fs-sm);color:var(--text-primary);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.set-card__confirm-yes,.set-card__confirm-no{font-size:var(--fs-sm);font-weight:500;border:none;padding:var(--sp-1) var(--sp-3);border-radius:var(--radius-sm);cursor:pointer;flex-shrink:0;transition:opacity var(--transition-fast)}.set-card__confirm-yes{background:var(--accent-score-low);color:var(--text-on-accent)}.set-card__confirm-yes:hover{opacity:.85}.set-card__confirm-no{background:var(--bg-card-hover);color:var(--text-secondary)}.set-card__confirm-no:hover{color:var(--text-primary)}.set-builder .library__live-btn:disabled{opacity:.35;cursor:default}.set-builder__delete-btn{font-size:var(--fs-lg);line-height:1;color:var(--text-muted);background:none;border:none;padding:var(--sp-1) var(--sp-2);cursor:pointer;border-radius:var(--radius-sm);transition:color var(--transition-fast)}.set-builder__delete-btn:hover{color:var(--accent-score-low)}.library-card__actions{display:flex;align-items:center;gap:var(--sp-1);flex-shrink:0}.library-card__favorite{font-size:var(--fs-md);line-height:1;color:var(--text-muted);background:none;border:none;padding:var(--sp-1);cursor:pointer;transition:color var(--transition-fast)}.library-card__favorite:hover{color:var(--accent-primary-soft)}.library-card__favorite--active{color:var(--accent-primary)}.library-card__favorite--active:hover{color:var(--accent-primary-soft)}.library-card__archive{font-size:var(--fs-sm);line-height:1;color:var(--text-muted);background:none;border:none;padding:var(--sp-1);cursor:pointer;transition:color var(--transition-fast)}.library-card__archive:hover{color:var(--text-secondary)}.library-card--favorite{border-left:2px solid var(--accent-primary)}.library-card--archived{opacity:.45}.library-card--archived:hover{opacity:.65}.library-card--in-set{border-color:var(--accent-primary-muted);background:#c4873b0a}.library-card--in-set:after{content:"✓";position:absolute;top:var(--sp-3);right:var(--sp-3);font-size:var(--fs-sm);font-weight:700;color:var(--accent-primary)}.library-card--in-set{position:relative}.section-heading-row{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-3);animation:fade-up .4s ease-out .16s both}.section-heading-row .section-heading,.sets-section .section-heading{animation:none}.section-heading-row__actions{display:flex;align-items:center;gap:var(--sp-2)}.library__archive-toggle{font-size:var(--fs-xs);color:var(--text-tertiary);background:none;border:none;cursor:pointer;padding:var(--sp-1) var(--sp-2);transition:color var(--transition-fast)}.library__archive-toggle:hover{color:var(--text-secondary)}
