body{color:#1a1a2e;-webkit-font-smoothing:antialiased;background:#f8f7ff;min-height:100vh;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}#root{width:100%;min-height:100vh}:root{--pink:#d63f6e;--purple:#5c5cb8;--teal:#45b8c0;--green:#6bb82e;--orange:#f0823a;--yellow:#f5d03a;--navy:#1a2456;--dark:#1a1a2e;--light:#9ebf5f;--white:#fff;--shadow:0 4px 18px #5c5cb821;--radius:14px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--light);color:var(--dark);min-height:100vh;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.app{flex-direction:column;min-height:100vh;display:flex}.app-header{background:var(--white);border-bottom:3px solid var(--pink);box-shadow:var(--shadow);align-items:center;gap:16px;padding:12px 32px;display:flex}.header-logo{object-fit:contain;width:auto;height:140px}.header-title{background:linear-gradient(90deg, var(--pink) 0%, var(--purple) 45%, var(--teal) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.8rem;font-weight:800;line-height:1}.header-sub{color:var(--navy);margin-top:3px;font-size:.85rem}.app-main{flex:1;width:100%;max-width:1600px;margin:0 auto;padding:32px 24px}.home-screen{max-width:680px;margin:0 auto}.home-heading{color:var(--purple);margin-bottom:8px;font-size:2rem;font-weight:800}.home-desc{color:#555;margin-bottom:28px;font-size:1.05rem;line-height:1.6}.upload-zone{border:3px dashed var(--teal);border-radius:var(--radius);background:var(--white);text-align:center;cursor:pointer;padding:48px 32px;transition:border-color .2s,background .2s}.upload-zone:hover,.upload-zone.dragging{border-color:var(--pink);background:#fff0f5}.upload-icon{margin-bottom:12px;font-size:3rem}.upload-title{color:var(--purple);margin-bottom:6px;font-size:1.25rem;font-weight:700}.upload-sub{color:#666;margin-bottom:8px;font-size:.95rem}.upload-hint{color:var(--teal);font-size:.82rem;font-style:italic}.recent-scores{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);margin-top:36px;padding:24px 28px}.recent-scores-title{color:var(--purple);margin-bottom:14px;font-size:1.1rem;font-weight:700}.recent-scores-list{flex-wrap:wrap;gap:10px;padding:0;list-style:none;display:flex}.recent-score-card{border:2px solid var(--teal);background:var(--white);border-radius:10px;align-items:stretch;transition:border-color .15s,box-shadow .15s;display:flex;overflow:hidden}.recent-score-card:hover{border-color:var(--pink);box-shadow:0 3px 10px #d63f6e2e}.recent-score-open{cursor:pointer;font:inherit;background:0 0;border:none;align-items:center;gap:8px;padding:10px 12px;display:flex}.recent-score-icon{font-size:1.2rem}.recent-score-name{color:var(--purple);text-overflow:ellipsis;white-space:nowrap;max-width:220px;font-weight:600;overflow:hidden}.recent-score-date{color:#888;font-size:.78rem}.recent-score-remove{cursor:pointer;color:#bbb;background:0 0;border:none;border-left:1px solid #eee;padding:0 10px;font-size:.85rem;transition:color .15s,background .15s}.recent-score-remove:hover{color:var(--pink);background:#fff0f5}.how-it-works{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);margin-top:36px;padding:24px 28px}.how-it-works h3{color:var(--pink);margin-bottom:14px;font-size:1.1rem;font-weight:700}.how-it-works ol{flex-direction:column;gap:10px;padding-left:20px;display:flex}.how-it-works li{color:#444;line-height:1.5}.practice-session{flex-direction:column;gap:16px;display:flex}.session-body{align-items:flex-start;gap:16px;display:flex}.session-main{flex-direction:column;flex:1;gap:16px;min-width:0;display:flex}.practice-log-list{flex-direction:column;gap:6px;max-height:400px;list-style:none;display:flex;overflow-y:auto}.practice-log-entry{cursor:pointer;background:#f5f5fb;border-radius:8px;align-items:center;gap:5px;padding:6px 8px;font-size:.8rem;transition:background .15s;display:flex}.practice-log-entry:hover{background:#ebebf8}.log-time{color:#999;white-space:nowrap;font-size:.72rem}.log-mode{font-size:.85rem}.log-range{color:var(--navy);white-space:nowrap;font-weight:700}.log-clear{color:#888;cursor:pointer;background:#f5f5f8;border:1px solid #ddd;border-radius:8px;align-self:flex-start;margin-top:2px;padding:5px 10px;font-size:.75rem}.log-clear:hover{color:#555;background:#eee}.practice-toolbar{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);z-index:100;flex-direction:column;gap:0;display:flex;position:sticky;top:0;overflow:hidden}.toolbar-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;padding:12px 20px;display:flex}.file-name{color:var(--purple);font-size:.95rem;font-weight:600}.toolbar-actions{flex-wrap:wrap;gap:10px;display:flex}.btn-new-score{background:var(--pink);cursor:pointer;border:none;border-radius:50px;flex-direction:column;flex-shrink:0;align-items:center;gap:4px;padding:10px 18px;transition:opacity .15s,transform .12s;display:flex;box-shadow:0 4px 14px #d63f6e59}.btn-new-score:hover{opacity:.88;transform:translateY(-2px)}.btn-new-score:active{transform:translateY(0)}.btn-new-score-plus{color:var(--white);font-size:2rem;font-weight:900;line-height:1}.btn-new-score-label{color:var(--white);text-transform:uppercase;letter-spacing:.05em;text-align:center;font-size:.65rem;font-weight:700;line-height:1.2}.btn{cursor:pointer;border:none;border-radius:8px;padding:10px 22px;font-size:.95rem;font-weight:700;transition:opacity .15s,transform .1s}.btn:hover{opacity:.88;transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.45;cursor:not-allowed;transform:none}.btn-start{background:var(--green);color:var(--white)}.btn-stop{background:var(--orange);color:var(--white)}.btn-reset{background:var(--purple);color:var(--white)}.btn-restart{background:var(--teal);color:var(--white)}.btn-metro{color:var(--navy);letter-spacing:.03em;background:#e8e8f0;border:2px solid #ccc;font-size:1rem}.btn-metro.on{background:var(--teal);color:var(--white);border-color:var(--teal)}.btn-ref{color:var(--navy);background:#e8e8f0;border:2px solid #ccc}.btn-ref.on{background:var(--purple);color:var(--white);border-color:var(--purple)}.volume-control{background:#e8e8f0;border:2px solid #ccc;border-radius:10px;align-items:center;gap:6px;height:38px;padding:0 10px;display:flex}.volume-icon{-webkit-user-select:none;user-select:none;font-size:1rem;line-height:1}.volume-slider{appearance:none;cursor:pointer;background:#bbb;border-radius:2px;outline:none;width:120px;height:5px}.volume-slider::-webkit-slider-thumb{-webkit-appearance:none;background:var(--navy);cursor:pointer;border-radius:50%;width:18px;height:18px}.volume-slider::-moz-range-thumb{background:var(--navy);cursor:pointer;border:none;border-radius:50%;width:18px;height:18px}.score-wrapper{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px;overflow-x:auto}.feedback-bar{color:var(--white);border-radius:0;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:20px;padding:10px 24px;transition:background .3s;display:flex}.feedback-status{align-items:center;gap:12px;min-width:180px;display:flex}.feedback-icon{font-size:2rem;line-height:1}.feedback-text{font-size:1.2rem;font-weight:800}.score-pct{background:#ffffff2e;border-radius:12px;flex-direction:column;align-items:center;padding:8px 24px;display:flex}.score-pct-value{color:var(--white);font-size:2rem;font-weight:900;line-height:1}.score-pct-label{opacity:.85;text-transform:uppercase;letter-spacing:.05em;margin-top:2px;font-size:.72rem}.done-banner{background:linear-gradient(90deg, var(--pink), var(--purple));color:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);flex-wrap:wrap;align-items:center;gap:8px;padding:18px 28px;font-size:1.1rem;font-weight:700;display:flex}.mic-level-bar{background:var(--white);border:1px solid #ddd;border-radius:10px;align-items:center;gap:10px;padding:8px 16px;font-size:.85rem;display:flex}.mic-level-label{white-space:nowrap;color:var(--navy);min-width:100px;font-weight:600}.mic-level-track{background:#e8e8f0;border-radius:5px;flex:1;height:10px;overflow:hidden}.mic-level-fill{background:linear-gradient(90deg, var(--teal), var(--green));border-radius:5px;min-width:2px;height:100%;transition:width 80ms linear}.mic-level-pct{text-align:right;color:#666;width:36px;font-size:.8rem}.error-banner{border:1px solid var(--orange);color:#7a4800;background:#fff3cd;border-radius:10px;padding:14px 20px;font-size:.95rem}.mode-toggle{border:2px solid var(--purple);border-radius:10px;display:flex;overflow:hidden}.mode-btn{color:var(--purple);cursor:pointer;white-space:nowrap;background:0 0;border:none;padding:8px 14px;font-size:.85rem;font-weight:600;transition:all .15s}.mode-btn.active{background:var(--purple);color:var(--white)}.mode-btn:not(.active):hover{background:#5c5cb81a}.btn-settings{background:var(--navy);color:var(--white)}.btn-settings:hover{background:#2a3870}.btn-settings.active{background:var(--purple)}.settings-overlay{z-index:200;background:#00000059;position:fixed;inset:0}.settings-panel{background:var(--white);z-index:201;flex-direction:column;width:300px;transition:transform .25s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;bottom:0;right:0;overflow-y:auto;transform:translate(100%);box-shadow:-4px 0 24px #0000002e}.settings-panel.open{transform:translate(0)}.settings-header{background:var(--navy);color:var(--white);z-index:1;justify-content:space-between;align-items:center;padding:18px 20px;font-size:1rem;font-weight:700;display:flex;position:sticky;top:0}.settings-close{color:var(--white);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 8px;font-size:1.1rem;line-height:1}.settings-close:hover{background:#ffffff26}.settings-section{border-bottom:1px solid #eee;flex-direction:column;gap:12px;padding:20px;display:flex}.settings-section-title{color:var(--navy);text-transform:uppercase;letter-spacing:.05em;margin:0;font-size:.9rem;font-weight:700}.settings-hint{color:#666;margin:0;font-size:.82rem;line-height:1.4}.toggle-btn{color:#555;cursor:pointer;background:#f5f5f8;border:2px solid #ddd;border-radius:20px;align-self:flex-start;padding:9px 16px;font-size:.88rem;font-weight:600;transition:all .15s}.toggle-btn.on{background:var(--purple);border-color:var(--purple);color:var(--white)}.toggle-btn:hover{opacity:.85}.bpm-row,.transpose-row{align-items:center;gap:10px;display:flex}.bpm-step{border:2px solid var(--purple);background:var(--white);width:40px;height:40px;color:var(--purple);cursor:pointer;border-radius:10px;flex-shrink:0;font-size:1rem;font-weight:700;transition:all .12s}.bpm-step:hover{background:var(--purple);color:var(--white)}.bpm-display{text-align:center;flex:1;line-height:1.2}.bpm-value{color:var(--navy);font-size:1.6rem;font-weight:800;display:block}.bpm-unit{color:#888;text-transform:uppercase;letter-spacing:.08em;font-size:.72rem}.bpm-slider{width:100%;accent-color:var(--purple);cursor:pointer}.slider-labels{color:#aaa;justify-content:space-between;margin-top:-6px;font-size:.75rem;display:flex}.range-row{color:var(--navy);align-items:center;gap:8px;font-size:.88rem;font-weight:500;display:flex}.measure-input{text-align:center;width:58px;color:var(--navy);border:2px solid #ddd;border-radius:8px;padding:7px 8px;font-size:.95rem;font-weight:600;transition:border-color .15s}.measure-input:focus{border-color:var(--purple);outline:none}.measure-hint{color:#888;margin:0;font-size:.8rem}.reset-btn{color:#666;cursor:pointer;background:#f5f5f8;border:1px solid #ccc;border-radius:8px;align-self:flex-start;padding:6px 12px;font-size:.82rem}.reset-btn:hover{background:#eee}.back-to-top{background:var(--purple);width:44px;height:44px;color:var(--white);cursor:pointer;z-index:150;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:1.2rem;transition:opacity .2s,transform .2s;display:flex;position:fixed;bottom:28px;right:28px;box-shadow:0 4px 14px #5c5cb866}.back-to-top:hover{opacity:.85;transform:translateY(-2px)}.app-footer{text-align:center;color:#aaa;background:var(--white);border-top:1px solid #eee;padding:16px;font-size:.8rem}.piano-keyboard-wrap{background:#1a1610;border-top:3px solid #0d0b08;width:100%;padding:8px 16px 0}.piano-legend{color:#bbb;justify-content:center;gap:18px;margin-bottom:6px;font-size:.72rem;display:flex}.legend-item{align-items:center;gap:5px;display:flex}.legend-dot{border-radius:50%;width:10px;height:10px;display:inline-block}.hand-filter-toggle{gap:4px;margin-left:auto;display:flex}.hf-btn{color:#aaa;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #555;border-radius:20px;padding:5px 14px;font-size:.78rem;font-weight:600;transition:background .15s,color .15s}.hf-btn:hover{color:#fff;background:#444}.hf-btn.active{color:#fff}.hf-btn.active-both{background:var(--yellow);border-color:var(--yellow);color:#222!important}.piano-scroll{background:#1a1610;overflow-x:auto}.piano-rail{background:linear-gradient(#0d0b08 0%,#1a1610 100%);border-radius:0;height:10px}@media (width<=700px){.app-main{padding:16px 12px}.practice-toolbar,.feedback-bar{flex-direction:column;align-items:flex-start}.feedback-notes,.session-body{flex-direction:column}}.confetti-overlay{pointer-events:none;z-index:9999;position:fixed;inset:0;overflow:hidden}.confetti-piece{animation:linear forwards confetti-fall;position:absolute;top:-20px}@keyframes confetti-fall{0%{opacity:1;transform:translateY(0)rotate(0)}80%{opacity:1}to{transform:translateY(108vh) rotate(var(--cf-rot,360deg));opacity:0}}.confetti-note{text-shadow:0 2px 6px #00000026;font-weight:700;line-height:1;animation:ease-in forwards confetti-note-fall;position:absolute;top:-70px}@keyframes confetti-note-fall{0%{opacity:0;transform:translate(0)rotate(0)scale(.6)}8%{opacity:1;transform:translate(calc(var(--cf-sway) * .2), 8vh) rotate(calc(var(--cf-rot) * .1)) scale(1.15)}30%{transform:translate(var(--cf-sway), 30vh) rotate(calc(var(--cf-rot) * .35)) scale(1)}55%{transform:translate(calc(var(--cf-sway) * -.6), 58vh) rotate(calc(var(--cf-rot) * .6)) scale(1.05)}80%{opacity:1;transform:translate(calc(var(--cf-sway) * .5), 84vh) rotate(calc(var(--cf-rot) * .85)) scale(.95)}to{transform:translate(0, 112vh) rotate(var(--cf-rot)) scale(.9);opacity:0}}
