:root{--primary-color:#6366f1;--primary-hover:#4f46e5;--secondary-color:#64748b;--danger-color:#ef4444;--danger-hover:#dc2626;--success-color:#22c55e;--bg-color:#0f172a;--card-bg:#1e293b;--border-color:#334155;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--ai-color:#a855f7;--ai-hover:#9333ea}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-color);color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.app{flex-direction:column;min-height:100vh;display:flex}.app-main{flex:1;width:100%;max-width:1400px;margin:0 auto;padding:2rem}.password-gate{place-items:center;min-height:100vh;padding:1.5rem;display:grid}.password-gate-card{border:1px solid var(--border-color);background:var(--card-bg);border-radius:1rem;width:min(100%,24rem);padding:2rem;box-shadow:0 20px 60px #00000059}.password-gate-card h1,.password-gate-card p{margin-bottom:1rem}.password-gate-card label{color:var(--text-secondary);margin-bottom:.5rem;font-weight:600;display:block}.password-gate-card input{border:2px solid var(--border-color);background:var(--bg-color);width:100%;color:var(--text-primary);font:inherit;border-radius:.5rem;margin-bottom:1rem;padding:.75rem}.password-gate-error{color:#fca5a5}button{cursor:pointer;border:none;font-family:inherit;transition:all .2s}.btn-primary{background-color:var(--primary-color);color:#fff;border-radius:.5rem;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-weight:600;display:flex}.btn-primary:hover{background-color:var(--primary-hover);transform:translateY(-2px);box-shadow:0 4px 12px #6366f166}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-secondary{background-color:var(--secondary-color);color:#fff;border-radius:.5rem;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-weight:600;display:flex}.btn-secondary:hover{background-color:#475569}.btn-ai{background:linear-gradient(135deg, var(--ai-color), var(--primary-color));color:#fff;border-radius:.5rem;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-weight:600;display:flex}.btn-ai:hover{background:linear-gradient(135deg, var(--ai-hover), var(--primary-hover));transform:translateY(-2px);box-shadow:0 4px 12px #a855f766}.btn-ai:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-icon{color:var(--text-primary);background:0 0;border-radius:.5rem;justify-content:center;align-items:center;padding:.5rem;display:flex}.btn-icon:hover{background-color:var(--border-color)}.btn-icon-sm{color:var(--text-secondary);background:0 0;border-radius:.25rem;justify-content:center;align-items:center;padding:.25rem;display:flex}.btn-icon-sm:hover{background-color:var(--border-color);color:var(--text-primary)}.btn-danger{color:var(--danger-color)}.btn-danger:hover{color:var(--danger-hover);background-color:#ef44441a}.concert-list{flex-direction:column;gap:2rem;display:flex}.concert-list-header{justify-content:space-between;align-items:center;display:flex}.concert-list-header h2{align-items:center;gap:.75rem;font-size:1.75rem;display:flex}.concert-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;display:grid}.concert-card{background-color:var(--card-bg);border:2px solid var(--border-color);cursor:pointer;border-radius:1rem;padding:1.5rem;transition:all .2s}.concert-card:hover{border-color:var(--primary-color);transform:translateY(-4px);box-shadow:0 8px 24px #6366f133}.concert-card h3{margin-bottom:1rem;font-size:1.5rem}.concert-info{color:var(--text-secondary);align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.concert-stats{border-top:1px solid var(--border-color);color:var(--text-secondary);margin-top:1rem;padding-top:1rem;font-size:.875rem}.empty-state{text-align:center;color:var(--text-secondary);padding:4rem 2rem}.empty-state svg{color:var(--border-color);margin-bottom:1rem}.empty-state p{margin-bottom:1.5rem;font-size:1.125rem}.empty-state .hint{color:var(--text-secondary);margin-top:.5rem;font-size:.875rem}.concert-form-overlay{z-index:1000;background-color:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.concert-form{background-color:var(--card-bg);border-radius:1rem;width:100%;max-width:500px;padding:2rem;box-shadow:0 20px 60px #00000080}.concert-form h2,.form-group{margin-bottom:1.5rem}.form-group label{color:var(--text-secondary);margin-bottom:.5rem;font-weight:600;display:block}.form-group input{border:2px solid var(--border-color);background-color:var(--bg-color);width:100%;color:var(--text-primary);border-radius:.5rem;padding:.75rem;font-size:1rem}.form-group input:focus{border-color:var(--primary-color);outline:none}.form-actions{justify-content:flex-end;gap:1rem;margin-top:2rem;display:flex}.setlist-editor{flex-direction:column;gap:2rem;display:flex}.setlist-header{align-items:center;gap:1rem;display:flex}.setlist-header h2{font-size:2rem}.subtitle{color:var(--text-secondary);margin-top:.25rem;font-size:.875rem}.setlist-actions{flex-direction:column;gap:1rem;display:flex}.add-song-form{gap:1rem;display:flex}.add-song-form input{border:2px solid var(--border-color);background-color:var(--card-bg);color:var(--text-primary);border-radius:.5rem;flex:1;padding:.75rem;font-size:1rem}.add-song-form input:focus{border-color:var(--primary-color);outline:none}.ai-actions{flex-wrap:wrap;gap:1rem;display:flex}.error-message{border:1px solid var(--danger-color);color:var(--danger-color);background-color:#ef44441a;border-radius:.5rem;width:100%;padding:.75rem 1rem;font-size:.875rem}.retry-button{margin-left:.75rem;padding:.35rem .65rem;font-size:.85rem}.status-message,.lyrics-status{border-radius:.5rem;align-items:center;gap:.75rem;padding:.85rem 1rem;font-size:.9rem;display:flex}.status-message{color:var(--text-primary);background-color:#6366f11a;border:1px solid #6366f173;width:100%}.suggestions-panel{background-color:var(--card-bg);border:2px solid var(--ai-color);border-radius:1rem;padding:1.5rem}.suggestions-panel.loading-panel{color:var(--text-secondary);border-color:#a855f773;align-items:center;gap:.75rem;display:flex}.suggestions-panel h3{align-items:center;gap:.5rem;margin-bottom:1rem;display:flex}.suggestions-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem;display:grid}.suggestion-item{background-color:var(--bg-color);color:var(--text-primary);text-align:left;border:1px solid var(--border-color);border-radius:.5rem;align-items:center;gap:.5rem;padding:.75rem;display:flex}.suggestion-item:hover{background-color:var(--border-color);border-color:var(--ai-color)}.setlist-container{background-color:var(--card-bg);border:2px solid var(--border-color);border-radius:1rem;padding:1.5rem}.setlist-items{flex-direction:column;gap:.5rem;display:flex}.setlist-item{background-color:var(--bg-color);border:1px solid var(--border-color);border-radius:.5rem;align-items:center;gap:1rem;padding:1rem;transition:all .2s;display:flex}.setlist-reorder-controls{flex-direction:column;gap:.1rem;display:flex}.setlist-item:hover{border-color:var(--primary-color);box-shadow:0 2px 8px #6366f133}.setlist-item.dragging{opacity:.45}.setlist-item.drag-over{border-color:var(--primary-color);box-shadow:0 -3px 0 var(--primary-color)}.drag-handle{color:var(--text-secondary);cursor:grab}.drag-handle:active{cursor:grabbing}.song-order{color:var(--text-secondary);min-width:2rem;font-weight:600}.song-title{cursor:pointer;flex:1;font-weight:500}.song-title:hover{color:var(--primary-color)}.setlist-marker-tools{align-items:center;gap:.5rem;margin-left:auto;display:flex}.marker-badge{background-color:var(--primary-color);color:#fff;border-radius:9999px;margin-left:.25rem;padding:.1rem .4rem;font-size:.7rem;font-weight:700}.song-marker-badge{color:var(--text-secondary);background-color:#6366f11a;border-radius:.3rem;margin-right:.25rem;padding:.1rem .4rem;font-size:.75rem}.markers-modal-overlay{z-index:500;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#000000bf;justify-content:center;align-items:flex-start;padding:2rem 1rem;display:flex;position:fixed;inset:0;overflow-y:auto}.markers-modal{background-color:var(--card-bg);border:2px solid var(--border-color);border-radius:1rem;width:100%;max-width:860px;overflow:hidden;box-shadow:0 24px 64px #0009}.markers-modal-header{border-bottom:1px solid var(--border-color);background-color:#ffffff05;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex}.markers-modal-header h3{align-items:center;gap:.5rem;margin:0;font-size:1.1rem;display:flex}.markers-modal-actions{align-items:center;gap:.5rem;display:flex}.markers-table-wrap{max-height:65vh;overflow:auto}.markers-table{border-collapse:collapse;width:100%;font-size:.875rem}.markers-table th{background-color:var(--card-bg);text-align:left;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-color);padding:.75rem 1rem;font-size:.75rem;font-weight:600;position:sticky;top:0}.markers-table td{vertical-align:middle;border-bottom:1px solid #ffffff0a;padding:.65rem 1rem}.marker-row:last-child td{border-bottom:none}.marker-row--good{background-color:#22c55e08}.marker-row--bad{background-color:#ef444408}.marker-row:hover td{background-color:#ffffff08}.marker-type-badge{letter-spacing:.04em;border-radius:9999px;align-items:center;gap:.3rem;padding:.2rem .65rem;font-size:.75rem;font-weight:700;display:inline-flex}.marker-type-badge.good{color:#22c55e;background-color:#22c55e26;border:1px solid #22c55e4d}.marker-type-badge.bad{color:#ef4444;background-color:#ef444426;border:1px solid #ef44444d}.marker-song-cell{font-weight:500}.marker-tc-cell,.marker-clock-cell{font-variant-numeric:tabular-nums;color:var(--text-secondary);font-family:SF Mono,Fira Mono,monospace;font-size:.82rem}.marker-action-cell{text-align:center;width:40px}.song-view{flex-direction:column;gap:2rem;display:flex}.song-header{align-items:center;gap:1rem;display:flex}.song-info{flex:1}.song-info h2{margin:0;font-size:2rem}.title-container{align-items:center;gap:.5rem;display:flex}.title-container h2{margin:0}.edit-btn{opacity:.5;transition:opacity .2s}.title-container:hover .edit-btn,.concert-title-row:hover .edit-btn{opacity:1}.edit-title-container{align-items:center;gap:.5rem;display:flex}.edit-title-input{border:2px solid var(--primary-color);background-color:var(--bg-color);color:var(--text-primary);border-radius:.5rem;flex:1;padding:.5rem;font-size:1.5rem;font-weight:600}.edit-title-input:focus{outline:none;box-shadow:0 0 0 3px #6366f133}.spinning{animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.lyrics-status{background-color:#6366f11a;border:1px solid #6366f173}.lyrics-status.notice{background-color:#eab3081a;border-color:#eab30873}.lyrics-status>div{flex-direction:column;gap:.2rem;display:flex}.lyrics-status strong{font-size:.85rem}.lyrics-status span{color:var(--text-secondary)}.lyrics-empty-loading{min-height:10rem;color:var(--text-secondary);justify-content:center;align-items:center;gap:.75rem;display:flex}.manual-search-modal{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background-color:var(--card-bg);border:2px solid var(--border-color);border-radius:1rem;width:90%;max-width:500px;padding:2rem;box-shadow:0 20px 60px #00000080}.modal-content h3{color:var(--text-primary);margin:0 0 .5rem}.modal-description{color:var(--text-secondary);margin-bottom:1.5rem;font-size:.875rem}.modal-inputs{flex-direction:column;gap:1rem;margin-bottom:1.5rem;display:flex}.input-group{flex-direction:column;gap:.5rem;display:flex}.input-group label{color:var(--text-secondary);font-size:.875rem;font-weight:500}.input-group input{border:2px solid var(--border-color);background-color:var(--bg-color);color:var(--text-primary);border-radius:.5rem;padding:.75rem;font-size:1rem;transition:border-color .2s}.input-group input:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px #6366f11a}.modal-actions{justify-content:flex-end;gap:1rem;display:flex}.concert-title-row{align-items:center;gap:.5rem;display:flex}.concert-title-row h2{margin:0}.edit-concert-info{flex:1}.edit-row{align-items:center;gap:.5rem;display:flex}.edit-input{border:2px solid var(--primary-color);background-color:var(--bg-color);color:var(--text-primary);border-radius:.5rem;padding:.5rem;font-size:1rem}.edit-input:focus{outline:none;box-shadow:0 0 0 3px #6366f133}.song-navigation{border-left:1px solid var(--border-color);border-right:1px solid var(--border-color);align-items:center;gap:.5rem;padding:0 1rem;display:flex}.setlist-dropdown{background-color:var(--card-bg);border:2px solid var(--border-color);border-radius:.75rem;margin-top:-1rem;padding:1rem}.setlist-dropdown h3{color:var(--text-secondary);margin-bottom:.75rem;font-size:1rem}.setlist-quick-nav{flex-direction:column;gap:.5rem;max-height:300px;display:flex;overflow-y:auto}.setlist-item-btn{background-color:var(--bg-color);color:var(--text-primary);text-align:left;border:1px solid var(--border-color);cursor:pointer;border-radius:.5rem;padding:.75rem 1rem;font-size:.875rem;transition:all .2s}.setlist-item-btn:hover{background-color:var(--border-color);border-color:var(--primary-color)}.setlist-item-btn.active{background-color:var(--primary-color);border-color:var(--primary-color);color:#fff;font-weight:600}.lyrics-container,.lyrics-notebook{flex-direction:column;gap:1rem;display:flex}.lyrics-notebook h3{margin:0;font-size:1.25rem}.notebook-content{flex-direction:column;gap:.75rem;display:flex}.section-with-insert{flex-direction:column;gap:.4rem;display:flex}.add-section-between{border:1px dashed var(--border-color);color:var(--text-secondary);background:0 0;border-radius:999px;align-self:center;align-items:center;gap:.25rem;padding:.2rem .55rem;font-size:.75rem;display:inline-flex}.add-section-between:hover{border-color:var(--primary-color);color:var(--text-primary)}.notebook-section{background-color:var(--card-bg);border:2px solid var(--border-color);border-radius:.75rem;padding:1rem;transition:all .2s}.notebook-section:hover{border-color:#6366f14d}.notebook-section.inactive{opacity:.5;border-style:dashed}.section-content{flex-direction:column;gap:.75rem;display:flex}.section-type{cursor:text}.section-title-input,.lyric-line-input{border:1px solid var(--primary-color);background:var(--bg-color);width:100%;color:var(--text-primary);font:inherit;border-radius:.3rem;padding:.2rem .4rem}.lyric-line-input{resize:vertical;min-height:2.2rem}.section-title-input{max-width:20rem;font-weight:600}.lyrics-lines{flex-direction:column;gap:.25rem;line-height:1.4;display:flex}.lyric-line-row{border-left:3px solid #0000;border-radius:.3rem;align-items:center;gap:.5rem;padding:.2rem .25rem;transition:background-color .12s;display:flex}.lyric-line-row:hover{background-color:#ffffff08}.lyric-line-row.inactive{opacity:.4}.lyric-line-row.has-note{border-left-color:var(--primary-color);background-color:#6366f114}.lyric-line-row.has-note:hover{background-color:#6366f11f}.lyric-line-row.line-current{background-color:#facc1514;border-left-color:#facc15}.lyric-line-row.line-current.has-note{background:linear-gradient(90deg,#facc151f,#6366f114);border-left-color:#facc15}.lyric-line-row.line-current .lyric-text span{color:#fef08a;font-weight:600}.line-tc-col{flex-shrink:0;align-items:center;min-width:200px;padding-right:.25rem;display:flex}.line-tc-controls{flex-wrap:nowrap;align-items:center;gap:.25rem;display:flex}.btn-go{letter-spacing:.06em;color:#facc15;white-space:nowrap;background-color:#facc1526;border:1px solid #facc1559;border-radius:.35rem;padding:.25rem .55rem;font-size:.65rem;font-weight:700;transition:all .12s}.btn-go:hover{background-color:#facc1547;border-color:#facc15;transform:scale(1.05)}.btn-go:active{transform:scale(.95)}.perf-marker-inline{align-items:center;gap:.3rem;margin-left:auto;display:flex}.lyric-text{align-items:center;gap:.5rem;font-size:.95rem;display:flex}.line-toggle{color:var(--text-secondary);cursor:pointer;opacity:.5;background:0 0;border:none;flex-shrink:0;align-items:center;padding:.25rem;transition:opacity .2s;display:flex}.line-toggle:hover{opacity:1;color:var(--primary-color)}.lyric-text span{flex:1}.lyric-text .strikethrough{text-decoration:line-through}.lyric-note{flex-shrink:0;min-width:200px;margin-left:auto}.line-note-input{border:1px solid var(--primary-color);width:100%;color:var(--text-primary);background-color:#6366f11a;border-radius:.35rem;padding:.4rem .6rem;font-size:.85rem;font-style:italic}.line-note-input:focus{outline:none;box-shadow:0 0 0 2px #6366f133}.line-note-display{cursor:pointer;color:var(--text-secondary);background-color:#ffffff05;border:1px solid #0000;border-radius:.35rem;align-items:center;min-height:28px;padding:.4rem .6rem;font-size:.85rem;font-style:italic;transition:all .2s;display:flex}.line-note-display:hover{border-color:var(--primary-color);background-color:#6366f10d}.lyric-line-row.has-note .line-note-display{color:var(--text-primary);background-color:#6366f124;border-color:#6366f173}.lyric-line-row.has-note .lyric-text span{color:var(--text-primary)}.line-note-display:empty:before{content:"+";opacity:.5}.line-note-display:has(:only-child:empty):before{content:"+";opacity:.5}.lyric-line{cursor:pointer;border-radius:.25rem;padding:.25rem .5rem;font-size:.95rem;transition:background-color .15s}.lyric-line.inactive{opacity:.4}.lyric-line .strikethrough{text-decoration:line-through}.production-note-inline{border-top:1px dashed var(--border-color);margin-top:.5rem;padding-top:.75rem}.note-editor-inline{border:2px solid var(--primary-color);width:100%;min-height:60px;color:var(--text-primary);resize:vertical;background-color:#6366f10d;border-radius:.5rem;padding:.75rem;font-family:inherit;font-size:.875rem;line-height:1.5}.note-editor-inline:focus{outline:none;box-shadow:0 0 0 3px #6366f11a}.note-display-inline{cursor:pointer;background-color:#ffffff05;border:1px solid #0000;border-radius:.5rem;padding:.75rem;font-size:.875rem;line-height:1.5;transition:all .2s}.note-display-inline:hover{border-color:var(--primary-color);background-color:#6366f10d}.note-content{color:var(--text-primary)}.note-content strong{color:var(--primary-color);margin-right:.5rem}.note-placeholder{color:var(--text-secondary);opacity:.6;font-style:italic}.lyrics-column,.production-column{flex-direction:column;gap:1rem;display:flex}.lyrics-sections-wrapper,.production-notes-wrapper{grid-auto-rows:auto;gap:1rem;display:grid}.lyric-section,.production-note{grid-row:span 1}.lyrics-column h3,.production-column h3{margin-bottom:.5rem;font-size:1.25rem}.lyric-section{background-color:var(--card-bg);border:2px solid var(--border-color);border-radius:.75rem;padding:1rem}.lyric-section.inactive{opacity:.5;border-style:dashed}.section-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;margin-bottom:.75rem;padding-bottom:.5rem;display:flex}.section-type{color:var(--primary-color);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem;font-weight:600}.section-actions{gap:.5rem;display:flex}.section-lines{flex-direction:column;gap:.5rem;display:flex}.lyric-line{cursor:pointer;border-radius:.25rem;padding:.5rem;transition:background-color .2s}.lyric-line:hover{background-color:var(--bg-color)}.lyric-line.inactive{color:var(--text-secondary);text-decoration:line-through}.production-note{background-color:var(--card-bg);border:2px solid var(--border-color);border-radius:.75rem;flex-direction:column;padding:1rem;display:flex}.production-note.inactive{opacity:.5}.note-header{border-bottom:1px solid var(--border-color);margin-bottom:.75rem;padding-bottom:.5rem}.note-editor{border:2px solid var(--primary-color);background-color:var(--bg-color);width:100%;min-height:80px;color:var(--text-primary);resize:vertical;border-radius:.5rem;padding:.75rem;font-family:inherit;font-size:.875rem}.note-editor:focus{outline:none}.note-display{cursor:pointer;white-space:pre-wrap;border-radius:.5rem;flex:1;min-height:40px;padding:.75rem;font-size:.875rem;line-height:1.6;transition:background-color .2s}.note-display:hover{background-color:var(--bg-color)}.note-placeholder{color:var(--text-secondary);font-style:italic}.mode-tabs{background-color:var(--card-bg);border:1px solid var(--border-color);border-radius:.75rem;gap:.25rem;width:fit-content;padding:.25rem;display:flex}.mode-tab{color:var(--text-secondary);background:0 0;border-radius:.55rem;align-items:center;gap:.4rem;padding:.5rem 1.1rem;font-size:.875rem;font-weight:500;transition:all .18s;display:flex}.mode-tab:hover{color:var(--text-primary);background-color:#ffffff0d}.mode-tab.active{background-color:var(--primary-color);color:#fff;font-weight:600;box-shadow:0 2px 8px #6366f159}.timecode-ctrl-bar{background:linear-gradient(#141e33fa,#0d1525fa);border:1px solid #6366f147;border-radius:.8rem;flex-direction:column;gap:0;padding:0;display:flex;overflow:hidden}.timecode-ctrl-bar.prep{border-color:#6366f152}.timecode-ctrl-bar.perf{border-color:#facc156b;box-shadow:0 0 0 1px #facc1514,0 18px 40px #0000005c}.song-sticky-top,.song-sticky-bottom,.song-sticky-cue{align-items:center;gap:.9rem;display:grid}.song-sticky-top{border-bottom:1px solid #94a3b81f;grid-template-columns:auto minmax(260px,1fr) auto;padding:.85rem 1rem .7rem}.song-sticky-bottom{background-color:#0f172a75;border-bottom:1px solid #94a3b81a;grid-template-columns:minmax(470px,1fr) auto auto auto;padding:.75rem 1rem}.song-sticky-cue{background-color:#080d1880;grid-template-columns:1fr;padding:.65rem 1rem .8rem}.song-back-btn{color:var(--text-primary);border:1px solid #0000;width:2.45rem;height:2.45rem}.song-back-btn:hover{background-color:#94a3b81a;border-color:#94a3b82e}.song-info-compact,.song-info-compact .title-container{min-width:0}.song-info-compact h2{text-overflow:ellipsis;white-space:nowrap;letter-spacing:0;font-size:1.45rem;line-height:1.1;overflow:hidden}.song-info-compact .subtitle{color:#cbd5e1b3;margin-top:.18rem}.song-info-compact .edit-title-container{max-width:36rem}.song-info-compact .edit-title-input{min-width:0}.header-control-group{background-color:#0000;border:0;flex-direction:column;gap:.38rem;padding:0;display:flex}.setlist-control-group,.cue-control-group{border-left:1px solid #94a3b81f;padding-left:.85rem}.control-group-label,.time-display-label{color:#94a3b8db;letter-spacing:0;text-transform:uppercase;font-size:.62rem;font-weight:800}.segmented-icon-group,.cue-controls-row{align-items:center;gap:.4rem;min-width:0;display:flex}.cue-control-group{min-width:0}.btn-header-icon{width:2.35rem;height:2.35rem;color:var(--text-primary);background-color:#0f172aa3;border:1px solid #94a3b829;border-radius:.5rem;justify-content:center;align-items:center;display:inline-flex}.btn-header-icon:hover:not(:disabled){background-color:#6366f129;border-color:#818cf873}.btn-header-icon:disabled{opacity:.3;cursor:not-allowed}.list-toggle-btn{color:#c7d2fe;background-color:#6366f12e;border-color:#818cf857}.header-actions{flex-wrap:wrap;justify-content:flex-end;gap:.45rem;display:flex}.header-action-btn{white-space:nowrap;min-height:2.45rem;box-shadow:none;border-radius:.5rem;padding:.55rem .85rem}.header-actions .btn-secondary{background-color:#64748b6b;border:1px solid #94a3b824}.header-actions .btn-secondary:hover{background-color:#64748b94}.header-actions .btn-primary{background-color:#6366f1;border:1px solid #818cf840}.time-display-group{grid-template-columns:minmax(190px,1.25fr) minmax(140px,.75fr);gap:.5rem;display:grid}.transport-cluster{grid-template-columns:minmax(340px,auto) auto;align-items:center;gap:.65rem;min-width:0;display:grid}.time-display-card{border:1px solid #94a3b824;border-radius:.62rem;flex-direction:column;justify-content:center;gap:.24rem;min-height:4.1rem;padding:.62rem .85rem;display:flex}.song-time-card{background:linear-gradient(#14532d47,#14532d24);border-color:#22c55e5c}.realtime-card{background-color:#0f172a94;border-color:#94a3b829}.timecode-main-display{font-variant-numeric:tabular-nums;color:#dcfce7;letter-spacing:0;font-family:SF Mono,Fira Mono,monospace;font-size:2rem;font-weight:800;line-height:1}.timecode-ctrl-bar.perf .timecode-main-display{color:#facc15;text-shadow:0 0 16px #facc1559}.wall-clock-display{font-variant-numeric:tabular-nums;color:#cbd5e1d1;letter-spacing:0;white-space:nowrap;font-family:SF Mono,Fira Mono,monospace;font-size:1.05rem;font-weight:700}.timecode-ctrl-bar.perf .wall-clock-display{color:#facc15b8}.timer-controls{justify-content:center;align-items:center;gap:.45rem;display:flex}.btn-timer{white-space:nowrap;border-radius:.5rem;align-items:center;gap:.4rem;min-height:2.5rem;padding:.55rem .9rem;font-size:.875rem;font-weight:600;transition:all .15s;display:flex}.btn-play{background-color:var(--success-color);color:#fff;justify-content:center;min-width:8.3rem}.btn-play:hover{background-color:#16a34a;transform:translateY(-1px);box-shadow:0 3px 10px #22c55e59}.btn-pause{color:#fff;background-color:#f59e0b;justify-content:center;min-width:8.3rem}.btn-pause:hover{background-color:#d97706}.btn-reset{color:#cbd5e1d1;background-color:#64748b57;border:1px solid #94a3b81f;padding:.55rem .75rem}.btn-reset:hover{color:var(--text-primary);background-color:#475569}.btn-section-nav{color:#93c5fd;background-color:#3b82f61a;border:1px solid #3b82f63d;padding:.55rem .75rem}.btn-section-nav:hover:not(:disabled){background-color:#3b82f640;border-color:#93c5fdb8}.btn-section-nav:disabled{opacity:.35;cursor:not-allowed}.next-cue-display{background:linear-gradient(#1e293b70,#0f172a80);border:1px solid #6366f12e;border-radius:.55rem;align-items:center;gap:.65rem;min-width:0;min-height:2.8rem;padding:.58rem .8rem;font-size:.9rem;display:flex}.next-cue-display-empty{opacity:.7}.next-cue-label{color:#93c5fd;text-transform:uppercase;letter-spacing:0;flex-shrink:0;font-size:.68rem;font-weight:800}.next-cue-name{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-weight:600;overflow:hidden}.next-cue-note{color:#a78bfa;text-overflow:ellipsis;white-space:nowrap;background-color:#a78bfa1a;border:1px solid #a78bfa40;border-radius:.3rem;max-width:200px;padding:.1rem .45rem;font-size:.78rem;font-style:italic;overflow:hidden}.next-cue-spacer{background-color:#94a3b824;flex:none;align-self:stretch;width:1px}.next-cue-in{color:var(--text-secondary);flex-shrink:0;font-size:.8rem}.next-cue-time{color:#bfdbfe;font-variant-numeric:tabular-nums;flex-shrink:0;font-family:SF Mono,Fira Mono,monospace;font-size:1.15rem;font-weight:800}.prep-hint{color:var(--text-secondary);max-width:340px;font-size:.8rem;font-style:italic}.section-row{align-items:flex-start;gap:0;display:flex}.section-main{flex:1;min-width:0}.timecode-col{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:.3rem;width:140px;padding:.6rem .75rem 0 0;display:flex}.timecode-pill-wrap{flex-direction:column;align-items:flex-end;gap:.3rem;display:flex}.timecode-pill{font-variant-numeric:tabular-nums;cursor:pointer;white-space:nowrap;border:1px solid #0000;border-radius:.4rem;padding:.3rem .6rem;font-family:SF Mono,Fira Mono,monospace;font-size:.78rem;transition:all .15s}.timecode-pill.unset{color:var(--text-secondary);border-color:var(--border-color);background-color:#ffffff0a}.timecode-pill.unset:hover{border-color:var(--primary-color);color:var(--text-primary)}.timecode-pill.set{color:#34d399;background-color:#34d3991a;border-color:#34d3994d}.timecode-pill.set:hover{background-color:#34d3992e;border-color:#34d39999}.timecode-pill.current{color:#facc15;background-color:#facc1526;border-color:#facc1580;box-shadow:0 0 6px #facc1540}.btn-tap{letter-spacing:.06em;background-color:var(--primary-color);color:#fff;border-radius:.35rem;padding:.25rem .6rem;font-size:.65rem;font-weight:700;transition:all .12s}.btn-tap:hover{background-color:var(--primary-hover);transform:scale(1.05)}.btn-tap:active{transform:scale(.96);box-shadow:0 0 0 3px #6366f159}.timecode-input{background-color:var(--bg-color);border:2px solid var(--primary-color);width:110px;color:var(--text-primary);text-align:right;border-radius:.4rem;padding:.35rem .6rem;font-family:SF Mono,Fira Mono,monospace;font-size:.82rem}.timecode-input:focus{outline:none;box-shadow:0 0 0 3px #6366f133}.timecode-pill-perf{font-variant-numeric:tabular-nums;color:var(--text-secondary);border:1px solid var(--border-color);white-space:nowrap;background-color:#ffffff08;border-radius:.4rem;margin-top:.6rem;padding:.3rem .6rem;font-family:SF Mono,Fira Mono,monospace;font-size:.78rem}.timecode-pill-perf.active{color:#facc15;background-color:#facc151f;border-color:#facc1566;box-shadow:0 0 8px #facc1533}.section-current-perf{box-shadow:0 0 0 2px #facc1526,inset 3px 0 #facc15;background-color:#facc150d!important;border-color:#facc15!important}.current-badge{letter-spacing:.07em;color:#facc15;background-color:#facc1526;border:1px solid #facc1559;border-radius:.3rem;padding:.15rem .5rem;font-size:.7rem;font-weight:700;animation:1.4s ease-in-out infinite pulse-badge}@keyframes pulse-badge{0%,to{opacity:1}50%{opacity:.6}}.perf-marker-col{flex-direction:column;flex-shrink:0;align-items:center;gap:.3rem;padding:.5rem 0 0 .75rem;display:flex}.btn-marker-good,.btn-marker-bad{border:2px solid #0000;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:1rem;transition:all .15s;display:flex}.btn-marker-good{color:#22c55e;background-color:#22c55e1f;border-color:#22c55e4d}.btn-marker-good:hover{background-color:#22c55e40;border-color:#22c55e;transform:scale(1.12)}.btn-marker-good:active{transform:scale(.93)}.btn-marker-bad{color:#ef4444;background-color:#ef44441f;border-color:#ef44444d}.btn-marker-bad:hover{background-color:#ef444440;border-color:#ef4444;transform:scale(1.12)}.btn-marker-bad:active{transform:scale(.93)}.marker-counts{flex-direction:column;align-items:center;gap:.15rem;display:flex}.marker-count{border-radius:.3rem;padding:.1rem .35rem;font-size:.7rem;font-weight:700}.marker-count.good{color:#22c55e;background-color:#22c55e26}.marker-count.bad{color:#ef4444;background-color:#ef444426}.perf-summary-bar{border:1px solid var(--border-color);background-color:#ffffff08;border-radius:.6rem;flex-wrap:wrap;align-items:center;gap:.5rem;padding:.6rem 1rem;font-size:.8rem;display:flex}.perf-summary-label{color:var(--text-secondary);margin-right:.25rem;font-weight:500}.perf-summary-chip{cursor:default;border-radius:9999px;align-items:center;gap:.35rem;padding:.2rem .6rem;font-family:SF Mono,Fira Mono,monospace;font-size:.75rem;display:inline-flex}.chip-song-time{font-variant-numeric:tabular-nums;opacity:.9}.chip-wall-time{font-variant-numeric:tabular-nums;opacity:.6;border-left:1px solid;padding-left:.35rem;font-size:.7rem}.perf-summary-chip.good{color:#22c55e;background-color:#22c55e1f;border:1px solid #22c55e40}.perf-summary-chip.bad{color:#ef4444;background-color:#ef44441f;border:1px solid #ef444440}.production-note-readonly{color:var(--text-secondary);background-color:#6366f10f;border-left:3px solid #6366f166;border-radius:0 .4rem .4rem 0;margin-top:.5rem;padding:.6rem .75rem;font-size:.82rem;font-style:italic;line-height:1.5}.perf-mode .notebook-section{padding:.75rem 1rem}.perf-mode .lyrics-notebook h3{color:#facc15}.timecode-ctrl-bar.sticky-bar{z-index:100;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);position:sticky;top:0;box-shadow:0 18px 36px #00000061}.timecode-ctrl-bar.sticky-bar.prep{background-color:#0d1525f5}.timecode-ctrl-bar.sticky-bar.perf{background-color:#0a0f1ef5}.bar-marker-btns{background-color:#0000;border-left:1px solid #94a3b824;justify-content:flex-end;align-items:center;gap:.45rem;padding-left:.8rem;display:flex}.btn-marker-bar{border:1px solid #0000;border-radius:.5rem;justify-content:center;align-items:center;gap:.4rem;width:auto;min-width:6.9rem;height:auto;min-height:2.5rem;padding:.45rem .85rem;font-size:.95rem;font-weight:800;transition:all .15s;display:flex}.btn-marker-bar span{letter-spacing:0;font-size:.72rem;font-weight:800}.btn-marker-good.btn-marker-bar{color:#22c55e;background-color:#22c55e1a;border-color:#22c55e57}.btn-marker-good.btn-marker-bar:hover{background-color:#22c55e33;border-color:#22c55e;transform:translateY(-1px)}.btn-marker-bad.btn-marker-bar{color:#ef4444;background-color:#ef44441a;border-color:#ef444457}.btn-marker-bad.btn-marker-bar:hover{background-color:#ef444433;border-color:#ef4444;transform:translateY(-1px)}.bar-marker-count{color:#94a3b8db;white-space:nowrap;font-size:.75rem}.chip-remove{color:currentColor;opacity:.5;cursor:pointer;background:0 0;border:none;padding:0 .1rem;font-size:.9rem;line-height:1;transition:opacity .15s}.chip-remove:hover{opacity:1}@media (width<=768px){.app-main{padding:1rem}.song-sticky-top,.song-sticky-bottom,.song-sticky-cue{grid-template-columns:1fr;padding-left:.8rem;padding-right:.8rem}.song-back-btn{justify-self:start}.header-actions,.timer-controls,.bar-marker-btns{justify-content:stretch}.bar-marker-btns{border-left:0;padding-left:0}.header-action-btn,.timer-controls .btn-timer,.btn-marker-bar{flex:1;justify-content:center}.transport-cluster,.time-display-group{grid-template-columns:1fr}.setlist-control-group,.cue-control-group{border-left:0;padding-left:0}.cue-controls-row{flex-wrap:wrap;align-items:stretch}.next-cue-display{flex-wrap:wrap;align-items:flex-start;width:100%}.next-cue-name,.next-cue-note{flex-basis:100%}.next-cue-spacer{display:none}.lyrics-container,.concert-grid{grid-template-columns:1fr}.ai-actions{flex-direction:column}.suggestions-grid{grid-template-columns:1fr}}@media (width>=769px) and (width<=1180px){.song-sticky-top{grid-template-columns:auto minmax(220px,1fr)}.header-actions{grid-column:1/-1;justify-content:flex-start}.song-sticky-bottom{grid-template-columns:minmax(360px,1fr) auto auto}.transport-cluster{grid-template-columns:1fr}.bar-marker-btns{grid-column:1/-1}.setlist-control-group,.cue-control-group{padding-left:.75rem}.bar-marker-btns{border-left:0;justify-content:flex-start;padding-left:0}}
