.piano-sketch{--ps-accent: #2f6feb;--ps-ink: #0f172a;--ps-muted: #475569;--ps-surface: #ffffff;--ps-border: #e6ebf4;display:grid;gap:16px;max-width:980px;margin:0 auto 32px}.piano-sketch h1{font-size:24px;margin:0 0 8px}.piano-sketch .ps-card{background:var(--ps-surface);border:1px solid var(--ps-border);border-radius:16px;padding:16px 18px;box-shadow:0 14px 40px #0f172a14}.piano-sketch .ps-hero{background:radial-gradient(circle at 12% 24%,rgba(47,111,235,.18),transparent 30%),radial-gradient(circle at 85% 15%,rgba(56,189,248,.18),transparent 32%),linear-gradient(135deg,#f8fbff,#eef3ff);border:none}.piano-sketch .ps-lede{color:var(--ps-muted);margin:0 0 10px;max-width:720px}.piano-sketch .ps-controls{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin:10px 0}.piano-sketch .ps-control-bar{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:8px}.piano-sketch .ps-buttons{display:flex;gap:8px;align-items:center}.piano-sketch .ps-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid #d5ddf0;background:#f7f9ff;color:var(--ps-ink);padding:9px 14px;border-radius:12px;font-weight:700;cursor:pointer;transition:transform .05s ease,box-shadow .12s ease,background .15s ease}.piano-sketch .ps-btn.primary{background:linear-gradient(135deg,#2f6feb,#2ab7ff);color:#fff;border-color:#2f6feb;box-shadow:0 10px 24px #2f6feb33}.piano-sketch .ps-btn.ghost{background:#f6f8ff;color:var(--ps-ink)}.piano-sketch .ps-btn.small{padding:6px 10px;font-size:12px}.piano-sketch .ps-btn.danger{color:#b42318;border-color:#f1c0bc;background:#fff4f3}.piano-sketch .ps-btn:active{transform:translateY(1px);box-shadow:none}.piano-sketch .ps-field{display:inline-flex;align-items:center;gap:8px;background:#f6f8ff;border:1px solid #e2e8f5;border-radius:12px;padding:8px 10px;color:var(--ps-muted)}.piano-sketch .ps-field.inline{background:transparent;border:none;padding:0}.piano-sketch .ps-field input{width:72px;border:none;background:transparent;padding:6px 8px;border-radius:10px;border:1px solid #d8e0ef;outline:none}.piano-sketch .ps-field select{border:1px solid #d8e0ef;background:#fff;padding:6px 10px;border-radius:10px;min-width:120px}.piano-sketch .ps-field .unit{color:#94a3b8}.piano-sketch .ps-hint{font-size:13px;color:#475569;margin:6px 0 0}.piano-sketch .ps-row{display:flex;flex-wrap:wrap;gap:10px;align-items:center;justify-content:space-between}.piano-sketch .ps-label{font-weight:700;color:#111827}.piano-sketch .ps-sub{color:#6b7280;font-size:14px;margin-top:2px;max-width:720px}.piano-sketch .ps-chip{display:inline-flex;align-items:center;gap:6px;padding:7px 12px;border-radius:999px;font-size:13px;border:1px solid #dfe8ff;background:#eef2ff;color:#1d4ed8;font-weight:700}.piano-sketch .ps-chip.muted{color:#334155;background:#f6f7fb;border-color:#e4e7ec}.piano-sketch .ps-chip.subtle{background:#f8fafc;border-color:#e4e7ec;color:#475569}.piano-sketch .ps-staff{position:relative;padding:8px;border-radius:14px;background:linear-gradient(180deg,#f1f5f999,#f8fafce6);border:1px solid #e7edf6;min-height:260px;overflow:auto}.piano-sketch .ps-staff canvas{position:absolute;top:8px;right:8px;bottom:8px;left:8px;width:calc(100% - 16px);height:calc(100% - 16px);display:block;border-radius:12px;background:transparent;pointer-events:auto;z-index:2}.piano-sketch #abcStaff svg{width:100%;height:auto;display:block}.piano-sketch #abcStaff{min-height:240px;min-width:100%}.ps-modal{position:fixed;top:0;right:0;bottom:0;left:0;display:none;align-items:center;justify-content:center;z-index:2000}.ps-modal.open{display:flex}.ps-modal__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#0f172a73}.ps-modal__dialog{position:relative;background:#fff;border-radius:16px;padding:16px 18px;width:min(520px,92vw);max-height:80vh;overflow:auto;box-shadow:0 22px 60px #00000040;z-index:1}.ps-modal__header{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:8px}.ps-modal__header h2{margin:0;font-size:18px}.ps-modal__body p{margin:12px 0 6px;font-weight:700;color:#0f172a}.ps-modal__body ul{margin:0 0 8px 18px;padding:0;color:#475569;font-size:14px;line-height:1.5}.piano-sketch .ps-piano{position:relative;padding:16px 10px 12px;border-radius:14px;border:1px solid #e4e7ec;background:#f8fafc;overflow:hidden;--ps-white-w: 46px;--ps-white-gap: 2px}.piano-sketch .ps-io-row{margin-top:10px;align-items:center}.piano-sketch .ps-keys{position:relative}.piano-sketch .ps-keys-white{display:flex;gap:var(--ps-white-gap, 2px)}.piano-sketch .ps-keys-black{position:absolute;inset:12px 0 auto 0;height:112px;pointer-events:auto;--ps-black-w: 30px;width:100%}.piano-sketch .ps-key{border:1px solid #d7dce7;background:#fff;color:#cbd5e1;cursor:pointer;padding:0;border-radius:10px;transition:transform .05s ease,box-shadow .12s ease,background .18s ease,border-color .18s ease;position:relative}.piano-sketch .ps-key.white{width:var(--ps-white-w);height:168px;box-shadow:inset 0 -2px 4px #00000014;background:linear-gradient(180deg,#fff,#f3f6fd)}.piano-sketch .ps-key.white:hover{background:#f8fbff}.piano-sketch .ps-key.black{position:absolute;left:calc((var(--i) + 1) * (var(--ps-white-w) + var(--ps-white-gap, 0px)) - var(--ps-black-w) / 2);width:var(--ps-black-w);height:110px;background:linear-gradient(180deg,#111827,#1f2937);color:#e5e7eb;border-radius:0 0 8px 8px;box-shadow:0 8px 18px #00000059;pointer-events:auto;z-index:2;top:0}.piano-sketch .ps-key-label{display:block;font-size:11px;font-weight:700;color:#1e293b;margin-top:4px;opacity:.85}.piano-sketch .ps-key.black .ps-key-label{color:#e2e8f0;margin-top:6px}.piano-sketch .ps-key.black:hover{background:#1f2a3b}.piano-sketch .ps-key.active{transform:translateY(1px);box-shadow:inset 0 -1px 4px #00000040}.piano-sketch .ps-piano:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(circle at 10% 0%,rgba(47,111,235,.06),transparent 30%),radial-gradient(circle at 90% 0%,rgba(56,189,248,.07),transparent 30%)}.piano-sketch .ps-chip,.piano-sketch .ps-btn,.piano-sketch .ps-field input{font-family:inherit}.piano-sketch .ps-key-label{position:absolute;left:50%;transform:translate(-50%);font-size:11px;font-weight:700;color:#1e293b;pointer-events:none}.piano-sketch .ps-key.white .ps-key-label{bottom:6px}.piano-sketch .ps-key.black .ps-key-label{top:6px;color:#e2e8f0;text-align:center}.piano-sketch .ps-piano.hide-note-labels .ps-key-label{display:none}@media (max-width: 820px){.piano-sketch{margin:0 auto 22px}.piano-sketch .ps-controls{flex-direction:column;align-items:flex-start}.piano-sketch .ps-buttons{width:100%}.piano-sketch .ps-buttons .ps-btn{flex:1;text-align:center}.piano-sketch .ps-keys-white{--ps-white-w: 48px}.piano-sketch .ps-keys-black{--ps-black-w: 30px}}@media (max-width: 560px){.piano-sketch h1{font-size:20px}.piano-sketch .ps-key.white{height:148px}.piano-sketch .ps-keys-white{--ps-white-w: 42px}.piano-sketch .ps-keys-black{--ps-black-w: 28px}}
