:root{--bg-primary: #1a1a1a;--bg-secondary: #2d2d2d;--bg-tertiary: #3d3d3d;--text-primary: #ffffff;--text-secondary: #bbbbbb;--text-muted: #888888;--accent: #00d0ff;--accent-glow: rgba(0, 208, 255, .3);--accent-hover: #00b8e0;--success: #00ff66;--success-dark: #006633;--warning: #ffaa00;--danger: #ff4444;--timecode-bg: #000000;--timecode-fg: #00ff66;--progress-bg: #1e1e1e;--progress-fill: #00d0ff;--space-xs: 4px;--space-sm: 8px;--space-md: 12px;--space-lg: 16px;--space-xl: 20px;--space-2xl: 24px;--space-3xl: 32px;--space-4xl: 40px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-pill: 20px;--transition-fast: .1s linear;--transition-normal: .15s ease;--transition-slow: .3s ease;--font-ui: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: "SF Mono", "Menlo", "Monaco", "Fira Code", monospace;--text-xs: .625rem;--text-sm: .75rem;--text-base: .875rem;--text-md: 1rem;--text-lg: 1.25rem;--text-xl: 1.5rem;--text-2xl: 2rem;--text-3xl: 3rem;--text-4xl: 4.5rem;--text-5xl: 5rem;--text-6xl: 7rem;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .3);--shadow-glow: 0 0 12px var(--accent-glow)}[data-theme=light]{--bg-primary: #f5f5f5;--bg-secondary: #ffffff;--bg-tertiary: #e8e8e8;--text-primary: #1a1a1a;--text-secondary: #555555;--text-muted: #888888;--accent: #0088cc;--accent-glow: rgba(0, 136, 204, .3);--accent-hover: #006faa;--success: #00aa44;--success-dark: #005522;--warning: #cc8800;--danger: #dd3333;--timecode-bg: #1a1a1a;--timecode-fg: #00ff66;--progress-bg: #dddddd;--progress-fill: #0088cc;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .1);--shadow-md: 0 4px 12px rgba(0, 0, 0, .1);--shadow-glow: 0 0 12px var(--accent-glow)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;font-family:var(--font-ui);background-color:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);overscroll-behavior:none;-webkit-tap-highlight-color:transparent}#root{height:100%;display:flex;flex-direction:column}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes slideInLeft{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes slideInUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.sp-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);font-family:var(--font-ui);font-weight:600;border:none;border-radius:var(--radius-md);cursor:pointer;transition:opacity var(--transition-fast),background var(--transition-normal);white-space:nowrap;line-height:1}.sp-btn:active{opacity:.7}.sp-btn:disabled{opacity:.4;cursor:not-allowed}.sp-btn--sm{padding:6px 12px;font-size:var(--text-base)}.sp-btn--md{padding:10px 18px;font-size:var(--text-base)}.sp-btn--lg{padding:14px 24px;font-size:var(--text-md)}.sp-btn--transport{padding:var(--space-xl) var(--space-lg);font-size:var(--text-lg);border-radius:var(--radius-lg);min-width:120px}.sp-btn--primary{background:var(--accent);color:var(--bg-primary)}.sp-btn--primary:hover:not(:disabled){background:var(--accent-hover)}.sp-btn--success{background:var(--success);color:var(--bg-primary)}.sp-btn--success:hover:not(:disabled){background:#0d5}.sp-btn--danger{background:var(--danger);color:#fff}.sp-btn--danger:hover:not(:disabled){background:#e33}.sp-btn--ghost{background:transparent;color:var(--text-secondary)}.sp-btn--ghost:hover:not(:disabled){background:var(--bg-tertiary)}.sp-btn--outline{background:transparent;color:var(--accent);border:1px solid var(--accent)}.sp-btn--outline:hover:not(:disabled){background:var(--accent);color:var(--bg-primary)}.sp-btn__icon{display:flex;align-items:center}.sp-btn__spinner{width:16px;height:16px;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:spin .6s linear infinite}.sp-input-wrapper{display:flex;flex-direction:column;gap:var(--space-xs)}.sp-input-label{font-size:var(--text-base);font-weight:500;color:var(--text-secondary)}.sp-input{width:100%;padding:var(--space-md) var(--space-lg);font-size:var(--text-md);background:var(--bg-secondary);border:1px solid var(--bg-tertiary);border-radius:var(--radius-md);color:var(--text-primary);transition:border-color var(--transition-normal)}.sp-input::placeholder{color:var(--text-muted)}.sp-input:focus{outline:none;border-color:var(--accent)}.sp-input--error{border-color:var(--danger)}.sp-input-error{font-size:var(--text-sm);color:var(--danger)}.sp-modal{position:fixed;inset:0;z-index:100}.sp-modal__backdrop{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fadeIn .15s ease}.sp-modal__container{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:var(--space-lg);z-index:101}.sp-modal__panel{background:var(--bg-secondary);border:1px solid var(--bg-tertiary);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);width:100%;max-height:85vh;display:flex;flex-direction:column;animation:scaleIn .15s ease}.sp-modal__panel--sm{max-width:360px}.sp-modal__panel--md{max-width:480px}.sp-modal__panel--lg{max-width:640px}.sp-modal__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg) var(--space-xl);border-bottom:1px solid var(--bg-tertiary)}.sp-modal__title{font-size:var(--text-lg);font-weight:700;color:var(--text-primary)}.sp-modal__close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer}.sp-modal__close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.sp-modal__body{padding:var(--space-xl);overflow-y:auto}.sp-badge{display:inline-flex;align-items:center;padding:2px 8px;font-size:var(--text-sm);font-weight:600;border-radius:var(--radius-pill);line-height:1.4}.sp-badge--default{background:var(--bg-tertiary);color:var(--text-secondary)}.sp-badge--success{background:#00ff6626;color:var(--success)}.sp-badge--warning{background:#ffaa0026;color:var(--warning)}.sp-badge--danger{background:#ff444426;color:var(--danger)}.sp-progress{height:8px;background:var(--progress-bg);border-radius:4px;overflow:hidden}.sp-progress__fill{height:100%;background:var(--progress-fill);border-radius:4px;transition:width var(--transition-fast)}.sp-toast-container{position:fixed;bottom:var(--space-xl);left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);z-index:200;max-width:480px;width:max-content}.sp-toast{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);font-size:var(--text-base);font-weight:500;animation:slideInUp .2s ease;box-shadow:var(--shadow-md)}.sp-toast--info{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--bg-tertiary)}.sp-toast--success{background:#00ff6626;color:var(--success);border:1px solid var(--success)}.sp-toast--error{background:#ff444426;color:var(--danger);border:1px solid var(--danger)}.sp-toast__close{background:none;border:none;color:inherit;cursor:pointer;opacity:.6;padding:2px;display:flex}.sp-toast__close:hover{opacity:1}.sp-toast__action{background:transparent;border:1px solid currentColor;border-radius:999px;color:inherit;padding:3px 12px;font-size:.75rem;font-weight:600;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:background .15s,color .15s}.sp-toast__action:hover{background:currentColor;color:var(--bg-primary)}.sp-tooltip-wrapper{position:relative;display:inline-flex}.sp-tooltip{position:absolute;z-index:150;padding:var(--space-xs) var(--space-sm);font-size:var(--text-sm);font-weight:500;color:var(--text-primary);background:var(--bg-tertiary);border-radius:var(--radius-sm);white-space:nowrap;pointer-events:none;animation:fadeIn .1s ease;box-shadow:var(--shadow-md)}.sp-tooltip--top{bottom:calc(100% + 6px);left:50%;transform:translate(-50%)}.sp-tooltip--bottom{top:calc(100% + 6px);left:50%;transform:translate(-50%)}.sp-tooltip--left{right:calc(100% + 6px);top:50%;transform:translateY(-50%)}.sp-tooltip--right{left:calc(100% + 6px);top:50%;transform:translateY(-50%)}.sp-sidebar{position:fixed;inset:0;z-index:100}.sp-sidebar__backdrop{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fadeIn .2s ease}.sp-sidebar__container{position:fixed;inset:0;display:flex;z-index:101}.sp-sidebar__container--right{justify-content:flex-end}.sp-sidebar__container--left{justify-content:flex-start}.sp-sidebar__panel{display:flex;flex-direction:column;width:340px;max-width:85vw;height:100%;background:var(--bg-secondary);border:1px solid var(--bg-tertiary);box-shadow:var(--shadow-md)}.sp-sidebar__panel--right{animation:slideInRight .2s ease}.sp-sidebar__panel--left{animation:slideInLeft .2s ease}.sp-sidebar__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg) var(--space-xl);border-bottom:1px solid var(--bg-tertiary);flex-shrink:0}.sp-sidebar__title{font-size:var(--text-lg);font-weight:700;color:var(--text-primary)}.sp-sidebar__close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer}.sp-sidebar__close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.sp-sidebar__body{flex:1;overflow-y:auto;padding:var(--space-xl)}.app{height:100%;display:flex;flex-direction:column;overflow:hidden}.header{display:flex;align-items:center;padding:var(--space-md) var(--space-lg);background:var(--bg-secondary);border-bottom:1px solid var(--bg-tertiary);gap:var(--space-sm)}.header-brand{display:flex;align-items:center;gap:var(--space-sm);flex:1}.header-indicator{width:10px;height:10px;border-radius:50%;background:var(--danger);box-shadow:0 0 8px var(--danger);transition:background .3s ease,box-shadow .3s ease}.header-indicator--connected{background:var(--success);box-shadow:0 0 8px var(--success)}.header-indicator--connecting{background:#fa0;box-shadow:0 0 8px #fa0;animation:pulse-indicator 1.5s ease-in-out infinite}.header-indicator--disconnected{background:var(--danger);box-shadow:0 0 8px var(--danger)}@keyframes pulse-indicator{0%,to{opacity:1}50%{opacity:.4}}.header-title{font-size:var(--text-sm);font-weight:600;letter-spacing:.1em;color:var(--text-secondary);text-transform:uppercase}.header-actions{display:flex;align-items:center;gap:var(--space-xs)}.header-divider{width:1px;height:20px;background:var(--bg-tertiary);margin:0 var(--space-xs)}.icon-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:none;border-radius:var(--radius-md);background:transparent;color:var(--text-secondary);font-size:var(--text-lg);cursor:pointer;transition:background var(--transition-normal)}.icon-btn:hover,.icon-btn:active{background:var(--bg-tertiary)}.icon-btn.active{background:var(--accent);color:var(--bg-primary)}.icon-btn:disabled{opacity:.25;cursor:not-allowed}.icon-btn:disabled:hover{background:transparent}.main-content{flex:1;display:flex;overflow:hidden}.panel-left{width:140px;min-width:420px;max-width:430px;display:flex;flex-direction:column;overflow:hidden;border-right:1px solid var(--bg-tertiary);background:var(--bg-primary);flex-shrink:0}.panel-right{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-primary)}.section-label{font-size:var(--text-md);font-weight:600;color:var(--text-muted);letter-spacing:.1em;text-transform:uppercase}.setlist-header{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--bg-tertiary);background:var(--bg-secondary);display:flex;align-items:center;gap:var(--space-sm)}.setlist-header-actions{display:flex;gap:var(--space-xs);margin-left:auto}.setlist-live-badge{display:inline-flex;align-items:center;gap:4px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--danger);background:#ff44441a;border:1px solid rgba(255,68,68,.3);border-radius:var(--radius-sm);padding:2px 8px;animation:pulse-live 2s ease-in-out infinite}@keyframes pulse-live{0%,to{opacity:1}50%{opacity:.6}}.setlist-viewer-badge{font-size:.7rem;color:var(--text-muted);background:var(--bg-tertiary);border-radius:var(--radius-sm);padding:2px 8px;font-style:italic}.setlist-collaborators{display:flex;gap:-4px}.setlist-collaborator-avatar{width:24px;height:24px;border-radius:50%;background:var(--accent);color:var(--bg-primary);font-size:.7rem;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid var(--bg-secondary);margin-left:-4px}.setlist-collaborator-avatar:first-child{margin-left:0}.panel-left.live-flash{box-shadow:inset 0 0 0 2px var(--accent);transition:box-shadow .15s ease}.setlist-items{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.setlist-items.drag-over{background:#00d0ff0a}.setlist-drop-indicator{height:2px;background:var(--accent);margin:0 var(--space-lg);border-radius:1px;pointer-events:none}.setlist-item{display:flex;align-items:center;padding:var(--space-md) var(--space-lg);font-size:.95rem;font-weight:500;color:var(--text-secondary);border-bottom:1px solid var(--bg-tertiary);transition:background var(--transition-normal),color var(--transition-normal);cursor:grab}.setlist-item:hover{background:var(--bg-secondary)}.setlist-item.current{background:var(--success);color:var(--bg-primary);font-weight:700}.setlist-item.past{opacity:.5}.setlist-item-number{width:28px;font-size:var(--text-sm);color:var(--text-muted);font-weight:400;flex-shrink:0}.setlist-item.current .setlist-item-number{color:var(--bg-primary)}.setlist-item-info{flex:1;overflow:hidden;min-width:0;display:flex;flex-direction:column;gap:1px}.setlist-item-name{overflow:hidden;white-space:nowrap;min-width:0}.setlist-item-meta{display:flex;gap:var(--space-sm);font-size:.7rem;color:var(--text-muted);opacity:.7}.setlist-item-bpm,.setlist-item-key{font-family:var(--font-mono)}.setlist-item-notes{font-style:italic;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.setlist-item-audio-icon{flex-shrink:0;color:var(--success);opacity:.7}.setlist-item.current .setlist-item-audio-icon{color:var(--bg-primary);opacity:1}.setlist-item-duration{font-size:var(--text-sm);color:var(--text-muted);font-family:var(--font-mono);margin-left:var(--space-md);flex-shrink:0;padding:2px 8px;border-radius:var(--radius-sm)}.setlist-item.current .setlist-item-duration{background:#00000040;color:#fff;font-weight:600}.setlist-break{border-left:3px solid var(--warning);background:#f59e0b0f}.setlist-break .break-icon{color:var(--warning);flex-shrink:0;margin-right:var(--space-sm)}.setlist-break .break-label{font-size:var(--text-sm);color:var(--warning);font-style:italic;font-weight:500;flex:1}.setlist-break.current{background:var(--warning);border-left-color:var(--warning)}.setlist-break.current .break-icon,.setlist-break.current .break-label{color:#000}.setlist-break.past{opacity:.4}.setlist-footer{padding:var(--space-md) var(--space-lg);background:var(--bg-secondary);border-top:1px solid var(--bg-tertiary);display:flex;align-items:center;justify-content:space-between;font-size:var(--text-base)}.setlist-footer-total{font-family:var(--font-mono);font-weight:600;color:var(--timecode-fg)}.setlist-footer-count{color:var(--text-muted)}.setlist-title{text-align:center;padding:var(--space-xl) var(--space-lg);font-size:var(--text-2xl);font-weight:700;display:flex;align-items:center;justify-content:center;gap:var(--space-sm)}.dirty-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--warning);flex-shrink:0}.now-playing{padding:var(--space-lg);flex:1;min-height:0;display:flex;flex-direction:column}.now-playing-card{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:var(--space-4xl);text-align:center;flex:1;min-height:0;display:flex;flex-direction:column;justify-content:center}.now-playing-card.playing{border:1px solid var(--success);box-shadow:0 0 20px #00ff661a}.now-playing-name{font-weight:700;line-height:1.1;word-break:break-word;flex:1;min-height:0;overflow:hidden}.now-playing-notes{font-size:var(--text-sm);color:var(--accent);font-style:italic;margin-top:var(--space-sm);opacity:.85}.progress-bar-container{position:relative;margin-top:var(--space-lg);padding:10px 0}.progress-bar{position:relative;height:6px;background:var(--bg-tertiary);border-radius:3px;cursor:pointer;overflow:visible}.progress-bar-fill{position:absolute;top:0;height:100%;background:var(--success);border-radius:3px;transition:width .1s linear,left .1s linear}.progress-bar-dim{position:absolute;top:0;left:0;height:100%;background:#00000080;border-radius:3px 0 0 3px;pointer-events:none;z-index:1}.progress-bar-dim-end{position:absolute;top:0;height:100%;background:#00000080;border-radius:0 3px 3px 0;pointer-events:none;z-index:1}.cue-handle{position:absolute;width:0;height:0;cursor:ew-resize;z-index:2;transform:translate(-6px);transition:opacity var(--transition-fast)}.cue-handle-in{top:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:8px solid var(--accent)}.cue-handle-out{top:auto;bottom:0;border-left:6px solid transparent;border-right:6px solid transparent;border-bottom:8px solid var(--accent)}.cue-handle:hover{opacity:.8}.cue-handle:after{content:"";position:absolute;inset:-10px}.cue-controls-row{display:flex;justify-content:center;gap:var(--space-sm);margin-top:var(--space-md)}.cue-btn{padding:4px 12px;font-size:var(--text-sm);font-weight:600;background:var(--bg-tertiary);border:none;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:background var(--transition-normal),color var(--transition-normal)}.cue-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.cue-btn--clear{color:var(--danger)}.cue-btn--clear:hover{background:#ff444426;color:var(--danger)}.audio-controls-row{display:flex;align-items:center;gap:var(--space-sm);padding:0 var(--space-lg);justify-content:center}.volume-slider{width:100px;height:4px;-webkit-appearance:none;appearance:none;background:var(--bg-tertiary);border-radius:2px;outline:none;cursor:pointer}.volume-slider::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--text-secondary);cursor:pointer}.volume-slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--text-secondary);border:none;cursor:pointer}.speed-btn{background:var(--bg-tertiary);border:none;border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--text-sm);font-weight:600;font-family:var(--font-mono);padding:4px 10px;cursor:pointer;transition:background var(--transition-normal),color var(--transition-normal)}.speed-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.song-position{text-align:center;font-size:var(--text-xs);color:var(--text-muted);padding:var(--space-xs) var(--space-lg)}.gap-countdown{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg)}.gap-countdown-label{font-size:var(--text-xs);color:var(--accent);white-space:nowrap;font-weight:500;min-width:70px}.gap-countdown-bar{flex:1;height:4px;background:var(--bg-tertiary);border-radius:2px;overflow:hidden}.gap-countdown-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .05s linear}.drop-zone-row{display:flex;margin:0 var(--space-lg)}.drop-zone-action{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-lg) var(--space-xl);background:var(--bg-tertiary);border-radius:var(--radius-lg);border:none;font-size:var(--text-lg);font-weight:600;color:var(--text-secondary);cursor:pointer;transition:background var(--transition-normal),color var(--transition-normal)}.drop-zone-action:hover{color:var(--text-primary);background:var(--bg-secondary)}.drop-zone-row.drag-over .drop-zone-action{border:2px dashed var(--accent);background:#00d0ff14;color:var(--accent)}.timer-row{display:flex;justify-content:center;padding:var(--space-md) var(--space-lg);gap:var(--space-sm)}.timer-item{flex:1;display:flex;flex-direction:column;align-items:center;padding:var(--space-md) var(--space-sm);background:var(--timecode-bg);border-radius:var(--radius-lg)}.timer-label{font-size:.6rem;font-weight:600;color:var(--text-muted);letter-spacing:.12em;text-transform:uppercase;margin-bottom:var(--space-xs)}.timer-value{font-family:var(--font-mono);font-size:var(--text-2xl);font-weight:600;color:var(--timecode-fg)}.transport-controls{display:flex;gap:var(--space-md);padding:var(--space-md) var(--space-lg) var(--space-lg);justify-content:center;align-items:center}.transport-btn{flex:1;max-width:160px;padding:var(--space-lg) var(--space-md);font-size:var(--text-base);font-weight:600;border:none;border-radius:var(--radius-lg);cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-xs);transition:opacity var(--transition-fast)}.transport-label{font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.08em}.transport-btn:active{opacity:.7}.transport-btn.play{background:var(--success);color:var(--bg-primary)}.transport-btn.play.playing{background:var(--success-dark);box-shadow:inset 0 2px 8px #0006}.transport-btn.stop{background:var(--danger);color:var(--text-primary)}.transport-btn.auto-play{background:var(--bg-tertiary);color:var(--text-secondary)}.transport-btn.auto-play:hover{background:var(--bg-secondary);color:var(--text-primary)}.transport-btn.auto-play.active{background:var(--accent);color:var(--bg-primary)}.transport-btn.nav{flex:0;max-width:48px;padding:var(--space-md);background:var(--bg-tertiary);color:var(--text-secondary)}.transport-btn.nav:hover{background:var(--bg-secondary);color:var(--text-primary)}.transport-btn.nav:disabled{opacity:.3;cursor:not-allowed}.library{width:400px;min-width:320px;display:flex;flex-direction:column;background:var(--bg-secondary);border-right:1px solid var(--bg-tertiary);overflow:hidden}.library-header{padding:var(--space-md) var(--space-lg);display:flex;flex-direction:column;gap:var(--space-sm);border-bottom:1px solid var(--bg-tertiary)}.library-header-top{display:flex;align-items:center;gap:var(--space-sm);color:var(--text-muted)}.library-count{font-size:var(--text-sm);color:var(--text-muted);margin-left:var(--space-xs)}.library-team-badge{display:inline-flex;align-items:center;gap:4px;font-size:.7rem;color:var(--accent);background:#00d0ff1a;border:1px solid rgba(0,208,255,.2);border-radius:var(--radius-sm);padding:2px 6px;margin-left:var(--space-xs)}.library-team-role{color:var(--text-muted);font-style:italic}.library-search{position:relative;display:flex;align-items:center}.library-search-icon{position:absolute;left:10px;color:var(--text-muted);pointer-events:none}.library-search-input{width:100%;padding:var(--space-sm) var(--space-md) var(--space-sm) 32px;font-size:var(--text-base);background:var(--bg-primary);border:1px solid var(--bg-tertiary);border-radius:var(--radius-md);color:var(--text-primary)}.library-search-input::placeholder{color:var(--text-muted)}.library-search-input:focus{outline:none;border-color:var(--accent)}.library-items{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.library-empty{padding:var(--space-3xl);text-align:center;color:var(--text-muted);font-style:italic;font-size:var(--text-base)}.library-item{padding:var(--space-sm) var(--space-lg);display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm);border-bottom:1px solid var(--bg-tertiary);transition:background var(--transition-normal)}.library-item:hover{background:var(--bg-primary)}.library-item[draggable=true]{cursor:grab}.library-item[draggable=true]:active{cursor:grabbing}.library-item-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.library-item-name{font-size:var(--text-base);font-weight:500;color:var(--text-primary);overflow:hidden;white-space:nowrap;min-width:0}.library-item-badge{flex-shrink:0}.library-item-duration{font-size:var(--text-sm);font-family:var(--font-mono);color:var(--text-muted)}.library-item-meta{font-family:var(--font-sans);color:var(--text-muted);font-size:var(--text-xs)}.library-upload-progress{position:relative;height:14px;background:var(--bg-tertiary, #1a1a1a);border-radius:7px;overflow:hidden;margin-top:3px}.library-upload-progress-bar{position:absolute;top:0;left:0;height:100%;background:var(--accent, #00d0ff);border-radius:7px;transition:width .15s ease-out}.library-upload-progress-text{position:relative;z-index:1;display:block;text-align:center;font-size:.6rem;line-height:14px;color:var(--text-primary, #fff);font-family:var(--font-mono)}.library-item-actions{display:flex;align-items:center;gap:var(--space-xs);flex-shrink:0}.library-item-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;transition:background var(--transition-normal),color var(--transition-normal)}.library-item-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.library-item-btn--danger:hover{color:var(--danger)}.library-item-btn--audio{color:var(--success)}.library-item-btn--audio:hover{color:var(--success);background:var(--bg-tertiary)}.library-toolbar{display:flex;gap:var(--space-sm);align-items:center}.library-sort{display:flex;align-items:center;gap:4px;color:var(--text-muted);flex-shrink:0}.library-sort-select{background:var(--bg-primary);border:1px solid var(--bg-tertiary);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:var(--text-sm);padding:4px 6px;cursor:pointer}.library-sort-select:focus{outline:none;border-color:var(--accent)}.library-item--selected{background:#00d0ff14;border-color:var(--accent)}.library-item-checkbox{color:var(--text-muted);flex-shrink:0;display:flex;align-items:center}.library-item--selected .library-item-checkbox{color:var(--accent)}.library-bulk-bar{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--bg-primary);border-radius:var(--radius-sm);border:1px solid var(--border)}.library-bulk-count{font-size:var(--text-sm);color:var(--text-secondary);margin-right:auto}.load-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);background:var(--bg-primary);border-radius:var(--radius-md);gap:var(--space-md)}.load-item-info{flex:1;min-width:0}.load-item-name{font-size:var(--text-md);font-weight:600;color:var(--text-primary);display:block}.load-item-meta{font-size:var(--text-sm);color:var(--text-muted);display:block;margin-top:2px}.load-item-actions{display:flex;align-items:center;gap:var(--space-sm);flex-shrink:0}.auth-page{height:100%;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);padding:var(--space-lg)}.auth-loading{color:var(--text-muted);font-size:var(--text-lg)}.auth-card{width:100%;max-width:400px;background:var(--bg-secondary);border-radius:var(--radius-lg);padding:var(--space-3xl);border:1px solid var(--bg-tertiary)}.auth-header{text-align:center;margin-bottom:var(--space-xl)}.auth-logo{display:inline-flex;align-items:center;gap:var(--space-sm);font-size:var(--text-lg);font-weight:700;color:var(--text-primary);margin-bottom:var(--space-lg)}.auth-header h1{font-size:var(--text-2xl);font-weight:700;color:var(--text-primary);margin:0 0 var(--space-xs)}.auth-header p{color:var(--text-muted);font-size:var(--text-base);margin:0}.auth-form{display:flex;flex-direction:column;gap:var(--space-md)}.auth-error{background:#ff44441a;border:1px solid rgba(255,68,68,.3);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);color:var(--danger);font-size:var(--text-sm)}.auth-warning{background:#ffbb0014;border:1px solid rgba(255,187,0,.3);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);color:var(--warning);font-size:var(--text-sm)}.auth-warning p{margin:0}.auth-warning-detail{font-size:.8rem;margin-top:.5rem}.auth-field{display:flex;flex-direction:column;gap:var(--space-xs)}.auth-field label{font-size:var(--text-sm);font-weight:600;color:var(--text-secondary)}.auth-field input{padding:var(--space-sm) var(--space-md);font-size:var(--text-base);background:var(--bg-primary);border:1px solid var(--bg-tertiary);border-radius:var(--radius-md);color:var(--text-primary);transition:border-color var(--transition-normal)}.auth-field input::placeholder{color:var(--text-muted)}.auth-field input:focus{outline:none;border-color:var(--accent)}.auth-submit{margin-top:var(--space-sm);padding:var(--space-md);font-size:var(--text-base);font-weight:600;background:var(--accent);color:var(--bg-primary);border:none;border-radius:var(--radius-md);cursor:pointer;transition:opacity var(--transition-fast)}.auth-submit:hover{opacity:.9}.auth-submit:disabled{opacity:.5;cursor:not-allowed}.auth-footer{margin-top:var(--space-lg);text-align:center;font-size:var(--text-sm);color:var(--text-muted);display:flex;align-items:center;justify-content:center;gap:var(--space-xs)}.auth-link{background:none;border:none;color:var(--accent);font-size:var(--text-sm);font-weight:600;cursor:pointer;text-decoration:none;padding:0}.auth-link:hover{text-decoration:underline}.auth-forgot{align-self:flex-end;margin-top:var(--space-xs);font-size:.8125rem}.auth-success{padding:var(--space-md);background:color-mix(in srgb,var(--success) 10%,transparent);border:1px solid color-mix(in srgb,var(--success) 30%,transparent);border-radius:var(--radius-md);color:var(--success);font-size:.875rem;text-align:center}.auth-consent{display:flex;align-items:flex-start;gap:var(--space-sm);cursor:pointer;font-size:.8125rem;color:var(--text-secondary);line-height:1.4}.auth-consent input[type=checkbox]{margin-top:2px;flex-shrink:0;accent-color:var(--accent)}.auth-consent a{color:var(--accent);text-decoration:none}.auth-consent a:hover{text-decoration:underline}.auth-verify-status{display:flex;flex-direction:column;align-items:center;gap:var(--space-lg);padding:var(--space-xl) 0;text-align:center}.auth-verify-status p{font-size:1rem;color:var(--text-secondary)}.auth-verify-spinner{width:40px;height:40px;border:3px solid var(--bg-tertiary);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.legal-page{min-height:100vh;background:var(--bg-primary);display:flex;justify-content:center;padding:var(--space-xl) var(--space-md)}.legal-card{max-width:720px;width:100%;color:var(--text-primary)}.legal-back{background:none;border:none;color:var(--accent);font-size:.875rem;cursor:pointer;padding:0;margin-bottom:var(--space-lg);display:inline-block}.legal-back:hover{text-decoration:underline}.legal-card h1{font-size:1.75rem;font-weight:700;margin:0 0 var(--space-xs)}.legal-updated{font-size:.8125rem;color:var(--text-secondary);margin:0 0 var(--space-xl)}.legal-card section{margin-bottom:var(--space-xl)}.legal-card h2{font-size:1.125rem;font-weight:600;margin:0 0 var(--space-sm)}.legal-card h3{font-size:.9375rem;font-weight:600;margin:var(--space-md) 0 var(--space-xs)}.legal-card p{font-size:.875rem;line-height:1.6;color:var(--text-secondary);margin:0 0 var(--space-sm)}.legal-card ul{margin:0 0 var(--space-sm);padding-left:var(--space-lg)}.legal-card li{font-size:.875rem;line-height:1.6;color:var(--text-secondary);margin-bottom:var(--space-xs)}.legal-card a{color:var(--accent);text-decoration:none}.legal-card a:hover{text-decoration:underline}.app-footer{display:flex;align-items:center;justify-content:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);font-size:.75rem;color:var(--text-secondary);border-top:1px solid var(--border-color);flex-shrink:0}.app-footer a{color:var(--text-secondary);text-decoration:none}.app-footer a:hover{color:var(--text-primary);text-decoration:underline}.app-footer .footer-dot{opacity:.4}.header-user{display:flex;align-items:center;gap:var(--space-xs);font-size:var(--text-sm);color:var(--text-muted);padding:0 var(--space-xs)}.header-user-name{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.upgrade-modal{text-align:center}.upgrade-icon{color:var(--warning);margin-bottom:var(--space-md)}.upgrade-message{font-size:var(--text-base);color:var(--text-primary);margin:0 0 var(--space-xs);font-weight:500}.upgrade-current{font-size:var(--text-sm);color:var(--text-muted);margin:0 0 var(--space-lg)}.upgrade-plans{display:flex;gap:var(--space-md);margin-bottom:var(--space-sm)}.upgrade-plan{flex:1;background:var(--bg-primary);border:1px solid var(--bg-tertiary);border-radius:var(--radius-lg);padding:var(--space-lg);text-align:left}.upgrade-plan.featured{border-color:var(--accent);box-shadow:0 0 12px #00d0ff26}.upgrade-plan-name{font-size:var(--text-base);font-weight:700;color:var(--text-primary);margin-bottom:var(--space-xs)}.upgrade-plan-price{font-size:var(--text-xl);font-weight:700;color:var(--accent);margin-bottom:var(--space-md)}.upgrade-plan-price span{font-size:var(--text-sm);font-weight:400;color:var(--text-muted)}.upgrade-plan-features{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-xs)}.upgrade-plan-features li{font-size:var(--text-sm);color:var(--text-secondary);padding-left:var(--space-md);position:relative}.upgrade-plan-features li:before{content:"✓";position:absolute;left:0;color:var(--success);font-weight:700}.upgrade-note{font-size:var(--text-xs);color:var(--text-muted);margin:var(--space-sm) 0 0;font-style:italic}@media(min-width:768px){.now-playing-name{font-size:var(--text-5xl)}.timer-value{font-size:1.75rem}.setlist-item{font-size:1.1rem;padding:14px 20px}}@media(min-width:1200px){.timer-value{font-size:var(--text-3xl)}}@media(max-width:1024px)and (min-width:769px){.panel-left{min-width:280px;max-width:320px}.library{width:260px;min-width:260px}.now-playing-card{padding:var(--space-xl)}.setlist-title{font-size:var(--text-xl);padding:var(--space-lg)}.transport-btn{max-width:120px;padding:var(--space-md)}}@media(max-width:768px){.main-content{flex-direction:column}.header{padding:var(--space-sm) var(--space-md)}.header-title{font-size:.65rem}.icon-btn{width:32px;height:32px}.header-actions{gap:2px}.header-divider{margin:0 2px}.panel-left{width:100%;min-width:100%;max-width:100%;border-right:none;border-bottom:1px solid var(--bg-tertiary);max-height:35vh;flex-shrink:1}.setlist-header{padding:var(--space-sm) var(--space-md)}.setlist-item{padding:var(--space-sm) var(--space-md);font-size:.85rem}.setlist-item-meta{display:none}.setlist-footer{padding:var(--space-sm) var(--space-md);font-size:var(--text-sm)}.setlist-title{font-size:var(--text-lg);padding:var(--space-md)}.now-playing{padding:var(--space-sm) var(--space-md)}.now-playing-card{padding:var(--space-lg)}.now-playing-name{font-size:var(--text-2xl)}.timer-row{padding:var(--space-sm) var(--space-md);gap:var(--space-xs)}.timer-item{padding:var(--space-sm) var(--space-xs)}.timer-label{font-size:.5rem}.timer-value{font-size:var(--text-base)}.transport-controls{padding:var(--space-sm) var(--space-md);gap:var(--space-sm)}.transport-btn{padding:var(--space-md) var(--space-sm);max-width:100px}.transport-btn.nav{max-width:36px;padding:var(--space-sm)}.drop-zone-row{margin:0 var(--space-md)}.drop-zone-action{padding:var(--space-md);font-size:var(--text-base)}.audio-controls-row{padding:0 var(--space-md)}.volume-slider{width:80px}.library{width:100%;min-width:100%;max-height:50vh;border-right:none;border-bottom:1px solid var(--bg-tertiary)}.library-header,.library-item{padding:var(--space-sm) var(--space-md)}}@media(max-width:480px){.header-title{display:none}.panel-left{max-height:30vh}.now-playing-name{font-size:var(--text-xl)}.timer-value{font-size:var(--text-sm)}.transport-btn{max-width:80px}.setlist-title{font-size:var(--text-base);padding:var(--space-sm) var(--space-md)}}.account-settings{display:flex;flex-direction:column;gap:var(--space-xl)}.settings-section{display:flex;flex-direction:column;gap:var(--space-sm)}.settings-section-title{font-size:.875rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-xs)}.settings-section-desc{font-size:.8125rem;color:var(--text-secondary);margin:0}.settings-section--danger{border-top:1px solid var(--danger);padding-top:var(--space-lg)}.settings-form{display:flex;flex-direction:column;gap:var(--space-md)}.settings-error{font-size:.8125rem;color:var(--danger)}.settings-toggle-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);cursor:pointer;padding:var(--space-sm) 0}.settings-toggle-label{display:flex;flex-direction:column;gap:2px;font-size:.875rem;color:var(--text-primary)}.settings-toggle-desc{font-size:.75rem;color:var(--text-secondary)}.settings-toggle{appearance:none;-webkit-appearance:none;width:40px;height:22px;background:var(--border-color);border-radius:11px;position:relative;cursor:pointer;flex-shrink:0;transition:background .2s}.settings-toggle:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:var(--text-primary);transition:transform .2s}.settings-toggle:checked{background:var(--accent)}.settings-toggle:checked:after{transform:translate(18px)}.account-plan-badge{display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-sm) var(--space-md)}.plan-badge{display:inline-block;padding:var(--space-xs) var(--space-md);border-radius:var(--radius-sm);font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.plan-badge--free{background:var(--bg-tertiary);color:var(--text-secondary)}.plan-badge--pro{background:var(--accent);color:var(--bg-primary)}.plan-badge--band{background:var(--success);color:var(--bg-primary)}.plan-hint{font-size:.8125rem;color:var(--text-secondary)}.plan-status{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:2px 8px;border-radius:var(--radius-sm)}.plan-status--past_due{background:#ffaa0026;color:#fa0}.plan-status--cancelled{background:#ff444426;color:var(--danger)}.cancel-confirm{margin-top:var(--space-md);padding:var(--space-md);background:#ff44440d;border:1px solid rgba(255,68,68,.2);border-radius:var(--radius-md, 8px)}.cancel-confirm-title{font-weight:600;color:var(--danger);margin-bottom:var(--space-sm)}.cancel-confirm-text{font-size:.85rem;color:var(--text-secondary);margin:var(--space-xs) 0;line-height:1.4}.cancel-confirm-list{margin:var(--space-sm) 0;padding-left:1.25rem;font-size:.85rem;color:var(--text-secondary);line-height:1.6}.cancel-confirm-actions{display:flex;gap:var(--space-sm);margin-top:var(--space-md)}.password-strength{display:flex;gap:3px;margin-top:var(--space-xs)}.password-strength-bar{height:4px;flex:1;border-radius:2px;background:var(--bg-tertiary, #3d3d3d);transition:background .2s}.password-strength-bar--filled.strength-weak{background:var(--danger)}.password-strength-bar--filled.strength-fair{background:var(--warning, #ffaa00)}.password-strength-bar--filled.strength-good{background:#8c0}.password-strength-bar--filled.strength-strong{background:var(--success)}.password-strength-label{font-size:.75rem;margin-top:2px;color:var(--text-muted, #888)}.password-strength-label.strength-weak{color:var(--danger)}.password-strength-label.strength-fair{color:var(--warning, #ffaa00)}.password-strength-label.strength-good{color:#8c0}.password-strength-label.strength-strong{color:var(--success)}.auth-remember{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-secondary);cursor:pointer}.auth-remember input{accent-color:var(--accent, #00d0ff)}.payment-history{display:flex;flex-direction:column;gap:var(--space-xs)}.payment-row{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-md);background:var(--bg-primary);border-radius:var(--radius-sm);border:1px solid var(--bg-tertiary)}.payment-info{display:flex;align-items:center;gap:var(--space-sm)}.payment-amount{font-weight:600;font-size:var(--text-base)}.payment-status{font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:1px 6px;border-radius:var(--radius-pill)}.payment-status--succeeded{background:#00ff6626;color:var(--success)}.payment-status--failed{background:#ff444426;color:var(--danger)}.payment-meta{display:flex;align-items:center;gap:var(--space-md);color:var(--text-muted);font-size:var(--text-sm)}.payment-tier{font-weight:500}.scroll-on-hover{display:inline-block;white-space:nowrap}.scroll-on-hover.scrolling{animation:scroll-name 3s linear .3s both}@keyframes scroll-name{0%{transform:translate(0)}15%{transform:translate(0)}85%{transform:translate(var(--scroll-distance))}to{transform:translate(var(--scroll-distance))}}.team-selector{position:relative;display:flex;align-items:center}.team-selector-btn{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);border:1px solid var(--bg-tertiary);border-radius:var(--radius-md);background:var(--bg-primary);color:var(--text-primary);font-size:var(--text-sm);cursor:pointer;transition:border-color var(--transition-normal);max-width:180px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.team-selector-btn:hover{border-color:var(--accent)}.team-selector-btn--team{border-color:var(--accent);color:var(--accent)}.team-selector-dropdown{position:absolute;top:calc(100% + 4px);right:0;min-width:200px;background:var(--bg-secondary);border:1px solid var(--bg-tertiary);border-radius:var(--radius-md);box-shadow:0 8px 24px #0006;z-index:100;padding:var(--space-xs)}.team-selector-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-primary);font-size:var(--text-sm);cursor:pointer;width:100%;text-align:left;transition:background var(--transition-fast)}.team-selector-item:hover{background:var(--bg-tertiary)}.team-selector-item--active{color:var(--accent)}.team-selector-item--create{color:var(--accent);border-top:1px solid var(--bg-tertiary);margin-top:var(--space-xs);padding-top:var(--space-sm)}.team-stats{display:flex;gap:var(--space-lg);justify-content:center}.team-stat{display:flex;flex-direction:column;align-items:center;gap:2px}.team-stat-value{font-size:var(--text-2xl);font-weight:700;color:var(--accent)}.team-stat-label{font-size:var(--text-xs);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.team-tabs{display:flex;gap:2px;border-bottom:1px solid var(--bg-tertiary)}.team-tab{padding:var(--space-sm) var(--space-lg);border:none;border-bottom:2px solid transparent;background:transparent;color:var(--text-secondary);font-size:var(--text-sm);cursor:pointer;transition:color var(--transition-normal),border-color var(--transition-normal)}.team-tab:hover{color:var(--text-primary)}.team-tab--active{color:var(--accent);border-bottom-color:var(--accent)}.team-members{display:flex;flex-direction:column;gap:var(--space-xs);max-height:300px;overflow-y:auto}.team-member{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);background:var(--bg-primary)}.team-member-avatar{width:36px;height:36px;border-radius:50%;background:var(--accent);color:var(--bg-primary);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--text-sm);flex-shrink:0}.team-member-info{flex:1;min-width:0}.team-member-name{font-size:var(--text-sm);font-weight:600;color:var(--text-primary);display:flex;align-items:center}.team-member-email{font-size:var(--text-xs);color:var(--text-secondary)}.team-member-actions{display:flex;align-items:center;gap:var(--space-sm)}.team-member-remove{color:var(--danger)!important}.team-member-remove:hover{background:#ff444426!important}.team-role-select{padding:var(--space-xs) var(--space-sm);border:1px solid var(--bg-tertiary);border-radius:var(--radius-sm);background:var(--bg-primary);color:var(--text-primary);font-size:var(--text-xs);cursor:pointer}.team-invite-toggle{display:flex;gap:2px;background:var(--bg-primary);border-radius:var(--radius-md);padding:2px}.team-invite-mode{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-xs);padding:var(--space-sm);border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);font-size:var(--text-sm);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.team-invite-mode:hover{color:var(--text-primary)}.team-invite-mode--active{background:var(--bg-tertiary);color:var(--accent)}.team-invite-link{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm);background:var(--bg-primary);border-radius:var(--radius-md);border:1px solid var(--bg-tertiary)}.team-invite-link-url{flex:1;font-size:var(--text-xs);color:var(--accent);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.team-activity-item{display:flex;align-items:flex-start;gap:var(--space-sm);padding:var(--space-sm);border-radius:var(--radius-sm)}.team-activity-avatar{width:28px;height:28px;min-width:28px;border-radius:50%;background:var(--bg-tertiary);color:var(--text-secondary);font-size:.7rem;font-weight:700;display:flex;align-items:center;justify-content:center}.team-activity-content{display:flex;flex-direction:column;gap:2px}.team-activity-message{font-size:var(--text-sm);color:var(--text-primary)}.team-activity-time{display:inline-flex;align-items:center;gap:4px;font-size:.7rem;color:var(--text-muted)}.team-invitation{display:flex;align-items:center;justify-content:space-between;padding:var(--space-xs) var(--space-sm);background:var(--bg-primary);border-radius:var(--radius-sm);font-size:var(--text-sm)}.pdf-export-modal{display:flex;flex-direction:column;gap:var(--space-xl)}.pdf-export-section{display:flex;flex-direction:column;gap:var(--space-md)}.pdf-export-label{font-size:var(--text-sm);font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.pdf-export-templates{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-md)}.pdf-template-card{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);padding:var(--space-lg) var(--space-md);background:var(--bg-secondary);border:2px solid var(--bg-tertiary);border-radius:var(--radius-md);cursor:pointer;transition:border-color var(--transition-normal),background var(--transition-normal);text-align:center}.pdf-template-card:hover{border-color:var(--text-muted)}.pdf-template-card--active{border-color:var(--accent);background:#00d0ff14}.pdf-template-name{font-size:var(--text-base);font-weight:700;color:var(--text-primary)}.pdf-template-desc{font-size:var(--text-xs);color:var(--text-muted);line-height:1.3}.pdf-export-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md)}.pdf-export-row-label{font-size:var(--text-base);color:var(--text-secondary)}.pdf-export-btn-group{display:flex;gap:0;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--bg-tertiary)}.pdf-size-btn{padding:var(--space-xs) var(--space-lg);background:var(--bg-secondary);border:none;color:var(--text-secondary);font-size:var(--text-sm);cursor:pointer;transition:background var(--transition-normal),color var(--transition-normal)}.pdf-size-btn:not(:last-child){border-right:1px solid var(--bg-tertiary)}.pdf-size-btn:hover{background:var(--bg-tertiary)}.pdf-size-btn--active{background:var(--accent);color:var(--bg-primary)}.pdf-export-toggles{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-sm) var(--space-lg)}.pdf-export-toggle{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--text-base);color:var(--text-secondary);cursor:pointer}.pdf-export-toggle input[type=checkbox]{accent-color:var(--accent);width:16px;height:16px}.pdf-export-stage-note{font-size:var(--text-sm);color:var(--text-muted);font-style:italic;padding:var(--space-sm) 0}.pdf-preview-container{border:1px solid var(--bg-tertiary);border-radius:var(--radius-md);overflow:hidden;height:300px}.pdf-preview-iframe{width:100%;height:100%;border:none;background:#fff}.pdf-export-actions{display:flex;gap:var(--space-md)}.listening-party-banner{display:flex;align-items:center;gap:var(--space-sm);padding:6px var(--space-md);background:#00d0ff0f;border-bottom:1px solid rgba(0,208,255,.15);font-size:.75rem;color:var(--text-secondary);min-height:32px}.listening-party-banner--active{background:#00d0ff1a;border-bottom-color:#00d0ff4d;color:var(--accent)}.listening-party-label{display:flex;align-items:center;gap:6px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;font-size:.65rem;white-space:nowrap}.listening-party-count{font-weight:400;text-transform:none;letter-spacing:0;opacity:.7}.listening-party-dot{width:7px;height:7px;border-radius:50%;background:var(--accent);animation:pulse-dot 1.5s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.85)}}.listening-party-participants{display:flex;margin-left:auto}.listening-party-avatar{width:22px;height:22px;border-radius:50%;background:var(--accent);color:var(--bg-primary);font-size:.6rem;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid var(--bg-primary);margin-left:-4px;flex-shrink:0}.listening-party-avatar:first-child{margin-left:0}.listening-party-avatar--host{background:var(--success)}.listening-party-avatar--muted{opacity:.45}.listening-party-actions{display:flex;align-items:center;gap:4px;margin-left:var(--space-sm)}.party-btn{padding:2px 10px;border:1px solid var(--accent);border-radius:999px;background:transparent;color:var(--accent);font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;transition:background .15s,color .15s;display:inline-flex;align-items:center;gap:2px;white-space:nowrap}.party-btn:hover{background:var(--accent);color:var(--bg-primary)}.party-btn--danger{border-color:var(--danger);color:var(--danger)}.party-btn--danger:hover{background:var(--danger);color:#fff}.party-mic-btn{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border:none;border-radius:50%;background:var(--bg-tertiary);color:var(--text-secondary);cursor:pointer;transition:background .15s;flex-shrink:0}.party-mic-btn:hover{background:var(--bg-secondary)}.party-mic-btn--active{background:var(--success);color:var(--bg-primary)}.party-mic-btn--muted{background:var(--danger);color:#fff}.mic-level-indicator{display:flex;align-items:flex-end;gap:1px;height:14px;padding:0 2px}.mic-level-bar{width:3px;background:var(--text-secondary);opacity:.15;border-radius:1px;transition:opacity .08s,background .08s}.mic-level-bar:nth-child(1){height:3px}.mic-level-bar:nth-child(2){height:6px}.mic-level-bar:nth-child(3){height:9px}.mic-level-bar:nth-child(4){height:12px}.mic-level-bar.active{background:var(--success);opacity:1}.changelog-dot{position:absolute;top:4px;right:4px;width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 6px var(--accent-glow)}.changelog{display:flex;flex-direction:column;gap:var(--space-2xl);max-height:400px;overflow-y:auto}.changelog-release{display:flex;flex-direction:column;gap:var(--space-md)}.changelog-release-header{display:flex;align-items:center;gap:var(--space-md)}.changelog-version{font-size:var(--text-md);font-weight:700;color:var(--text-primary)}.changelog-date{font-size:var(--text-sm);color:var(--text-muted)}.changelog-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-sm)}.changelog-item{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--text-base);color:var(--text-secondary)}.changelog-badge{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:2px 6px;border-radius:var(--radius-sm);flex-shrink:0}.changelog-badge--added{background:#00ff661a;color:var(--success)}.changelog-badge--improved{background:#00d0ff1a;color:var(--accent)}.changelog-badge--fixed{background:#ffaa001a;color:var(--warning)}.feedback-form{display:flex;flex-direction:column;gap:var(--space-lg)}.feedback-types{display:flex;gap:var(--space-xs)}.feedback-type-btn{flex:1;padding:var(--space-sm) var(--space-md);border:1px solid var(--bg-tertiary);border-radius:var(--radius-md);background:transparent;color:var(--text-secondary);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-normal)}.feedback-type-btn:hover{border-color:var(--text-muted)}.feedback-type-btn--active{border-color:var(--accent);color:var(--accent);background:#00d0ff14}.feedback-textarea{width:100%;padding:var(--space-md);border:1px solid var(--bg-tertiary);border-radius:var(--radius-md);background:var(--bg-primary);color:var(--text-primary);font-size:var(--text-base);font-family:var(--font-ui);resize:vertical;min-height:100px;transition:border-color var(--transition-normal)}.feedback-textarea::placeholder{color:var(--text-muted)}.feedback-textarea:focus{outline:none;border-color:var(--accent)}.usage-dashboard{display:flex;flex-direction:column;gap:var(--space-md)}.usage-item{display:flex;flex-direction:column;gap:var(--space-xs)}.usage-item-header{display:flex;justify-content:space-between;align-items:center}.usage-item-label{font-size:var(--text-sm);color:var(--text-secondary)}.usage-item-value{font-size:var(--text-sm);color:var(--text-primary);font-weight:600}.usage-upgrade-hint{font-size:var(--text-xs);color:var(--warning);margin-top:2px}.onboarding-overlay{position:fixed;inset:0;z-index:1000;background:#000000b3;display:flex;align-items:center;justify-content:center}.onboarding-card{background:var(--bg-secondary);border:1px solid var(--bg-tertiary);border-radius:var(--radius-lg);padding:var(--space-3xl);max-width:480px;width:90%;text-align:center}.onboarding-card h2{font-size:var(--text-xl);font-weight:700;margin-bottom:var(--space-md)}.onboarding-card p{font-size:var(--text-base);color:var(--text-secondary);line-height:1.5;margin-bottom:var(--space-2xl)}.onboarding-step-icon{width:64px;height:64px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#00d0ff1a;color:var(--accent);margin:0 auto var(--space-lg)}.onboarding-dots{display:flex;justify-content:center;gap:var(--space-sm);margin-bottom:var(--space-2xl)}.onboarding-dot{width:8px;height:8px;border-radius:50%;background:var(--bg-tertiary);transition:background var(--transition-normal)}.onboarding-dot--active{background:var(--accent)}.show-mode{position:fixed;inset:0;z-index:9000;background:#000;color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;overflow:hidden;-webkit-user-select:none;user-select:none}.show-exit{position:absolute;top:1rem;right:1rem;background:#ffffff1a;border:none;color:#888;padding:.5rem;border-radius:50%;cursor:pointer;transition:color .15s,background .15s;z-index:10}.show-exit:hover{color:#fff;background:#fff3}.show-position{font-size:.9rem;text-transform:uppercase;letter-spacing:.1em;color:#666;margin-bottom:.5rem}.show-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.15em;color:#0f6;margin-bottom:.5rem}.show-current-song{font-size:clamp(2.5rem,8vw,6rem);font-weight:700;text-align:center;line-height:1.1;max-width:90vw;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:text-shadow .3s}.show-current-song--playing{text-shadow:0 0 40px rgba(0,255,102,.3)}.show-notes{font-size:1rem;color:#888;margin-top:.5rem;text-align:center;max-width:70vw;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.show-next{margin-top:1.5rem;display:flex;align-items:center;gap:.75rem}.show-next-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.15em;color:#555}.show-next-name{font-size:1.25rem;font-weight:500;color:#888}.show-progress-track{width:min(80vw,800px);height:6px;background:#1a1a1a;border-radius:3px;margin-top:2rem;overflow:hidden}.show-progress-fill{height:100%;background:#0f6;border-radius:3px;transition:width .1s linear}.show-timecodes{display:flex;gap:3rem;margin-top:1.5rem}.show-timecode{text-align:center}.show-timecode-value{font-family:SF Mono,Menlo,Cascadia Code,Consolas,monospace;font-size:clamp(1.5rem,4vw,3rem);font-weight:700;color:#0f6;line-height:1}.show-timecode-label{font-size:.6rem;text-transform:uppercase;letter-spacing:.15em;color:#555;margin-top:.25rem}.show-transport{display:flex;align-items:center;gap:1.5rem;margin-top:2rem}.show-transport-btn{background:#ffffff0d;border:2px solid rgba(255,255,255,.1);color:#ccc;padding:.75rem;border-radius:50%;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center}.show-transport-btn:hover:not(:disabled){background:#ffffff1a;color:#fff;border-color:#fff3}.show-transport-btn:disabled{opacity:.25;cursor:default}.show-transport-btn--main{padding:1.25rem;border-color:#0f6;color:#0f6}.show-transport-btn--main:hover:not(:disabled){background:#00ff6626;color:#0f6;border-color:#0f6}.show-transport-btn--playing{background:#00ff6626;box-shadow:0 0 20px #0f63}.show-transport-btn--stop{color:#f44;border-color:#ff44444d}.show-transport-btn--stop:hover{background:#ff444426;color:#f44;border-color:#f44}.show-setlist{position:absolute;bottom:0;left:0;right:0;max-height:30vh;overflow-y:auto;padding:1rem 2rem;background:linear-gradient(transparent,#000000f2 20%);display:flex;flex-direction:column;gap:2px}.show-setlist-item{display:flex;align-items:center;gap:.75rem;padding:.35rem .75rem;border-radius:4px;font-size:.85rem;color:#888;transition:all .15s}.show-setlist-item--current{background:#00ff661a;color:#0f6;font-weight:600}.show-setlist-item--past{opacity:.35}.show-setlist-item--break{color:#fa0;font-style:italic;font-size:.8rem}.show-setlist-num{font-size:.75rem;color:#555;min-width:1.5rem;text-align:right}.show-setlist-item--current .show-setlist-num{color:#0f6}.show-setlist-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.show-setlist-dur{font-family:SF Mono,Menlo,monospace;font-size:.8rem;color:#555}.show-setlist-item--current .show-setlist-dur{color:#0f6}@media(max-width:768px){.show-mode{padding:1rem}.show-timecodes{gap:1.5rem}.show-transport{gap:1rem}.show-setlist{max-height:25vh;padding:.75rem 1rem}}@media(max-width:480px){.show-current-song{font-size:clamp(2rem,10vw,3.5rem)}.show-timecodes{gap:1rem}}.analytics{display:flex;flex-direction:column;gap:var(--space-lg)}.analytics-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-sm)}.analytics-card{background:var(--bg-primary);border-radius:var(--radius-md);padding:var(--space-md);text-align:center}.analytics-card-value{font-size:1.5rem;font-weight:700;color:var(--text-primary);line-height:1.2}.analytics-card-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-top:2px}.analytics-section{display:flex;flex-direction:column;gap:var(--space-sm)}.analytics-section-title{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-weight:600}.analytics-stats-row{display:flex;gap:var(--space-lg)}.analytics-stat{display:flex;flex-direction:column}.analytics-stat-value{font-size:1.1rem;font-weight:600;color:var(--text-primary);font-family:SF Mono,Menlo,monospace}.analytics-stat-label{font-size:.75rem;color:var(--text-muted)}.analytics-bars{display:flex;flex-direction:column;gap:6px}.analytics-bar-row{display:flex;align-items:center;gap:var(--space-sm)}.analytics-bar-label{font-size:.75rem;color:var(--text-secondary);min-width:120px;flex-shrink:0}.analytics-bar-track{flex:1;height:8px;background:var(--bg-primary);border-radius:4px;overflow:hidden}.analytics-bar-fill{height:100%;border-radius:4px;min-width:2px;transition:width .3s ease}.analytics-bar-count{font-size:.75rem;color:var(--text-muted);min-width:1.5rem;text-align:right;font-variant-numeric:tabular-nums}.analytics-keys{display:flex;flex-wrap:wrap;gap:var(--space-sm)}.analytics-key-chip{display:flex;align-items:center;gap:6px;background:var(--bg-primary);border-radius:var(--radius-sm);padding:4px 10px}.analytics-key-name{font-weight:600;font-size:.85rem;color:var(--accent)}.analytics-key-count{font-size:.75rem;color:var(--text-muted)}.analytics-recent{display:flex;flex-direction:column;gap:2px}.analytics-recent-item{display:flex;justify-content:space-between;align-items:center;padding:6px 10px;background:var(--bg-primary);border-radius:var(--radius-sm)}.analytics-recent-name{font-size:.85rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.analytics-recent-meta{font-size:.75rem;color:var(--text-muted);white-space:nowrap;margin-left:var(--space-md)}.analytics-footer{text-align:center;font-size:.75rem;color:var(--text-muted);padding-top:var(--space-sm);border-top:1px solid var(--border)}@media(max-width:480px){.analytics-cards{grid-template-columns:repeat(2,1fr)}.analytics-stats-row{flex-wrap:wrap;gap:var(--space-md)}.analytics-bar-label{min-width:90px;font-size:.7rem}}.onboarding-overlay{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:#000000bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn var(--transition-normal) ease-out}.onboarding-card{background:var(--bg-secondary);border:1px solid var(--bg-tertiary);border-radius:var(--radius-lg);padding:var(--space-3xl) var(--space-3xl) var(--space-2xl);max-width:440px;width:90%;text-align:center;animation:scaleIn var(--transition-normal) ease-out}.onboarding-step-icon{width:64px;height:64px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#00d0ff1a;color:var(--accent);margin:0 auto var(--space-xl)}.onboarding-card h2{font-size:var(--text-xl);font-weight:700;margin-bottom:var(--space-md);color:var(--text-primary)}.onboarding-card p{font-size:var(--text-base);color:var(--text-secondary);line-height:1.6;margin-bottom:var(--space-xl)}.onboarding-dots{display:flex;justify-content:center;gap:var(--space-sm);margin-bottom:var(--space-xl)}.onboarding-dot{width:8px;height:8px;border-radius:50%;background:var(--bg-tertiary);transition:all var(--transition-normal)}.onboarding-dot--active{background:var(--accent);width:24px;border-radius:4px}.onboarding-actions{display:flex;justify-content:center;gap:var(--space-md)}@media(max-width:480px){.onboarding-card{padding:var(--space-2xl) var(--space-lg) var(--space-xl)}.onboarding-card h2{font-size:var(--text-lg)}}.landing{min-height:100vh;display:flex;flex-direction:column;background:var(--bg-primary);color:var(--text-primary);overflow-y:auto}.landing-nav{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg) var(--space-3xl);border-bottom:1px solid var(--bg-tertiary)}.landing-nav-brand{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--text-sm);font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-secondary)}.landing-nav-links{display:flex;align-items:center;gap:var(--space-lg)}.landing-nav-link{background:none;border:none;color:var(--text-secondary);font-size:var(--text-base);cursor:pointer;transition:color var(--transition-normal)}.landing-nav-link:hover{color:var(--text-primary)}.landing-nav-cta{background:var(--accent);color:var(--bg-primary);border:none;padding:var(--space-sm) var(--space-xl);border-radius:var(--radius-md);font-size:var(--text-base);font-weight:600;cursor:pointer;transition:background var(--transition-normal)}.landing-nav-cta:hover{background:var(--accent-hover)}.landing-hero{text-align:center;padding:10px var(--space-3xl) 60px;max-width:1100px;margin:0 auto}.landing-hero-title{font-size:clamp(2rem,5vw,3.5rem);font-weight:700;line-height:1.15;margin-bottom:var(--space-xl)}.landing-hero-accent{color:var(--accent)}.landing-hero-subtitle{font-size:var(--text-lg);color:var(--text-secondary);line-height:1.6;max-width:600px;margin:0 auto var(--space-3xl)}.landing-hero-actions{display:flex;justify-content:center;gap:var(--space-lg);flex-wrap:wrap}.landing-hero-screenshot{margin-top:48px;position:relative;max-width:1000px;margin-left:auto;margin-right:auto}.landing-hero-screenshot img{width:100%;border-radius:var(--radius-lg, 12px);border:1px solid var(--bg-tertiary, #3d3d3d);box-shadow:0 24px 80px #00000080,0 0 60px #00d0ff14}.landing-hero-screenshot:after{content:"";position:absolute;bottom:0;left:0;right:0;height:40%;background:linear-gradient(transparent,var(--bg-primary, #1a1a1a));border-radius:0 0 var(--radius-lg, 12px) var(--radius-lg, 12px);pointer-events:none}.landing-btn{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-2xl);border-radius:var(--radius-md);font-size:var(--text-base);font-weight:600;cursor:pointer;transition:all var(--transition-normal);border:none}.landing-btn--primary{background:var(--accent);color:var(--bg-primary)}.landing-btn--primary:hover{background:var(--accent-hover);box-shadow:var(--shadow-glow)}.landing-btn--outline{background:transparent;border:1px solid var(--bg-tertiary);color:var(--text-primary)}.landing-btn--outline:hover{border-color:var(--accent);color:var(--accent)}.landing-btn--lg{padding:var(--space-lg) var(--space-3xl);font-size:var(--text-md)}.landing-section{padding:60px var(--space-3xl);max-width:1100px;margin:0 auto;width:100%}.landing-section--alt{background:var(--bg-secondary);max-width:100%;border-top:1px solid var(--bg-tertiary);border-bottom:1px solid var(--bg-tertiary)}.landing-section--alt>*{max-width:1100px;margin-left:auto;margin-right:auto}.landing-section-title{text-align:center;font-size:var(--text-2xl);font-weight:700;margin-bottom:var(--space-4xl)}.landing-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--space-2xl)}.landing-feature-card{background:var(--bg-secondary);border:1px solid var(--bg-tertiary);border-radius:var(--radius-lg);padding:var(--space-2xl);transition:border-color var(--transition-normal)}.landing-feature-card:hover{border-color:var(--accent)}.landing-feature-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);background:#00d0ff1a;color:var(--accent);margin-bottom:var(--space-lg)}.landing-feature-card h3{font-size:var(--text-md);font-weight:600;margin-bottom:var(--space-sm)}.landing-feature-card p{color:var(--text-secondary);font-size:var(--text-base);line-height:1.5}.landing-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-2xl)}.landing-step{text-align:center}.landing-step-num{width:48px;height:48px;border-radius:50%;background:var(--accent);color:var(--bg-primary);display:flex;align-items:center;justify-content:center;font-size:var(--text-xl);font-weight:700;margin:0 auto var(--space-lg)}.landing-step h3{font-size:var(--text-lg);font-weight:600;margin-bottom:var(--space-sm)}.landing-step p{color:var(--text-secondary);font-size:var(--text-base);line-height:1.5}.landing-cta{text-align:center;padding:80px var(--space-3xl);max-width:100%;background:var(--bg-primary)}.landing-cta h2{font-size:var(--text-2xl);font-weight:700;margin-bottom:var(--space-md)}.landing-cta p{color:var(--text-secondary);font-size:var(--text-lg);margin-bottom:var(--space-3xl)}.landing-footer{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-xl) var(--space-3xl);border-top:1px solid var(--bg-tertiary);color:var(--text-muted);font-size:var(--text-sm);flex-wrap:wrap}.landing-footer-dot{color:var(--bg-tertiary)}.landing-footer-link{background:none;border:none;color:var(--text-muted);font-size:var(--text-sm);cursor:pointer;transition:color var(--transition-normal)}.landing-footer-link:hover{color:var(--accent)}@media(max-width:768px){.landing-nav{padding:var(--space-md) var(--space-lg)}.landing-hero{padding:40px var(--space-lg) 30px}.landing-section{padding:40px var(--space-lg)}.landing-features{grid-template-columns:1fr}}.pricing-page{min-height:100vh;background:var(--bg-primary);color:var(--text-primary);overflow-y:auto}.pricing-nav{padding:var(--space-lg) var(--space-3xl);border-bottom:1px solid var(--bg-tertiary)}.pricing-back{display:inline-flex;align-items:center;gap:var(--space-xs);background:none;border:none;color:var(--text-secondary);font-size:var(--text-base);cursor:pointer;transition:color var(--transition-normal)}.pricing-back:hover{color:var(--accent)}.pricing-content{max-width:1100px;margin:0 auto;padding:60px var(--space-3xl);text-align:center}.pricing-title{font-size:var(--text-2xl);font-weight:700;margin-bottom:var(--space-sm)}.pricing-subtitle{color:var(--text-secondary);font-size:var(--text-lg);margin-bottom:var(--space-4xl)}.pricing-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-2xl);text-align:left}.pricing-card{background:var(--bg-secondary);border:1px solid var(--bg-tertiary);border-radius:var(--radius-lg);padding:var(--space-3xl) var(--space-2xl);position:relative;display:flex;flex-direction:column}.pricing-card--featured{border-color:var(--accent);box-shadow:0 0 20px #00d0ff1a}.pricing-card--current{border-color:var(--success)}.pricing-card-badge{position:absolute;top:-12px;left:50%;transform:translate(-50%);background:var(--success);color:var(--bg-primary);font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:4px 12px;border-radius:var(--radius-pill);white-space:nowrap}.pricing-card-badge--recommended{background:var(--accent)}.pricing-card h2{font-size:var(--text-xl);font-weight:700;margin-bottom:var(--space-md)}.pricing-price{display:flex;align-items:baseline;gap:2px;margin-bottom:var(--space-md)}.pricing-amount{font-size:2.5rem;font-weight:700}.pricing-period{color:var(--text-muted);font-size:var(--text-base)}.pricing-desc{color:var(--text-secondary);font-size:var(--text-base);margin-bottom:var(--space-2xl)}.pricing-btn{display:block;width:100%;padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);font-size:var(--text-base);font-weight:600;cursor:pointer;transition:all var(--transition-normal);text-align:center;margin-bottom:var(--space-2xl)}.pricing-btn--primary{background:var(--accent);color:var(--bg-primary);border:none}.pricing-btn--primary:hover{background:var(--accent-hover);box-shadow:var(--shadow-glow)}.pricing-btn--outline{background:transparent;border:1px solid var(--bg-tertiary);color:var(--text-primary)}.pricing-btn--outline:hover{border-color:var(--accent);color:var(--accent)}.pricing-features{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-md);flex:1}.pricing-features li{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--text-base);color:var(--text-primary)}.pricing-feature--disabled{color:var(--text-muted)!important}.pricing-check{color:var(--success);flex-shrink:0}.pricing-x{color:var(--text-muted);flex-shrink:0}.pricing-card--enterprise{background:linear-gradient(135deg,var(--bg-secondary) 0%,rgba(0,208,255,.04) 100%);border-color:var(--bg-tertiary)}.pricing-enterprise-icon{width:56px;height:56px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);background:#00d0ff1a;color:var(--accent);margin-bottom:var(--space-lg)}.pricing-amount--custom{font-size:2rem;color:var(--accent)}.pricing-btn--enterprise{background:transparent;border:1px solid var(--accent);color:var(--accent);text-decoration:none}.pricing-btn--enterprise:hover{background:#00d0ff1a;box-shadow:0 0 16px #00d0ff26}@media(max-width:768px){.pricing-content{padding:30px var(--space-lg)}.pricing-cards{grid-template-columns:1fr;max-width:400px;margin:0 auto}.pricing-nav{padding:var(--space-md) var(--space-lg)}}.admin-page{min-height:100vh;background:var(--bg-primary);color:var(--text-primary);overflow-y:auto}.admin-nav{display:flex;align-items:center;gap:var(--space-lg);padding:var(--space-lg) var(--space-3xl);border-bottom:1px solid var(--bg-tertiary)}.admin-back{display:inline-flex;align-items:center;gap:var(--space-xs);background:none;border:none;color:var(--text-secondary);font-size:var(--text-base);cursor:pointer}.admin-back:hover{color:var(--accent)}.admin-title{font-size:var(--text-lg);font-weight:700;margin:0}.admin-content{max-width:1200px;margin:0 auto;padding:var(--space-3xl);display:flex;flex-direction:column;gap:var(--space-2xl)}.admin-error{text-align:center;color:var(--danger);padding:var(--space-3xl);font-size:var(--text-md)}.admin-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:var(--space-md)}.admin-stat-card{background:var(--bg-secondary);border:1px solid var(--bg-tertiary);border-radius:var(--radius-lg);padding:var(--space-xl) var(--space-lg);text-align:center}.admin-stat-value{font-size:var(--text-2xl);font-weight:700;color:var(--accent)}.admin-stat-label{font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-top:var(--space-xs)}.admin-tier-breakdown{display:flex;align-items:center;justify-content:center;gap:var(--space-2xl)}.admin-tier{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--text-md);font-weight:600}.admin-tabs{display:flex;gap:2px;border-bottom:1px solid var(--bg-tertiary)}.admin-tab{padding:var(--space-sm) var(--space-xl);border:none;border-bottom:2px solid transparent;background:transparent;color:var(--text-secondary);font-size:var(--text-base);cursor:pointer;transition:color var(--transition-normal),border-color var(--transition-normal)}.admin-tab:hover{color:var(--text-primary)}.admin-tab--active{color:var(--accent);border-bottom-color:var(--accent)}.admin-table-section{display:flex;flex-direction:column;gap:var(--space-md)}.admin-search{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--bg-secondary);border:1px solid var(--bg-tertiary);border-radius:var(--radius-md);max-width:350px}.admin-search input{flex:1;background:none;border:none;color:var(--text-primary);font-size:var(--text-base);outline:none}.admin-search input::placeholder{color:var(--text-muted)}.admin-table-wrapper{overflow-x:auto}.admin-table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}.admin-table th{text-align:left;padding:var(--space-sm) var(--space-md);color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.5px;font-size:var(--text-xs);border-bottom:1px solid var(--bg-tertiary);white-space:nowrap}.admin-table td{padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--bg-tertiary);vertical-align:middle}.admin-table tbody tr:hover{background:var(--bg-secondary)}.admin-user-cell{display:flex;flex-direction:column}.admin-user-name{font-weight:600;color:var(--text-primary)}.admin-user-email{font-size:var(--text-xs);color:var(--text-muted)}.admin-verified{color:var(--text-muted)}.admin-verified--yes{color:var(--success)}.admin-empty{text-align:center;color:var(--text-muted);padding:var(--space-3xl)!important}.admin-feedback-type{font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:2px 8px;border-radius:var(--radius-sm)}.admin-feedback-type--bug{background:#ff44441a;color:var(--danger)}.admin-feedback-type--feature{background:#00d0ff1a;color:var(--accent)}.admin-feedback-type--general{background:#88888826;color:var(--text-secondary)}.admin-feedback-message{max-width:400px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-pagination{display:flex;align-items:center;justify-content:center;gap:var(--space-md);font-size:var(--text-sm);color:var(--text-secondary)}.admin-pagination button{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid var(--bg-tertiary);border-radius:var(--radius-md);background:transparent;color:var(--text-primary);cursor:pointer;transition:all var(--transition-normal)}.admin-pagination button:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.admin-pagination button:disabled{opacity:.3;cursor:not-allowed}@media(max-width:768px){.admin-nav{padding:var(--space-md) var(--space-lg)}.admin-content{padding:var(--space-lg)}.admin-stats{grid-template-columns:repeat(2,1fr)}}.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:9999;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.5rem;background:var(--color-bg-card, #2d2d2d);border-top:1px solid var(--color-border, #3d3d3d);box-shadow:0 -2px 12px #0006;animation:cookie-slide-up .3s ease-out}@keyframes cookie-slide-up{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.cookie-text{margin:0;font-size:.85rem;color:var(--color-text-secondary, #999);line-height:1.4;flex:1}.cookie-link{color:var(--color-accent, #00d0ff);text-decoration:underline}.cookie-actions{display:flex;gap:.5rem;flex-shrink:0}.cookie-btn{padding:.5rem 1.25rem;border-radius:6px;border:none;font-size:.85rem;font-weight:500;cursor:pointer;transition:opacity .15s}.cookie-btn:hover{opacity:.85}.cookie-btn--accept{background:var(--color-accent, #00d0ff);color:#000}.cookie-btn--decline{background:transparent;color:var(--color-text-secondary, #999);border:1px solid var(--color-border, #3d3d3d)}@media(max-width:600px){.cookie-banner{flex-direction:column;text-align:center;padding:1rem}.cookie-actions{width:100%;justify-content:center}}.shared-page{min-height:100vh;background:var(--bg-primary, #1a1a1a);color:var(--text-primary, #fff);display:flex;flex-direction:column}.shared-loading,.shared-error{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;text-align:center}.shared-error-code{font-size:4rem;font-weight:800;color:var(--text-muted, #555);line-height:1;margin-bottom:.5rem}.shared-error h2{margin:0 0 .5rem;font-size:1.25rem}.shared-error p{color:var(--text-secondary, #888);margin:0 0 1.5rem}.shared-nav{display:flex;align-items:center;justify-content:space-between;padding:1rem 2rem;border-bottom:1px solid var(--border, #3d3d3d)}.shared-back-btn{display:inline-flex;align-items:center;gap:.4rem;background:none;border:1px solid var(--border, #3d3d3d);color:var(--text-secondary, #888);padding:.4rem .75rem;border-radius:6px;cursor:pointer;font-size:.85rem;transition:color .15s,border-color .15s}.shared-back-btn:hover{color:var(--text-primary, #fff);border-color:var(--text-secondary, #888)}.shared-nav-badge{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--accent, #00d0ff);background:#00d0ff1a;padding:.3rem .6rem;border-radius:4px}.shared-content{flex:1;max-width:700px;width:100%;margin:0 auto;padding:2rem}.shared-header{margin-bottom:2rem}.shared-title{font-size:1.75rem;font-weight:700;margin:0 0 .75rem}.shared-meta{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:.5rem}.shared-meta-item{display:inline-flex;align-items:center;gap:.35rem;font-size:.85rem;color:var(--text-secondary, #888)}.shared-author{font-size:.8rem;color:var(--text-muted, #555)}.shared-songs{display:flex;flex-direction:column;gap:2px}.shared-song{display:flex;align-items:center;gap:.75rem;padding:.65rem .75rem;border-radius:6px;background:var(--bg-secondary, #2d2d2d);transition:background .15s}.shared-song:hover{background:var(--bg-hover, #333)}.shared-song--break{background:transparent;justify-content:center;padding:.5rem}.shared-song-break-label{font-size:.8rem;font-style:italic;color:#fa0;text-transform:uppercase;letter-spacing:.05em}.shared-song-num{font-size:.8rem;color:var(--text-muted, #555);min-width:1.5rem;text-align:right;font-variant-numeric:tabular-nums}.shared-song-name{flex:1;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.shared-song-detail{font-size:.8rem;color:var(--text-secondary, #888);font-family:SF Mono,Menlo,monospace;white-space:nowrap}.shared-footer{margin-top:3rem;padding-top:1.5rem;border-top:1px solid var(--border, #3d3d3d);display:flex;align-items:center;justify-content:space-between;font-size:.8rem;color:var(--text-muted, #555)}.shared-footer strong{color:var(--text-secondary, #888)}.shared-footer-link{color:var(--accent, #00d0ff);text-decoration:none;transition:opacity .15s}.shared-footer-link:hover{opacity:.8}@media(max-width:768px){.shared-nav{padding:.75rem 1rem}.shared-content{padding:1.5rem 1rem}.shared-title{font-size:1.4rem}.shared-meta{gap:.75rem}.shared-footer{flex-direction:column;gap:.5rem;text-align:center}}.error-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-bg, #1a1a1a);padding:2rem}.error-card{text-align:center;max-width:420px}.error-code{font-size:6rem;font-weight:700;line-height:1;color:var(--color-accent, #00d0ff);opacity:.3;margin-bottom:.5rem}.error-title{font-size:1.5rem;font-weight:600;color:var(--color-text, #fff);margin:0 0 .75rem}.error-message{font-size:.95rem;color:var(--color-text-secondary, #999);line-height:1.5;margin:0 0 2rem}.error-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--color-accent, #00d0ff);color:#000;border:none;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:opacity .15s}.error-btn:hover{opacity:.85}
