.piano-outer.svelte-19i9hpt{display:flex;align-items:stretch;width:100%}.piano-wrapper.svelte-19i9hpt{flex:1;min-width:0;overflow:hidden}.piano.svelte-19i9hpt{position:relative;width:100%;height:160px;-moz-user-select:none;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;touch-action:none;overscroll-behavior:contain}.piano.color-mode.svelte-19i9hpt .key:where(.svelte-19i9hpt){cursor:cell}.key.svelte-19i9hpt{border:none;cursor:pointer;transition:background .1s ease;padding:0;margin:0;position:absolute;top:0;outline:none;touch-action:none;-moz-user-select:none;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}.key.svelte-19i9hpt:disabled{cursor:default}.chevron.svelte-19i9hpt{display:flex;align-items:center;justify-content:center;width:32px;flex-shrink:0;border:none;background:#ff8c0014;color:#ff8c00;cursor:pointer;transition:all .15s ease;padding:0;z-index:3}.chevron-left.svelte-19i9hpt{border-radius:8px 0 0 8px}.chevron-right.svelte-19i9hpt{border-radius:0 8px 8px 0}.chevron.svelte-19i9hpt:hover:not(:disabled){background:#ff8c0026;color:#e07800}.chevron.svelte-19i9hpt:disabled{opacity:.3;cursor:default}.dark .chevron.svelte-19i9hpt{background:#ff8c001a;color:#f59e0b}.dark .chevron.svelte-19i9hpt:hover:not(:disabled){background:#ff8c0033}.key.natural.svelte-19i9hpt{height:100%;background:linear-gradient(to bottom,#f8f8f8,#fff 6%,#fff 92%,#eee);border:1px solid #bbb;border-top:none;border-radius:0 0 5px 5px;z-index:1;display:flex;align-items:flex-end;justify-content:center;padding-bottom:6px;box-shadow:inset 0 -1px 2px #00000014,0 1px 2px #0000001a,inset 1px 1px #fff6,inset -1px -1px #fff3}.key.natural.svelte-19i9hpt+.key.natural:where(.svelte-19i9hpt){border-left:none}.key.natural.svelte-19i9hpt:hover:not(:disabled):not(.correct):not(.incorrect){background:linear-gradient(to bottom,#eef,#f5f5ff 6%,#f5f5ff 92%,#e8e8f0)}.key.natural.selected.svelte-19i9hpt{background:linear-gradient(to bottom,#bfdbfe,#dbeafe,#c7d2fe);border-color:#3b82f6;box-shadow:inset 0 0 0 999px #bfdbfed1,inset 0 0 0 2px #3b82f6}.key.natural.correct.svelte-19i9hpt{background:linear-gradient(to bottom,#86efac,#a7f3c4,#6ee7a0);border-color:#22c55e;box-shadow:inset 0 0 0 2px #22c55e}.key.natural.incorrect.svelte-19i9hpt{background:linear-gradient(to bottom,#fca5a5,#fecaca,#f98c8c);border-color:#ef4444;box-shadow:inset 0 0 0 2px #ef4444}.dark .key.natural.svelte-19i9hpt{background:linear-gradient(to bottom,#2a2a3a,#1f1f2e 6%,#1f1f2e 92%,#1a1a28);border:1px solid #555;border-top:none;box-shadow:inset 0 -1px 2px #ffffff0d,0 1px 2px #0000004d,inset 1px 1px #ffffff4d,inset -1px -1px #ffffff26}.dark .key.natural.svelte-19i9hpt:hover:not(:disabled):not(.correct):not(.incorrect){background:linear-gradient(to bottom,#353550,#2a2a40,#242438)}.dark .key.natural.selected.svelte-19i9hpt{background:linear-gradient(to bottom,#60a5fa,#93c5fd,#7c9ef5);border-color:#3b82f6;box-shadow:inset 0 0 0 999px #60a5faa6,inset 0 0 0 2px #3b82f6,0 0 8px #3b82f680}.dark .key.natural.correct.svelte-19i9hpt{background:linear-gradient(to bottom,#166534,#1a7a3e,#145c2e);border-color:#4ade80;box-shadow:inset 0 0 0 2px #4ade80}.dark .key.natural.incorrect.svelte-19i9hpt{background:linear-gradient(to bottom,#7f1d1d,#991b1b,#6f1a1a);border-color:#f87171;box-shadow:inset 0 0 0 2px #f87171}.key.accidental.svelte-19i9hpt{width:calc(100% / var(--nat-count) * .58);height:62%;background:linear-gradient(to bottom,#222,#333 40%,#222 90%,#111);border:1px solid #000;border-top:none;border-radius:0 0 4px 4px;z-index:2;transform:translate(-50%);box-shadow:inset 0 -1px 2px #ffffff0d,1px 1px 3px #0006,-1px 0 3px #0006,inset 1px 1px 1px #ffffff26}.key.accidental.svelte-19i9hpt:hover:not(:disabled):not(.correct):not(.incorrect):not(.selected){background:linear-gradient(to bottom,#333,#444 40%,#333 90%,#222)}.key.accidental.selected.svelte-19i9hpt{background:linear-gradient(to bottom,#3b82f6,#2563eb,#1d4ed8);border-color:#1d4ed8;box-shadow:none;z-index:10}.key.accidental.correct.svelte-19i9hpt{background:linear-gradient(to bottom,#16a34a,#22c55e,#15803d);border-color:#14532d;box-shadow:0 0 10px #22c55eb3}.key.accidental.incorrect.svelte-19i9hpt{background:linear-gradient(to bottom,#dc2626,#ef4444,#b91c1c);border-color:#7f1d1d;box-shadow:0 0 10px #ef4444b3}.dark .key.accidental.svelte-19i9hpt{background:linear-gradient(to bottom,#d4d4e0,#e5e5f0 40%,#d4d4e0 90%,#c5c5d5);border:1px solid #888;border-top:none;box-shadow:inset 0 -1px 2px #0000001a,1px 1px 3px #0003,-1px 0 3px #0003,inset 1px 1px 1px #fff6}.dark .key.accidental.svelte-19i9hpt:hover:not(:disabled):not(.correct):not(.incorrect):not(.selected){background:linear-gradient(to bottom,#c5c5d5,#d4d4e0 40%,#c5c5d5 90%,#b5b5c5)}.dark .key.accidental.selected.svelte-19i9hpt{background:linear-gradient(to bottom,#3b82f6,#2563eb,#1d4ed8);border-color:#1d4ed8;box-shadow:none;z-index:10}.dark .key.accidental.correct.svelte-19i9hpt{background:linear-gradient(to bottom,#16a34a,#22c55e,#15803d);box-shadow:0 0 10px #22c55eb3}.dark .key.accidental.incorrect.svelte-19i9hpt{background:linear-gradient(to bottom,#dc2626,#ef4444,#b91c1c);box-shadow:0 0 10px #ef4444b3}.key-label.svelte-19i9hpt{font-size:12px;font-weight:700;color:#6b7280;pointer-events:none}.dark .key-label.svelte-19i9hpt{color:#9ca3af}.selected.svelte-19i9hpt .key-label:where(.svelte-19i9hpt){color:#1e3a5f}.dark .selected.svelte-19i9hpt .key-label:where(.svelte-19i9hpt){color:#1e293b}.key-label-accidental.svelte-19i9hpt{font-size:10px;font-weight:700;color:#fffc;pointer-events:none;position:absolute;bottom:6px;left:50%;transform:translate(-50%)}.dark .key-label-accidental.svelte-19i9hpt{color:#0009}.selected.svelte-19i9hpt .key-label-accidental:where(.svelte-19i9hpt){color:#fffffff2}.dark .selected.svelte-19i9hpt .key-label-accidental:where(.svelte-19i9hpt){color:#fffffff2}@media (max-width: 640px){.piano.svelte-19i9hpt{height:150px}.chevron.svelte-19i9hpt{width:28px}.key.natural.svelte-19i9hpt{border-radius:0 0 6px 6px}.key.accidental.svelte-19i9hpt{border-radius:0 0 5px 5px}}.color-backdrop.svelte-19i9hpt{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100}.color-menu.svelte-19i9hpt{position:fixed;z-index:101;display:flex;flex-direction:column;gap:4px;padding:8px;background:#fff;border:1px solid #d1d5db;border-radius:10px;box-shadow:0 8px 24px #0003;transform:translate(-50%,-100%) translateY(-8px)}.color-row.svelte-19i9hpt{display:flex;gap:4px}.dark .color-menu.svelte-19i9hpt{background:#1f1f2e;border-color:#444;box-shadow:0 8px 24px #00000080}.color-swatch.svelte-19i9hpt{width:24px;height:24px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform .1s,border-color .1s;padding:0}.color-swatch.svelte-19i9hpt:hover{transform:scale(1.2)}.color-swatch.active.svelte-19i9hpt{border-color:#fff;box-shadow:0 0 0 2px currentColor}.clear-swatch.svelte-19i9hpt{background:#f3f4f6;color:#9ca3af;font-size:11px;display:flex;align-items:center;justify-content:center;font-weight:700}.dark .clear-swatch.svelte-19i9hpt{background:#333;color:#666}.color-actions.svelte-19i9hpt{display:flex;flex-direction:column;gap:2px;border-top:1px solid #e5e7eb;padding-top:4px}.dark .color-actions.svelte-19i9hpt{border-top-color:#444}.color-action-btn.svelte-19i9hpt{display:flex;align-items:center;gap:6px;padding:4px 8px;border:none;border-radius:6px;background:transparent;color:#6b7280;font-size:11px;font-weight:500;cursor:pointer;white-space:nowrap;transition:background .1s}.color-action-btn.svelte-19i9hpt:hover{background:#f3f4f6;color:#374151}.dark .color-action-btn.svelte-19i9hpt{color:#9ca3af}.dark .color-action-btn.svelte-19i9hpt:hover{background:#2a2a3a;color:#e5e7eb}.action-dot.svelte-19i9hpt{width:10px;height:10px;border-radius:50%;flex-shrink:0}
