*,:after,:before{margin:0;padding:0;box-sizing:border-box}:root{--black:#0a0a0a;--white:#fafafa;--gray-100:#f5f5f5;--gray-200:#e8e8e8;--gray-300:#ddd;--gray-400:#999;--gray-600:#666;--gray-800:#333;--mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono",monospace}html{scroll-behavior:smooth}body,html{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,Noto Sans CJK SC,system-ui,sans-serif;background:var(--white);color:var(--black);line-height:1.8;font-size:16px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}::selection{background:var(--black);color:var(--white)}.container{max-width:980px;margin:0 auto;padding:0 24px}.header{position:-webkit-sticky;position:sticky;top:0;z-index:100;background:hsla(0,0%,98%,.92);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--gray-200)}.header-inner{max-width:980px;margin:0 auto;padding:18px 24px;display:flex;justify-content:space-between;align-items:center;gap:12px}.logo{font-size:11px;letter-spacing:4px;text-transform:uppercase;font-weight:650;color:var(--gray-600);white-space:nowrap}.hero{max-width:980px;margin:0 auto;padding:86px 24px 56px;text-align:center}.hero-label{font-size:11px;letter-spacing:6px;text-transform:uppercase;color:var(--gray-400);margin-bottom:18px}.hero h1{font-size:clamp(30px,5vw,54px);font-weight:300;letter-spacing:2px;line-height:1.15;margin-bottom:14px}.hero h1 strong{font-weight:650}.hero-sub{font-size:13px;color:var(--gray-600);letter-spacing:1px}.hero-sub span{margin:0 8px;color:var(--gray-400)}.card{padding:32px;display:grid;grid-template-columns:1.2fr .8fr;grid-gap:28px;gap:28px;background:#fff}.card,.panel{border:1px solid var(--gray-200)}.panel{background:hsla(0,0%,96%,.55);padding:14px}.footer{border-top:1px solid var(--gray-200);padding:34px 24px;text-align:center;margin-top:70px}.footer-inner{max-width:980px;margin:0 auto}.footer-note{font-size:12px;color:var(--gray-600);line-height:1.8;max-width:720px;margin:0 auto 14px}.footer-meta{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--gray-400)}.app-root{min-height:100vh;padding:16px;background:var(--white);display:flex;align-items:flex-start;justify-content:center}.app-card{width:100%;max-width:980px;border:1px solid var(--gray-200);background:#fff;box-shadow:0 18px 60px hsla(0,0%,4%,.07);padding:32px;display:flex;flex-direction:column;gap:16px}.app-card--wide{max-width:1040px}.app-header{display:flex;justify-content:space-between;align-items:flex-end;gap:12px}.app-title{font-size:11px;letter-spacing:6px;text-transform:uppercase;font-weight:650;color:var(--gray-600)}.app-subtitle{font-size:13px;color:var(--gray-600);letter-spacing:1px}.tool-tabs{align-items:center;flex-wrap:wrap}.tool-tab,.tool-tabs{display:inline-flex;gap:8px}.tool-tab{align-items:baseline;border-radius:0;border:1px solid var(--gray-200);background:transparent;padding:10px 14px;font-size:12px;letter-spacing:2px;text-transform:uppercase;text-decoration:none;color:var(--black);transition:border-color .12s ease,background .12s ease,color .12s ease}.tool-tab:hover{border-color:var(--black)}.tool-tab-sub{font-size:11px;color:var(--gray-600);letter-spacing:.02em;text-transform:none}.tool-tab[aria-current=page]{background:var(--black);color:var(--white);border-color:var(--black)}.tool-tab[aria-current=page] .tool-tab-sub{color:hsla(0,0%,100%,.7)}.app-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:14px 16px;gap:14px 16px}.app-section{border-top:1px solid var(--gray-200);padding-top:10px}.app-footer{display:flex;justify-content:space-between;gap:8px;font-size:11px;color:var(--gray-600);flex-wrap:wrap}.field{display:flex;flex-direction:column;gap:6px;font-size:13px}.field-row{display:flex;flex-wrap:wrap;gap:10px}.field-label{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--gray-600);font-weight:650}.field-label-inline{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:var(--gray-800)}input[type=range],select{padding:10px 12px;border-radius:0;border:1px solid var(--gray-200);background:#fff;color:var(--black);font-size:13px;outline:none}input[type=range]{padding:0}input[type=range]:focus,select:focus{border-color:var(--black)}.tempo-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.tempo-value{font-feature-settings:"tnum";font-variant-numeric:tabular-nums;font-size:12px;color:var(--gray-800)}.btn{border-radius:0;border:1px solid var(--black);background:var(--black);color:var(--white);padding:10px 14px;font-size:12px;text-transform:uppercase;letter-spacing:2px;cursor:pointer;transition:background .12s ease,color .12s ease,border-color .12s ease}.btn.secondary{background:transparent;color:var(--black);border-color:var(--gray-200)}.btn.small{padding:6px 12px;font-size:11px}.btn:disabled{opacity:.35;cursor:default}.btn:not(:disabled):hover{border-color:var(--black)}.btn:not(:disabled):active{transform:translateY(0)}.btn-row{display:flex;flex-wrap:wrap;gap:8px}.btn{text-decoration:none;display:inline-flex;align-items:center;justify-content:center}.status-text{font-size:12px;color:var(--gray-600);min-height:1.2em}.status-text strong{font-weight:600;color:var(--black)}.history-header,.piano-header{display:flex;justify-content:space-between;align-items:center;gap:8px;font-size:12px;margin-bottom:6px}.section-title{font-weight:650;letter-spacing:3px;text-transform:uppercase;font-size:10px;color:var(--gray-400)}.history-list{display:flex;flex-direction:column;gap:6px;max-height:180px;overflow-y:auto}.history-item{border:1px solid var(--gray-200);padding:6px 8px;font-size:12px;display:flex;justify-content:space-between;gap:10px}.history-meta{display:flex;flex-direction:column;gap:2px}.history-line{white-space:nowrap}.piano-wrapper{display:flex;border:1px solid var(--gray-200);overflow:hidden;background:#fff}.piano-empty{font-size:12px;color:var(--gray-600);padding:8px}canvas.piano-canvas{display:block}.piano-labels{flex:0 0 52px;border-right:1px solid var(--gray-200);background:#fff;font-size:10px;color:var(--gray-800);padding-top:8px}.piano-canvas-container{flex:1 1 auto;overflow-x:auto;overflow-y:hidden}.iframe-shell{border:1px solid var(--gray-200);overflow:hidden;background:#fff}.iframe-meta{border-bottom:1px solid var(--gray-200);padding:8px 10px;display:flex;justify-content:space-between;gap:10px}.tool-iframe{display:block;width:100%;height:min(860px,calc(100vh - 260px));border:0;background:#fff}@media (max-width:900px){.app-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:640px){.app-root{align-items:flex-start;padding:0}.app-card{border-radius:0;max-width:none;min-height:100vh;padding:24px}.tool-iframe{height:calc(100vh - 300px)}.app-grid{grid-template-columns:1fr}.hero{padding:58px 24px 40px}.card{grid-template-columns:1fr;gap:22px;padding:24px}}