@font-face{font-family:DM Sans;font-style:normal;font-weight:400;font-display:swap;src:url(../media/c3cb240f9c892514-s.163v2i5cux7-c.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:DM Sans;font-style:normal;font-weight:400;font-display:swap;src:url(../media/5c285b27cdda1fe8-s.p.0yo6-5yoeeudq.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:DM Sans;font-style:normal;font-weight:500;font-display:swap;src:url(../media/c3cb240f9c892514-s.163v2i5cux7-c.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:DM Sans;font-style:normal;font-weight:500;font-display:swap;src:url(../media/5c285b27cdda1fe8-s.p.0yo6-5yoeeudq.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:DM Sans;font-style:normal;font-weight:600;font-display:swap;src:url(../media/c3cb240f9c892514-s.163v2i5cux7-c.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:DM Sans;font-style:normal;font-weight:600;font-display:swap;src:url(../media/5c285b27cdda1fe8-s.p.0yo6-5yoeeudq.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:DM Sans;font-style:normal;font-weight:700;font-display:swap;src:url(../media/c3cb240f9c892514-s.163v2i5cux7-c.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:DM Sans;font-style:normal;font-weight:700;font-display:swap;src:url(../media/5c285b27cdda1fe8-s.p.0yo6-5yoeeudq.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:DM Sans Fallback;src:local(Arial);ascent-override:94.9%;descent-override:29.66%;line-gap-override:0.0%;size-adjust:104.53%}.dm_sans_81a33cc5-module___RQdfW__className{font-family:DM Sans,DM Sans Fallback;font-style:normal}.dm_sans_81a33cc5-module___RQdfW__variable{--font-dm-sans:"DM Sans", "DM Sans Fallback"}
:root{--bg:#fff;--bg2:#f5f5f3;--text:#1a1a1a;--text2:#555;--text3:#999;--border:#ddd;--border2:#e5e5e5;--blue-bg:#e6f1fb;--blue-border:#378add;--blue-text:#0c447c;--blue-fill:#378add;--amber-bg:#faeeda;--amber-border:#ba7517;--amber-text:#633806;--amber-fill:#ba7517;--green-bg:#e3f5ee;--green-border:#2da67a;--green-text:#0d5a3e;--green-fill:#2da67a}@media (prefers-color-scheme:dark){:root{--bg:#1a1a1a;--bg2:#252525;--text:#e8e8e8;--text2:#aaa;--text3:#666;--border:#333;--border2:#383838;--blue-bg:#162a42;--blue-text:#7db8f0;--amber-bg:#3a2a10;--amber-text:#e0a94e;--green-bg:#122e22;--green-text:#5cd6a4}}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-dm-sans), "DM Sans", system-ui, -apple-system, sans-serif;background:var(--bg2);color:var(--text);padding:40px 16px 16px;line-height:1.5}#app{max-width:960px;margin:0 auto}.top-row{flex-direction:column;gap:16px;margin-bottom:16px;display:flex}@media (min-width:1024px){#app{max-width:1280px}.top-row{flex-direction:row;align-items:flex-start}#selector-card{flex-shrink:0;width:320px;margin-bottom:0;position:sticky;top:16px}#fretboard-card{flex:1;min-width:0;margin-bottom:0}.top-row>.card{margin-bottom:0}}.card{background:var(--bg);border:.5px solid var(--border2);border-radius:16px;margin-bottom:16px;padding:24px}.section-label{color:var(--text3);letter-spacing:.06em;text-transform:uppercase;margin-bottom:8px;font-size:12px;font-weight:500}.pill-row{flex-wrap:wrap;gap:8px;margin-bottom:8px;display:flex}.pill{border:.5px solid var(--border);background:var(--bg2);color:var(--text2);white-space:nowrap;cursor:pointer;border-radius:24px;outline:none;padding:8px 16px;font-family:inherit;font-size:12px;font-weight:500;line-height:1;transition:all .15s}.pill:hover:not(.dim){border-color:var(--blue-border)}.pill.blue{background:var(--blue-bg);border-color:var(--blue-border);color:var(--blue-text)}.pill.green{background:var(--green-bg);border-color:var(--green-border);color:var(--green-text)}.pill.dim{opacity:.35;cursor:default;pointer-events:none}.pill .x-btn{opacity:.6;margin-left:4px;font-size:12px}.group-row{flex-direction:column;gap:8px;margin-bottom:16px;display:flex}.group-label{color:var(--text3);font-size:12px;font-weight:500}.group-divider{background:var(--border2);width:100%;height:.5px;margin:8px 0}.badge-row{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:16px;display:flex}.badge{border:.5px solid;border-radius:8px;align-items:center;gap:8px;padding:8px 16px;font-size:12px;font-weight:600;display:inline-flex}.badge.blue{background:var(--blue-bg);border-color:var(--blue-border);color:var(--blue-text)}.badge.green{background:var(--green-bg);border-color:var(--green-border);color:var(--green-text)}.badge-dot{border-radius:50%;width:8px;height:8px;display:inline-block}.badge-x{opacity:.6;cursor:pointer;margin-left:8px;font-size:12px}.voicing-btn{color:var(--blue-fill);border:.5px solid var(--blue-fill);cursor:pointer;background:0 0;border-radius:16px;padding:4px 8px;font-family:inherit;font-size:12px}.voicing-btn:hover{background:var(--blue-bg)}.voicing-btn.green{color:var(--green-fill);border-color:var(--green-fill)}.voicing-btn.green:hover{background:var(--green-bg)}.thumb-row{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.thumb-item{cursor:pointer;border:1.5px solid var(--border2);background:var(--bg2);text-align:center;border-radius:8px;padding:8px 8px 4px;transition:all .15s}.thumb-item:hover{border-color:var(--blue-border)}.thumb-item.selected{border-color:var(--blue-border);background:var(--blue-bg)}.thumb-label{color:var(--text2);white-space:nowrap;margin-top:4px;font-size:12px;font-weight:500}.thumb-item.selected .thumb-label{color:var(--blue-text);font-weight:600}.hand-switch{align-items:center;gap:8px;display:flex}.hand-switch span{color:var(--text3);font-size:12px;font-weight:500;transition:color .15s}.hand-switch span.active{color:var(--text)}.switch-track{background:var(--border);cursor:pointer;border-radius:12px;width:40px;height:24px;transition:background .2s;position:relative}.switch-knob{background:var(--bg);border-radius:50%;width:20px;height:20px;transition:left .2s;position:absolute;top:2px;left:2px;box-shadow:0 1px 3px #0000001f}.switch-track.on .switch-knob{left:18px}.fretboard-scroll{-webkit-overflow-scrolling:touch;touch-action:pan-x;background:var(--bg2);border-radius:12px;padding:16px 8px;overflow-x:auto}.fretboard-scroll.left-handed svg{transform:scaleX(-1)}.fretboard-scroll.left-handed svg text,.fretboard-scroll.left-handed svg .degree-label{transform-box:fill-box;transform-origin:50%;transform:scaleX(-1)}.legend{flex-wrap:wrap;align-items:center;gap:16px;margin-top:16px;display:flex}.legend-item{color:var(--text2);align-items:center;gap:8px;font-size:12px;display:flex}.legend-dot{border-radius:50%;width:8px;height:8px}.info-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;display:grid}.info-card{background:var(--bg2);border-radius:16px;padding:16px}.info-title{color:var(--text2);margin-bottom:8px;font-size:12px;font-weight:600}.tag{cursor:pointer;border:none;border-radius:8px;outline:none;margin:4px;padding:4px 8px;font-family:inherit;font-size:12px;font-weight:500;transition:all .12s;display:inline-block}.tag:hover{filter:brightness(.97)}.tag-blue{background:var(--blue-bg);color:var(--blue-text)}.tag-green{background:var(--green-bg);color:var(--green-text)}.tag-muted{background:var(--bg);border:.5px solid var(--border2);color:var(--text2)}.scale-label{color:var(--text3);margin-bottom:4px;font-size:12px}.scale-row{flex-wrap:wrap;gap:4px;margin-bottom:8px;display:flex}.cof-segment{cursor:pointer;transition:opacity .15s}.cof-segment:hover{opacity:.8}.scale-note{cursor:pointer;transition:transform .3s,filter .3s}.scale-note:hover{transform:scale(1.2)}.scale-note.pulsing{filter:brightness(1.3)drop-shadow(0 0 8px #2da67ab3);transform:scale(1.25)}.scale-note .degree-label{opacity:0;pointer-events:none;transition:opacity .15s}.scale-note:hover .degree-label{opacity:1}.fret-note{cursor:pointer}.fret-note .note-ring{opacity:.35;transition:opacity .15s}.fret-note .hover-bg{opacity:0;transition:opacity .15s}.fret-note:hover .note-ring{opacity:.6}.fret-note:hover .hover-bg{opacity:.1}.section-toggle{cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:8px 0;display:flex}.section-toggle:hover .toggle-arrow{opacity:1}.toggle-arrow{color:var(--text3);opacity:.6;font-size:12px;transition:transform .2s,opacity .15s}.toggle-arrow.collapsed{transform:rotate(-90deg)}.section-content{transition:max-height .3s,opacity .2s,padding .2s;overflow:hidden}.section-content.collapsed{opacity:0;max-height:0!important;padding-top:0!important;padding-bottom:0!important}
