:root{--bg:#0a0a0f;--surface:#14141f;--surface2:#1e1e2e;--accent:#7c3aed;--accent-hover:#6d28d9;--text:#f4f4f5;--muted:#a1a1aa;--border:#27272a;--danger:#ef4444;--success:#22c55e}*{box-sizing:border-box;margin:0;padding:0}body,html{max-width:100vw;min-height:100vh;background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif}a{color:var(--accent);text-decoration:none}button{cursor:pointer;font:inherit}input,textarea{font:inherit;background:var(--surface2);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:.6rem .75rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.6rem 1rem;border-radius:8px;border:none;background:var(--accent);color:white;font-weight:600}.btn:hover{background:var(--accent-hover)}.btn-secondary{background:var(--surface2);color:var(--text);border:1px solid var(--border)}.btn-danger{background:var(--danger)}.card{border:1px solid var(--border);border-radius:12px;padding:1rem}.card,.tabs{background:var(--surface)}.tabs{display:flex;gap:0;border-top:1px solid var(--border);position:fixed;bottom:0;left:0;right:0;z-index:100}.tab{flex:1 1;padding:.85rem;text-align:center;color:var(--muted);border:none;background:transparent;font-weight:500}.tab.active{color:var(--accent);border-top:2px solid var(--accent)}.app-shell{padding-bottom:4rem;min-height:100vh}.page{padding:1rem;max-width:720px;margin:0 auto}.page.mixer-page{max-width:min(1280px,calc(100vw - 2rem))}.mixer-header{margin-bottom:1rem}.mixer-header input[style]{font-size:1.25rem;font-weight:700;width:100%;margin-bottom:.5rem}.mixer-header__toolbar{display:flex;align-items:center;gap:.75rem;width:100%}.mixer-header__actions{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;flex:1 1;min-width:0}.mixer-header__delete{margin-left:auto;flex-shrink:0}.mixer-message{margin-top:.5rem}.mixer-section-title{font-size:.95rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin:1.25rem 0 .65rem}.timeline-editor{margin-bottom:.5rem;width:100%}.timeline-editor__toolbar{display:flex;align-items:center;margin-bottom:.4rem}.timeline-editor__length{font-size:.75rem}.timeline-editor__frame{--timeline-label-w:172px;--timeline-label-w-wide:320px;--timeline-row-ruler:28px;--timeline-row-collapsed:40px;--timeline-row-expanded:300px;display:flex;width:100%;border:1px solid var(--border);border-radius:10px;background:var(--surface);overflow:hidden}.timeline-metro-mute{padding:0 .45rem}.timeline-editor__hint{font-size:.7rem}.timeline-editor__labels{flex-shrink:0;width:var(--timeline-label-w);display:flex;flex-direction:column;border-right:1px solid var(--border);background:var(--surface2);transition:width .15s ease}.timeline-editor__labels--wide{width:var(--timeline-label-w-wide)}.timeline-editor__row{flex-shrink:0;box-sizing:border-box;border-bottom:1px solid var(--border)}.timeline-editor__row--metro,.timeline-editor__row--ruler{height:var(--timeline-row-ruler)}.timeline-editor__row--metro{display:flex;align-items:center}.timeline-editor__row--collapsed{height:var(--timeline-row-collapsed)}.timeline-editor__row--expanded{height:var(--timeline-row-expanded)}.timeline-editor__ruler-spacer{background:var(--surface2)}.timeline-editor__controls{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem}.timeline-chip{display:inline-flex;align-items:center;gap:.35rem;height:1.75rem;padding:0 .45rem;border:1px solid var(--border);border-radius:6px;background:var(--surface2);font-size:.68rem;color:var(--muted)}.timeline-chip__label{font-weight:600;letter-spacing:.02em;text-transform:uppercase;font-size:.6rem;flex-shrink:0}.timeline-chip--bpm input,.timeline-meter__field{border:none;background:transparent;color:var(--text);font-size:.75rem;font-weight:600;padding:0;min-height:0}.timeline-chip--bpm .timeline-bpm-input,.timeline-chip--bpm input{width:2.75rem;text-align:right}.timeline-chip--bpm input[type=number]::-webkit-inner-spin-button,.timeline-chip--bpm input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.timeline-chip--bpm input[type=number]{-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}.timeline-chip--bpm input:focus,.timeline-meter__field:focus{outline:none}.timeline-meter{gap:.1rem;padding-right:.3rem}.timeline-meter__field{width:2rem;text-align:center;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;color:var(--text);background-color:var(--surface2);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='5' viewBox='0 0 8 5'%3E%3Cpath fill='%23a1a1aa' d='M0 0l4 5 4-5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 0 center;padding:0 .55rem 0 0}.timeline-meter__field option{background-color:var(--surface);color:var(--text)}.timeline-meter__slash{color:var(--muted);font-weight:600;font-size:.7rem;line-height:1;-webkit-user-select:none;-moz-user-select:none;user-select:none}.timeline-chip--btn{justify-content:center;min-width:1.75rem;padding:0 .4rem;cursor:pointer;color:var(--muted)}.timeline-chip--btn:hover{color:var(--text);border-color:var(--muted)}.timeline-chip--btn-on{color:var(--text);border-color:rgba(124,58,237,.55);background:rgba(124,58,237,.15)}.timeline-chip--zoom{gap:.4rem;padding-right:.5rem}.timeline-chip--zoom input[type=range].timeline-zoom-slider{width:88px;height:14px;margin:0;padding:0;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent}.timeline-chip--zoom .timeline-zoom-slider::-webkit-slider-runnable-track{height:4px;border-radius:2px;background:rgba(63,63,70,.9)}.timeline-chip--zoom .timeline-zoom-slider::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;margin-top:-4px;border-radius:50%;border:none;background:var(--accent);box-shadow:0 0 0 1px rgba(0,0,0,.25)}.timeline-chip--zoom .timeline-zoom-slider::-moz-range-track{height:4px;border-radius:2px;background:rgba(63,63,70,.9);border:none}.timeline-chip--zoom .timeline-zoom-slider::-moz-range-thumb{width:12px;height:12px;border:none;border-radius:50%;background:var(--accent);box-shadow:0 0 0 1px rgba(0,0,0,.25)}.timeline-editor__track-label{padding:0;display:flex;align-items:stretch;font-size:.8rem;font-weight:600;overflow:hidden;background:var(--surface2)}.timeline-editor__track-label.timeline-editor__row--expanded{overflow:hidden;min-height:var(--timeline-row-expanded)}.timeline-editor__track-label--recording{background:rgba(239,68,68,.08)}.timeline-editor__metro-label{display:flex;align-items:center;justify-content:space-between;gap:.35rem;padding:0 .5rem;color:var(--muted);font-size:.72rem;font-weight:600}.timeline-metro-mute-btn{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;width:1.65rem;height:1.65rem;padding:0;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--muted);cursor:pointer}.timeline-metro-mute-btn:hover{color:var(--text);border-color:var(--muted)}.timeline-metro-mute-btn--on{color:var(--text);border-color:rgba(124,58,237,.55);background:rgba(124,58,237,.15)}.timeline-editor__labels .timeline-editor__row:last-child{border-bottom:none}.timeline-track-panel{width:100%;min-width:0}.timeline-track-panel--collapsed{height:100%;display:flex;align-items:center;gap:.35rem;min-width:0}.timeline-track-panel__stop-collapsed{flex-shrink:0;margin-left:auto}.timeline-track-panel__rec-quick{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:1.6rem;border:none;border-left:1px solid var(--border);background:transparent;color:var(--muted);cursor:pointer}.timeline-track-panel__rec-quick:hover:not(:disabled){color:var(--danger);background:rgba(239,68,68,.08)}.timeline-track-panel__rec-quick:disabled{opacity:.35;cursor:not-allowed}.timeline-track-panel__chevron{flex-shrink:0;display:flex;align-items:center;color:var(--muted)}.timeline-track-panel__select:hover .timeline-track-panel__chevron{color:var(--accent)}.timeline-track-panel__select{display:flex;align-items:center;gap:.4rem;flex:1 1;min-width:0;height:100%;padding:0 .6rem;border:none;background:transparent;color:var(--text);font:inherit;font-size:.85rem;font-weight:600;line-height:1.2;text-align:left;cursor:pointer}.timeline-track-panel__select:hover{background:rgba(124,58,237,.12)}.timeline-track-panel__name{flex:1 1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.2}.timeline-track-panel__badge{flex-shrink:0;font-size:.6rem;padding:.1rem .35rem;border-radius:999px;background:rgba(124,58,237,.35);color:#ede9fe}.timeline-track-panel__muted-dot,.timeline-track-panel__rec-dot{flex-shrink:0;width:6px;height:6px;border-radius:50%}.timeline-track-panel__muted-dot{background:var(--muted)}.timeline-track-panel__rec-dot{background:var(--danger);animation:timeline-rec-pulse 1s ease-in-out infinite}.timeline-track-panel--expanded{position:relative;flex:1 1;min-height:0;width:100%;padding:.45rem .55rem .55rem;display:flex;flex-direction:column;gap:.45rem;overflow-x:hidden;overflow-y:auto;overscroll-behavior:contain}.timeline-track-panel__header{display:flex;align-items:center;gap:.3rem}.timeline-track-panel__collapse{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:1.5rem;height:1.5rem;padding:0;border:none;border-radius:4px;background:var(--surface);color:var(--muted);cursor:pointer}.timeline-track-panel__collapse:hover{color:var(--text);background:var(--bg)}.timeline-track-panel__name-input{flex:1 1;min-width:0;font-size:.8rem;font-weight:700}.timeline-track-panel__actions{display:flex;flex-wrap:wrap;gap:.3rem}.timeline-track-panel__actions .mixer-btn span{font-size:.65rem}.timeline-track-panel__volume{display:grid;grid-template-columns:auto 1fr auto;align-items:center;grid-gap:.35rem;gap:.35rem;font-size:.68rem;color:var(--muted)}.timeline-track-panel__volume .slider{width:100%}.timeline-track-panel__vol-pct{font-size:.65rem;min-width:2rem;text-align:right}.timeline-track-panel--expanded .fx-panel{margin:0}.timeline-track-panel--expanded .fx-rack{grid-template-columns:1fr;gap:.45rem}.timeline-track-panel--expanded .fx-column{gap:.3rem}.timeline-track-panel--expanded .fx-toggle{flex-direction:row;justify-content:flex-start;height:auto;min-height:2.25rem;padding:.35rem .45rem;gap:.4rem}.timeline-track-panel--expanded .fx-toggle__label{font-size:.7rem}.timeline-track-panel--expanded .fx-slider{height:6px;margin-top:.15rem}.timeline-track-panel__record-row .btn--compact{width:100%;font-size:.75rem;padding:.45rem .5rem}.timeline-track-panel__delete{display:inline-flex;align-items:center;gap:.25rem;padding:0;border:none;background:none;color:var(--muted);font-size:.68rem;cursor:pointer}.timeline-track-panel__delete:hover{color:var(--danger)}.btn--compact{font-size:.8rem;padding:.45rem .65rem}.timeline-editor__scroll{flex:1 1;min-width:0;overflow-x:auto;overflow-y:hidden;scrollbar-width:thin;scrollbar-color:var(--border) var(--surface2)}.timeline-editor__scroll::-webkit-scrollbar{height:10px}.timeline-editor__scroll::-webkit-scrollbar-track{background:var(--surface2);border-radius:0 0 6px 6px}.timeline-editor__scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:5px;border:2px solid var(--surface2)}.timeline-editor__scroll::-webkit-scrollbar-thumb:hover{background:var(--muted)}.timeline-editor__canvas{position:relative;min-width:100%;display:flex;flex-direction:column}.timeline-editor__playhead{position:absolute;top:0;bottom:0;width:2px;margin-left:-1px;background:#fbbf24;box-shadow:0 0 8px rgba(251,191,36,.6);z-index:20;pointer-events:none}.timeline-editor__grid{position:absolute;inset:0;pointer-events:none}.timeline-editor__grid-line{position:absolute;top:0;bottom:0;width:1px;background:rgba(63,63,70,.55)}.timeline-editor__grid-line--bar{width:2px;background:rgba(124,58,237,.35)}.timeline-editor__ruler{position:relative;flex-shrink:0;background:var(--surface2);z-index:5}.timeline-editor__tick{position:absolute;top:0;height:100%;border-left:1px solid rgba(63,63,70,.8);padding-left:3px;font-size:.6rem;color:var(--muted);pointer-events:none}.timeline-editor__tick--bar{border-left-color:rgba(167,139,250,.55);color:#c4b5fd;font-weight:600}.timeline-editor__tick span{display:inline-block;margin-top:6px}.timeline-editor__lane{position:relative;flex-shrink:0;background:var(--surface)}.timeline-editor__lane--expanded .timeline-editor__clip:not(.timeline-editor__clip--compact){top:12px;height:72px;border-radius:8px}.timeline-editor__canvas>.timeline-editor__row:last-child{border-bottom:none}.timeline-editor__lane--recording{background-color:rgba(239,68,68,.06)}.timeline-editor__lane.timeline-editor__row--metro{background:rgba(124,58,237,.06)}.timeline-editor__beat{position:absolute;top:0;bottom:0;width:1px;background:rgba(124,58,237,.2);pointer-events:none}.timeline-editor__clip--compact{top:50%;height:12px;margin-top:-6px;border-radius:3px;padding:0;min-width:2px;box-shadow:none;border-width:1px}.timeline-editor__clip--compact.timeline-editor__clip--recording{margin-top:-6px;min-height:12px}.timeline-editor__clip{position:absolute;top:6px;height:32px;z-index:10;cursor:-webkit-grab;cursor:grab;touch-action:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;border-radius:6px;background:linear-gradient(180deg,rgba(124,58,237,.55),rgba(124,58,237,.35));border:1px solid rgba(167,139,250,.6);box-shadow:inset 0 1px 0 rgba(255,255,255,.12);overflow:hidden;display:flex;align-items:center;justify-content:space-between;gap:4px;padding:0 6px;font-size:.65rem;font-weight:600;color:#ede9fe;min-width:4px}.timeline-editor__clip:active{cursor:-webkit-grabbing;cursor:grabbing}.timeline-editor__clip--recording{background:linear-gradient(90deg,rgba(239,68,68,.5),rgba(239,68,68,.2));border-color:var(--danger);animation:timeline-rec-pulse 1.2s ease-in-out infinite}@keyframes timeline-rec-pulse{50%{opacity:.65}}.timeline-editor__clip-end,.timeline-editor__clip-start{flex-shrink:0;opacity:.85}.timeline-editor__clip-dur{flex:1 1;text-align:center;opacity:.7;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.timeline-editor__clip--narrow .timeline-editor__clip-end,.timeline-editor__clip--narrow .timeline-editor__clip-start{display:none}.timeline-editor__clip--narrow .timeline-editor__clip-dur{width:100%;text-align:center}.timeline-editor__footer{display:flex;align-items:center;gap:.75rem;margin-top:.65rem;padding-top:.5rem;border-top:1px solid var(--border)}.timeline-editor__add-track{font-size:.85rem}.timeline-editor__track-count{font-size:.75rem}.timeline-editor__empty{margin-top:.5rem;font-size:.8rem}.confirm-dialog-backdrop{position:fixed;inset:0;z-index:300;display:flex;align-items:center;justify-content:center;padding:1rem;background:rgba(0,0,0,.55)}.confirm-dialog{width:min(100%,22rem);padding:1.1rem 1.15rem;border-radius:10px;border:1px solid var(--border);background:var(--surface);box-shadow:0 12px 40px rgba(0,0,0,.45)}.confirm-dialog h3{margin:0 0 .5rem;font-size:1.05rem}.confirm-dialog h3.save-public-heading{display:flex;align-items:center;gap:.45rem}.confirm-dialog p{margin:0 0 1rem;font-size:.875rem;line-height:1.45}.confirm-dialog__actions{display:flex;justify-content:flex-end;gap:.5rem}.confirm-dialog.title-required{border:2px solid #ef4444;background:#1a0a0a}.confirm-dialog.title-required h3{color:#ef4444;font-weight:800;text-align:center}.confirm-dialog.title-required .title-required-message{color:#fecaca;font-weight:600;font-size:1.05rem;text-align:center}.confirm-dialog.title-required .title-required-hint{margin-top:.65rem;text-align:center}.confirm-dialog.title-required .confirm-dialog__actions{justify-content:center;margin-top:.25rem}.confirm-dialog.title-required .btn-title-required-ok{min-width:7rem;font-weight:700}.confirm-dialog.latency-calibration{width:min(100%,32rem)}.latency-calibration__steps{margin:0 0 1rem 1.1rem;padding:0;font-size:.85rem;line-height:1.5}.latency-calibration__steps li{margin-bottom:.35rem}.confirm-dialog.latency-calibration .confirm-dialog__actions{flex-wrap:wrap}.latency-calibration__slider-block label{display:block;margin-bottom:.35rem;font-size:.875rem}.latency-calibration__slider-block input[type=range]{width:100%;margin:.25rem 0 .5rem}.latency-calibration__device,.latency-calibration__hint{margin:0 0 .75rem;font-size:.8rem}.profile-tabs{display:flex;gap:.35rem;margin:0 0 1rem;border-bottom:1px solid var(--border)}.profile-tabs__tab{padding:.5rem .85rem;font-size:.9rem;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--muted);cursor:pointer;margin-bottom:-1px}.profile-tabs__tab--active{color:var(--text);border-bottom-color:var(--accent);font-weight:600}.mic-calibration h2{margin:0 0 .5rem;font-size:1.1rem}.mic-calibration__melody,.mic-calibration__status{margin:0 0 .75rem;font-size:.875rem}.mic-calibration__actions{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}.mic-calibration__open{width:100%;margin:.5rem 0 1rem}.mic-calibration__fine-tune{margin-top:.25rem;padding-top:1rem;border-top:1px solid var(--border)}.mic-calibration__save-nudge{margin-top:.5rem}.mic-calibration__saved{margin:0 0 .5rem;font-size:.85rem;color:var(--accent)}.mic-prompt-backdrop{z-index:120}.confirm-dialog.mic-prompt{width:min(100%,24rem);text-align:center;padding:1.35rem 1.25rem 1.1rem}.mic-prompt__icon{width:4.5rem;height:4.5rem;margin:0 auto .75rem;display:block}.confirm-dialog.mic-prompt h3{margin-bottom:.35rem}.mic-prompt__steps{margin:0 0 1rem;padding:0 0 0 1.15rem;text-align:left;font-size:.875rem;line-height:1.5;color:var(--text)}.mic-prompt__steps li{margin-bottom:.4rem}.mic-prompt__hint{margin:0 0 .75rem;font-size:.85rem;color:var(--accent)}.mic-prompt__actions{justify-content:center;flex-wrap:wrap}.mic-prompt__footer{margin:.75rem 0 0;font-size:.75rem}.save-menu-wrap{position:relative}.save-menu{position:absolute;top:calc(100% + .35rem);left:0;z-index:120;min-width:13.5rem;padding:.35rem 0;border-radius:8px;border:1px solid var(--border);background:var(--surface);box-shadow:0 8px 24px rgba(0,0,0,.45)}.save-menu__item{display:flex;align-items:center;gap:.55rem;width:100%;padding:.55rem .85rem;border:none;background:transparent;color:inherit;font:inherit;text-align:left;cursor:pointer}.save-menu__item:hover:not(:disabled){background:rgba(255,255,255,.06)}.save-menu__item:disabled{opacity:.55;cursor:not-allowed}.save-menu__item span{display:flex;flex-direction:column;gap:.1rem}.save-menu__item strong{font-size:.875rem;font-weight:600}.save-menu__item small{font-size:.72rem;color:var(--muted,#888)}.save-share-description{display:flex;flex-direction:column;gap:.35rem;margin:1rem 0 0}.save-share-description__label{font-size:.85rem;color:#a1a1aa}.save-share-description__input{width:100%;resize:vertical;min-height:4.5rem;padding:.5rem .65rem;border-radius:8px;border:1px solid #3f3f46;background:#18181b;color:#fff;font:inherit}.save-share-description__count{text-align:right;font-size:.75rem}.save-share-options{display:flex;flex-direction:column;gap:.5rem;margin:0 0 .85rem}.save-share-option{display:flex;align-items:flex-start;gap:.5rem;padding:.55rem .65rem;border-radius:8px;border:1px solid var(--border);cursor:pointer}.save-share-option>span{display:flex;flex-direction:column;align-items:flex-start;gap:.4rem}.save-share-option strong{display:block;line-height:1.2}.save-share-option small{display:block;line-height:1.35}.save-share-option:has(input:checked){border-color:var(--accent,#6b8cff);background:rgba(107,140,255,.08)}.save-share-friends-panel{margin:0 0 .85rem}.save-share-friends-search{width:100%;box-sizing:border-box;margin:0 0 .75rem;padding:.5rem .65rem;font-size:.875rem;color:var(--text);background:var(--surface2,#18181b);border:1px solid var(--border);border-radius:8px}.save-share-section-title{margin:0 0 .15rem;font-size:.8rem;font-weight:700;color:var(--text)}.save-share-section-hint{margin:0 0 .45rem;font-size:.72rem}.save-share-friends-list-section{margin-top:.65rem}.save-share-best-friends{margin-bottom:.5rem}.save-share-best-friends__list{display:flex;flex-wrap:wrap;gap:.4rem}.save-share-best-friends__list .save-share-friend{border:1px solid var(--border);border-radius:999px;padding:.35rem .75rem}.save-share-best-friends__list .save-share-friend:has(input:checked){border-color:var(--accent,#6b8cff);background:rgba(107,140,255,.12)}.save-share-friends-error{color:#ef4444!important}.save-share-search-hint{margin:.35rem 0 0;font-size:.75rem}.save-share-friends{max-height:11rem;overflow-y:auto;margin:0;padding:.35rem 0;border:1px solid var(--border);border-radius:8px}.save-share-friend{display:flex;align-items:center;gap:.5rem;padding:.4rem .65rem;cursor:pointer;font-size:.875rem}.save-share-friend:hover{background:rgba(255,255,255,.04)}.track-context-menu{position:fixed;z-index:200;min-width:160px;padding:.35rem 0;background:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:0 8px 24px rgba(0,0,0,.45)}.track-context-menu__title{padding:.35rem .75rem;font-size:.7rem;font-weight:600;color:var(--muted);border-bottom:1px solid var(--border);margin-bottom:.25rem}.track-context-menu__item{display:block;width:100%;text-align:left;padding:.5rem .75rem;border:none;background:transparent;color:var(--text);font:inherit;cursor:pointer}.track-context-menu__item:hover{background:var(--surface2)}.track-context-menu__item--danger{color:var(--danger)}.track-context-menu__note{padding:.5rem .75rem;font-size:.75rem}.track-context-menu--with-nudge .track-context-menu__title{margin-bottom:0}.track-context-menu__nudge{padding:.5rem .6rem .55rem;background:rgba(124,58,237,.08)}.track-context-menu__nudge-label{margin:0 0 .4rem;padding:0 .15rem;font-size:.65rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);text-align:center}.track-context-menu__nudge-row{display:flex;gap:.35rem}.track-context-menu__item--nudge{flex:1 1;text-align:center;padding:.45rem .35rem;font-size:.8rem;border:1px solid var(--border);border-radius:6px;background:var(--surface2)}.track-context-menu__item--nudge:hover{background:rgba(124,58,237,.12)}.track-context-menu__divider{height:1px;background:var(--border);margin:0}.track-context-menu__actions{padding:.2rem 0}.muted{color:var(--muted);font-size:.875rem}.track-row{display:grid;grid-template-columns:minmax(100px,120px) 1fr auto;grid-gap:.75rem;gap:.75rem;align-items:start;padding:.85rem;background:var(--surface2);border:1px solid var(--border);border-radius:10px;margin-bottom:.6rem}.track-row--recording{border-color:var(--danger);box-shadow:0 0 0 1px rgba(239,68,68,.35)}.track-name-col{display:flex;flex-direction:column;min-width:0}.track-name-input{width:100%;font-weight:700;font-size:.9rem;padding:.45rem .5rem;margin-bottom:0}.track-mixer{gap:.5rem}.track-mixer,.track-transport{display:flex;flex-direction:column}.track-transport{align-items:stretch;gap:.35rem;min-width:88px}.mixer-btn-row{display:flex;gap:.35rem}.mixer-btn{display:inline-flex;align-items:center;justify-content:center;gap:.25rem;padding:.4rem .55rem;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--muted);font-size:.7rem;font-weight:600}.mixer-btn:hover{color:var(--text);border-color:var(--muted)}.mixer-btn--on{background:rgba(124,58,237,.25);border-color:var(--accent);color:var(--text)}.btn-danger,.mixer-btn--danger.mixer-btn--on{background:var(--danger);border-color:var(--danger);color:#fff}.fx-panel,.fx-rack{width:100%}.fx-rack{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:.5rem;gap:.5rem}.fx-column{align-items:stretch;gap:.35rem;min-width:0}.fx-column,.fx-toggle{display:flex;flex-direction:column}.fx-toggle{align-items:center;justify-content:center;gap:.2rem;height:64px;width:100%;padding:.35rem;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--muted);box-sizing:border-box}.fx-toggle:hover{color:var(--text);border-color:var(--muted)}.fx-toggle--on{color:var(--accent);border-color:var(--accent);background:rgba(124,58,237,.12);box-shadow:none}.fx-toggle__label{font-size:.6rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;line-height:1}.fx-slider{width:100%;margin:0;opacity:1}.fx-slider:disabled{opacity:.35}.track-header-actions{display:flex;gap:.35rem;margin-top:.4rem}.track-delete-btn{margin-top:.5rem;padding:.35rem .5rem;font-size:.7rem;border-radius:6px;border:1px solid var(--border);background:transparent;color:var(--muted);display:inline-flex;align-items:center;gap:.25rem}.track-delete-btn:hover{color:var(--danger);border-color:var(--danger)}.slider{width:100%;accent-color:var(--accent)}.vol-label{display:flex;justify-content:space-between;font-size:.7rem;color:var(--muted);margin-bottom:.15rem}.profile-card{overflow:hidden;position:relative}.profile-header{display:flex;gap:1.25rem;align-items:flex-start;flex-wrap:wrap}.profile-edit-btn{position:absolute;top:.75rem;right:.75rem;z-index:1;border:none;background:transparent;color:var(--accent);font-size:1.25rem;line-height:1;cursor:pointer;padding:.25rem .35rem}.profile-edit-btn:hover{opacity:.85}.profile-avatar-wrap{display:flex;flex-direction:column;align-items:center;gap:.5rem;flex-shrink:0}.profile-avatar{width:88px;height:88px;border-radius:50%;object-fit:cover;border:2px solid var(--border)}.profile-avatar--placeholder{display:flex;align-items:center;justify-content:center;background:var(--surface2);color:var(--muted);font-size:2rem;font-weight:700}.profile-avatar-btn{font-size:.75rem;color:var(--accent);cursor:pointer;text-align:center}.profile-avatar-btn:hover{text-decoration:underline}.profile-fields{flex:1 1;min-width:200px}.profile-fields textarea{width:100%;margin-top:.5rem}.profile-actions{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}.profile-message{margin-bottom:1rem}.profile-songs-header{margin-bottom:.75rem}.profile-songs-header h2{margin-bottom:.25rem}.song-list{list-style:none}.song-card{margin-bottom:.5rem}.song-card-top{display:flex;justify-content:space-between;gap:.75rem;align-items:flex-start}.song-card-actions{display:flex;gap:.35rem;flex-shrink:0}.song-title{display:block;margin-top:.35rem}.song-audio{width:100%;margin-top:.75rem}.song-badges{display:inline-flex;gap:.35rem;flex-wrap:wrap}.song-badge{display:inline-block;font-size:.65rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:.15rem .45rem;border-radius:4px;line-height:1.3}.song-badge--saved{background:rgba(34,197,94,.15);color:var(--success);border:1px solid rgba(34,197,94,.35)}.song-badge--published{background:rgba(124,58,237,.15);color:#c4b5fd;border:1px solid rgba(124,58,237,.35)}.song-badge--friends{background:rgba(124,58,237,.12);color:#c4b5fd;border:1px solid rgba(124,58,237,.4)}.post-friends-share-btn{display:inline-flex;align-items:center;margin:.35rem 0 .5rem;padding:.35rem .65rem;font-size:.75rem;font-weight:600;color:#c4b5fd;background:rgba(124,58,237,.15);border:1px solid rgba(124,58,237,.45);border-radius:6px;cursor:pointer}.post-friends-share-btn:hover{background:rgba(124,58,237,.28)}.post-audience-dialog__hint{margin:0 0 .75rem;font-size:.85rem}.post-audience-list{list-style:none;margin:0 0 1rem;padding:0;max-height:14rem;overflow-y:auto;border:1px solid var(--border);border-radius:8px}.post-audience-list li{padding:.55rem .75rem;border-bottom:1px solid var(--border);font-weight:600}.post-audience-list li:last-child{border-bottom:none}.feed-card__main .post-friends-share-btn{margin-top:.25rem}.song-badge--remix{background:rgba(251,191,36,.12);color:#fbbf24;border:1px solid rgba(251,191,36,.35)}.profile-song-tabs{display:flex;gap:.5rem;margin:.75rem 0 1rem}.profile-song-tab{flex:1 1;padding:.5rem .75rem;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--muted);font-weight:600;font-size:.875rem;cursor:pointer}.profile-song-tab--active{border-color:#7c3aed;background:rgba(124,58,237,.12);color:#e9d5ff}.discover-top-bar{display:grid;grid-template-columns:3rem 1fr 3rem;align-items:center;margin-bottom:1.25rem;padding-top:.5rem}.discover-top-bar__side{width:3rem}.discover-top-bar__side--end{display:flex;justify-content:flex-end}.discover-brand{margin:0;text-align:center;font-size:1.65rem;font-weight:800;letter-spacing:.2em;color:var(--text,#fff)}.discover-bell{position:relative;display:flex;align-items:center;justify-content:center;width:2.75rem;height:2.75rem;border-radius:12px;border:1px solid var(--border,#27272a);background:var(--surface-2,#1e1e2e);cursor:pointer;color:#a78bfa;padding:0}.discover-bell__icon{display:block}.discover-bell__badge{position:absolute;top:.15rem;right:.15rem;min-width:1.1rem;height:1.1rem;padding:0 .25rem;border-radius:999px;background:#ef4444;color:#fff;font-size:.65rem;font-weight:800;display:flex;align-items:center;justify-content:center}.notif-overlay{position:fixed;inset:0;z-index:100;display:flex;align-items:flex-end;justify-content:center}.notif-overlay__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.55);border:none;cursor:pointer}.notif-panel{position:relative;z-index:1;width:min(100%,28rem);max-height:85vh;overflow:auto;background:#14141f;border:1px solid #27272a;border-radius:1rem 1rem 0 0;padding:1.25rem;margin:0 auto}.notif-panel__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.notif-panel__header h2{margin:0;font-size:1.25rem}.notif-mark-all{background:none;border:none;color:#a78bfa;font-weight:600;cursor:pointer;font-size:.85rem}.notif-list{list-style:none;margin:0;padding:0}.notif-item{display:block;width:100%;text-align:left;padding:.75rem 0;border:none;border-bottom:1px solid #27272a;background:transparent;color:#fff;cursor:pointer;font-size:.9rem;line-height:1.4}.notif-item--unread{background:rgba(124,58,237,.08)}.notif-item__hint{display:block;margin-top:.25rem;font-size:.75rem;color:#71717a}.notif-close{width:100%;margin-top:.75rem}.likers-list{list-style:none;margin:.5rem 0;padding:0}.likers-list li{padding:.5rem 0;border-bottom:1px solid #27272a;color:#fff;font-weight:600}.btn-liked{border-color:#a78bfa!important;background:rgba(124,58,237,.2)!important;color:#a78bfa!important}.btn-icon{display:inline-flex;align-items:center;justify-content:center;min-width:2.75rem;padding-left:.65rem;padding-right:.65rem}.timeline-track-panel__name--locked{display:inline-flex;align-items:center;gap:.35rem;color:#c4b5fd;font-weight:600;cursor:default}.discover-heading,.feed-mode-tabs{margin-bottom:.75rem}.feed-mode-tabs{display:flex;gap:.5rem}.feed-mode-tab{flex:1 1;padding:.55rem .75rem;border-radius:8px;border:1px solid var(--border);background:var(--surface2);color:var(--muted);font-weight:600}.feed-mode-tab.active{background:var(--accent);border-color:var(--accent);color:white}.feed-mode-desc{margin-bottom:1rem}.feed-list{list-style:none;margin-bottom:2rem}.feed-card{margin-bottom:.75rem;display:flex;flex-direction:column;gap:.75rem}@media (min-width:520px){.feed-card{flex-direction:row;justify-content:space-between;align-items:flex-start}}.feed-card__main{flex:1 1;min-width:0}.feed-card__header{display:flex;align-items:center;gap:.65rem}.feed-card__header-text{flex:1 1;min-width:0}.feed-card__avatar{width:44px;height:44px;border-radius:50%;object-fit:cover;flex-shrink:0}.feed-card__avatar--placeholder{display:flex;align-items:center;justify-content:center;background:var(--surface2);color:var(--muted);font-weight:700;font-size:1.1rem}.feed-card__title{display:block;font-size:1rem}.feed-card__username{margin:.15rem 0 0;font-size:.9rem}.feed-card__description{margin:.35rem 0 0;color:#d4d4d8;font-size:.95rem;line-height:1.45;white-space:pre-wrap}.feed-card__meta{margin-top:.25rem}.feed-card__audio{width:100%;margin-top:.5rem;max-height:32px}.feed-card__actions{display:flex;flex-direction:column;gap:.5rem;flex-shrink:0}.feed-empty{margin-bottom:1.5rem}.find-friends{margin-bottom:1.25rem;padding-bottom:1.25rem;border-bottom:1px solid var(--border)}.find-friends__title{margin-bottom:.25rem;font-size:1.1rem}.find-friends__hint{margin-bottom:.75rem}.find-friends__search{width:100%;margin-bottom:.75rem}.find-friends__message{margin-bottom:.5rem}.user-list{list-style:none}.user-row{justify-content:space-between;margin-bottom:.5rem}.user-row,.user-row__profile{display:flex;align-items:center;gap:.75rem}.user-row__profile{flex:1 1;min-width:0;color:inherit;text-decoration:none}.user-row__profile:hover strong{color:var(--accent)}.user-row__avatar{width:44px;height:44px;border-radius:50%;object-fit:cover;flex-shrink:0}.user-row__avatar--placeholder{display:flex;align-items:center;justify-content:center;background:var(--surface2);color:var(--muted);font-weight:700}.user-row__info{min-width:0}.user-row__bio{font-size:.85rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-page{padding-bottom:5rem}.admin-center__header{margin-bottom:1.25rem}.admin-center__header h1{font-size:1.35rem;margin-bottom:.35rem}.admin-center__search-label{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.5rem;max-width:28rem}.admin-center__search{width:100%;padding:.55rem .75rem;border-radius:8px;border:1px solid var(--border,#27272a);background:var(--surface-elevated,#1e1e2e);color:inherit;font-size:.95rem}.admin-center__search-count{margin-bottom:.75rem;font-size:.85rem}.admin-center__username-link{font-weight:700;color:var(--accent,#a78bfa);text-decoration:underline;text-underline-offset:2px}.admin-center__username-link:hover{color:#c4b5fd}.admin-center__setup{margin-bottom:1rem;padding:.85rem 1rem;border-radius:8px;border:1px solid rgba(251,191,36,.45);background:rgba(251,191,36,.08);font-size:.85rem;line-height:1.45}.admin-center__setup strong{display:block;margin-bottom:.35rem}.admin-center__setup-steps{margin:.5rem 0 .5rem 1.1rem;padding:0}.admin-center__setup code{font-size:.8em}.admin-center__setup-code{margin:.5rem 0;padding:.5rem .65rem;border-radius:6px;background:var(--surface2);border:1px solid var(--border);word-break:break-all}.admin-center__diag{margin-top:.5rem;font-size:.75rem;font-family:ui-monospace,monospace}.admin-center__message{margin-bottom:.75rem}.admin-center__error{color:var(--danger);margin-bottom:.75rem}.admin-center__table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:10px;background:var(--surface)}.admin-center__table{width:100%;border-collapse:collapse;font-size:.8rem}.admin-center__table td,.admin-center__table th{padding:.65rem .75rem;text-align:left;vertical-align:top;border-bottom:1px solid var(--border)}.admin-center__table th{font-size:.65rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);background:var(--surface2)}.admin-center__row--blocked{opacity:.75}.admin-center__user{display:flex;flex-direction:column;gap:.15rem}.admin-center__email{font-size:.75rem;word-break:break-all}.admin-center__sub{display:flex;flex-direction:column;gap:.35rem;min-width:7.5rem}.admin-center__plan-input,.admin-center__select{font-size:.75rem;padding:.35rem .45rem;border-radius:6px;border:1px solid var(--border);background:var(--surface2);color:var(--text)}.admin-center__stats{list-style:none;margin:0;padding:0;line-height:1.45;color:var(--muted)}.admin-center__badge{display:inline-block;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:.15rem .4rem;border-radius:4px}.admin-center__badge--active{background:rgba(34,197,94,.15);color:var(--success)}.admin-center__badge--blocked{background:rgba(239,68,68,.15);color:var(--danger)}.admin-center__block-reason{display:block;margin-top:.25rem;font-size:.72rem}.admin-center__actions{display:flex;flex-direction:column;gap:.35rem}.admin-center__hint{margin-top:1.25rem;font-size:.75rem;line-height:1.45}.admin-center__hint code{font-size:.7rem}.signup-confirm__card h1{font-size:1.35rem}.signup-confirm__waiting{display:flex;align-items:center;gap:.65rem;margin-top:1.25rem;line-height:1.45}.signup-confirm__spinner{width:1rem;height:1rem;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:signup-confirm-spin .8s linear infinite;flex-shrink:0}@keyframes signup-confirm-spin{to{transform:rotate(1turn)}}.signup-confirm__actions{display:flex;flex-direction:column;gap:.5rem;margin-top:1.25rem}.signup-confirm__error{color:var(--danger);margin-top:1rem}.signup-confirm__success{color:var(--success);margin-top:1rem}.password-field{position:relative;display:flex;align-items:stretch}.password-field input{width:100%;padding-right:2.75rem}.password-field__toggle{position:absolute;right:.35rem;top:50%;transform:translateY(-50%);display:flex;align-items:center;justify-content:center;width:2.25rem;height:2.25rem;padding:0;border:none;border-radius:6px;background:transparent;color:var(--muted)}.password-field__toggle:hover{color:var(--text);background:rgba(255,255,255,.06)}.auth-form__error{color:var(--danger);font-size:.9rem;line-height:1.45}