*,:before,:after{box-sizing:border-box}:root{--primary:#1a56db;--primary-light:#e8f0fe;--primary-dark:#1340a8;--success:#0e9f6e;--success-light:#d1fae5;--danger:#e02424;--danger-light:#fde8e8;--bg:#f9fafb;--surface:#fff;--border:#e5e7eb;--text:#111827;--text-muted:#6b7280;--radius:8px;--radius-lg:12px;--shadow:0 1px 3px #0000001a, 0 1px 2px #0000000f;--shadow-lg:0 10px 25px #00000026}html,body,#root{height:100%;margin:0;padding:0}body{color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-size:16px;line-height:1.5}#root{flex-direction:column;align-items:center;min-height:100%;display:flex}button{cursor:pointer;border-radius:var(--radius);border:none;padding:.5rem 1rem;font-family:inherit;font-size:1rem;transition:opacity .1s,transform .1s}button:active{transform:scale(.97)}button:disabled{opacity:.4;cursor:not-allowed;transform:none}select{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);padding:.4rem .6rem;font-family:inherit;font-size:1rem}.app{background:var(--bg);flex-direction:column;width:100%;max-width:480px;min-height:100vh;display:flex}.app-header{background:var(--surface);border-bottom:1px solid var(--border);box-shadow:var(--shadow);z-index:10;justify-content:space-between;align-items:center;padding:.75rem 1rem;display:flex;position:sticky;top:0}.app-title{color:var(--primary);letter-spacing:-.3px;margin:0;font-size:1.2rem;font-weight:700}.header-actions{gap:.5rem;display:flex}.icon-btn{border-radius:var(--radius);background:0 0;border:none;padding:.25rem;font-size:1.4rem;line-height:1;transition:background .15s}.icon-btn:hover{background:var(--primary-light)}.context-bar{background:var(--primary-light);flex-wrap:wrap;gap:.4rem;padding:.5rem 1rem;display:flex}.context-badge{white-space:nowrap;border-radius:999px;padding:.2rem .6rem;font-size:.75rem;font-weight:600}.mode-badge{background:var(--primary);color:#fff}.key-badge{color:#fff;background:#7c3aed}.naming-badge{color:#fff;background:#0e9f6e}.ext-badge{color:#fff;background:#d97706}.staff-area{background:var(--surface);border-bottom:1px solid var(--border);justify-content:center;align-items:center;min-height:160px;padding:1rem;display:flex}.no-note{color:var(--text-muted);text-align:center;padding:2rem;font-style:italic}.input-area{background:var(--surface);border-bottom:1px solid var(--border);flex-direction:column;gap:1rem;padding:1rem;display:flex}.input-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.4rem;font-size:.85rem;font-weight:600;display:block}.note-row{flex-wrap:wrap;gap:.35rem;margin-bottom:.35rem;display:flex}.note-row:last-child{margin-bottom:0}.note-btn{background:var(--bg);border:2px solid var(--border);min-width:44px;min-height:48px;color:var(--text);border-radius:var(--radius);padding:.2rem .4rem;font-size:.9rem;font-weight:600;transition:all .1s}.note-btn.accidental{min-width:40px;color:var(--text-muted);border-style:dashed;font-size:.8rem}.note-btn:hover{border-color:var(--primary);color:var(--primary)}.note-btn.selected{background:var(--primary);border-color:var(--primary);color:#fff}.slide-input{flex-direction:column;gap:.5rem;display:flex}.slide-trigger-row{justify-content:space-between;align-items:center;display:flex}.trigger-btn{background:var(--bg);border:2px solid var(--border);color:var(--text-muted);border-radius:999px;padding:.3rem .8rem;font-size:.85rem;font-weight:700;transition:all .15s}.trigger-btn.active{color:#fff;background:#d97706;border-color:#d97706}.position-buttons{gap:.4rem;display:flex}.pos-btn{background:var(--bg);border:2px solid var(--border);min-height:52px;color:var(--text);border-radius:var(--radius);flex:1;font-size:1.2rem;font-weight:700;transition:all .1s}.pos-btn:hover{border-color:var(--primary);color:var(--primary)}.pos-btn.selected{background:var(--primary);border-color:var(--primary);color:#fff}.current-selection{color:var(--primary);text-align:center;font-size:.9rem;font-weight:600}.submit-btn{background:var(--primary);color:#fff;border-radius:var(--radius-lg);letter-spacing:.3px;width:100%;padding:.9rem;font-size:1.05rem;font-weight:700;transition:background .15s}.submit-btn:hover:not(:disabled){background:var(--primary-dark)}.feedback-area{border-bottom:1px solid var(--border);text-align:center;flex-direction:column;align-items:center;gap:.6rem;padding:1.25rem 1rem;display:flex}.feedback-area.correct{background:var(--success-light);border-left:4px solid var(--success)}.feedback-area.incorrect{background:var(--danger-light);border-left:4px solid var(--danger)}.feedback-icon{font-size:2rem;font-weight:700}.feedback-area.correct .feedback-icon{color:var(--success)}.feedback-area.incorrect .feedback-icon{color:var(--danger)}.feedback-note{color:var(--text);font-size:1.1rem;font-weight:700}.intl-name{color:var(--text-muted);font-weight:400}.feedback-explanation{color:var(--text-muted);max-width:340px;font-size:.9rem}.next-btn{background:var(--text);color:#fff;border-radius:var(--radius-lg);margin-top:.25rem;padding:.75rem 2rem;font-size:1rem;font-weight:700}.next-btn:hover{background:var(--primary)}.app-footer{border-top:1px solid var(--border);background:var(--surface);margin-top:auto;position:sticky;bottom:0}.stats-bar{flex-wrap:wrap;justify-content:center;align-items:center;gap:.75rem;padding:.6rem 1rem;display:flex}.stat-item{flex-direction:column;align-items:center;gap:0;display:flex}.stat-value{color:var(--text);font-size:1.1rem;font-weight:700;line-height:1.2}.stat-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-size:.65rem}.stat-divider{color:var(--border);font-size:1.2rem}.error-box-count .stat-value{color:var(--danger)}.overlay{z-index:100;background:#00000080;justify-content:center;align-items:flex-start;padding:1rem;display:flex;position:fixed;inset:0;overflow-y:auto}.stats-screen,.settings-panel{background:var(--surface);border-radius:var(--radius-lg);width:100%;max-width:440px;box-shadow:var(--shadow-lg);margin-top:3.5rem;padding:1.25rem}.stats-header,.settings-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.stats-header h2,.settings-header h2{margin:0;font-size:1.2rem;font-weight:700}.close-btn{color:var(--text-muted);border-radius:var(--radius);background:0 0;border:none;padding:.25rem .5rem;font-size:1.2rem}.close-btn:hover{background:var(--danger-light);color:var(--danger)}.stats-screen section,.settings-panel section{margin-bottom:1.25rem}.stats-screen h3{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin:0 0 .5rem;font-size:.9rem}.empty-msg{color:var(--text-muted);font-size:.9rem;font-style:italic}.error-list{flex-direction:column;gap:.3rem;margin:0;padding:0;list-style:none;display:flex}.error-list li{border-bottom:1px solid var(--border);padding:.3rem 0;font-size:.95rem}.octave-sup{vertical-align:super;font-size:.7em}.stats-table{border-collapse:collapse;width:100%;font-size:.9rem}.stats-table th,.stats-table td{text-align:left;border-bottom:1px solid var(--border);padding:.35rem .5rem}.stats-table th{color:var(--text-muted);font-size:.8rem;font-weight:600}.stats-table .row-bad td{color:var(--danger)}.reset-btn{background:var(--danger-light);width:100%;color:var(--danger);border:1px solid var(--danger);border-radius:var(--radius);padding:.7rem;font-weight:600}.setting-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:.4rem;font-size:.8rem;font-weight:700;display:block}.checkbox-label{text-transform:none;cursor:pointer;align-items:center;gap:.4rem;font-size:.9rem;display:flex}.segmented{flex-wrap:wrap;gap:.4rem;display:flex}.segmented button{background:var(--bg);border:2px solid var(--border);min-height:40px;color:var(--text);border-radius:var(--radius);flex:1;font-size:.85rem;font-weight:600}.segmented button.active{background:var(--primary);border-color:var(--primary);color:#fff}.key-select{width:100%;padding:.5rem;font-size:1rem}.range-selects{gap:1rem;display:flex}.range-selects>div{flex:1}.small-label{color:var(--text-muted);margin-bottom:.2rem;font-size:.75rem;display:block}.range-select{width:100%}.range-hint{color:var(--text-muted);margin-top:.3rem;font-size:.8rem}.tab-nav{background:var(--surface);border-bottom:2px solid var(--border);display:flex}.tab-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-bottom:3px solid #0000;flex:1;margin-bottom:-2px;padding:.6rem .5rem;font-size:.9rem;font-weight:600;transition:color .15s,border-color .15s}.tab-btn:hover{color:var(--primary)}.tab-btn.active{color:var(--primary);border-bottom-color:var(--primary)}.lookup-tab{flex-direction:column;flex:1;gap:1rem;padding:1rem;display:flex;overflow-y:auto}.lookup-hint{text-align:center;color:var(--text-muted);margin:0;padding:2rem 1rem;font-style:italic}.lookup-not-in-key{text-align:center;color:var(--danger);background:var(--danger-light);border-radius:var(--radius);padding:.75rem 1rem;font-weight:500}.lookup-results{flex-direction:column;gap:.75rem;display:flex}.lookup-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden}.lookup-card-header{background:var(--primary-light);border-bottom:1px solid var(--border);align-items:baseline;gap:.5rem;padding:.45rem .9rem;display:flex}.lookup-note-name{color:var(--primary);font-size:1.25rem;font-weight:700}.lookup-octave{color:var(--primary);opacity:.75;font-size:.85rem;font-weight:500}.lookup-intl{color:var(--text-muted);font-size:.85rem}.lookup-card-body{align-items:center;gap:.5rem;padding:.5rem;display:flex;overflow:hidden}.lookup-positions{flex-direction:column;flex:1;gap:.35rem;min-width:0;display:flex}.lookup-pos{border-radius:var(--radius);align-items:center;gap:.4rem;padding:.35rem .6rem;display:flex}.lookup-pos.canonical{background:var(--primary);color:#fff}.lookup-pos.alternative{background:var(--bg);border:1.5px solid var(--border);color:var(--text)}.lp-num{text-align:center;min-width:1.6rem;font-size:1.5rem;font-weight:800;line-height:1}.lp-qv{white-space:nowrap;background:#ffffff4d;border-radius:999px;padding:.1rem .35rem;font-size:.65rem;font-weight:700}.lp-qv-alt{color:#fff;background:#d97706}.lp-tag{opacity:.75;white-space:nowrap;text-transform:uppercase;letter-spacing:.3px;margin-left:auto;font-size:.7rem}.key-select-wrapper{align-items:center;display:inline-flex;position:relative}.key-select-badge{appearance:none;color:#fff;cursor:pointer;background:#7c3aed;border:none;padding-right:1.5rem}.key-select-badge:focus{outline-offset:2px;outline:2px solid #7c3aed}.key-select-badge option{background:var(--surface);color:var(--text)}.key-select-arrow{color:#fffc;pointer-events:none;font-size:.65rem;line-height:1;position:absolute;right:.4rem}.clickable-staff-wrapper{flex-direction:column;align-items:center;gap:.25rem;display:flex;position:relative}.clickable-staff-svg{display:block}.clickable-staff-overlay{cursor:pointer;z-index:1;position:absolute;top:0;left:0}.staff-hover-band{pointer-events:none;background:#3b82f638;border-top:1px solid #3b82f673;border-bottom:1px solid #3b82f673;align-items:center;height:10px;display:flex;position:absolute;left:0;right:0}.staff-hover-label{color:var(--primary);white-space:nowrap;background:var(--surface);border-radius:2px;padding:0 3px;font-size:.68rem;font-weight:700;line-height:1;position:absolute;right:6px}.staff-click-hint{color:var(--text-muted);text-align:center;margin:0;font-size:.72rem}.lookup-acc-row{align-items:center;gap:.5rem;margin-top:.5rem;margin-bottom:.25rem;display:flex}.lookup-acc-label{color:var(--text-muted);white-space:nowrap;font-size:.85rem;font-weight:600}.lookup-acc-buttons{flex:1;gap:.4rem;display:flex}.acc-btn{background:var(--surface);color:var(--text);border:2px solid var(--border);border-radius:var(--radius);flex:1;padding:.4rem .3rem;font-size:.9rem;font-weight:700;transition:all .15s}.acc-btn:hover{border-color:var(--primary);color:var(--primary)}.acc-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.lookup-key-row{align-items:center;gap:.5rem;display:flex}.lookup-key-label{color:var(--text-muted);white-space:nowrap;font-size:.85rem;font-weight:600}.lookup-key-select{border:1.5px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);flex:1;padding:.35rem .5rem;font-size:.9rem}.lookup-or-divider{color:var(--text-muted);align-items:center;gap:.5rem;font-size:.78rem;font-style:italic;display:flex}.lookup-or-divider:before,.lookup-or-divider:after{content:"";background:var(--border);flex:1;height:1px}.valve-input{width:100%;padding:.5rem 0}.valve-row{flex-wrap:wrap;justify-content:center;gap:.4rem;display:flex}.valve-btn{border:2px solid var(--border);border-radius:var(--radius);background:var(--surface);min-width:3rem;color:var(--text);cursor:pointer;-webkit-tap-highlight-color:transparent;padding:.55rem .6rem;font-family:inherit;font-size:.95rem;font-weight:600;transition:background .12s,border-color .12s,color .12s}.valve-btn.selected{background:var(--primary);border-color:var(--primary);color:#fff}.valve-btn:hover:not(:disabled){border-color:var(--primary);background:#eef4ff}.valve-btn:disabled{opacity:.5;cursor:default}.lp-valve{letter-spacing:.03em;font-size:1rem;font-weight:700}.instrument-toggle{border-radius:var(--radius);border:1.5px solid var(--border);gap:0;display:flex;overflow:hidden}.instr-btn{background:var(--surface);color:var(--text-muted);cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;padding:.3rem .55rem;font-family:inherit;font-size:.78rem;font-weight:600;transition:background .12s,color .12s}.instr-btn.active{background:var(--primary);color:#fff}.instr-btn:first-child{border-right:1px solid var(--border)}.help-tab{max-width:480px;color:var(--text);margin:0 auto;padding:1rem 1rem 2rem;line-height:1.6}.help-tab h1{color:var(--primary);margin:0 0 .75rem;font-size:1.2rem;font-weight:700}.help-tab h2{color:var(--text);margin:1.25rem 0 .5rem;font-size:1rem;font-weight:700}.help-tab p,.help-tab ul{margin:0 0 .75rem;font-size:.9rem}.help-tab ul{padding-left:1.2rem}.help-tab li{margin-bottom:.4rem}.help-tab hr{border:none;border-top:1px solid var(--border);margin:1rem 0}.help-table-wrap{border-radius:var(--radius);border:1px solid var(--border);margin-bottom:.75rem;overflow-x:auto}.help-table{border-collapse:collapse;white-space:nowrap;width:100%;font-size:.82rem}.help-table th{background:var(--surface);text-align:left;border-bottom:2px solid var(--border);color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;padding:.45rem .6rem;font-size:.78rem;font-weight:700}.help-table td{border-bottom:1px solid var(--border);padding:.4rem .6rem}.help-table tbody tr:last-child td{border-bottom:none}.help-table tbody tr:nth-child(2n){background:var(--surface)}.help-warning{border-radius:0 var(--radius) var(--radius) 0;color:var(--text);background:#fff8e1;border-left:4px solid #f59e0b;margin:.75rem 0;padding:.65rem .85rem;font-size:.88rem}.copyright-footer{text-align:center;color:var(--text-muted);opacity:.7;padding:.5rem 1rem .8rem;font-size:.7rem}
