:root{--bg: #1a1b1e;--surface: #25262b;--border: #373a40;--text: #e9ecef;--muted: #868e96;--accent: #4dabf7;--chord-color: #ffa94d;--lyric-color: #e9ecef;--chord-min-height: 28px;--lyric-min-height: 40px;--chord-font-size: 13px;--lyric-font-size: 16px;--editor-font: ui-monospace, "Cascadia Mono", "Segoe UI Mono", "Noto Sans Mono", "Liberation Mono", monospace}*,*:before,*:after{box-sizing:border-box}html{font-family:system-ui,Segoe UI,Roboto,sans-serif}body{margin:0;min-height:100vh;background:var(--bg);color:var(--text)}#app{max-width:56rem;margin:0 auto;padding:1rem 1.25rem 2rem}.toolbar{position:sticky;top:0;z-index:20;display:flex;flex-direction:column;gap:.55rem;margin-bottom:1rem;padding:.85rem 0 .9rem;border-bottom:1px solid var(--border);background:#1a1b1ef5;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 6px 18px #0000002e}.toolbar-top{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.toolbar h1{margin:0;font-size:1.2rem;font-weight:700}.toolbar-row{display:flex;flex-wrap:wrap;gap:.55rem .75rem;align-items:center}.toolbar-row-song,.toolbar-row-output{padding:.1rem 0}.toolbar-group{display:flex;flex-wrap:wrap;gap:.42rem;align-items:center}.toolbar label{font-size:.8125rem;color:var(--muted)}button,select{font:inherit;font-size:.875rem;padding:.42rem .72rem;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer}button:hover,select:hover{border-color:var(--muted)}button.primary{background:#1c7ed6;border-color:#1971c2;color:#fff}button.primary:hover{background:#228be6}#btn-guide{background:#d0ebff;border-color:#74c0fc;color:#0b4f87;white-space:nowrap}#btn-guide:hover{background:#a5d8ff;border-color:#4dabf7}button.attention-save{background:#c92a2a;border-color:#a61e1e;color:#fff}button.attention-save:hover{background:#e03131;border-color:#c92a2a}@media(max-width:900px){.toolbar-top{align-items:flex-start;flex-direction:column}}.config-panel{display:none;grid-template-columns:repeat(auto-fill,minmax(11rem,1fr));gap:.75rem 1rem;padding:.75rem 0 0;margin-bottom:.5rem;font-size:.8125rem}.config-panel.open{display:grid}.guide-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000009e;display:none;align-items:center;justify-content:center;padding:1rem;z-index:50}.guide-modal.open{display:flex}.layout-inline{margin:0 0 .5rem}.layout-sheet{width:100%;max-height:none;overflow:auto;background:#202126;border:1px solid var(--border);border-radius:12px;padding:.65rem;position:relative}.layout-toolbar{display:flex;align-items:center;flex-wrap:wrap;gap:.45rem;margin:.35rem 0 .5rem}#sel-layout-cols{width:3.1rem;padding:.2rem .25rem}.layout-stats{margin-left:auto;color:var(--muted);font-size:.72rem}.layout-body{display:block}.layout-preview{border:1px solid var(--border);border-radius:10px;background:#181a1f;padding:.45rem;max-height:260px;overflow:auto;direction:ltr}.layout-page{border:1px dashed #4a4d55;border-radius:8px;padding:.45rem;margin-bottom:.6rem;background:#22252c}.layout-page h4{margin:0 0 .4rem;font-size:.78rem;color:#c8d0da}.layout-page-grid{display:grid;gap:.55rem;direction:ltr}.layout-page-grid.cols-1{grid-template-columns:1fr}.layout-page-grid.cols-2{grid-template-columns:1fr 1fr}.layout-page-grid.cols-3{grid-template-columns:1fr 1fr 1fr}.layout-col{display:flex;flex-direction:column;gap:.45rem}.layout-card{border:1px solid #4f6478;background:linear-gradient(180deg,#1f3142,#172633);border-radius:8px;padding:.28rem;display:flex;flex-direction:column;cursor:grab}.layout-card.dragging{opacity:.45}.layout-card.drop-before{outline:2px solid #74c0fc;outline-offset:1px}.layout-card strong{font-size:.72rem}.layout-card span{font-size:.68rem;color:#b7cfe5;margin-top:auto}.guide-sheet{width:min(900px,100%);max-height:90vh;overflow:auto;background:#202126;border:1px solid var(--border);border-radius:12px;padding:1rem;position:relative}.lyrics-import-sheet{width:min(760px,100%)}.lyrics-import-text{width:100%;min-height:280px;resize:vertical;border:1px solid var(--border);border-radius:8px;background:#181a1f;color:var(--text);padding:.75rem .85rem;font:inherit;line-height:1.45}.lyrics-import-text:focus{outline:1px solid var(--accent);outline-offset:1px}.lyrics-import-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:.75rem}.guide-sheet h2{margin:0;font-size:1.1rem}.guide-sub{margin:.25rem 0 .9rem;color:var(--muted);font-size:.82rem}.guide-close{position:absolute;right:.65rem;top:.6rem;width:1.9rem;height:1.9rem;border-radius:999px;padding:0;font-size:.95rem}.guide-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.65rem}@media(max-width:900px){.layout-body{grid-template-columns:1fr}.layout-stats{margin-left:0}}.guide-card{border:1px solid var(--border);background:#2a2c33;border-radius:10px;padding:.65rem}.guide-card h3{margin:0;font-size:.86rem}.guide-card p{margin:.35rem 0 .55rem;font-size:.76rem;line-height:1.35;color:#d3d7de}.guide-visual{border:1px dashed #4a4d55;border-radius:8px;background:#1b1d22;padding:.45rem .5rem;font-size:.74rem;line-height:1.35;color:#dde1e8}.guide-visual.mono{font-family:var(--editor-font)}.guide-accent{color:#7fc6ff}.config-panel fieldset{margin:0;padding:.65rem .75rem;border:1px solid var(--border);border-radius:8px;background:var(--surface)}.config-panel legend{padding:0 .35rem;color:var(--muted);font-size:.75rem}.config-row{display:flex;align-items:center;gap:.5rem;margin-top:.45rem}.config-row:first-of-type{margin-top:0}.config-row input[type=number]{width:4.5rem;font:inherit;padding:.25rem .4rem;border-radius:4px;border:1px solid var(--border);background:var(--bg);color:var(--text)}.config-row select{flex:1;min-width:0}.hint{font-size:.75rem;color:var(--muted);line-height:1.4;margin:0 0 1rem}.editor{display:flex;flex-direction:column;gap:0}.stanza-row{display:flex;flex-direction:column;border-left:3px solid var(--border);padding-left:.5rem;width:85%;margin-left:auto;margin-right:auto;margin-bottom:.75rem;position:relative}.stanza-row:focus-within{border-left-color:var(--accent)}.row-meta{display:flex;align-items:center;flex-wrap:wrap;gap:.4rem;margin:0 0 .3rem}.row-drag-handle{font:inherit;font-size:.9rem;line-height:1;padding:.15rem .35rem;border-radius:4px;border:1px dashed var(--border);background:transparent;color:var(--muted);cursor:grab}.row-drag-handle:active{cursor:grabbing}.row-kind-buttons{display:inline-flex;border:1px solid var(--border);border-radius:6px;overflow:hidden}.row-kind-btn{font-size:.7rem;padding:.2rem .45rem;border:0;border-right:1px solid var(--border);border-radius:0;background:#1c1d22;color:var(--muted);white-space:nowrap}.row-kind-btn:last-child{border-right:0}.row-kind-btn:hover{color:var(--text);background:#262932}.row-kind-btn.active{color:#fff;background:var(--accent)}.row-section-preset{font-size:.72rem;padding:.18rem .35rem;border-radius:4px;max-width:12rem}.row-select-cb{width:1rem;height:1rem;cursor:pointer;accent-color:var(--accent);flex-shrink:0}.row-action-btn{font-size:.7rem;padding:.15rem .45rem;border-radius:4px;border:1px solid var(--border);background:var(--surface);color:var(--muted);cursor:pointer;margin:0 .1rem;transition:color .15s,border-color .15s,background-color .15s;white-space:nowrap}.row-action-btn:hover:not(:disabled){color:var(--text);border-color:var(--muted)}.row-action-btn:disabled{opacity:.35;cursor:default}.row-delete-btn{color:#ffb4b4;border-color:#7f3030}.row-delete-btn:hover:not(:disabled){color:#ffd9d9;border-color:#c94b4b;background:#c94b4b1f}.row-section-tag{margin-left:auto;font-size:.68rem;color:var(--muted);border:1px solid var(--border);border-radius:999px;padding:.05rem .45rem;background:#0000001f}.row-end-section-btn.active{background-color:#4dabf726;border-color:var(--accent);color:var(--accent)}.section-divider{height:2px;background:linear-gradient(90deg,var(--accent) 0%,transparent 100%);margin:.5rem 0 .5rem .5rem}.section-live-preview{position:absolute;top:0;width:min(29vw,320px);border:1px solid #3f434c;border-radius:8px;background:#1b1d23;padding:.45rem;z-index:3;box-shadow:0 8px 20px #00000047}.section-live-preview[data-side=right]{left:calc(100% + 12px)}.section-live-preview[data-side=left]{right:calc(100% + 12px)}.section-live-preview h5{margin:0 0 .35rem;font-size:.72rem;color:#9fb8d4}.section-live-preview-body{display:flex;flex-direction:column;gap:.24rem}.section-live-row{font-size:.72rem;color:#d6d9df;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.section-live-row.row-header{font-weight:700;color:#8fc6ff}.section-live-row.row-chords{color:#f0b58e}@media(max-width:1200px){.section-live-preview{display:none!important}}.row-insert-between{position:absolute;right:-1.1rem;bottom:-.78rem;width:1.45rem;height:1.45rem;border-radius:999px;padding:0;margin:0;font-size:.95rem;font-weight:700;line-height:1;color:#0b4f87;background:#d0ebff;border:1px solid #74c0fc;z-index:3}.row-insert-between:hover{background:#a5d8ff;border-color:#4dabf7}.stanza-row[data-dir=ltr].section-child-row{transform:translate(1rem)}.stanza-row[data-dir=rtl].section-child-row{transform:translate(-1rem)}.stanza-row.section-active{background:#4dabf712;border-radius:6px}.stanza-row.row-drop-target{outline:2px dashed var(--accent);outline-offset:2px}.stanza-row.row-drag-origin{opacity:.55}.lyric-stage{position:relative;width:100%;overflow:visible}.lyric-input{display:block;width:100%;margin:0;padding:calc(var(--chord-min-height) + .35rem) .4rem .35rem;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--lyric-color);font-family:var(--editor-font);font-size:var(--lyric-font-size);line-height:1.35;resize:vertical;field-sizing:content;min-height:calc(var(--lyric-min-height) + var(--chord-min-height) + .8rem);overflow:auto;position:relative;z-index:1;-webkit-user-select:text;user-select:text;cursor:text}.lyric-input::placeholder{color:var(--muted);opacity:.7}.lyric-input:focus{outline:1px solid var(--accent);outline-offset:1px}.stanza-row[data-dir=rtl] .lyric-input{direction:rtl;text-align:right}.stanza-row[data-dir=ltr] .lyric-input{direction:ltr;text-align:left}.chord-overlay{position:absolute;left:0;top:0;width:100%;height:100%;pointer-events:none;z-index:2;overflow:visible}.lyric-mirror{position:absolute;left:0;top:0;visibility:hidden;pointer-events:none;white-space:pre-wrap;overflow-wrap:break-word}.caret-marker{display:inline-block;width:0;overflow:hidden}.chord-zone{position:absolute;left:0;top:0;width:100%;height:calc(var(--chord-min-height) + .5rem);z-index:1;background:transparent;pointer-events:auto;cursor:default}.lyric-stage:hover .chord-zone{cursor:crosshair}.stanza-row[data-kind=header] .chord-zone,.stanza-row[data-kind=header] .chord-overlay{display:none}.stanza-row[data-kind=header] .lyric-input{padding-top:.4rem;border-color:#5c7cfa;color:#dbe4ff;font-weight:700;text-decoration:underline}.stanza-row[data-kind=chords] .lyric-input{color:#e9ecef26;caret-color:var(--muted)}.stanza-row[data-kind=chords] .lyric-input::placeholder{color:#868e9659}.chord-bubble{position:absolute;pointer-events:auto;width:auto;min-width:2.6ch;padding:.1rem .2rem;margin:0;border:1px solid var(--border);border-radius:4px;background:#25262bf2;color:var(--chord-color);font-family:var(--editor-font);font-size:var(--chord-font-size);font-weight:600;line-height:1.2;transform:translate(-50%);text-align:center;direction:ltr;unicode-bidi:isolate;-webkit-user-select:none;user-select:none;cursor:grab;transition:border-color .15s,box-shadow .15s}.chord-bubble:readonly{cursor:grab}.chord-bubble:not(:readonly){cursor:text}.chord-bubble.selected{border-color:var(--accent);box-shadow:0 0 0 2px #4dabf733}.chord-bubble:focus{outline:1px solid var(--accent);outline-offset:1px}body.use-system-font .lyric-input,body.use-system-font .chord-bubble{font-family:system-ui,Segoe UI,Roboto,sans-serif}
