:root{--sidebar-w: 260px;--top-bar-h: 52px;--bg: #0b1120;--surface: #151f32;--surface-2: #1e2d45;--surface-3: #243452;--border: #253452;--border-2: #2e3f60;--text: #e8eef8;--text-2: #b0bdd4;--text-muted: #7889a8;--text-faint: #4a5a78;--accent: #4f93ff;--accent-dim: #1a3566;--accent-hover: #6aa8ff;--success: #34d399;--warn: #fbbf24;--danger: #f87171;--tok-meta: #60a5fa;--tok-section-open: #34d399;--tok-section-end: #059669;--tok-directive: #a78bfa;--tok-chord: #fb923c;--tok-annotation: #22d3ee;--tok-comment: #6b7280;--tok-lyric: #e8eef8;--chord-color: #60a5fa;--annotation-color: #22d3ee;--radius: 6px;--radius-lg: 10px;--font: system-ui, -apple-system, "Segoe UI", sans-serif;--font-mono: "Fira Code", "Cascadia Code", "Consolas", monospace;font-family:var(--font);font-size:16px;line-height:1.6;color:var(--text);background:var(--bg);box-sizing:border-box}*,*:before,*:after{box-sizing:inherit}body{margin:0;min-height:100vh;display:flex;flex-direction:column}.app-body{display:flex;flex:1;padding-top:var(--top-bar-h)}.top-bar{position:fixed;top:0;left:0;right:0;height:var(--top-bar-h);background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px;padding:0 16px 0 12px;z-index:100}.menu-toggle{display:none;width:36px;height:36px;background:none;border:1px solid var(--border-2);border-radius:var(--radius);cursor:pointer;align-items:center;justify-content:center;flex-shrink:0}.hamburger,.hamburger:before,.hamburger:after{display:block;width:18px;height:2px;background:var(--text-2);border-radius:2px;position:relative;transition:transform .2s}.hamburger:before{content:"";position:absolute;top:-5px;left:0}.hamburger:after{content:"";position:absolute;top:5px;left:0}.top-bar-title{display:flex;align-items:baseline;gap:8px;flex:1}.brand{font-size:1rem;font-weight:700;letter-spacing:-.02em;color:var(--text)}.brand-sub{font-size:.75rem;color:var(--text-muted)}.top-bar-links{display:flex;gap:4px}.top-bar-links a{font-size:.8rem;color:var(--text-muted);text-decoration:none;padding:4px 10px;border:1px solid var(--border);border-radius:var(--radius);white-space:nowrap;transition:color .15s,border-color .15s,background .15s}.top-bar-links a:hover{color:var(--accent);border-color:var(--accent-dim);background:var(--accent-dim)}.sidebar{width:var(--sidebar-w);flex-shrink:0;position:fixed;top:var(--top-bar-h);bottom:0;left:0;overflow-y:auto;background:var(--surface);border-right:1px solid var(--border);scrollbar-width:thin;scrollbar-color:var(--border-2) transparent;z-index:90}.sidebar::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-track{background:transparent}.sidebar::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:4px}.sidebar-nav{padding:12px 0 40px}.nav-group{margin-bottom:4px}.nav-group-label{padding:10px 16px 4px;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-faint)}.nav-item{display:block;padding:6px 16px 6px 24px;font-size:.875rem;color:var(--text-muted);text-decoration:none;border-left:2px solid transparent;transition:color .15s,border-color .15s,background .15s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-item:hover{color:var(--text);background:var(--surface-2)}.nav-item.active{color:var(--accent);border-left-color:var(--accent);background:var(--accent-dim)}.doc-main{flex:1;margin-left:var(--sidebar-w);min-width:0;padding:0 0 80px}.doc-section{padding:48px 40px 0;max-width:1200px}.section-title{font-size:1.6rem;font-weight:700;letter-spacing:-.03em;color:var(--text);margin:0 0 24px;padding-bottom:12px;border-bottom:1px solid var(--border)}.doc-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.prose-block{padding:20px 24px 16px;font-size:.95rem;line-height:1.7;color:var(--text-2);border-bottom:1px solid var(--border)}.prose-block p{margin:0 0 12px}.prose-block p:last-child{margin-bottom:0}.prose-block ul,.prose-block ol{margin:0 0 12px;padding-left:20px}.prose-block li{margin-bottom:4px}.prose-block strong{color:var(--text);font-weight:600}.prose-block a{color:var(--accent)}.prose-block a:hover{color:var(--accent-hover)}code{font-family:var(--font-mono);font-size:.82em;background:var(--surface-3);color:var(--tok-chord);padding:1px 5px;border-radius:4px}.prose-code{font-family:var(--font-mono);font-size:.83rem;background:var(--surface-3);color:var(--text);padding:12px 16px;border-radius:var(--radius);overflow-x:auto;white-space:pre;margin:10px 0;border:1px solid var(--border-2)}.example-area{display:grid;grid-template-columns:1fr 1fr;min-height:240px}.example-pane{display:flex;flex-direction:column;min-height:0;border-right:1px solid var(--border)}.example-pane:last-child{border-right:none}.pane-label{padding:6px 12px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-faint);background:var(--surface-2);border-bottom:1px solid var(--border);flex-shrink:0}.code-editor{flex:1;padding:12px;background:var(--bg);color:var(--text);font-family:var(--font-mono);font-size:.83rem;line-height:1.55;border:none;resize:none;outline:none;min-height:180px}.code-editor:focus{box-shadow:inset 0 0 0 2px var(--accent-dim)}.example-output{flex:1;overflow:auto;padding:12px;font-size:.88rem}.card-controls{grid-column:1 / -1;background:var(--surface-2);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:8px 12px}.tp-controls{display:flex;gap:16px;flex-wrap:wrap;align-items:center}.tp-group{display:flex;align-items:center;gap:6px}.tp-btn{width:28px;height:28px;background:var(--surface-3);border:1px solid var(--border-2);border-radius:var(--radius);color:var(--text);font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.tp-btn:hover{background:var(--accent-dim);border-color:var(--accent)}.tp-display{min-width:30px;text-align:center;font-weight:700;color:var(--text-2);font-family:var(--font-mono)}.tp-reset{font-size:.78rem;padding:4px 10px;background:var(--surface-3);border:1px solid var(--border-2);border-radius:var(--radius);color:var(--text-muted);cursor:pointer}.tp-reset:hover{color:var(--accent);border-color:var(--accent)}.tp-radio{display:flex;align-items:center;gap:4px;font-size:.83rem;color:var(--text-2);cursor:pointer}.rendered-preview{max-width:600px;font-size:.9rem}.cp-header{margin-bottom:16px;padding-bottom:10px;border-bottom:1px solid var(--border)}.cp-title{margin:0 0 2px;font-size:1.2rem;font-weight:700;color:var(--text)}.cp-artist{margin:0;font-size:.85rem;color:var(--text-muted)}.cp-key{margin:4px 0 0;font-size:.78rem;color:var(--text-faint)}.cp-section{margin-bottom:16px;padding:10px 14px;border-radius:var(--radius);background:var(--surface-2);border:1px solid var(--border)}.cp-section--chorus{border-left:3px solid var(--accent)}.cp-section--verse{border-left:3px solid var(--success)}.cp-section--bridge{border-left:3px solid var(--warn)}.cp-section--prechorus{border-left:3px solid #a78bfa}.cp-section--tab{background:#0a1020;border-left:3px solid var(--text-faint)}.cp-section--grid{border-left:3px solid var(--tok-annotation)}.cp-section--custom{border-left:3px solid var(--text-faint)}.cp-section-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-faint);margin-bottom:6px}.cp-lyric-line{display:flex;align-items:flex-end;flex-wrap:wrap;margin-bottom:2px}.cp-segment{display:inline-flex;flex-direction:column;align-items:flex-start}.cp-chord{font-size:.78rem;font-weight:700;color:var(--chord-color);white-space:pre;display:block;min-height:1.2em;padding-right:6px}.cp-annotation{font-size:.78rem;font-style:italic;color:var(--annotation-color);white-space:pre;display:block;min-height:1.2em}.cp-lyric{white-space:pre;display:block}.cp-comment{color:var(--text-muted);font-style:italic;margin:4px 0;font-size:.88rem}.cp-comment-italic em{font-style:italic}.cp-comment-box{border:1px solid var(--border-2);border-radius:var(--radius);padding:3px 8px}.cp-chorus-ref{font-size:.82rem;color:var(--accent);font-style:italic;padding:4px 0}.cp-blank{height:10px}.cp-tab{font-family:var(--font-mono);font-size:.82rem;padding:10px;border-radius:var(--radius);overflow-x:auto;white-space:pre;color:var(--text-2)}.cp-grid-row{margin:2px 0}.cp-grid-bar{color:var(--text-faint);margin:0 4px}.cp-delegated{font-family:var(--font-mono);font-size:.78rem;white-space:pre;color:var(--text-muted);border:1px dashed var(--border-2);padding:8px;border-radius:var(--radius);margin-top:4px}.line-list{display:flex;flex-direction:column;gap:3px}.line-row{display:flex;align-items:center;gap:8px;font-size:.82rem}.line-num{min-width:24px;text-align:right;color:var(--text-faint);font-family:var(--font-mono)}.line-type{padding:1px 7px;border-radius:10px;font-size:.72rem;font-weight:600;white-space:nowrap}.type-blank{background:var(--surface-3);color:var(--text-faint)}.type-comment{background:#1f2937;color:var(--tok-comment)}.type-directive{background:#1e1337;color:var(--tok-directive)}.type-lyric{background:#0f2040;color:var(--tok-lyric)}.type-section{background:#0f2a1a;color:var(--tok-section-open)}.type-chorus_reference{background:#0f1f40;color:var(--accent)}.type-tab_line{background:#1a1a2e;color:var(--text-faint)}.type-grid_row{background:#0f2030;color:var(--tok-annotation)}.line-preview{font-family:var(--font-mono);font-size:.75rem;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.meta-table,.data-table,.chord-prop-table{width:100%;border-collapse:collapse;font-size:.82rem}.meta-table th,.data-table th{text-align:left;padding:6px 10px;color:var(--text-muted);font-weight:600;border-bottom:2px solid var(--border-2);background:var(--surface-2)}.meta-table td,.data-table td{padding:5px 10px;border-bottom:1px solid var(--border);color:var(--text-2)}.meta-table tr:hover td,.data-table tr:hover td{background:var(--surface-2)}.meta-key{font-family:var(--font-mono);font-size:.78rem;color:var(--tok-meta)}.meta-val{color:var(--text)}.seg-display{margin-bottom:12px}.seg-line{display:flex;flex-wrap:wrap;gap:2px;margin-bottom:6px;padding:6px 8px;background:var(--bg);border-radius:var(--radius)}.seg{display:inline-flex;flex-direction:column;border:1px solid var(--border);border-radius:4px;overflow:hidden}.seg-chord{font-size:.75rem;font-weight:700;color:var(--tok-chord);padding:2px 5px;background:#1a0f00;border-bottom:1px solid var(--border);white-space:nowrap}.seg-ann{font-size:.75rem;font-style:italic;color:var(--tok-annotation);padding:2px 5px;background:#001a1a;border-bottom:1px solid var(--border);white-space:nowrap}.seg-lyric{font-size:.78rem;padding:2px 5px;font-family:var(--font-mono);color:var(--text-2);white-space:pre}.chord-inspector-area{padding:16px}.ci-input-row,.shapes-input-row{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap}.chord-name-input{flex:1;min-width:140px;max-width:220px;padding:7px 12px;border:1px solid var(--border-2);border-radius:var(--radius);background:var(--surface-3);color:var(--text);font-family:var(--font-mono);font-size:1rem}.chord-name-input:focus{outline:none;border-color:var(--accent)}.instrument-select{padding:7px 12px;border:1px solid var(--border-2);border-radius:var(--radius);background:var(--surface-3);color:var(--text-2);font-size:.85rem}.ci-grid,.inspector-grid{display:flex;gap:16px;flex-wrap:wrap;align-items:flex-start}.chord-prop-table{min-width:180px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.chord-prop-table caption{text-align:left;padding:6px 10px 3px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-faint)}.pl{padding:4px 10px;color:var(--text-muted);font-size:.78rem;border-bottom:1px solid var(--border);white-space:nowrap}.pv{padding:4px 10px;font-family:var(--font-mono);font-size:.78rem;border-bottom:1px solid var(--border);color:var(--text-2)}.pv.ok{color:var(--success)}.pv.fail{color:var(--danger)}.none{color:var(--text-faint);font-family:inherit;font-style:italic}.diag-wrap,.diagram-wrap{padding:10px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);display:inline-block}.diag-wrap.large .chord-diagram{width:120px;height:140px}.no-shape,.no-diagram{font-size:.82rem;color:var(--text-muted);font-style:italic}.shapes-area{padding:16px}.shapes-grid{display:flex;flex-wrap:wrap;gap:12px;margin-top:14px}.mini-diag{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:8px}.shape-data{font-family:var(--font-mono);font-size:.75rem;color:var(--text-muted);background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:8px;overflow:auto;margin-top:10px}.chord-diagram{display:block}.chord-diagram .diagram-name{font-family:var(--font);font-weight:700;fill:var(--text);font-size:12px}.chord-diagram .nut{stroke:var(--text-2);stroke-width:4}.chord-diagram .fret-line{stroke:var(--border-2);stroke-width:1}.chord-diagram .string-line{stroke:var(--text-muted);stroke-width:1.5}.chord-diagram .finger-dot{fill:var(--text-2)}.chord-diagram .finger-label{font-family:var(--font);fill:var(--bg);font-size:10px;font-weight:700}.chord-diagram .open-marker{fill:none;stroke:var(--success);stroke-width:2}.chord-diagram .muted-marker{font-family:var(--font);fill:var(--danger);font-size:12px;font-weight:700}.chord-diagram .basefret-label{font-family:var(--font);fill:var(--text-muted);font-size:10px}.ok{color:var(--success)}.fail{color:var(--danger)}.dim{color:var(--text-faint);font-style:italic}.ext-filter{width:100%;padding:8px 12px;margin-bottom:12px;border:1px solid var(--border-2);border-radius:var(--radius);background:var(--surface-3);color:var(--text);font-size:.85rem}.ext-filter:focus{outline:none;border-color:var(--accent)}.ext-grid{display:flex;flex-wrap:wrap;gap:6px}.ext-chip{background:var(--surface-3);border:1px solid var(--border-2);border-radius:4px;padding:3px 8px;font-size:.8rem;color:var(--text-2)}.ext-chip .ext-part{color:var(--tok-chord)}.tp-key-badge{font-size:.82rem;color:var(--text-muted);background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:4px 10px;margin-bottom:10px;display:inline-block}.tp-key-badge strong{color:var(--text)}.sounding-key-bar{font-size:.82rem;color:var(--text-muted);background:var(--accent-dim);border:1px solid var(--border);border-radius:var(--radius);padding:4px 10px;margin-bottom:10px;display:inline-block}.sounding-key-bar strong{color:var(--text)}.nash-controls{display:flex;align-items:center;gap:12px;margin-bottom:12px}.nash-key-label{font-size:.82rem;color:var(--text-2);display:flex;align-items:center;gap:6px}.nash-key-input{width:56px;text-align:center;font-weight:700}.nash-output-col{display:flex;flex-direction:column;gap:10px;flex:1;min-width:0}.cref-block{margin-bottom:16px}.cref-header{font-size:.82rem;color:var(--text-2);background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius) var(--radius) 0 0;padding:6px 10px}.cref-content{border:1px solid var(--border);border-top:none;border-radius:0 0 var(--radius) var(--radius);padding:8px}.cdef-block{margin-bottom:16px}.cdef-name{font-family:var(--font-mono);font-size:.82rem;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius) var(--radius) 0 0;padding:5px 10px;color:var(--text-2)}.cdef-row{display:flex;gap:12px;align-items:flex-start;border:1px solid var(--border);border-top:none;border-radius:0 0 var(--radius) var(--radius);padding:10px}.diag-wrap{flex-shrink:0}.cdef-json{flex:1;min-width:0;margin:0;font-size:.75rem}.key-result{display:flex;gap:14px;align-items:center;margin-bottom:12px}.key-badge{font-size:2rem;font-weight:800;color:var(--accent);letter-spacing:-.04em;padding:8px 16px;background:var(--accent-dim);border-radius:var(--radius)}.key-detail{font-size:.85rem;color:var(--text-2)}.conf-bar{height:6px;background:var(--surface-3);border-radius:3px;width:160px;margin-top:6px}.conf-fill{height:100%;background:var(--accent);border-radius:3px;transition:width .3s}.token-display{font-family:var(--font-mono);font-size:.82rem;white-space:pre-wrap;line-height:1.7;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:12px;margin-bottom:12px;overflow:auto}.tok{border-radius:2px}.tok-legend{display:flex;flex-wrap:wrap;gap:8px;font-size:.75rem;color:var(--text-muted)}.legend-item{display:flex;align-items:center;gap:4px}.legend-dot{width:9px;height:9px;border-radius:50%;display:inline-block}.ft-layout{display:grid;grid-template-columns:1fr 1fr;min-height:340px}.ft-col{display:flex;flex-direction:column;border-right:1px solid var(--border)}.ft-col:last-child{border-right:none}.ft-editor{flex:1;padding:12px;background:var(--bg);color:var(--text);font-family:var(--font-mono);font-size:.82rem;border:none;resize:none;outline:none}.ft-meta-row{display:flex;flex-wrap:wrap;gap:4px;padding:8px 12px;border-bottom:1px solid var(--border);min-height:36px;background:var(--surface-2)}.meta-pill{display:inline-flex;border-radius:12px;overflow:hidden;font-size:.72rem;border:1px solid var(--border-2)}.meta-key{background:var(--accent);color:var(--bg);padding:2px 7px;font-weight:600}.meta-val{background:var(--surface-3);color:var(--text-2);padding:2px 7px}.ft-output-pre{flex:1;margin:0;padding:12px;font-family:var(--font-mono);font-size:.8rem;color:var(--text-2);white-space:pre;overflow:auto}.rt-checks{display:flex;gap:16px;flex-wrap:wrap;padding:10px;background:var(--surface-2);border-radius:var(--radius);margin-bottom:12px;font-size:.85rem}.rt-check{display:flex;align-items:center;gap:6px}.rt-split{display:grid;grid-template-columns:1fr 1fr;gap:10px}.rt-pre{font-family:var(--font-mono);font-size:.78rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:10px;overflow:auto;max-height:340px;white-space:pre;margin:4px 0 0}.warn-section{margin-bottom:12px}.warn-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}.warn-list li{display:flex;gap:8px;align-items:baseline;font-size:.82rem;padding:5px 10px;background:#1a1000;border:1px solid #3d2a00;border-left:3px solid var(--warn);border-radius:var(--radius)}.warn-loc{color:var(--text-faint);min-width:50px}.warn-code{font-family:var(--font-mono);font-size:.75rem;color:var(--warn)}.warn-msg{color:var(--text-muted)}.warn-chip{font-family:var(--font-mono);font-size:.72rem;padding:1px 6px;background:#1a1000;border:1px solid #3d2a00;border-radius:10px;color:var(--warn)}.no-warnings{font-size:.82rem;color:var(--success)}.sc-warnings{padding:6px 12px;background:#1a1000;border-top:1px solid #3d2a00;font-size:.8rem;display:flex;gap:6px;flex-wrap:wrap;align-items:center;color:var(--warn)}.dir-table{font-size:.8rem}.dir-table th{position:sticky;top:0}.scratch-shell{display:grid;grid-template-columns:1fr 1fr;min-height:500px}.scratch-left{display:flex;flex-direction:column;border-right:1px solid var(--border)}.scratch-input-header{display:flex;align-items:center;justify-content:space-between;padding:6px 12px;background:var(--surface-2);border-bottom:1px solid var(--border)}.scratch-editor{flex:1;padding:12px;background:var(--bg);color:var(--text);font-family:var(--font-mono);font-size:.82rem;border:none;resize:none;outline:none;min-height:200px}.scratch-controls{padding:10px 12px;border-top:1px solid var(--border);background:var(--surface-2);display:flex;flex-direction:column;gap:6px}.ctrl-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.ctrl-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-faint);min-width:70px}.stepper{display:flex;align-items:center;gap:4px}.scratch-right{display:flex;flex-direction:column;min-height:0}.sc-tabs{display:flex;background:var(--surface-2);border-bottom:1px solid var(--border);padding:0 8px;overflow-x:auto}.sc-tab{padding:8px 12px;font-size:.8rem;border:none;background:transparent;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;white-space:nowrap;transition:color .15s,border-color .15s}.sc-tab:hover{color:var(--text)}.sc-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.sc-panel-wrap{flex:1;min-height:0;overflow:hidden;position:relative}.sc-panel{display:none;height:100%;overflow:auto;padding:12px}.sc-panel.active{display:block}.sc-panel pre{font-family:var(--font-mono);font-size:.78rem;margin:0;white-space:pre;overflow:auto}.site-footer{background:var(--surface);border-top:1px solid var(--border);padding:10px 40px;display:flex;gap:20px;flex-wrap:wrap;font-size:.75rem;color:var(--text-faint);margin-left:var(--sidebar-w)}.site-footer a{color:var(--text-muted)}@media (max-width: 900px){:root{--sidebar-w: 0px}.menu-toggle{display:flex}.sidebar{width:260px;transform:translate(-100%);transition:transform .25s ease;z-index:200}.sidebar.open{transform:translate(0)}.backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:150}.doc-main{margin-left:0}.doc-section{padding:32px 16px 0}.site-footer{margin-left:0}.example-area{grid-template-columns:1fr}.example-pane{border-right:none;border-bottom:1px solid var(--border)}.example-pane:last-child{border-bottom:none}.ft-layout{grid-template-columns:1fr}.ft-col{border-right:none;border-bottom:1px solid var(--border)}.scratch-shell{grid-template-columns:1fr}.scratch-left{border-right:none;border-bottom:1px solid var(--border)}.rt-split{grid-template-columns:1fr}.ci-grid{flex-direction:column}.top-bar-links a:not(:first-child){display:none}}@media (max-width: 600px){.doc-section{padding:24px 12px 0}.section-title{font-size:1.3rem}.prose-block{padding:14px 16px 12px}}
