@font-face{font-family:MontserratLocal;src:url(/fonts/montserrat-latin-400.woff2)format("woff2");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:MontserratLocal;src:url(/fonts/montserrat-latin-500.woff2)format("woff2");font-weight:500;font-style:normal;font-display:swap}@font-face{font-family:MontserratLocal;src:url(/fonts/montserrat-latin-600.woff2)format("woff2");font-weight:600;font-style:normal;font-display:swap}@font-face{font-family:MontserratLocal;src:url(/fonts/montserrat-latin-700.woff2)format("woff2");font-weight:700;font-style:normal;font-display:swap}:root{--bg:#f5f8fb;--panel:#fff;--panel-border:#d8e1ea;--text:#213444;--muted:#5c7488;--select-bg:#f8fbfe;--select-border:#c6d4e1;--chip-bg:#f3f7fb;--chip-border:#c7d6e3;--chip-active-bg:#dff0ff;--chip-active-border:#5d9bd1;--font-body:"MontserratLocal", "Avenir Next", "Segoe UI", sans-serif;--font-display:"MontserratLocal", "Avenir Next", "Segoe UI", sans-serif;--font-size-body:1rem;--line-body:1.5;--line-heading:1.2;font-family:var(--font-body);color:var(--text);line-height:var(--line-body);background:radial-gradient(circle at 20% 0,#fff 0%,#f5f8fb 55%,#edf3f8 100%);font-weight:500}*{box-sizing:border-box}body{min-height:100vh;font-size:var(--font-size-body);font-family:var(--font-body);letter-spacing:.01em;margin:0}#app{min-height:100vh;padding:24px}.page{flex-direction:column;min-height:calc(100vh - 48px);display:flex}.layout{flex:1;grid-template-columns:320px 1fr;align-items:start;gap:20px;width:100%;max-width:1100px;margin:0 auto;display:grid}.panel,.diagram-wrap{background:var(--panel);border:1px solid var(--panel-border);border-radius:18px;padding:18px}h1,h2,h3,h4{font-family:var(--font-display);line-height:var(--line-heading);letter-spacing:.01em;color:#193042}h1{margin:0;font-size:clamp(1.45rem,1.2rem + 1vw,2rem);font-weight:700}.subtitle{color:var(--muted);margin:8px 0 16px;font-size:.98rem;line-height:1.45}.field{gap:6px;margin-bottom:12px;display:grid}.field span{letter-spacing:.03em;text-transform:uppercase;color:var(--muted);font-size:.86rem;font-weight:700}select{border:1px solid var(--select-border);background:var(--select-bg);width:100%;color:var(--text);font-family:var(--font-body);border-radius:10px;padding:10px;font-size:.95rem;font-weight:500}.chord-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.chord-chip{border:1px solid var(--chip-border);background:var(--chip-bg);color:var(--text);font-family:var(--font-body);letter-spacing:.01em;cursor:pointer;text-align:center;border-radius:10px;padding:10px 12px;font-size:.92rem;font-weight:700}.chord-chip:hover{border-color:#8db2d2}.chord-chip.is-active{background:var(--chip-active-bg);border-color:var(--chip-active-border);box-shadow:inset 0 0 0 1px #5d9bd133}.diagram-wrap{place-items:center;min-height:560px;display:grid}.advanced{border-top:1px dashed var(--panel-border);margin-top:14px;padding-top:10px}.advanced summary{color:var(--muted);text-transform:uppercase;letter-spacing:.04em;cursor:pointer;-webkit-user-select:none;user-select:none;font-size:.84rem;font-weight:700}.check-row{color:var(--text);align-items:center;gap:8px;margin-top:10px;font-size:.92rem;display:flex}.volume-row{justify-content:space-between}.volume-row input[type=range]{width:150px}.social-block{border-top:1px solid #c7d6e380;gap:8px;margin-top:14px;padding-top:10px;display:grid}.social-title{letter-spacing:.04em;text-transform:uppercase;color:var(--muted);font-size:.8rem;font-weight:700}.social-link{color:#2f6087;align-items:center;gap:8px;font-size:.9rem;font-weight:600;text-decoration:none;display:inline-flex}.social-link svg{fill:currentColor;width:18px;height:18px}.social-link:hover{color:#1e4462}.footer{border-top:1px solid var(--panel-border);width:100%;max-width:1100px;color:var(--muted);flex-wrap:wrap;justify-content:space-between;gap:10px;margin:18px auto 0;padding:10px 4px;font-size:.84rem;display:flex}.footer a{color:#2f6087;text-underline-offset:2px;font-weight:700;-webkit-text-decoration:underline #2f608759;text-decoration:underline #2f608759;transition:color .2s,text-decoration-color .2s}.footer a:hover{color:#1e4462;text-decoration-color:#1e4462b3}.footer-right{align-items:center;gap:10px;display:flex}.legal-page{background:var(--panel);border:1px solid var(--panel-border);width:100%;max-width:1100px;color:var(--text);border-radius:18px;margin:0 auto;padding:24px}.legal-page h1{margin-top:0}.legal-page h2{margin-top:1.6rem;margin-bottom:.7rem;font-size:1.2rem}.legal-page h3{margin-top:1.3rem;margin-bottom:.55rem;font-size:1.02rem}.legal-page h4{margin-top:1rem;margin-bottom:.4rem;font-size:.95rem}.legal-page p,.legal-page li{font-size:.95rem;line-height:1.55}a{color:#2f6087;text-underline-offset:2px;-webkit-text-decoration:underline #2f608759;text-decoration:underline #2f608759}a:hover{color:#1e4462;text-decoration-color:#1e4462b3}@media (width<=900px){#app{padding:12px}.layout{grid-template-columns:1fr}.diagram-wrap{min-height:420px}.footer{font-size:.82rem}}.app-header[data-v-6cfd102e]{margin-bottom:8px}.handpan[data-v-eed1c60b]{width:min(560px,92vw);height:auto}.shell[data-v-eed1c60b]{fill:url(#shellGradient);stroke:#b7c2cd;stroke-width:.8px}.tone[data-v-eed1c60b]{fill:#f9fbfd;stroke:#9aacbe;stroke-width:.65px;transition:fill .2s,stroke .2s}.center-tone[data-v-eed1c60b]{stroke-width:.75px}.tone-highlighted[data-v-eed1c60b]{fill:#ffe2ad;stroke:#de9b3e}.tone-label[data-v-eed1c60b]{fill:#243647;text-anchor:middle;dominant-baseline:middle;pointer-events:none;font-size:3.6px;font-weight:600}.slot-label[data-v-eed1c60b]{fill:#567188;text-anchor:middle;dominant-baseline:middle;pointer-events:none;font-size:2.6px;font-weight:700}
