*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}.app{min-height:100vh;background:#f5f5f5;padding-bottom:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}.header{display:flex;align-items:center;justify-content:space-between;padding:16px;background:#fff;box-shadow:0 2px 8px #0000001a;position:sticky;top:0;z-index:100}.header h1,.header h2{margin:0;font-size:20px}.back-btn{background:none;border:none;font-size:24px;cursor:pointer;padding:8px;min-width:48px;min-height:48px;border-radius:8px}.back-btn:hover{background:#f0f0f0}.tip{text-align:center;color:#999;margin:8px 0 16px;font-size:14px;padding:0 16px}.upload-section{padding:0 16px;margin-bottom:16px}.upload-buttons{display:flex;gap:12px}.upload-btn{flex:1;padding:16px 12px;color:#fff;text-align:center;border-radius:12px;cursor:pointer;font-size:16px;font-weight:500;min-height:52px;border:none;transition:background .2s}.upload-btn-local{background:#1989fa}.upload-btn-local:hover{background:#1678de}.upload-btn-camera{background:#07c160}.upload-btn-camera:hover{background:#06ad56}.upload-btn.disabled{opacity:.5;cursor:not-allowed;background:#ccc}.upload-btn.disabled:hover{background:#ccc}.progress-container{padding:0 16px;margin-bottom:16px}.progress-bar{width:100%;height:8px;background:#e0e0e0;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:#1989fa;transition:width .3s}.processing-tip{text-align:center;color:#666;margin:8px 0;font-size:14px}.song-list{padding:0 16px}.song-item{background:#fff;border-radius:12px;padding:16px;margin-bottom:12px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 1px 3px #0000001a}.song-info{flex:1;cursor:pointer;padding:4px 0}.song-name{font-size:16px;font-weight:500;margin-bottom:4px}.song-meta{font-size:12px;color:#999}.song-actions{display:flex;gap:8px}.empty{text-align:center;margin-top:60px;color:#999}.empty-icon{font-size:48px;margin-bottom:16px}.play-control{background:#fff;margin:16px;padding:24px;border-radius:16px;box-shadow:0 2px 8px #0000001a}.current-chord{text-align:center;margin-bottom:24px}.chord-name{font-size:64px;font-weight:700;color:#1989fa}.control-buttons{display:flex;gap:12px;justify-content:center;margin-bottom:24px;flex-wrap:wrap}.btn{padding:12px 24px;border:none;border-radius:24px;font-size:16px;cursor:pointer;min-height:48px;font-weight:500;transition:opacity .2s,transform .1s}.btn:active{transform:scale(.98)}.btn-large{padding:16px 32px;font-size:18px;border-radius:28px;min-width:120px}.btn-primary{background:#1989fa;color:#fff}.btn-danger{background:#ee0a24;color:#fff}.btn:hover{opacity:.9}.btn:disabled{opacity:.6;cursor:not-allowed}.settings{display:flex;flex-direction:column;gap:16px}.bpm-setting{display:flex;align-items:center;gap:16px}.slider{flex:1;-webkit-appearance:none;height:8px;background:#e0e0e0;border-radius:4px;outline:none}.slider::-webkit-slider-thumb{-webkit-appearance:none;width:28px;height:28px;border-radius:50%;background:#1989fa;cursor:pointer;box-shadow:0 2px 6px #0003}.slider::-moz-range-thumb{width:28px;height:28px;border-radius:50%;background:#1989fa;cursor:pointer;border:none;box-shadow:0 2px 6px #0003}.mode-buttons{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.mode-btn{padding:10px 20px;border:2px solid #e0e0e0;border-radius:24px;background:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;min-height:44px;color:#666}.mode-btn:hover{border-color:#1989fa;color:#1989fa}.mode-btn.active{background:#1989fa;color:#fff;border-color:#1989fa}.chord-list-header{display:flex;justify-content:space-between;align-items:center;padding:0 16px;margin-bottom:8px}.chord-list{padding:0 16px}.chord-item{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:#fff;border-radius:12px;margin-bottom:8px;box-shadow:0 1px 3px #0000001a}.chord-item.active{background:#e8f3ff;border-left:4px solid #1989fa;padding-left:12px}.chord-info{display:flex;align-items:center;gap:16px;flex:1;cursor:pointer;padding:4px 0}.chord{font-size:24px;font-weight:700;color:#1989fa;min-width:70px}.lyric{flex:1;color:#333;font-size:14px}.chord-actions{display:flex;gap:8px;align-items:center}.icon-btn{background:none;border:none;font-size:20px;cursor:pointer;padding:10px;min-width:44px;min-height:44px;border-radius:8px;transition:background .2s}.icon-btn:hover{background:#f0f0f0}.add-chord-section{padding:16px}.add-chord-main-btn{width:100%;padding:16px;background:#07c160;color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:500;cursor:pointer;transition:background .2s;min-height:52px}.add-chord-main-btn:hover{background:#06ad56}.edit-input{flex:0 0 auto;width:100px;padding:10px 12px;border:2px solid #1989fa;border-radius:8px;font-size:16px;min-height:44px}.add-input-row{display:flex;gap:12px;padding:12px 16px;background:#f5faff;border-radius:12px;margin-bottom:8px;align-items:center}.add-input{flex:1;padding:12px;border:2px solid #ddd;border-radius:8px;font-size:16px;min-height:48px}.add-input:focus{border-color:#1989fa;outline:none}.save-add-btn{min-width:80px}.cancel-add-btn{min-width:80px;background:#eee}@media(max-width:480px){.chord-name{font-size:48px}.btn-large{font-size:16px;padding:14px 24px}.mode-btn{padding:8px 14px;font-size:13px}.chord{font-size:20px;min-width:60px}.icon-btn{font-size:18px;padding:10px}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:200;display:flex;align-items:center;justify-content:center;padding:20px}.chord-picker-modal{background:#fff;border-radius:16px;padding:24px;width:100%;max-width:480px;max-height:80vh;overflow-y:auto;box-shadow:0 8px 32px #0003}.chord-picker-modal h3{text-align:center;margin-bottom:12px;font-size:18px;color:#333}.chord-category{font-size:13px;font-weight:600;color:#999;margin:14px 0 8px 2px;text-transform:uppercase}.chord-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(64px,1fr));gap:8px;margin-bottom:4px}.chord-option-btn{padding:10px 6px;border:2px solid #e0e0e0;border-radius:10px;background:#fff;font-size:14px;font-weight:600;cursor:pointer;min-height:44px;transition:all .15s;color:#333}.chord-option-btn:hover{border-color:#1989fa;color:#1989fa;background:#e8f3ff}.chord-option-btn:active{transform:scale(.95)}.manual-add-row{display:flex;gap:8px;align-items:center;margin:16px 0}.manual-chord-input{flex:1;padding:12px;border:2px solid #ddd;border-radius:10px;font-size:15px;min-height:44px}.manual-add-btn{padding:12px 20px;min-height:44px;white-space:nowrap}.cancel-picker-btn{display:block;width:100%;padding:14px;background:#eee;color:#666;border:none;border-radius:12px;font-size:16px;cursor:pointer;min-height:48px}.cancel-picker-btn:hover{background:#ddd}.instant-switch-setting{display:flex;align-items:center;justify-content:center;gap:12px;padding-top:4px}.toggle-switch{position:relative;display:inline-block;width:52px;height:28px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:#ccc;border-radius:28px;transition:background .25s}.toggle-slider:before{content:"";position:absolute;height:22px;width:22px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:transform .25s;box-shadow:0 1px 3px #0003}.toggle-switch input:checked+.toggle-slider{background:#1989fa}.toggle-switch input:checked+.toggle-slider:before{transform:translate(24px)}
