.auth-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100dvh;background:var(--bg-primary);padding:24px 16px}.auth-card{width:100%;max-width:380px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px 28px}.auth-logo{display:flex;flex-direction:column;align-items:center;gap:14px;margin-bottom:28px;text-align:center}.auth-logo-icon{width:300px;height:300px;object-fit:contain;border-radius:48px}.auth-logo-text{display:flex;flex-direction:column;gap:2px}.auth-logo-name{font-size:18px;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.auth-logo-tagline{font-size:11px;color:var(--text-dim);font-weight:400;letter-spacing:.02em}.auth-tabs{display:flex;gap:4px;background:var(--bg-tertiary);border-radius:var(--radius);padding:4px;margin-bottom:24px}.auth-tab{flex:1;padding:8px 0;border:none;background:transparent;color:var(--text-secondary);font-size:13px;font-weight:500;border-radius:calc(var(--radius) - 2px);transition:background .15s,color .15s}.auth-tab:hover{color:var(--text-primary)}.auth-tab--active{background:var(--bg-secondary);color:var(--text-primary);box-shadow:0 1px 3px #0000004d}.auth-form{display:flex;flex-direction:column;gap:16px}.auth-label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--text-secondary);font-weight:500}.auth-input{background:var(--bg-tertiary);border:1px solid var(--border-light);border-radius:var(--radius);color:var(--text-primary);padding:10px 12px;font-size:14px;outline:none;transition:border-color .15s;-webkit-appearance:none;-moz-appearance:none;appearance:none}.auth-input:focus{border-color:var(--accent)}.auth-error{font-size:13px;color:var(--red);padding:8px 12px;background:#e852521a;border:1px solid rgba(232,82,82,.25);border-radius:var(--radius)}.auth-submit{margin-top:4px;padding:11px;background:var(--accent);border:none;border-radius:var(--radius);color:#fff;font-size:14px;font-weight:600;transition:background .15s,opacity .15s}.auth-submit:hover:not(:disabled){background:var(--accent-hover)}.auth-submit:disabled{opacity:.5;cursor:not-allowed}.auth-username-row{display:flex;align-items:center;justify-content:space-between;background:var(--bg-tertiary);border:1px solid var(--border-light);border-radius:var(--radius);padding:10px 12px}.auth-username-display{font-size:14px;font-weight:600;color:var(--text-primary)}.auth-back-btn{background:none;border:none;color:var(--accent);font-size:13px;font-weight:500;cursor:pointer;padding:0}.auth-footer{margin-top:24px;font-size:11px;color:var(--text-dim);text-align:center;line-height:1.5}.profile-avatar{border-radius:50%;object-fit:cover;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;vertical-align:middle}.profile-avatar--initial{color:#fff;font-weight:700;line-height:1;-webkit-user-select:none;user-select:none}.confirm-modal{background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-lg);width:360px;max-width:calc(100vw - 40px);padding:24px;box-shadow:0 20px 60px #00000080;display:flex;flex-direction:column;gap:10px}.confirm-title{font-size:15px;font-weight:600;color:var(--text-primary)}.confirm-message{font-size:13px;color:var(--text-secondary);line-height:1.5}.confirm-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:6px}.btn-primary--danger{background:var(--red)!important}.btn-primary--danger:hover{background:#f06060!important}@media (max-width: 767px){.confirm-modal{width:100%;max-width:100%;border-radius:14px 14px 0 0;padding-bottom:calc(24px + env(safe-area-inset-bottom,0px))}.confirm-actions{flex-direction:column-reverse;gap:8px}.confirm-actions button{width:100%;text-align:center;padding:13px 20px}}.confirm-actions--wrap{flex-wrap:wrap}.btn-ghost--danger{color:var(--red);border-color:#e8525259}.btn-ghost--danger:hover:not(:disabled){color:var(--red);border-color:var(--red);background:#e8525214}.profile-picker{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100dvh;background:var(--bg-primary);padding:24px 16px;gap:28px}.pp-loading{color:var(--text-dim);font-size:14px}.pp-title{font-size:26px;font-weight:700;color:var(--text-primary);letter-spacing:-.02em;text-align:center}.pp-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:24px;max-width:560px}.pp-tile{display:flex;flex-direction:column;align-items:center;gap:10px;background:none;border:none;padding:6px;width:116px}.pp-tile-avatar-wrap{position:relative;display:block}.pp-avatar{border-radius:14px;transition:outline-color .15s,transform .15s;outline:2px solid transparent;outline-offset:3px}.pp-tile:hover .pp-avatar,.pp-tile:focus-visible .pp-avatar{outline-color:var(--accent);transform:scale(1.04)}.pp-tile-edit{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0000008c;border-radius:14px;color:#fff;font-size:26px}.pp-tile-name{font-size:14px;color:var(--text-secondary);font-weight:500;max-width:110px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pp-tile:hover .pp-tile-name{color:var(--text-primary)}.pp-add-circle{width:96px;height:96px;border-radius:14px;border:2px dashed var(--border-light);display:flex;align-items:center;justify-content:center;font-size:40px;color:var(--text-dim);font-weight:300;transition:border-color .15s,color .15s}.pp-tile--add:hover .pp-add-circle{border-color:var(--accent);color:var(--accent)}.pp-footer{display:flex;gap:16px;align-items:center}.pp-ghost-btn{background:none;border:1px solid var(--border-light);border-radius:var(--radius);color:var(--text-secondary);font-size:13px;font-weight:500;padding:8px 16px;transition:color .15s,border-color .15s}.pp-ghost-btn:hover{color:var(--text-primary);border-color:var(--text-dim)}.pp-logout:hover{color:var(--red);border-color:var(--red)}.pp-form{display:flex;flex-direction:column;align-items:center;gap:20px;width:100%;max-width:340px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px 28px}.pp-form-avatar{display:flex;flex-direction:column;align-items:center;gap:12px}.pp-form-avatar-btns{display:flex;gap:10px}.pp-input{width:100%;background:var(--bg-tertiary);border:1px solid var(--border-light);border-radius:var(--radius);color:var(--text-primary);padding:10px 12px;font-size:14px;outline:none;text-align:center;transition:border-color .15s}.pp-input:focus{border-color:var(--accent)}.pp-error{font-size:13px;color:var(--red);padding:8px 12px;background:#e852521a;border:1px solid rgba(232,82,82,.25);border-radius:var(--radius);text-align:center}.pp-form-actions{display:flex;gap:10px;width:100%;justify-content:center}.pp-primary-btn{padding:8px 24px;background:var(--accent);border:none;border-radius:var(--radius);color:#fff;font-size:14px;font-weight:600;transition:background .15s,opacity .15s}.pp-primary-btn:hover:not(:disabled){background:var(--accent-hover)}.pp-primary-btn:disabled{opacity:.5;cursor:not-allowed}.pp-delete-btn{background:none;border:none;color:var(--red);font-size:13px;padding:0;opacity:.8}.pp-delete-btn:hover{opacity:1;text-decoration:underline}.rules-panel{display:flex;flex-direction:column;gap:20px}.rules-section-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim);margin-bottom:8px}.rules-row{display:flex;align-items:center;gap:8px}.rules-unit{color:var(--text-dim);font-size:12px}.rules-input{background:var(--bg-tertiary);border:1px solid var(--border-light);border-radius:var(--radius);color:var(--text-primary);padding:6px 10px;outline:none;width:90px;transition:border-color .15s}.rules-input:focus{border-color:var(--accent)}.rules-input::placeholder{color:var(--text-dim);font-size:12px}.rules-input-album{flex:1;width:auto}.rules-input-count{width:54px}.album-rule{display:flex;align-items:center;gap:8px;padding:5px 0;border-bottom:1px solid var(--border)}.album-rule-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.album-rule-name{flex:1;font-size:13px;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.album-rule-count{font-size:12px;color:var(--text-secondary);font-weight:500}.album-rule-remove{background:none;border:none;color:var(--text-dim);font-size:11px;padding:2px 4px;border-radius:var(--radius);transition:color .15s,background .15s}.album-rule-remove:hover{color:var(--red);background:#e852521a}.album-rule-add{display:flex;gap:6px;margin-top:8px;align-items:center}.btn-add-rule{background:var(--accent);border:none;color:#fff;width:30px;height:30px;border-radius:var(--radius);font-size:18px;font-weight:300;display:flex;align-items:center;justify-content:center;transition:background .15s;flex-shrink:0}.btn-add-rule:hover{background:var(--accent-hover)}@media (max-width: 767px){.rules-input{width:100%;max-width:120px;min-height:44px;padding:10px 12px;font-size:16px}.rules-input-count{width:72px;min-height:44px;font-size:16px}.rules-input-album{flex:1;min-height:44px;font-size:16px}.album-rule{flex-wrap:wrap;gap:6px 8px;padding:8px 0}.album-rule-name{flex:1 1 100%}.album-rule-remove{min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}.album-rule-add{flex-wrap:wrap}.btn-add-rule{width:44px;height:44px}.rules-row{flex-wrap:wrap;gap:6px}}.nav-lockup{height:44px;width:auto;display:block;flex-shrink:0}.page-title{display:flex;align-items:center;gap:10px;font-size:24px;font-weight:800;letter-spacing:.02em;text-transform:uppercase;color:var(--text-primary);margin:0}.page-title-icon{color:var(--accent);display:inline-flex;align-items:center}.page-title-icon svg{width:22px;height:22px}.section-label{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim);padding:2px 2px 0}.time-badge{background:var(--time-badge-bg);color:var(--time-badge-text);font-size:11px;font-weight:700;font-variant-numeric:tabular-nums;padding:3px 8px;border-radius:7px;white-space:nowrap}.tuning-badge{color:#fff;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:3px 8px;border-radius:6px;white-space:nowrap}.breakdown-bar{display:flex;height:7px;border-radius:4px;overflow:hidden;gap:1px}.breakdown-bar-seg{height:100%}.setlist{display:flex;flex-direction:column;height:100%;overflow:hidden}.setlist-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--border);gap:12px;flex-shrink:0}.setlist-name-wrap{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}.setlist-name-input{background:none;border:none;outline:none;font-size:15px;font-weight:700;color:var(--text-primary);padding:2px 0;border-bottom:1px solid transparent;transition:border-color .15s;width:100%}.setlist-name-input:focus{border-bottom-color:var(--accent)}.setlist-name-input::placeholder{color:var(--text-dim)}.setlist-subtitle-input{background:none;border:none;outline:none;font-size:12px;font-weight:400;color:var(--text-secondary);padding:1px 0;border-bottom:1px solid transparent;transition:border-color .15s}.setlist-subtitle-input:focus{border-bottom-color:var(--border-light)}.setlist-subtitle-input::placeholder{color:var(--text-dim);font-style:italic}.setlist-stats{display:flex;flex-direction:column;align-items:flex-end;gap:2px;flex-shrink:0}.setlist-save-status{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em}.setlist-save-status--saved{color:var(--text-dim)}.setlist-save-status--unsaved{color:var(--accent)}.setlist-time{font-size:15px;font-weight:700;font-variant-numeric:tabular-nums;color:var(--text-primary)}.setlist-time--over{color:var(--red)}.setlist-track-count{font-size:11px;color:var(--text-dim)}.setlist-time-remaining{font-size:11px;color:var(--green);font-variant-numeric:tabular-nums}.setlist-progress-bar{height:3px;background:var(--border);flex-shrink:0;overflow:hidden;transition:max-height .25s ease,opacity .2s ease;max-height:3px}.setlist-progress-fill{height:100%;background:var(--accent);border-radius:0 2px 2px 0;transition:width .3s ease,background .3s}.setlist-progress-fill--over{background:var(--red)}.btn-add-spacer--active{background:var(--accent-dim);color:var(--accent);border-color:var(--accent)}.setlist-rules-bar{border-bottom:1px solid var(--border);flex-shrink:0;overflow:hidden;transition:max-height .25s ease,opacity .2s ease;max-height:600px}.setlist-rules-toggle{display:flex;align-items:center;gap:10px;width:100%;background:none;border:none;padding:9px 20px;cursor:pointer;text-align:left;transition:background .1s}.setlist-rules-toggle:hover{background:var(--bg-hover)}.setlist-rules-toggle-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim);flex-shrink:0}.setlist-rules-summary{display:flex;flex-wrap:wrap;gap:5px;flex:1;min-width:0}.setlist-rules-chip{font-size:11px;background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-light);border-radius:10px;padding:2px 8px;white-space:nowrap}.setlist-rules-summary-empty{flex:1;font-size:11px;color:var(--text-dim);font-style:italic}.setlist-rules-chevron{font-size:16px;color:var(--text-dim);flex-shrink:0;transition:transform .2s;line-height:1}.setlist-rules-chevron--open{transform:rotate(90deg)}.setlist-rules-panel{padding:16px 20px;max-height:340px;overflow-y:auto}.setlist-breakdown{padding:12px 20px;border-bottom:1px solid var(--border);flex-shrink:0;overflow:hidden;transition:max-height .25s ease,opacity .2s ease,padding .25s ease;max-height:200px;display:flex;align-items:center;gap:20px}.setlist-violations{padding:8px 16px;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:4px;flex-shrink:0}.violation{font-size:11px;color:var(--yellow);font-weight:500}.setlist-list{flex:1;overflow-y:auto;padding:4px 0;transition:background .15s;position:relative}.setlist-list--over{background:var(--accent-dim)}.setlist-list--empty{display:flex;align-items:center;justify-content:center}.btn-undo{background:none;border:1px solid var(--border-light);color:var(--text-dim);padding:5px 9px;border-radius:var(--radius);font-size:14px;cursor:pointer;transition:border-color .15s,color .15s;flex-shrink:0}.btn-undo:hover:not(:disabled){border-color:var(--text-dim);color:var(--text-secondary)}.btn-undo:disabled{opacity:.25;cursor:default}.spacer-add-wrap{position:relative}.btn-add-spacer{background:none;border:1px dashed var(--border-light);color:var(--text-dim);padding:5px 10px;border-radius:var(--radius);font-size:11px;font-weight:500;cursor:pointer;transition:border-color .15s,color .15s}.btn-add-spacer:hover{border-color:var(--text-dim);color:var(--text-secondary)}.btn-reset-setlist{background:none;border:1px solid var(--border-light);color:var(--text-dim);padding:5px 10px;border-radius:var(--radius);font-size:11px;font-weight:500;cursor:pointer;transition:border-color .15s,color .15s,background .15s;white-space:nowrap}.btn-reset-setlist:hover{border-color:var(--red);color:var(--red);background:#e8525214}.spacer-menu{position:absolute;top:calc(100% + 4px);right:0;background:var(--bg-tertiary);border:1px solid var(--border-light);border-radius:var(--radius);overflow:hidden;z-index:100;box-shadow:0 8px 24px #0006;min-width:180px}.spacer-menu button{display:flex;align-items:center;justify-content:space-between;width:100%;background:none;border:none;padding:9px 14px;color:var(--text-primary);font-size:13px;cursor:pointer;gap:12px;transition:background .1s}.spacer-menu button:hover{background:var(--bg-hover)}.spacer-menu button span{color:var(--text-dim);font-size:11px}.spacer-row{display:flex;align-items:center;gap:8px;padding:7px 20px;border-bottom:1px dashed var(--border-light);background:var(--bg-primary);opacity:.85;transition:opacity .1s}.spacer-row:hover{opacity:1}.spacer-row--dragging{opacity:.4}.spacer-row--tuning{border-left:3px solid var(--accent)}.spacer-row--chat{border-left:3px solid var(--green)}.spacer-drag{color:var(--text-dim);cursor:grab;display:flex;align-items:center}.spacer-drag:active{cursor:grabbing}.spacer-icon{font-size:13px}.spacer-label{flex:1;font-size:12px;font-style:italic;color:var(--text-secondary);cursor:text}.spacer-label:hover{color:var(--text-primary)}.spacer-label--auto{cursor:default;color:var(--text-secondary)}.spacer-label--auto:hover{color:var(--text-secondary)}.spacer-label-input{flex:1;background:var(--bg-tertiary);border:1px solid var(--accent);border-radius:3px;color:var(--text-primary);padding:2px 6px;font-size:12px;font-style:italic;outline:none}.spacer-right{display:flex;align-items:center;gap:6px}.spacer-dur{font-size:12px;font-variant-numeric:tabular-nums;color:var(--text-dim);cursor:text;border-bottom:1px dashed transparent;transition:border-color .15s,color .15s}.spacer-dur:hover{color:var(--text-secondary);border-bottom-color:var(--text-dim)}.spacer-dur-input{width:52px;background:var(--bg-tertiary);border:1px solid var(--accent);border-radius:3px;color:var(--text-primary);padding:2px 6px;font-size:12px;font-variant-numeric:tabular-nums;text-align:right;outline:none}.spacer-remove{background:none;border:none;color:var(--text-dim);font-size:11px;padding:3px 4px;border-radius:3px;cursor:pointer;opacity:0;transition:opacity .15s,color .15s}.spacer-row:hover .spacer-remove{opacity:1}.spacer-remove:hover{color:var(--red)}.setlist-drop-hint{color:var(--text-dim);font-size:13px;text-align:center;padding:40px;pointer-events:none}.btn-pick-songs--header{background:var(--accent);border:none;color:#fff;padding:6px 12px;border-radius:var(--radius);font-size:12px;font-weight:600;cursor:pointer;transition:background .15s;white-space:nowrap;flex-shrink:0}.btn-pick-songs--header:hover{background:var(--accent-hover)}.setlist-item-group{border-bottom:1px solid var(--border)}.setlist-item-group--dragging{opacity:.5;box-shadow:0 4px 16px #0006;z-index:100}.setlist-item{display:grid;grid-template-columns:28px 14px 4px 1fr auto;align-items:center;gap:0 10px;padding:9px 20px;background:var(--bg-secondary);transition:background .1s}.setlist-item:hover{background:var(--bg-hover)}.sub-row{display:flex;align-items:center;gap:8px;padding:5px 20px 5px 56px;background:var(--bg-primary)}.sub-row--intro{border-top:1px solid var(--border)}.sub-row--riff{border-top:1px dashed var(--border)}.sub-row-indent{width:0}.sub-row-tag{font-size:10px;font-weight:700;border-radius:4px;padding:1px 6px;flex-shrink:0;letter-spacing:.03em}.sub-row-tag--intro{color:var(--blue);background:#5296e81f;border:1px solid rgba(82,150,232,.25)}.sub-row-tag--riff{color:var(--purple);background:#9b52e81f;border:1px solid rgba(155,82,232,.25)}.sub-row-bar{width:3px;height:20px;border-radius:2px;flex-shrink:0}.sub-row-name{flex:1;font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sub-row-tuning{font-size:11px;color:var(--blue);font-weight:500}.sub-row-dur{font-size:11px;font-variant-numeric:tabular-nums;color:var(--text-dim)}.sub-row-remove{background:none;border:none;color:var(--text-dim);font-size:10px;padding:2px 4px;border-radius:3px;opacity:0;transition:opacity .15s,color .15s;cursor:pointer}.sub-row:hover .sub-row-remove{opacity:1}.sub-row-remove:hover{color:var(--red)}.sub-btn-wrap{position:relative}.sub-toggle-btn{font-size:10px;font-weight:600;padding:2px 6px;border-radius:4px;opacity:0;transition:opacity .15s,color .15s,background .15s}.setlist-item:hover .sub-toggle-btn{opacity:1}.sub-toggle-btn--intro{color:var(--text-dim)}.sub-toggle-btn--intro:hover{color:var(--blue);background:#5296e81a}.sub-toggle-btn--intro.sub-toggle-btn--on{color:var(--blue)!important;background:#5296e81a!important;opacity:1!important}.sub-toggle-btn--riff{color:var(--text-dim)}.sub-toggle-btn--riff:hover{color:var(--purple);background:#9b52e81a}.sub-toggle-btn--riff.sub-toggle-btn--on{color:var(--purple)!important;background:#9b52e81a!important;opacity:1!important}.sub-picker{position:absolute;right:0;top:calc(100% + 4px);background:var(--bg-tertiary);border:1px solid var(--border-light);border-radius:var(--radius);z-index:200;min-width:200px;box-shadow:0 8px 24px #0006;overflow:hidden}.sub-picker-header{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--picker-accent, var(--accent));padding:8px 12px 5px;border-bottom:1px solid var(--border)}.sub-picker-remove{display:block;width:100%;background:none;border:none;border-bottom:1px solid var(--border);padding:7px 12px;text-align:left;font-size:12px;color:var(--red);cursor:pointer;transition:background .1s}.sub-picker-remove:hover{background:#e8525214}.sub-picker-empty{padding:10px 12px;font-size:12px;color:var(--text-dim)}.sub-picker-item{display:flex;align-items:center;justify-content:space-between;width:100%;background:none;border:none;padding:8px 12px;cursor:pointer;transition:background .1s;gap:8px}.sub-picker-item:hover{background:var(--bg-hover)}.sub-picker-item--active{background:#ffffff0a}.sub-picker-item--mismatch{opacity:.38}.sub-picker-item--mismatch .sub-picker-name:after{content:" ⚠";font-size:10px;color:var(--yellow)}.sub-picker-name{font-size:13px;color:var(--text-primary);text-align:left;flex:1}.sub-picker-right{display:flex;align-items:center;gap:6px;flex-shrink:0}.sub-picker-tuning{font-size:10px;color:var(--blue);font-weight:600;background:#5296e81a;border-radius:3px;padding:1px 5px}.sub-picker-dur{font-size:11px;color:var(--text-dim);font-variant-numeric:tabular-nums}.setlist-item-num{font-size:11px;font-weight:600;color:var(--text-dim);font-variant-numeric:tabular-nums;text-align:right;-webkit-user-select:none;user-select:none}.setlist-item-drag{color:var(--text-dim);cursor:grab;display:flex;align-items:center}.setlist-item-drag:active{cursor:grabbing}.setlist-item:hover .setlist-item-drag{color:var(--text-secondary)}.setlist-item-bar{width:4px;height:32px;border-radius:2px;flex-shrink:0}.setlist-item-info{min-width:0}.setlist-item-name{font-size:13px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:baseline;gap:6px}.setlist-item-note{font-size:11px;font-weight:400;color:var(--text-dim);font-style:italic;flex-shrink:0}.setlist-item-sub{display:flex;align-items:center;gap:8px;margin-top:2px}.setlist-item-album{font-size:11px;color:var(--text-dim)}.setlist-item-tuning{font-size:11px;color:var(--blue);font-weight:500}.setlist-item-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.setlist-item-duration-wrap{display:flex;align-items:center;gap:5px;justify-content:flex-end}.setlist-item-duration{font-size:12px;font-variant-numeric:tabular-nums;color:var(--text-secondary);min-width:36px;text-align:right}.end-riff-badge{font-size:10px;font-weight:600;color:var(--purple);background:#9b52e81f;border:1px solid rgba(155,82,232,.3);border-radius:4px;padding:1px 4px}.setlist-item-actions{display:flex;gap:4px;opacity:0;transition:opacity .15s}.setlist-item:hover .setlist-item-actions{opacity:1}.row-btn{background:none;border:none;color:var(--text-dim);padding:4px 6px;border-radius:var(--radius);font-size:13px;transition:color .15s,background .15s}.row-btn:hover{color:var(--text-primary);background:var(--bg-tertiary)}.row-btn--danger:hover{color:var(--red);background:#e852521a}.alt-btn{font-size:15px}.alt-swap-wrap{position:relative}.alt-swap-menu{position:absolute;right:0;top:calc(100% + 4px);background:var(--bg-tertiary);border:1px solid var(--border-light);border-radius:var(--radius);z-index:100;min-width:180px;box-shadow:0 8px 24px #0006;overflow:hidden}.alt-swap-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim);padding:8px 12px 4px}.alt-swap-option{display:flex;align-items:center;justify-content:space-between;width:100%;background:none;border:none;padding:8px 12px;color:var(--text-primary);font-size:13px;text-align:left;cursor:pointer;transition:background .1s}.alt-swap-option:hover{background:var(--bg-hover)}.alt-swap-album{font-size:11px;color:var(--text-dim)}@media (max-width: 767px){.setlist-header{padding:10px 14px;gap:8px;flex-wrap:wrap}.setlist-name-input,.setlist-subtitle-input{font-size:16px}.setlist-name-wrap{flex:0 0 100%;order:0}.btn-pick-songs--header,.btn-undo,.spacer-add-wrap,.btn-copy-setlist,.btn-save{order:1}.btn-copy-setlist,.btn-save{min-height:44px;padding:0 16px}.btn-pick-songs--header{padding:10px 16px;min-height:44px}.btn-undo{min-width:44px;min-height:44px;padding:0 10px;display:flex;align-items:center;justify-content:center}.btn-add-spacer{min-height:44px;padding:0 12px}.setlist-item-actions{opacity:1}.row-btn{min-width:36px;min-height:36px;display:flex;align-items:center;justify-content:center;padding:6px 8px}.sub-toggle-btn{opacity:1;min-height:36px}.spacer-remove,.sub-row-remove{opacity:1;min-width:36px;min-height:36px;display:flex;align-items:center;justify-content:center}.sub-picker{position:fixed;left:0;right:0;bottom:calc(76px + env(safe-area-inset-bottom,0px));top:auto;border-radius:14px 14px 0 0;min-width:unset;max-height:60dvh;overflow-y:auto;z-index:200}.sub-picker-item,.sub-picker-remove{padding:13px 16px;min-height:44px}.alt-swap-menu{position:fixed;left:0;right:0;bottom:calc(76px + env(safe-area-inset-bottom,0px));top:auto;border-radius:14px 14px 0 0;min-width:unset;max-height:50dvh;overflow-y:auto;z-index:200}.alt-swap-option{padding:13px 16px;min-height:44px}.spacer-menu{position:fixed;left:0;right:0;bottom:calc(76px + env(safe-area-inset-bottom,0px));top:auto;border-radius:14px 14px 0 0;min-width:unset}.spacer-menu button{padding:14px 16px;width:100%;text-align:left}.setlist--scrolled .setlist-progress-bar,.setlist--scrolled .setlist-violations{max-height:0;opacity:0}.setlist--scrolled .setlist-rules-bar{max-height:0;opacity:0;border-bottom:none}.setlist--scrolled .setlist-breakdown{max-height:0;opacity:0;padding-top:0;padding-bottom:0}.setlist--scrolled .setlist-header{padding:7px 14px;gap:8px;align-items:flex-start}.setlist--scrolled .btn-pick-songs--header,.setlist--scrolled .spacer-add-wrap,.setlist--scrolled .btn-reset-setlist,.setlist--scrolled .btn-copy-setlist,.setlist--scrolled .btn-save{display:none}.setlist--scrolled .setlist-name-wrap{flex:1;min-width:0;flex-direction:column;gap:2px;overflow:hidden}.setlist--scrolled .setlist-name-input{font-size:13px;font-weight:600;width:100%}.setlist--scrolled .setlist-subtitle-input{font-size:11px;color:var(--text-dim);width:100%}.setlist--scrolled .setlist-stats{flex-direction:row;align-items:flex-start;gap:6px;flex-shrink:0;padding-top:2px}.setlist--scrolled .setlist-save-status,.setlist--scrolled .setlist-time-remaining{display:none}.setlist--scrolled .setlist-time{font-size:13px}.setlist--scrolled .setlist-track-count{font-size:11px}.setlist--scrolled .btn-pick-songs--header{padding:6px 10px;font-size:11px;min-height:unset}.setlist--scrolled .btn-add-spacer{min-height:unset;padding:5px 9px}}.setlist-venue-row{display:flex;align-items:center;gap:8px}.setlist-date-input{background:var(--bg-tertiary);border:1px solid var(--border-light);border-radius:var(--radius);color:var(--text-secondary);font-size:12px;padding:3px 8px;outline:none;color-scheme:dark}.setlist-date-input:focus{border-color:var(--accent)}.setlist-date-input--missing{border-color:var(--red)}.versions-wrap{position:relative}.versions-menu{position:absolute;top:calc(100% + 6px);right:0;min-width:230px;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:0 8px 28px #00000080;padding:6px;z-index:60;max-height:320px;overflow-y:auto}.versions-menu-title{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);padding:4px 8px 6px}.versions-empty{font-size:12px;color:var(--text-dim);padding:6px 8px}.versions-item{display:flex;align-items:center;gap:10px;width:100%;background:none;border:none;border-radius:var(--radius);padding:7px 8px;text-align:left;transition:background .1s}.versions-item:hover{background:var(--bg-hover)}.versions-no{font-size:11px;font-weight:700;color:var(--text-primary);background:var(--bg-tertiary);border-radius:5px;padding:2px 6px;font-variant-numeric:tabular-nums}.versions-meta{font-size:11px;color:var(--text-secondary)}@media (max-width: 767px){.setlist--scrolled .versions-wrap{display:none}.btn-versions{min-height:44px}.versions-menu{position:fixed;left:12px;right:12px;top:auto}}.ed-toolbar{display:flex;align-items:center;gap:8px;padding:12px 20px;border-bottom:1px solid var(--border);flex-shrink:0;position:relative}.ed-toolbar-right{margin-left:auto;display:flex;align-items:center;gap:8px;position:relative}.ed-menu-wrap{position:relative}.ed-menu{position:absolute;top:calc(100% + 6px);left:0;min-width:190px;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:0 10px 30px #0000008c;padding:5px;z-index:70}.ed-menu--right{left:auto;right:0}.ed-menu button{display:block;width:100%;background:none;border:none;border-radius:var(--radius);padding:8px 10px;color:var(--text-primary);font-size:12px;text-align:left;transition:background .1s}.ed-menu button:hover:not(:disabled){background:var(--bg-hover)}.ed-menu button:disabled{opacity:.4}.ed-toolbar-right .versions-menu{top:calc(100% + 6px);right:0}.ed-breakdown{padding:10px 20px;border-bottom:1px solid var(--border);flex-shrink:0}.dirty-dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--accent);margin-left:6px;vertical-align:middle}.date-clear{background:none;border:none;color:var(--text-dim);font-size:10px;padding:2px 4px}.date-clear:hover{color:var(--red)}.date-required-hint{font-size:10px;color:var(--red);font-style:italic}.setlist-list{padding-bottom:calc(var(--tab-bar-h) + 24px)}.floating-tabbar{position:fixed;left:50%;transform:translate(-50%);bottom:calc(14px + env(safe-area-inset-bottom,0px));display:flex;gap:4px;padding:5px;border-radius:999px;background:#1b1b1fd1;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid var(--border);box-shadow:0 10px 34px #0000008c;z-index:80}.ftab{display:flex;align-items:center;gap:7px;padding:9px 18px;border:none;border-radius:999px;background:transparent;color:var(--text-secondary);font-size:12px;font-weight:600;transition:background .15s,color .15s;position:relative}.ftab:hover{color:var(--text-primary)}.ftab--active{background:var(--surface3);color:var(--text-primary)}.ftab--active svg{color:var(--accent)}.ftab-badge{font-size:9px;font-weight:800;background:var(--surface2);color:var(--text-dim);border-radius:8px;padding:1px 6px}.ftab--active .ftab-badge{color:var(--accent)}@media (max-width: 767px){.ftab{padding:8px 14px}.ftab span:not(.ftab-badge){font-size:11px}}.sb{display:flex;flex-direction:column;height:100%;overflow:hidden;padding:16px 14px 0;gap:12px}.sb-header{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-shrink:0}.sb-header-actions{display:flex;align-items:center;gap:7px}.sb-icon-btn{width:32px;height:32px;border-radius:9px;background:var(--surface2);border:1px solid var(--border);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;font-size:14px;transition:color .15s,background .15s}.sb-icon-btn:hover{color:var(--text-primary);background:var(--surface3)}.sb-add-btn{width:32px;height:32px;border-radius:9px;background:var(--accent);border:none;color:#fff;font-size:18px;font-weight:600;line-height:1;display:flex;align-items:center;justify-content:center;transition:background .15s}.sb-add-btn:hover{background:var(--accent-hover)}.sb-organise{display:flex;align-items:center;gap:2px;background:var(--surface2);border:1px solid var(--border);border-radius:999px;padding:2px}.sb-organise-wrap{position:relative}.sb-organise-btn{width:30px;height:28px;border-radius:999px;border:none;background:transparent;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;gap:2px;transition:color .15s,background .15s}.sb-organise-btn:hover{color:var(--text-primary)}.sb-organise-btn--on{background:var(--surface3);color:var(--accent)}.sb-organise-dir{font-size:10px;font-weight:800}.sb-mode-toggle{border-radius:50%}.sb-popover{position:absolute;top:calc(100% + 6px);left:0;min-width:190px;max-height:300px;overflow-y:auto;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:0 10px 30px #0000008c;padding:5px;z-index:70}.sb-popover--right{left:auto;right:0}.sb-popover button{display:flex;align-items:center;gap:8px;width:100%;background:none;border:none;border-radius:var(--radius);padding:8px 9px;color:var(--text-primary);font-size:12px;text-align:left;transition:background .1s}.sb-popover button:hover{background:var(--bg-hover)}.sb-pop--on{color:var(--accent)!important}.sb-pop-sep{height:1px;background:var(--border);margin:4px 2px}.sb-pop-count{margin-left:auto;font-size:10px;color:var(--text-dim)}.sb-title-row{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-shrink:0}.sb-title-actions{display:flex;align-items:center;gap:6px}.sb-search{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);padding:8px 12px;font-size:13px;outline:none;flex-shrink:0}.sb-search:focus{border-color:var(--accent)}.sb-filter-chip{align-self:flex-start;display:flex;align-items:center;gap:6px;background:var(--surface3);border:1px solid var(--border-light);border-radius:999px;color:var(--text-primary);font-size:11px;font-weight:600;padding:4px 10px}.sb-filter-x{color:var(--text-dim)}.sb-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:7px;padding-bottom:calc(var(--tab-bar-h) + 28px)}.sb-section{display:flex;flex-direction:column;gap:7px}.sb-gap{height:8px}.sb-empty{font-size:12px;color:var(--text-dim);padding:6px 2px}.sb-card{position:relative;background:var(--bg-tertiary);border:1px solid transparent;border-radius:12px;padding:12px 13px;cursor:pointer;transition:background .1s,border-color .15s}.sb-card:hover{background:var(--bg-hover)}.sb-card--selected{border-color:var(--accent)}.sb-card-top{display:flex;align-items:center;gap:10px;margin-bottom:10px}.sb-card-info{flex:1;min-width:0}.sb-card-status{font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.07em;color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sb-card-name{font-size:15px;font-weight:700;color:var(--text-primary);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sb-card-meta{font-size:11px;color:var(--text-dim);margin-top:1px}.sb-card-right{display:flex;align-items:center;gap:7px;flex-shrink:0}.sb-card-hover-actions{position:absolute;top:6px;right:6px;display:flex;gap:2px;opacity:0;transition:opacity .15s}.sb-card:hover .sb-card-hover-actions{opacity:1}.sb-card-hover-actions button{background:var(--surface2);border:none;border-radius:6px;color:var(--text-secondary);font-size:11px;padding:4px 7px}.sb-card-hover-actions button:hover{color:var(--text-primary);background:var(--surface3)}.sb-card-hover-actions .sb-danger:hover{color:var(--red)}.sb-context-menu{position:absolute;top:30px;right:8px;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:0 10px 30px #0000008c;padding:5px;z-index:60;min-width:140px}.sb-context-menu button{display:block;width:100%;background:none;border:none;border-radius:var(--radius);padding:8px 10px;color:var(--text-primary);font-size:12px;text-align:left}.sb-context-menu button:hover{background:var(--bg-hover)}.sb-context-menu .sb-danger{color:var(--red)}.sb-row{position:relative;display:flex;align-items:center;gap:9px;background:var(--bg-tertiary);border:1px solid transparent;border-radius:10px;padding:9px 11px;cursor:pointer;transition:background .1s,border-color .15s}.sb-row:hover{background:var(--bg-hover)}.sb-row--selected{border-color:var(--accent)}.sb-row--static{cursor:default}.sb-row-star{background:none;border:none;color:var(--text-dim);padding:3px;display:flex;align-items:center;transition:color .15s;flex-shrink:0}.sb-row-star:hover,.sb-row-star--on{color:var(--accent)}.sb-row-info{flex:1;min-width:0}.sb-row-name{font-size:13px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:baseline;gap:6px}.sb-row-note{font-size:10px;font-weight:400;color:var(--text-dim);font-style:italic;flex-shrink:0}.sb-row-album{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--text-dim);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.album-dot{display:inline-block;width:7px;height:7px;border-radius:50%;flex-shrink:0}.sb-row-right{display:flex;align-items:center;gap:6px;flex-shrink:0}.sb-row-time{display:flex;align-items:center;gap:5px}.sb-fits-dot{width:6px;height:6px;border-radius:50%;background:var(--green)}.sb-row-hover-actions{position:absolute;right:8px;top:50%;transform:translateY(-50%);display:flex;gap:3px;opacity:0;transition:opacity .15s}.sb-row:hover .sb-row-hover-actions{opacity:1}.sb-row-hover-actions button{background:var(--surface3);border:none;border-radius:6px;color:var(--text-secondary);font-size:12px;padding:4px 8px}.sb-row-hover-actions .sb-green:hover{color:var(--green)}.sb-row-hover-actions .sb-danger:hover{color:var(--red)}@media (max-width: 767px){.sb-card-hover-actions,.sb-row-hover-actions{opacity:1}}.song-editor{display:flex;flex-direction:column;height:100%;overflow:hidden}.se-toolbar{display:flex;align-items:center;gap:10px;padding:14px 20px;border-bottom:1px solid var(--border);flex-shrink:0}.se-back{background:none;border:none;color:var(--accent);font-size:14px;font-weight:600;padding:4px 6px 4px 0}.se-kind{font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;border:1px solid var(--border-light);border-radius:5px;padding:3px 7px;color:var(--text-secondary)}.se-kind--riff{color:var(--purple)}.se-kind--intro{color:var(--blue)}.se-autosave{font-size:10px;font-weight:700;color:var(--green);opacity:0;transition:opacity .3s}.se-autosave--on{opacity:1}.se-toolbar-actions{margin-left:auto;display:flex;gap:8px}.se-btn{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-secondary);font-size:12px;font-weight:600;padding:6px 12px;transition:color .15s,background .15s,border-color .15s}.se-btn:hover:not(:disabled){color:var(--text-primary);background:var(--surface3)}.se-btn:disabled{opacity:.4;cursor:not-allowed}.se-btn--accent{background:var(--accent);border-color:var(--accent);color:#fff}.se-btn--accent:hover:not(:disabled){background:var(--accent-hover);color:#fff}.se-btn--danger:hover:not(:disabled){color:var(--red);border-color:var(--red);background:#e8525214}.se-body{flex:1;overflow-y:auto;padding:22px 24px calc(var(--tab-bar-h) + 30px);display:flex;flex-direction:column;gap:18px;max-width:640px}.se-name{background:none;border:none;border-bottom:1px solid transparent;outline:none;font-size:26px;font-weight:800;color:var(--text-primary);padding:2px 0;transition:border-color .15s}.se-name:focus{border-bottom-color:var(--accent)}.se-name::placeholder{color:var(--text-dim)}.se-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:14px}.se-field{display:flex;flex-direction:column;gap:6px}.se-field--row{flex-direction:row;align-items:center;justify-content:space-between;max-width:300px}.se-label{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim)}.se-hint{font-weight:400;text-transform:none;letter-spacing:0;font-style:italic}.se-input{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);padding:9px 12px;font-size:13px;outline:none;transition:border-color .15s}.se-input:focus{border-color:var(--accent)}.se-input--time{font-variant-numeric:tabular-nums;font-weight:700}.se-album-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.se-album-chip{display:flex;align-items:center;gap:6px;background:var(--surface2);border:1px solid var(--border);border-radius:999px;color:var(--text-secondary);font-size:11px;font-weight:600;padding:4px 10px;transition:color .15s,border-color .15s}.se-album-chip:hover{color:var(--text-primary)}.se-album-chip--on{border-color:var(--accent);color:var(--text-primary);background:var(--surface3)}.se-alt-chips{display:flex;flex-wrap:wrap;gap:6px}.se-alt-chip{display:inline-flex;align-items:center;gap:6px;background:var(--surface2);border:1px solid var(--border);border-radius:999px;font-size:11px;color:var(--text-primary);padding:4px 10px}.se-alt-chip button{background:none;border:none;color:var(--text-dim);font-size:10px;padding:0}.se-alt-chip button:hover{color:var(--red)}.se-alt-search{position:relative}.se-alt-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:0 10px 30px #00000080;list-style:none;padding:5px;z-index:40}.se-alt-dropdown li{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 10px;border-radius:var(--radius);font-size:12px;color:var(--text-primary);cursor:pointer}.se-alt-dropdown li:hover{background:var(--bg-hover)}.se-footer-note{font-size:11px;color:var(--text-dim);font-style:italic;border-top:1px solid var(--border);padding-top:14px}.toggle{width:40px;height:22px;border-radius:999px;background:var(--surface3);position:relative;cursor:pointer;transition:background .15s;flex-shrink:0}.toggle--on{background:var(--accent)}.toggle-knob{position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:#fff;transition:transform .15s}.toggle--on .toggle-knob{transform:translate(18px)}.hist-card-actions{display:flex;gap:6px;margin-top:10px}.hist-card-actions .se-btn{font-size:11px;padding:4px 10px}.hist-row-actions{display:flex;gap:5px;flex-shrink:0}.hist-row-actions .se-btn{font-size:10px;padding:3px 8px}.hist-kind{font-size:8px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--purple);border:1px solid var(--border-light);border-radius:4px;padding:1px 5px}.hist-viewer{display:flex;flex-direction:column;height:100%;overflow:hidden}.hist-viewer--empty{align-items:center;justify-content:center}.hist-lock{font-size:11px;font-weight:700;color:var(--text-secondary);background:var(--surface2);border:1px solid var(--border);border-radius:999px;padding:4px 12px}.hist-viewer-body{flex:1;overflow-y:auto;padding:22px 24px calc(var(--tab-bar-h) + 30px);display:flex;flex-direction:column;gap:12px;max-width:720px}.hist-title{font-size:26px;font-weight:800;color:var(--text-primary)}.hist-sub{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim)}.hist-stats{display:flex;align-items:center;gap:10px}.hist-count{font-size:12px;color:var(--text-secondary)}.hist-items{display:flex;flex-direction:column;gap:6px;margin-top:8px}.hist-item{display:flex;align-items:center;gap:10px;background:var(--bg-tertiary);border-radius:10px;padding:10px 12px}.hist-item-no{width:20px;text-align:right;font-size:11px;font-weight:700;color:var(--text-dim);font-variant-numeric:tabular-nums}.hist-item-bar{width:4px;height:30px;border-radius:2px;flex-shrink:0}.hist-item-info{flex:1;min-width:0}.hist-item-name{font-size:14px;font-weight:600;color:var(--text-primary);display:flex;align-items:baseline;gap:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hist-item-attach{display:flex;gap:12px;font-size:10px;color:var(--text-dim);margin-top:2px}.hist-spacer{display:flex;align-items:center;gap:8px;background:var(--surface2);border-radius:8px;padding:8px 14px;font-size:11px;color:var(--text-secondary)}.hist-spacer-dur{margin-left:auto;font-variant-numeric:tabular-nums;color:var(--text-dim)}.song-picker-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:flex}@media (max-width: 767px){.song-picker-overlay{background:var(--bg-primary);flex-direction:column;height:100dvh}.song-picker-modal{width:100%;flex:1;min-height:0;max-height:none;border-radius:0;box-shadow:none;border:none}.song-picker-overlay{padding-top:env(safe-area-inset-top)}.song-picker-header{padding:12px 16px}.song-picker-search{font-size:16px;padding:10px 12px}.song-picker-row{padding:13px 16px;min-height:52px}}@media (min-width: 768px){.song-picker-overlay{background:#0009;align-items:center;justify-content:center}}.song-picker-modal{background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:12px;width:100%;max-width:480px;max-height:70vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 8px 40px #00000080}.song-picker-header{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--border);flex-shrink:0}.song-picker-title{font-size:14px;font-weight:600;color:var(--text-primary);white-space:nowrap}.song-picker-search{flex:1;background:var(--bg-tertiary);border:1px solid var(--border-light);border-radius:var(--radius);color:var(--text-primary);padding:7px 11px;font-size:14px;outline:none;transition:border-color .15s}.song-picker-search:focus{border-color:var(--accent)}.song-picker-search::placeholder{color:var(--text-dim)}.song-picker-close{background:none;border:none;color:var(--text-dim);font-size:14px;padding:4px 6px;border-radius:var(--radius);cursor:pointer;transition:color .15s,background .15s;flex-shrink:0}.song-picker-close:hover{color:var(--text-primary);background:var(--bg-hover)}.song-picker-list{flex:1;overflow-y:auto;padding:4px 0}.song-picker-empty{padding:32px 20px;text-align:center;color:var(--text-dim);font-size:13px}.song-picker-row{display:flex;align-items:center;gap:10px;width:100%;padding:10px 16px;background:none;border:none;border-bottom:1px solid var(--border);cursor:pointer;text-align:left;transition:background .1s}.song-picker-row:hover{background:var(--bg-hover)}.song-picker-row:last-child{border-bottom:none}.song-picker-bar{width:4px;height:32px;border-radius:2px;flex-shrink:0}.song-picker-info{flex:1;min-width:0}.song-picker-name{font-size:13px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.song-picker-meta{display:flex;gap:8px;margin-top:2px}.song-picker-album{font-size:11px;color:var(--text-dim)}.song-picker-tuning{font-size:11px;color:var(--blue);font-weight:500}.song-picker-dur{font-size:12px;font-variant-numeric:tabular-nums;color:var(--text-secondary);flex-shrink:0}.song-picker-add{font-size:20px;font-weight:300;color:var(--green);flex-shrink:0;line-height:1;width:24px;text-align:center}.song-picker-regulars{background:var(--surface2);border:1px solid var(--border);border-radius:999px;color:var(--text-secondary);font-size:11px;font-weight:600;padding:5px 11px;white-space:nowrap}.song-picker-regulars--on{border-color:var(--accent);color:var(--accent);background:var(--surface3)}.settings-modal{width:480px}.settings-loading{padding:32px;text-align:center;color:var(--text-dim)}.settings-body{padding:20px;display:flex;flex-direction:column;gap:20px}.settings-section{display:flex;flex-direction:column;gap:10px}.settings-section-title{font-size:13px;font-weight:600;color:var(--text-primary);letter-spacing:.02em;text-transform:uppercase}.settings-section-desc{font-size:13px;color:var(--text-secondary);line-height:1.5}.settings-link{color:var(--accent);font-family:monospace;font-size:12px}.settings-note{font-size:12px;color:var(--text-dim);line-height:1.5}.settings-error{font-size:13px;color:var(--red);padding:8px 12px;background:#e852521a;border:1px solid rgba(232,82,82,.25);border-radius:var(--radius)}.field-label-hint{font-weight:400;color:var(--text-dim);font-size:11px;text-transform:none;letter-spacing:0}.logo-upload-area{display:flex;align-items:center;gap:12px}.logo-upload-btn{background:var(--bg-tertiary);border:1px dashed var(--border-light);color:var(--text-secondary);padding:8px 16px;border-radius:var(--radius);font-size:13px;cursor:pointer;transition:border-color .15s,color .15s}.logo-upload-btn:hover{border-color:var(--accent);color:var(--text-primary)}.logo-preview-wrap{display:flex;align-items:center;gap:12px}.logo-preview{max-height:48px;max-width:160px;object-fit:contain;border-radius:4px;background:var(--bg-tertiary);padding:4px}.logo-remove{background:none;border:none;color:var(--red);font-size:12px;cursor:pointer;padding:4px 0;opacity:.7;transition:opacity .15s}.logo-remove:hover{opacity:1}@media (max-width: 767px){.settings-modal{width:100%}}.settings-profile-row{display:flex;align-items:center;gap:14px;margin-bottom:12px}.settings-profile-btns,.settings-account-btns{display:flex;gap:8px}.import-modal{width:520px;max-height:82vh;display:flex;flex-direction:column}.import-modal-tabs{display:flex;border-bottom:1px solid var(--border);flex-shrink:0}.import-modal-tab{flex:1;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);font-size:13px;font-weight:500;padding:10px 8px;cursor:pointer;transition:color .15s,border-color .15s;margin-bottom:-1px}.import-modal-tab:hover{color:var(--text-primary)}.import-modal-tab--active{color:var(--accent);border-bottom-color:var(--accent)}.import-tab-body{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}.import-search-bar{display:flex;gap:8px;padding:16px 20px 8px;flex-shrink:0}.import-search-input{flex:1;background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius);color:var(--text-primary);font-size:14px;padding:8px 12px;outline:none;transition:border-color .15s}.import-search-input:focus{border-color:var(--accent)}.import-search-input::placeholder{color:var(--text-dim)}.import-back-btn{background:none;border:none;color:var(--text-secondary);font-size:18px;padding:0 6px 0 0;cursor:pointer;flex-shrink:0;transition:color .15s}.import-back-btn:hover{color:var(--text-primary)}.import-artist-genre{font-size:11px;color:var(--text-dim);margin-right:4px}.import-search-hint{padding:0 20px 12px;font-size:11px;color:var(--text-dim);flex-shrink:0}.import-results{flex:1;overflow-y:auto;min-height:0}.import-results-header{display:flex;align-items:center;justify-content:space-between;padding:8px 20px;border-bottom:1px solid var(--border);background:var(--bg-tertiary);flex-shrink:0;position:sticky;top:0;z-index:1}.import-results-count{font-size:12px;color:var(--text-dim)}.import-link-btn{background:none;border:none;color:var(--accent);font-size:12px;cursor:pointer;padding:0}.import-link-btn:hover{text-decoration:underline}.import-albums{padding-bottom:8px}.import-album{border-bottom:1px solid var(--border)}.import-album-header{display:flex;align-items:center;gap:10px;padding:10px 20px;background:var(--bg-card);position:sticky;top:37px;z-index:1}.import-album-header input[type=checkbox]{accent-color:var(--accent);width:15px;height:15px;flex-shrink:0;cursor:pointer}.import-album-name{flex:1;font-size:13px;font-weight:600;color:var(--text-primary)}.import-album-count{font-size:11px;color:var(--text-dim)}.import-track-row{display:flex;align-items:center;gap:10px;padding:9px 20px 9px 32px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s}.import-track-row:hover{background:var(--bg-hover)}.import-track-row input[type=checkbox]{accent-color:var(--accent);width:14px;height:14px;flex-shrink:0;cursor:pointer}.import-track-name{flex:1;font-size:13px;color:var(--text-primary)}.import-track-duration{font-size:12px;color:var(--text-dim);font-variant-numeric:tabular-nums;flex-shrink:0}.import-tab-body--samply{overflow-y:auto}.samply-back-btn{background:none;border:none;border-bottom:1px solid var(--border);color:var(--text-secondary);font-size:13px;padding:12px 20px;width:100%;text-align:left;cursor:pointer;transition:color .15s,background .12s;flex-shrink:0}.samply-back-btn:hover{color:var(--text-primary);background:var(--bg-hover)}.import-list{list-style:none;padding:0;margin:0}.import-list-row{display:flex;align-items:center;gap:10px;width:100%;padding:13px 20px;background:none;border:none;border-bottom:1px solid var(--border);color:var(--text-primary);font-size:14px;text-align:left;cursor:pointer;transition:background .12s}.import-list-row:hover{background:var(--bg-hover)}.import-list-row--check{cursor:pointer}.import-list-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.import-list-name{flex:1;font-size:14px;font-weight:500}.import-chevron{color:var(--text-dim);font-size:18px}.import-files-header{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;border-bottom:1px solid var(--border);background:var(--bg-tertiary);flex-shrink:0}.import-check-label{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary);cursor:pointer}.import-check-label input{accent-color:var(--accent);width:16px;height:16px;cursor:pointer}.import-sel-count{font-size:12px;color:var(--text-dim)}.import-list--files .import-list-row{gap:12px}.import-list--files input[type=checkbox]{accent-color:var(--accent);width:16px;height:16px;flex-shrink:0;cursor:pointer}.import-file-ext{font-size:11px;color:var(--text-dim);font-family:monospace}.samply-file-item{display:flex;flex-direction:column}.samply-play-btn{background:none;border:1px solid var(--border-light);border-radius:4px;color:var(--text-secondary);font-size:10px;padding:2px 7px;flex-shrink:0;transition:background .1s,color .1s,border-color .1s}.samply-play-btn:hover,.samply-play-btn--active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}.samply-embed-wrap{padding:4px 16px 12px}.samply-audio{width:100%;display:block}.samply-audio-error{padding:4px 16px 8px;font-size:11px;color:var(--red)}.import-tab-body--json{padding:28px 24px;gap:16px;justify-content:flex-start}.import-json-desc{font-size:13px;color:var(--text-secondary);line-height:1.6;margin:0 0 20px}.import-json-desc code{background:var(--bg-tertiary);padding:1px 5px;border-radius:3px;font-size:12px;color:var(--text-primary)}.import-loading,.import-empty{padding:40px 20px;text-align:center;color:var(--text-dim);font-size:14px}.import-error{padding:16px 20px;color:var(--red);font-size:13px;line-height:1.5}.import-error-hint{margin-top:8px;color:var(--text-secondary)}.import-note{padding:12px 20px;font-size:12px;color:var(--text-dim);line-height:1.5;border-top:1px solid var(--border)}.import-footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 20px;border-top:1px solid var(--border);background:var(--bg-secondary);flex-shrink:0}@media (max-width: 767px){.import-modal{width:100%;max-height:92dvh}.import-list-row,.import-track-row{min-height:48px}.import-album-header{top:0}}.albums-modal{width:100%;max-width:460px;display:flex;flex-direction:column;max-height:80vh}.albums-body{overflow-y:auto;padding:6px 0;flex:1}.albums-empty{font-size:12px;color:var(--text-dim);padding:10px 16px}.album-row-group{border-bottom:1px solid var(--border)}.album-row-group:last-child{border-bottom:none}.album-manage-row{display:flex;align-items:center;gap:10px;padding:10px 16px;cursor:pointer}.album-manage-row:hover{background:var(--bg-hover)}.album-manage-dot{width:12px;height:12px;border-radius:4px;flex-shrink:0}.album-manage-name{flex:1;min-width:0;font-size:13px;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.album-rename-input{flex:1;min-width:0;background:var(--bg-tertiary);border:1px solid var(--accent);border-radius:var(--radius);color:var(--text-primary);font-size:13px;padding:3px 8px;outline:none}.album-manage-count{font-size:11px;color:var(--text-dim);flex-shrink:0}.album-manage-btn{background:none;border:none;color:var(--text-dim);font-size:12px;padding:4px 6px;border-radius:var(--radius);transition:color .15s,background .15s}.album-manage-btn:hover:not(:disabled){color:var(--text-primary);background:var(--bg-tertiary)}.album-manage-btn:disabled{opacity:.3;cursor:not-allowed}.album-manage-btn--danger:hover:not(:disabled){color:var(--red);background:#e852521a}.album-manage-chevron{color:var(--text-dim);font-size:16px;transition:transform .15s}.album-manage-chevron--open{transform:rotate(90deg)}.album-tracks{padding:2px 16px 10px 38px}.album-track-row{display:flex;align-items:center;gap:8px;padding:4px 0}.album-track-no{width:18px;font-size:11px;font-weight:700;color:var(--text-dim);font-variant-numeric:tabular-nums;text-align:right}.album-track-name{flex:1;min-width:0;font-size:12px;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.album-track-dur{font-size:11px;color:var(--text-dim);font-variant-numeric:tabular-nums}.album-set-order{margin-top:6px;font-size:11px}.albums-error{font-size:12px;color:var(--red);padding:6px 16px}.albums-actions{justify-content:space-between;padding:12px 16px;border-top:1px solid var(--border)}.onboarding-modal{width:400px}.onboarding-body{padding:36px 32px 28px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px}.onboarding-icon{width:64px;height:64px;object-fit:contain;border-radius:16px}.onboarding-title{font-size:18px;font-weight:700;color:var(--text-primary);margin:0}.onboarding-desc{font-size:13px;color:var(--text-secondary);margin:0;line-height:1.5}.onboarding-input{width:100%;background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius);color:var(--text-primary);font-size:15px;padding:10px 14px;outline:none;margin-top:4px;box-sizing:border-box;transition:border-color .15s}.onboarding-input:focus{border-color:var(--accent)}.onboarding-input::placeholder{color:var(--text-dim)}.onboarding-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:8px;width:100%}@media (max-width: 767px){.onboarding-modal{width:100%;margin:0 16px}}.install-banner{position:fixed;left:16px;right:16px;bottom:calc(84px + env(safe-area-inset-bottom,0px));background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:16px;padding:14px 16px;display:flex;align-items:center;gap:12px;z-index:60;box-shadow:0 8px 32px #0009;animation:install-banner-in .3s ease}@keyframes install-banner-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.install-banner-icon{width:48px;height:48px;border-radius:12px;flex-shrink:0;object-fit:cover}.install-banner-body{flex:1;min-width:0}.install-banner-title{font-size:13px;font-weight:600;color:var(--text-primary);margin-bottom:3px}.install-banner-steps{font-size:12px;color:var(--text-secondary);line-height:1.4}.install-banner-icon-inline{font-size:13px;background:var(--bg-tertiary);border:1px solid var(--border-light);border-radius:4px;padding:1px 5px;font-family:inherit}.install-banner-close{background:none;border:none;color:var(--text-dim);font-size:12px;padding:6px;border-radius:6px;flex-shrink:0;cursor:pointer;transition:color .15s;align-self:flex-start}.install-banner-close:hover{color:var(--text-primary)}.shell{height:100%;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-primary)}.split{flex:1;display:flex;overflow:hidden}.sidebar{flex:0 0 340px;min-width:300px;border-right:1px solid var(--border);background:var(--bg-secondary);overflow:hidden;display:flex;flex-direction:column}.detail{flex:1;min-width:0;overflow:hidden;display:flex;flex-direction:column;background:var(--bg-primary)}.detail-empty-wrap{flex:1;display:flex;align-items:center;justify-content:center}.detail-empty{color:var(--text-dim);font-size:13px}@media (max-width: 767px){.sidebar{flex:1 1 auto;min-width:0;border-right:none}.split[data-detail=false] .detail,.split[data-detail=true] .sidebar{display:none}}.rule-alert{position:fixed;top:14px;left:50%;transform:translate(-50%);z-index:200;background:#e8525224;border:1px solid rgba(232,82,82,.45);color:#ffb3b3;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:9px 18px;border-radius:999px;font-size:12px;font-weight:600;cursor:pointer;box-shadow:0 8px 26px #00000073;max-width:min(92vw,560px);text-align:center}.drag-overlay-item{display:flex;align-items:center;gap:10px;background:var(--bg-card);border:1px solid var(--border-light);border-radius:10px;padding:10px 14px;box-shadow:0 14px 40px #0009;min-width:220px}.drag-overlay-bar{width:4px;height:30px;border-radius:2px;flex-shrink:0}.drag-overlay-info{flex:1;min-width:0}.drag-overlay-name{font-size:13px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.drag-overlay-album{font-size:11px;color:var(--text-dim)}.drag-overlay-duration{font-size:12px;color:var(--text-secondary);font-variant-numeric:tabular-nums}.app-version{position:fixed;bottom:4px;right:8px;font-size:9px;color:var(--text-dim);opacity:.5;z-index:10;pointer-events:none}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal{background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-lg);width:480px;max-width:calc(100vw - 40px);max-height:calc(100dvh - 60px);overflow-y:auto;box-shadow:0 20px 60px #00000080}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--border)}.modal-header h2{font-size:16px;font-weight:600;color:var(--text-primary)}.modal-close{background:none;border:none;color:var(--text-dim);font-size:14px;padding:4px 6px;border-radius:var(--radius);transition:color .15s,background .15s}.modal-close:hover{color:var(--text-primary);background:var(--bg-hover)}.modal-form{padding:20px 24px;display:flex;flex-direction:column;gap:18px}.field{display:flex;flex-direction:column;gap:7px}.field label{font-size:12px;font-weight:500;color:var(--text-secondary);letter-spacing:.04em;text-transform:uppercase}.label-hint{font-weight:400;text-transform:none;letter-spacing:0;color:var(--text-dim)}.field input,.field select,.field textarea{background:var(--bg-tertiary);border:1px solid var(--border-light);border-radius:var(--radius);color:var(--text-primary);padding:9px 12px;outline:none;transition:border-color .15s}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent)}.field input::placeholder{color:var(--text-dim)}.modal-actions{display:flex;justify-content:flex-end;gap:10px;padding-top:4px}.btn-primary{background:var(--accent);border:none;color:#fff;padding:9px 20px;border-radius:var(--radius);font-weight:600;font-size:13px;transition:background .15s,transform .1s}.btn-primary:hover{background:var(--accent-hover)}.btn-primary:active{transform:scale(.98)}.btn-ghost{background:none;border:1px solid var(--border-light);color:var(--text-secondary);padding:9px 16px;border-radius:var(--radius);font-weight:500;font-size:13px;transition:border-color .15s,color .15s,background .15s}.btn-ghost:hover{border-color:var(--text-dim);color:var(--text-primary);background:var(--bg-hover)}@media (max-width: 767px){.modal-overlay{align-items:flex-end;padding:0}.modal{width:100%;max-width:100%;max-height:90dvh;border-radius:14px 14px 0 0}.modal-close{min-width:44px;min-height:44px}.field input,.field select,.field textarea{font-size:16px}.modal-actions{flex-direction:column-reverse;gap:8px}.modal-actions .btn-primary,.modal-actions .btn-ghost{width:100%;padding:13px 20px;justify-content:center}.duration-inputs input{width:80px;padding:11px 12px}}.btn-ghost{background:none;border:1px solid var(--border-light);color:var(--text-secondary);padding:5px 10px;border-radius:var(--radius);font-size:12px;font-weight:500;cursor:pointer;transition:border-color .15s,color .15s}.btn-ghost:hover:not(:disabled){border-color:var(--text-dim);color:var(--text-primary)}.btn-ghost:disabled{opacity:.35;cursor:not-allowed}.btn-save{background:var(--accent);border:none;color:#fff;padding:5px 14px;border-radius:var(--radius);font-size:12px;font-weight:600;transition:background .15s,opacity .15s}.btn-save:hover:not(:disabled){background:var(--accent-hover)}.btn-save:disabled{opacity:.35;cursor:not-allowed}.btn-save--dirty{background:var(--accent);box-shadow:0 0 0 2px var(--accent-dim)}.btn-save--dirty:hover:not(:disabled){background:var(--accent-hover)}.save-dot{display:inline-block;width:5px;height:5px;background:#fff;border-radius:50%;margin-left:5px;opacity:.8;vertical-align:middle}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary: #0e0e10;--bg-secondary: #141417;--bg-tertiary: #1b1b1f;--surface2: #27272c;--surface3: #36363c;--bg-hover: #27272c;--bg-card: #1b1b1f;--border: #2a2a2f;--border-light: #36363c;--accent: #e8732a;--accent-hover: #f0863d;--accent-dim: rgba(232, 115, 42, .15);--text-primary: #f4f4f5;--text-secondary: #9a9aa0;--text-dim: #78787e;--time-badge-bg: #e9e9ec;--time-badge-text: #17171a;--red: #e85252;--green: #52c87a;--blue: #5296e8;--purple: #9b52e8;--yellow: #e8c952;--radius: 6px;--radius-lg: 10px;--tab-bar-h: 64px}html,body{height:100%;overflow:hidden;overscroll-behavior:none;background:var(--bg-primary);color:var(--text-primary);font-family:Inter,system-ui,-apple-system,sans-serif;font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}#root{height:100%;overflow:hidden}button{cursor:pointer;font-family:inherit;font-size:inherit}input,textarea,select{font-family:inherit;font-size:inherit}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}@media (max-width: 767px){input,textarea,select{font-size:max(16px,1em)!important}}
