.lock-screen{position:fixed;top:0;right:0;bottom:0;left:0;background:#0e0e12;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.lock-screen[hidden]{display:none}.lock-screen form{background:#1a1a22;border:1px solid #2a2a35;border-radius:.6rem;padding:1.6rem 1.8rem;display:flex;flex-direction:column;gap:.7rem;width:min(320px,90vw)}.lock-screen h2{margin:0;font-size:1.2rem}.lock-screen p{margin:0;color:#888;font-size:.85rem}.lock-screen input,.lock-screen button{font:inherit;padding:.7rem .9rem;background:#262633;color:#eee;border:1px solid #3a3a48;border-radius:.4rem}.lock-screen button{background:#2d5a3a;border-color:#6da66d;cursor:pointer;font-weight:600}.lock-screen button:hover{background:#356b46}.lock-error{color:#e57373;font-size:.8rem}.lock-error[hidden]{display:none}.lock-screen form.shake{animation:lockShake .36s}@keyframes lockShake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-5px)}80%{transform:translate(5px)}}*{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;background:#0e0e12;color:#eee;-webkit-font-smoothing:antialiased;min-height:100vh}#app{max-width:720px;margin:0 auto;padding:1.25rem max(1rem,env(safe-area-inset-left)) 3rem}header h1{font-size:1.4rem;margin:0 0 .25rem}header .sub{margin:0 0 1rem;color:#888;font-size:.85rem}header .sub a{color:#6cb6ff}.controls{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:.9rem}button,.upload,select{font:inherit;padding:.75rem 1.1rem;background:#2a2a35;color:#eee;border:1px solid #3a3a48;border-radius:.5rem;cursor:pointer;-webkit-user-select:none;user-select:none}button:disabled{opacity:.5;cursor:not-allowed}button.recording{background:#c0392b;border-color:#e74c3c;animation:pulse 1.4s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.upload{display:inline-block}.samples{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;margin-bottom:.9rem}.samples label{font-size:.95rem;color:#ccc}.samples select{padding:.5rem .7rem;flex:2 1 240px;min-width:0}.samples input[type=search]{font:inherit;padding:.5rem .7rem;background:#1a1a22;color:#eee;border:1px solid #3a3a48;border-radius:.5rem;flex:1 1 140px;min-width:0}.samples input[type=search]::placeholder{color:#666}.capo{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;margin-bottom:.9rem}.capo label{font-size:.95rem;color:#ccc}.capo select{padding:.5rem .7rem}.capo .hint{color:#777;font-size:.78rem;flex-basis:100%}.checkbox,.capo .checkbox{display:inline-flex;align-items:center;gap:.4rem;font-size:.9rem;color:#ccc;cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox input,.capo .checkbox input{width:1rem;height:1rem;accent-color:#6da66d}#status{font-size:.9rem;color:#aaa;margin:.5rem 0 1rem;min-height:1.2em}audio{width:100%;margin-bottom:1rem}.summary{margin:.6rem 0 .5rem;padding:.6rem .75rem;background:#14141c;border:1px solid #2a2a35;border-radius:.5rem;display:flex;flex-direction:column;gap:.4rem}.summary-row{display:flex;align-items:center;flex-wrap:wrap;gap:.4rem}.summary-label{font-size:.78rem;color:#888;text-transform:uppercase;letter-spacing:.04em;margin-right:.3rem}.summary-chips,.capo-suggest{display:flex;flex-wrap:wrap;gap:.35rem}.chip{display:inline-flex;align-items:baseline;gap:.3rem;padding:.25rem .55rem;background:#1d2230;border:1px solid #2e3447;border-radius:999px;font-size:.85rem;font-variant-numeric:tabular-nums}.chip .count{color:#888;font-size:.72rem}.chip.hard{border-color:#5a3a3a;background:#2a1f24}.chip.easy{border-color:#3a5a3a;background:#1f2a1f}.capo-chip{display:inline-flex;align-items:center;gap:.35rem;padding:.3rem .65rem;background:#1d2230;border:1px solid #2e3447;border-radius:.4rem;font-size:.85rem;cursor:pointer;-webkit-user-select:none;user-select:none}.capo-chip:hover{background:#262d3f}.capo-chip.current{background:#2d5a3a;border-color:#6da66d}.capo-chip .score{color:#999;font-size:.72rem}.timeline-wrap{position:relative;margin-top:.25rem}.timeline{position:relative;height:110px;overflow-x:auto;overflow-y:hidden;background:#14141c;border:1px solid #2a2a35;border-radius:.5rem;scrollbar-width:thin;scrollbar-color:#3a3a48 #14141c}.timeline::-webkit-scrollbar{height:8px}.timeline::-webkit-scrollbar-thumb{background:#3a3a48;border-radius:4px}.timeline-inner{position:relative;height:100%}.chord-block{position:absolute;top:10px;bottom:10px;background:#1d2230;border:1px solid #2e3447;border-radius:.4rem;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;padding:0 .55rem;cursor:pointer;overflow:hidden;transition:background .12s,border-color .12s,transform .12s;-webkit-user-select:none;user-select:none;box-sizing:border-box}.chord-block:hover{background:#262d3f}.chord-block.active{background:#2d5a3a;border-color:#6da66d;transform:scaleY(1.04)}.chord-block .name{font-weight:700;font-size:1.1rem;font-variant-numeric:tabular-nums;white-space:nowrap;line-height:1.1}.chord-block .sounding{display:block;font-weight:400;font-size:.65rem;color:#9aa;margin-top:2px;white-space:nowrap}.chord-block.narrow .name{font-size:.85rem}.chord-block.narrow .sounding{display:none}.playhead{position:absolute;top:0;bottom:0;width:2px;background:#ff5252;box-shadow:0 0 8px #ff5252aa;pointer-events:none;transform:translate(0);z-index:5}
