:root{--bg-app:#c1e7ff;--bg-canvas:#f0fdf4;--panel-bg:#fff;--panel-border:#fff;--text-primary:#334155;--text-secondary:#64748b;--accent-red:#ef4444;--accent-orange:#f59e0b;--accent-blue:#3b82f6;--accent-green:#22c55e;--accent-purple:#a855f7;--glass-bg:#fffffffa;--glass-shadow:0 10px 40px -10px #00000026}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-app);color:var(--text-primary);height:100vh;margin:0;padding:0;font-family:"M PLUS Rounded 1c",Inter,-apple-system,sans-serif;overflow:hidden}.app-container{grid-template:"header header header"56px"sidebar main inspector"1fr"footer footer footer"/240px 1fr 300px;gap:8px 16px;height:100vh;padding:16px;display:grid}.header{background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:4px solid var(--panel-border);box-shadow:var(--glass-shadow);z-index:1000;border-radius:24px;grid-area:header;justify-content:space-between;align-items:center;padding:0 24px;display:flex;position:relative}.header-left{flex-shrink:0;align-items:center;gap:8px;display:flex}.header-title-container{align-items:center;gap:12px;display:flex}.header-logo-text{letter-spacing:-.04em;text-shadow:1px 1px #fff,-1px -1px #fff,1px -1px #fff,-1px 1px #fff,1px 0 #fff,-1px 0 #fff,0 1px #fff,0 -1px #fff,0 4px 10px #0000001a;gap:2px;font-size:1.4rem;font-weight:900;line-height:1;display:flex}.header-subtitle{color:#334155;letter-spacing:0;white-space:nowrap;font-size:.9rem;font-weight:800}.header-right{align-items:center;gap:12px;display:flex;overflow:visible}.header-divider{background:#0000001a;flex-shrink:0;width:1px;height:24px}.header-controls{flex-shrink:0;align-items:center;gap:8px;display:flex}.btn-secondary{color:#475569;cursor:pointer;white-space:nowrap;background:#f8fafc;border:2px solid #e2e8f0;border-radius:12px;flex-shrink:0;align-items:center;gap:6px;padding:8px 12px;font-weight:700;transition:all .2s;display:flex}.btn-secondary:hover{background:#f1f5f9;border-color:#cbd5e1}.btn-secondary.priority-5{color:#ef4444}.btn-icon{color:#475569;cursor:pointer;background:#f8fafc;border:2px solid #e2e8f0;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;padding:8px;transition:all .2s;display:flex}.btn-icon:hover:not(:disabled){background:#f1f5f9;border-color:#cbd5e1}.btn-icon:disabled{opacity:.5;cursor:not-allowed}.header .btn-delete-selected{background:var(--accent-red);color:#fff;cursor:pointer;border:none;border-radius:12px;align-items:center;gap:8px;padding:8px 16px;font-weight:700;display:flex;box-shadow:0 4px #991b1b}.header .btn-play{background:var(--accent-blue);border:none;min-width:80px;box-shadow:0 4px #1d4ed8}.btn-play.playing{background:var(--accent-red);box-shadow:0 4px #991b1b}.header-undo-redo{gap:4px;display:flex}.header-more,.project-menu{flex-shrink:0;position:relative}.header-more{display:none}.project-menu .btn-primary{color:#fff;white-space:nowrap;border:none;flex-shrink:0;font-weight:800;background:#475569!important;box-shadow:0 4px #1e293b!important}.project-menu .btn-primary:hover{transform:translateY(1px);background:#334155!important;box-shadow:0 2px #1e293b!important}.header-dropdown{border:4px solid var(--panel-border);background:#fff;border-radius:20px;flex-direction:column;gap:4px;min-width:200px;margin-top:12px;padding:12px;animation:.2s cubic-bezier(.16,1,.3,1) dropdownFadeIn;display:flex;position:absolute;top:100%;right:0;box-shadow:0 20px 60px #00000026}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.menu-item{text-align:left;color:#475569;cursor:pointer;background:0 0;border:none;border-radius:12px;align-items:center;gap:10px;width:100%;padding:10px 12px;font-weight:700;transition:background .2s;display:flex}.menu-item:hover{background:#f1f5f9}.menu-divider{background:#0000000d;height:1px;margin:6px 0}.menu-undo-redo{gap:8px;padding:4px;display:flex}.menu-undo-redo .btn-icon{flex:1}.menu-priority-6,.menu-priority-5,.menu-priority-4,.menu-priority-3{display:none}@media (width<=1140px){.priority-3{display:none}.menu-priority-3{display:flex}.header-more{display:block}}@media (width<=1000px){.priority-4{display:none}}@media (width<=940px){.priority-5{display:none}.menu-priority-5{display:flex}.header-more{display:block}}@media (width<=840px){.priority-6{display:none}.menu-priority-6{display:block}.menu-undo-redo.menu-priority-6{display:flex}.header-more{display:block}}@media (width<=680px){.header-logo-text{font-size:1.1rem}.header-right{gap:6px}.btn-label{display:none}}.sidebar{flex-direction:column;grid-area:sidebar;gap:16px;display:flex}.editor-main{background:var(--bg-canvas);border:4px solid var(--panel-border);box-shadow:var(--glass-shadow), inset 0 2px 10px #0000000d;border-radius:32px;grid-area:main;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.inspector{background:var(--glass-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:4px solid var(--panel-border);box-shadow:var(--glass-shadow);border-radius:24px;flex-direction:column;grid-area:inspector;display:flex;overflow:hidden}.mobile-inspector-wrapper{grid-area:inspector;display:contents}.mobile-only-close-btn{display:none!important}.footer{background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:4px solid var(--panel-border);box-shadow:var(--glass-shadow);color:var(--text-secondary);z-index:1000;border-radius:16px;grid-area:footer;justify-content:space-between;align-items:center;padding:2px 24px;font-size:.7rem;font-weight:700;display:flex}.footer-link{color:var(--accent-blue);border-radius:8px;align-items:center;gap:6px;padding:4px 12px;text-decoration:none;transition:all .2s;display:flex}.footer-link:hover{background:#3b82f60d;transform:translateY(-1px)}.tool-btn{flex-direction:column;gap:4px;padding:12px;display:flex}.tool-btn-label{font-size:.7rem;font-weight:500}.sidebar-section-header{background:#3b82f60d;justify-content:space-between;align-items:center;padding:12px;display:flex}.btn-layer-toggle:hover{transform:translateY(-1px);box-shadow:0 4px 12px #3b82f61a;color:#3b82f6!important;background:#f8fafc!important;border-color:#3b82f6!important}.btn-delete-selected{color:#ef4444;cursor:pointer;white-space:nowrap;background:#fee2e2;border:1px solid #fecaca;border-radius:12px;flex-shrink:0;font-size:.8rem;font-weight:800;transition:all .2s}.btn-delete-selected:hover{color:#fff;background:#ef4444;border-color:#ef4444;transform:translateY(-1px);box-shadow:0 4px 12px #ef444433}.btn-play{color:#fff;cursor:pointer;white-space:nowrap;background:#3b82f6;border:none;border-radius:12px;flex-shrink:0;font-weight:800;transition:all .2s;box-shadow:0 4px #1d4ed8}.btn-play:hover{background:#2563eb;transform:translateY(1px);box-shadow:0 2px #1d4ed8}.btn-play:active{box-shadow:none;transform:translateY(3px)}.glass-panel{background:var(--glass-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:4px solid var(--panel-border);box-shadow:var(--glass-shadow);border-radius:24px;padding:20px}.btn-primary{background:var(--accent-blue);color:#fff;cursor:pointer;border:none;border-radius:16px;padding:10px 20px;font-weight:700}.help-overlay-bg{z-index:2000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;animation:.3s ease-out helpFadeIn;position:fixed;inset:0}@keyframes helpFadeIn{0%{opacity:0}to{opacity:1}}.help-container{z-index:2001;background:#f8fafc;border-radius:32px;flex-direction:column;width:90%;max-width:1000px;max-height:85vh;animation:.4s cubic-bezier(.16,1,.3,1) helpSlideUp;display:flex;position:fixed;top:50%;left:50%;overflow:hidden;transform:translate(-50%,-50%);box-shadow:0 30px 60px -12px #0000004d}@keyframes helpSlideUp{0%{opacity:0;transform:translate(-50%,-45%)}to{opacity:1;transform:translate(-50%,-50%)}}.help-header{background:#fff;border-bottom:2px solid #f1f5f9;justify-content:space-between;align-items:center;padding:24px 32px;display:flex}.help-header h2{color:#1e293b;align-items:center;gap:12px;margin:0;font-size:1.4rem;font-weight:900;display:flex}.help-content{background:#f8fafc;flex-direction:column;gap:48px;padding:32px;display:flex;overflow-y:auto}.help-section-title{color:#1e293b;border-left:4px solid #3b82f6;align-items:center;gap:12px;margin-bottom:20px;padding-left:12px;font-size:1.1rem;font-weight:800;display:flex}.help-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;display:grid}.help-card{background:#fff;border:1px solid #e2e8f0;border-radius:24px;flex-direction:column;gap:14px;padding:24px;transition:all .2s cubic-bezier(.16,1,.3,1);display:flex}.help-card:hover{border-color:#3b82f6;transform:translateY(-2px);box-shadow:0 12px 30px #3b82f614}.help-card h4{color:#334155;align-items:center;gap:10px;margin:0;font-size:1rem;font-weight:800;display:flex}.help-card p{color:#64748b;margin:0;font-size:.85rem;font-weight:500;line-height:1.7}.key-badge{color:#334155;background:#fff;border:1px solid #cbd5e1;border-bottom-width:3px;border-radius:8px;justify-content:center;align-items:center;min-width:26px;height:26px;margin:0 2px;padding:0 8px;font-family:Outfit,ui-monospace,sans-serif;font-size:.8rem;font-weight:800;display:inline-flex;box-shadow:0 2px 4px #0000000d}.material-row{color:#475569;background:#f1f5f9;border-radius:12px;justify-content:space-between;align-items:center;padding:12px 16px;font-size:.85rem;display:flex}.material-label{align-items:center;gap:10px;font-weight:800;display:flex}.tip-card{background:linear-gradient(135deg,#fff7ed 0%,#fff 100%);border:1px solid #fed7aa;position:relative;overflow:hidden}.tip-card:before{content:"TIPS";color:#fff;background:#f97316;padding:2px 25px;font-size:.6rem;font-weight:950;position:absolute;top:12px;right:-20px;transform:rotate(45deg)}.tip-text{color:#ea580c!important;font-weight:700!important}.help-list{flex-direction:column;gap:12px;margin-top:4px;display:flex}.help-item{color:#64748b;align-items:flex-start;gap:12px;font-size:.85rem;line-height:1.5;display:flex}.help-item-icon{color:#3b82f6;background:#f1f5f9;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.help-item-content{flex:1;padding-top:4px}.help-item-label{color:#334155;margin-right:6px;font-weight:800}.help-diagram-container{flex-wrap:wrap;gap:20px;margin-top:12px;display:flex}.diagram-item{flex-direction:column;align-items:center;gap:8px;display:flex}.diagram-label{color:#64748b;font-size:.75rem;font-weight:700}.diagram-grid{background:#e2e8f0;border-radius:6px;grid-template-rows:repeat(3,24px);grid-template-columns:repeat(3,24px);gap:2px;padding:2px;display:grid}.diagram-cell{background:#fff;border-radius:2px;justify-content:center;align-items:center;width:24px;height:24px;font-size:.7rem;font-weight:900;display:flex}.cell-s{color:#fff;background:#3b82f6}.cell-d{color:#0369a1;background:#bae6fd}.cell-o{color:#15803d;background:#bbf7d0}.cell-x{color:#cbd5e1;background:#f1f5f9}.pitch-compass{background:#fff1f2;border:1px solid #fecdd3;border-radius:50%;justify-content:center;align-items:center;width:100px;height:100px;display:flex;position:relative}.pitch-node{color:#e11d48;background:#fff;border:1px solid #fb7185;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;width:32px;height:32px;font-size:.65rem;font-weight:800;display:flex;position:absolute;box-shadow:0 2px 4px #e11d481a}.node-center{color:#fff;background:#fb7185;border:none;width:30px;height:30px}.node-n{top:-10px}.node-s{bottom:-10px}.node-e{right:-10px}.node-w{left:-10px}.diagram-grid-v{background:#e2e8f0;border-radius:6px;grid-template-rows:repeat(4,24px);grid-template-columns:repeat(3,24px);gap:2px;padding:2px;display:grid}.pitch-line{z-index:0;background:#fecdd3;position:absolute}.line-v{width:2px;height:70px;top:15px;left:49px}.line-h{width:70px;height:2px;top:49px;left:15px}.pitch-arrow-head{z-index:0;border-style:solid;width:0;height:0;position:absolute}.arrow-n{border-width:0 4px 6px;border-color:#0000 #0000 #fb7185;top:10px;left:46px}.arrow-s{border-width:6px 4px 0;border-color:#fb7185 #0000 #0000;bottom:10px;left:46px}.arrow-e{border-width:4px 0 4px 6px;border-color:#0000 #0000 #0000 #fb7185;top:46px;right:10px}.arrow-w{border-width:4px 6px 4px 0;border-color:#0000 #fb7185 #0000 #0000;top:46px;left:10px}.piano-mini{background:#f1f5f9;border-radius:8px;width:fit-content;height:44px;margin-top:8px;padding:6px;display:flex;position:relative}.white-key{background:#fff;border:1px solid #cbd5e1;border-radius:0 0 3px 3px;width:18px;height:100%;box-shadow:0 1px 2px #0000000d}.black-key{z-index:1;background:#334155;border-radius:0 0 2px 2px;width:12px;height:60%;position:absolute;box-shadow:0 1px 3px #0003}.virtual-keyboard-container{-webkit-backdrop-filter:blur(16px);z-index:1200;background:#ffffffe6;border:1px solid #fff6;border-radius:20px 20px 0 0;flex-direction:column;align-items:center;gap:8px;width:auto;max-width:95vw;padding:16px 24px 8px;transition:all .3s;animation:.3s cubic-bezier(.16,1,.3,1) slideUp;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%);box-shadow:0 -10px 40px #00000026}@keyframes slideUp{0%{transform:translate(-50%,100%)}to{transform:translate(-50%)}}.piano-keys{height:140px;padding-bottom:0;display:flex;position:relative}.piano-key{cursor:pointer;-webkit-user-select:none;user-select:none;flex-direction:column;justify-content:flex-end;align-items:center;padding-bottom:8px;transition:all .1s;display:flex;position:relative}.piano-key.white{z-index:1;color:#94a3b8;background:#fff;border:1px solid #e2e8f0;border-radius:0 0 6px 6px;width:40px;height:140px;font-size:.65rem;font-weight:700}.piano-key.white:hover{background:#f8fafc;height:142px}.piano-key.white.active{color:#3b82f6;background:#eff6ff;border-color:#3b82f6;box-shadow:inset 0 -4px #3b82f6}.piano-key.black{z-index:2;color:#64748b;background:#1e293b;border-radius:0 0 4px 4px;width:26px;height:85px;margin-left:-13px;margin-right:-13px;font-size:.55rem;font-weight:700}.piano-key.black:hover{background:#334155}.piano-key.black.active{color:#fff;background:#2563eb;box-shadow:0 4px 10px #2563eb66}.key-label{pointer-events:none;position:absolute;bottom:6px}.virtual-keyboard-controls{color:#64748b;justify-content:space-between;width:100%;padding:0 4px;font-size:.7rem;font-weight:700;display:flex}.keyboard-close-btn{color:#94a3b8;cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:4px;transition:all .2s;display:flex}.keyboard-close-btn:hover{color:#475569;background:#f1f5f9}@keyframes progress-shimmer{0%{opacity:.3;transform:translate(-100%)}50%{opacity:1;transform:translate(0)}to{opacity:.3;transform:translate(100%)}}.ad-modal-overlay,.help-overlay{-webkit-backdrop-filter:blur(8px);background:#0006;justify-content:center;align-items:center;animation:.3s ease-out helpFadeIn;display:flex;position:fixed;inset:0;z-index:2000!important}.ad-modal{max-height:90vh;overflow-y:auto;max-width:800px!important}.ad-modal-content{padding:0 10px}.premium-glass-panel{-webkit-backdrop-filter:blur(20px);background:#ffffffb3;border:1px solid #ffffff80}.ad-modal-content-premium{max-height:60vh;padding:20px 32px;overflow-y:auto}.ad-intro{text-align:center;margin-bottom:32px}.ad-intro p{color:#1e293b;margin:0;font-size:1rem;font-weight:700}.ad-intro .sub-text{color:#64748b;margin-top:8px;font-size:.8rem;font-weight:500}.ad-list-container{flex-direction:column;align-items:center;gap:20px;display:flex}.ad-sponsor-card{background:#fff;border:1px solid #f1f5f9;border-radius:20px;flex-direction:column;align-items:center;width:100%;max-width:480px;padding:32px 20px 24px;transition:all .3s cubic-bezier(.16,1,.3,1);display:flex;position:relative;box-shadow:0 10px 25px -5px #0000000d,0 8px 10px -6px #0000000d}.ad-sponsor-card:hover{border-color:#e2e8f0;transform:translateY(-4px)scale(1.01);box-shadow:0 20px 40px -12px #0000001a}.card-badge{color:#94a3b8;letter-spacing:.1em;text-transform:uppercase;font-size:.6rem;font-weight:900;position:absolute;top:12px;left:20px}.ad-banner-frame{border-radius:8px;justify-content:center;align-items:center;width:100%;min-height:250px;display:flex;overflow:hidden}.sponsor-icon-wrapper{background:#fff1f2;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.btn-premium-close{color:#fff;cursor:pointer;background:#1e293b;border:none;border-radius:16px;width:100%;padding:16px;font-size:.95rem;font-weight:800;transition:all .2s;box-shadow:0 10px 20px -5px #1e293b4d}.btn-premium-close:hover{background:#334155;transform:translateY(-2px);box-shadow:0 15px 30px -5px #1e293b66}.ad-modal-footer{padding:0 32px 32px}.ad-button-premium{cursor:pointer;color:var(--text-secondary);background:#ffffff1a;border:1px solid #ffffff1a;border-radius:12px;outline:none;align-items:center;gap:8px;padding:6px 16px;font-size:.75rem;font-weight:800;transition:all .3s cubic-bezier(.16,1,.3,1);display:flex}.ad-button-premium:hover{color:var(--text-primary);background:#fff3;border-color:#ffffff4d;transform:translateY(-1px);box-shadow:0 4px 12px #0000001a}.ad-button-premium:active{transform:translateY(0)scale(.98)}@media (width<=1150px){.footer-center span,.footer-right .ad-button-premium span{display:none}.disclaimer-text{white-space:normal;max-width:400px}}@media (width<=768px){.mobile-hidden{display:none!important}.app-container{grid-template:"header"44px"main"1fr"toolbar""footer"/1fr;gap:4px;height:100dvh;padding:4px}.header{border-width:3px;border-radius:14px;padding:0 12px}.header-logo-text{font-size:1rem}.header-subtitle{display:none}.header-right{gap:4px}.header-divider{display:none}.header-controls{gap:4px}.btn-secondary{border-radius:10px;padding:6px 8px;font-size:.75rem}.btn-icon{border-radius:10px;padding:6px}.btn-label{display:none}.sidebar{-webkit-overflow-scrolling:touch;scrollbar-width:none;background:var(--glass-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:3px solid var(--panel-border);box-shadow:var(--glass-shadow);border-radius:14px;flex-direction:row;grid-area:toolbar;gap:6px;padding:6px;overflow:auto hidden}.sidebar::-webkit-scrollbar{display:none}.sidebar .glass-panel{background:#fff6;border-radius:12px;flex-direction:row;flex-shrink:0;align-items:stretch;min-width:fit-content;display:flex;padding:0!important}.sidebar-section-header{writing-mode:vertical-rl;text-orientation:mixed;white-space:nowrap;background:#3b82f608;border-right:1px solid #3b82f61a;justify-content:center;align-items:center;min-width:20px;display:flex;border-bottom:none!important;padding:4px 2px!important}.sidebar-section-header h3{letter-spacing:.05em!important;font-size:.6rem!important;line-height:1!important}.sidebar-section-header button{display:none!important}.tool-btn{white-space:nowrap;flex-direction:row;gap:6px;height:40px;padding:4px 8px}.tool-btn-label{font-size:.65rem}.sidebar .glass-panel>div:nth-child(2){flex-flow:row;align-items:center;gap:4px;overflow:visible;max-height:none!important;padding:4px!important;display:flex!important}.sidebar .glass-panel:last-child{display:none}.editor-main{border-width:3px;border-radius:14px;min-height:0}.editor-main canvas{touch-action:none}.mobile-inspector-wrapper{z-index:1500;border:4px solid var(--panel-border);opacity:0;pointer-events:none;background:#fff;border-radius:24px 24px 0 0;flex-direction:column;max-height:60vh;transition:transform .4s cubic-bezier(.16,1,.3,1),opacity .3s;position:fixed;bottom:0;left:0;right:0;transform:translateY(100%);box-shadow:0 -10px 40px #00000026;display:flex!important}.mobile-only-close-btn{background:#fffc;justify-content:flex-end;padding:8px 16px 0;display:flex!important}.mobile-inspector-wrapper.inspector-open{opacity:1;pointer-events:auto;transform:translateY(0)}.mobile-inspector-wrapper .inspector{overflow-y:auto;background:0 0!important;border:none!important;width:100%!important;height:100%!important;display:flex!important}.footer{border-width:3px;border-radius:14px;flex-direction:column;gap:2px;padding:4px 12px}.footer-left{text-align:center}.footer-left span:first-child{font-size:.6rem}.footer-left span:last-child{font-size:.5rem}.footer-center{display:none}.footer-right{justify-content:center}.footer-right .ad-button-premium{display:none}.help-container{border-radius:20px;width:95%;max-height:90vh}.help-header{padding:16px 20px}.help-content{gap:32px;padding:20px}.help-grid{grid-template-columns:1fr;gap:16px}.virtual-keyboard-container{display:none!important}.ad-modal{max-width:95vw!important}.ad-modal-content-premium{padding:16px 20px}}
