*{box-sizing:border-box}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;color:#213547;background-color:#f5f5f5;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}body{margin:0;padding:0;min-width:320px;min-height:100vh}#root{width:100%;min-height:100vh}input,select,button{font-family:inherit}button{cursor:pointer;-webkit-tap-highlight-color:transparent}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}.keyboard-container{overflow-x:auto;margin-top:.5rem;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:#667eea #f0f0f0}.keyboard-container::-webkit-scrollbar{height:6px}.keyboard-container::-webkit-scrollbar-track{background:#f0f0f0;border-radius:3px}.keyboard-container::-webkit-scrollbar-thumb{background:#667eea;border-radius:3px}.keyboard-container::-webkit-scrollbar-thumb:hover{background:#764ba2}.keyboard{display:flex;flex-direction:column;gap:2px;padding:.5rem;background:#f0f0f0;border-radius:4px;width:fit-content}.keyboard-row{display:flex;gap:1px}.black-keys-row{margin-left:11px}.octave-group{display:flex;gap:1px}.key{width:21px;height:27px;border-radius:3px;transition:all .2s;display:flex;align-items:center;justify-content:center;position:relative}.key-label{font-size:9px;font-weight:700;line-height:1;-webkit-user-select:none;user-select:none}.black-key{background-color:#000;border:1px solid #000}.black-key .key-label{color:#fff}.black-key.active{background-color:#9b59b6;border:1px solid #9b59b6;box-shadow:0 0 4px #9b59b699}.black-key.gap{background-color:transparent;border:none;pointer-events:none}.white-key{background-color:#fff;border:1px solid #ccc}.white-key .key-label{color:#333}.white-key.active{background-color:#764ba2;border:1px solid #764ba2;box-shadow:0 0 4px #764ba299}.white-key.active .key-label{color:#fff}@media(max-width:480px){.keyboard{padding:.375rem}.key{width:18px;height:24px}.key-label{font-size:7px}}.trigger-key-container{margin-bottom:.5rem}.trigger-keyboard{display:flex;flex-direction:column;gap:1px;width:fit-content}.trigger-keyboard-row{display:flex;gap:1px}.trigger-black-keys-row{margin-left:6px}.trigger-key-gap{width:3px}.trigger-key{width:12px;height:16px;border-radius:2px;transition:all .2s;display:flex;align-items:center;justify-content:center;position:relative}.trigger-key-label{font-size:6px;font-weight:700;line-height:1;-webkit-user-select:none;user-select:none}.trigger-black-key{background-color:#fff;border:1px solid #ccc}.trigger-black-key .trigger-key-label{color:#333}.trigger-black-key.active{background-color:#667eea;border:1px solid #667eea;box-shadow:0 0 3px #667eea99}.trigger-black-key.active .trigger-key-label{color:#fff}.trigger-black-key.gap{background-color:transparent;border:none;pointer-events:none}.trigger-white-key{background-color:#fff;border:1px solid #ccc}.trigger-white-key .trigger-key-label{color:#333}.trigger-white-key.active{background-color:#667eea;border:1px solid #667eea;box-shadow:0 0 3px #667eea99}.trigger-white-key.active .trigger-key-label{color:#fff}@media(max-width:480px){.trigger-key{width:10px;height:14px}.trigger-key-label{font-size:5px}}.chord-preview-keyboard-container{padding:.75rem 1rem;background:linear-gradient(135deg,#667eea1a,#764ba21a);border-bottom:1px solid #e0e0e0;display:flex;justify-content:center;overflow:hidden}.chord-preview-keyboard{display:flex;flex-direction:column;gap:2px;width:100%}.preview-keyboard-row{display:flex;gap:2px}.preview-black-keys-row{margin-left:calc((100% - 6 * 2px) / 7 / 2 + 2px)}.preview-key{border-radius:4px;transition:all .2s;display:flex;align-items:center;justify-content:center;overflow:hidden}.preview-key-label{font-size:clamp(11px,2.5cqi,20px);font-weight:600;line-height:1;-webkit-user-select:none;user-select:none;white-space:nowrap;writing-mode:vertical-rl;text-orientation:mixed;transform:rotate(180deg);padding:8px 0}.preview-black-key{flex:1;height:130px;background-color:#222;border:1px solid #000;box-shadow:0 2px 4px #0000004d}.preview-black-key .preview-key-label{color:#fff}.preview-black-key.gap{background-color:transparent;border:none;box-shadow:none}.preview-white-key{flex:1;height:140px;background-color:#fff;border:1px solid #333;box-shadow:0 2px 4px #0003}.preview-white-key .preview-key-label{color:#333}.preview-white-key.active{background-color:#667eea;border-color:#5a6fd6}.preview-white-key.active .preview-key-label{color:#fff}.preview-black-key.active{background-color:#8b9cf7;border-color:#7b8ce7}.chord-sets-container{max-width:1200px;margin:0 auto;padding:1rem}.app-header{text-align:center;margin-bottom:2rem;padding:1.5rem 0;border-bottom:2px solid #e0e0e0}.app-header h1{margin:0 0 .5rem;font-size:2rem;color:#333}.subtitle{margin:0;color:#666;font-size:1rem}.header-info{margin-top:1rem;padding:.75rem 1rem;background:#fff3cd;border:1px solid #ffc107;border-radius:6px;display:inline-flex;align-items:center;gap:.5rem;font-size:.9rem;color:#856404}.info-icon{font-size:1.2rem;cursor:help}.info-text{line-height:1.4}.issue-link{color:#667eea;text-decoration:none;font-weight:600;border-bottom:1px solid transparent;transition:border-color .2s}.issue-link:hover{border-bottom-color:#667eea}.filters{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem;padding:1rem 1.25rem;background:#f8f9fa;border-radius:8px;box-shadow:0 2px 4px #0000001a}.filters-row{display:flex;flex-wrap:wrap;gap:.75rem;align-items:flex-end}.filter-group{flex:1;min-width:120px;display:flex;flex-direction:column;gap:.3rem}.filter-group-compact{flex:0 0 auto;min-width:auto}.filter-group label{font-weight:600;color:#555;font-size:.9rem}.filter-group input,.filter-group select{padding:.5rem;border:1px solid #ddd;border-radius:6px;font-size:.85rem;background:#fff;transition:border-color .2s}.filter-group input:focus,.filter-group select:focus{outline:none;border-color:#4caf50;box-shadow:0 0 0 3px #4caf501a}.midi-row{display:flex;gap:.5rem}.midi-row select:first-child{flex:1;min-width:0}.channel-select{width:80px;flex-shrink:0}.transpose-control{display:flex;align-items:center;gap:.25rem}.transpose-control button{width:28px;height:28px;padding:0;border:1px solid #ddd;border-radius:4px;background:#fff;font-size:1rem;font-weight:600;cursor:pointer;color:#333;transition:background .2s}.transpose-control button:hover:not(:disabled){background:#e8e8e8}.transpose-control button:disabled{opacity:.3;cursor:default}.transpose-value{min-width:2rem;text-align:center;font-weight:600;font-size:.9rem;color:#333}.favourites-btn{padding:.4rem .75rem;border:1px solid #ddd;border-radius:6px;background:#fff;font-size:.85rem;font-weight:600;cursor:pointer;color:#555;transition:background .2s,border-color .2s;white-space:nowrap}.favourites-btn:hover{background:#f0f0f0}.favourites-btn.active{background:#fff8e1;border-color:#ffc107;color:#f57f17}.fav-btn{background:none;border:none;font-size:1.2rem;cursor:pointer;color:#ffffff80;padding:0;line-height:1;transition:color .2s}.fav-btn:hover{color:#fffc}.fav-btn.active{color:#ffd54f}.midi-help-btn{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;margin-left:6px;padding:0;border:1px solid #aaa;border-radius:50%;background:#f0f0f0;color:#555;font-size:.7rem;font-weight:700;cursor:pointer;vertical-align:middle}.midi-help-btn:hover{background:#ddd}.midi-help{margin-top:.5rem;padding:.75rem 1rem;background:#f8f9fa;border:1px solid #ddd;border-radius:6px;font-size:.8rem;line-height:1.5;color:#333}.midi-help p{margin:0 0 .4rem}.midi-help ol{margin:0 0 .5rem;padding-left:1.25rem}.midi-help li{margin-bottom:.2rem}.midi-help kbd{display:inline-block;padding:1px 5px;background:#eee;border:1px solid #ccc;border-radius:3px;font-family:monospace;font-size:.75rem}.clear-btn{align-self:flex-end;padding:.75rem 1.5rem;background:#ff5252;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:600;transition:background .2s}.clear-btn:hover{background:#ff1744}.clear-btn:active{transform:scale(.98)}.now-playing{display:flex;align-items:center;gap:.6rem;margin-bottom:.75rem;padding:.5rem .75rem;border-radius:6px;background:linear-gradient(135deg,#667eea,#764ba2);font-size:.85rem}.now-playing-label,.now-playing-set{font-weight:700;color:#fff}.now-playing-genre{padding:.1rem .5rem;background:#fff3;color:#fff;border-radius:10px;font-size:.8rem;font-weight:600}.now-playing-warning{color:#ffd54f;font-size:.8rem;margin-left:auto}.now-playing-empty{color:#ffffffb3;font-size:.85rem}.results-info{margin-bottom:.5rem;padding:.35rem .5rem;background:#e3f2fd;border-left:3px solid #2196F3;border-radius:3px;color:#1565c0;font-weight:400;font-size:.85rem}.chord-sets-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem;margin-bottom:2rem}.chord-sets-grid.single-item{grid-template-columns:1fr}.chord-set-card{background:#fff;border:2px solid #e0e0e0;border-radius:8px;overflow:hidden;transition:box-shadow .2s,transform .2s,border-color .2s;cursor:pointer}.chord-set-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.chord-set-card.selected{border-color:#667eea;box-shadow:0 0 0 2px #667eea4d,0 4px 12px #667eea33}.card-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:linear-gradient(135deg,#667eea,#764ba2)}.chord-preview{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem;padding:.75rem 1rem;background:linear-gradient(135deg,#667eea1a,#764ba21a);border-bottom:1px solid #e0e0e0}.preview-chord{font-size:.8rem;color:#667eea;font-weight:600;padding:.25rem .5rem;background:#fff;border-radius:4px;box-shadow:0 1px 2px #0000001a;text-align:center}.card-title{display:flex;align-items:center;gap:.75rem}.set-number{font-size:1.25rem;font-weight:700;color:#fff}.genre-badge{padding:.25rem .75rem;background:#fff3;color:#fff;border-radius:12px;font-size:.85rem;font-weight:600;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.card-content{padding:1rem;background:#fafafa}.details-toggle{width:100%;padding:.5rem;background:#e8e8e8;border:none;border-bottom-left-radius:8px;border-bottom-right-radius:8px;color:#555;font-size:.85rem;cursor:pointer;transition:background .2s}.details-toggle:hover{background:#ddd}.chords-list{display:flex;flex-direction:column;gap:.75rem}.chord-item{padding:.75rem;background:#fff;border-left:3px solid #667eea;border-radius:4px;box-shadow:0 1px 3px #0000001a}.chord-item-top{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:.5rem}.chord-info{flex:1}.chord-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.chord-key{display:inline-flex;align-items:center;justify-content:center;min-width:2rem;padding:.25rem .5rem;background:#667eea;color:#fff;border-radius:4px;font-size:.85rem;font-weight:700}.chord-name{font-weight:600;color:#333;font-size:1.1rem}.chord-notes{color:#666;font-size:.9rem;font-family:Courier New,monospace;margin-left:.5rem}.no-results{text-align:center;padding:3rem 1rem;background:#f8f9fa;border-radius:8px;color:#666}.no-results p{margin-bottom:1rem;font-size:1.1rem}.no-results button{padding:.75rem 1.5rem;background:#4caf50;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:600;transition:background .2s}.no-results button:hover{background:#45a049}.app-footer{margin-top:3rem;padding:1.5rem 0;text-align:center;border-top:2px solid #e0e0e0;color:#666}.app-footer p{margin:0;font-size:.95rem}.github-link{color:#667eea;text-decoration:none;font-weight:600;transition:color .2s}.github-link:hover{color:#764ba2;text-decoration:underline}@media(max-width:768px){.chord-sets-container{padding:.5rem}.app-header h1{font-size:1.5rem}.subtitle{font-size:.9rem}.header-info{font-size:.85rem;padding:.625rem .875rem;flex-direction:column;text-align:center}.filters{padding:.75rem}.filter-group{min-width:100%}.filter-group-compact{min-width:auto;flex:1}.clear-btn{width:100%}.chord-sets-grid{grid-template-columns:1fr;gap:1rem}.card-header{padding:.875rem}.set-number{font-size:1.1rem}.genre-badge{font-size:.75rem;padding:.2rem .6rem}.chord-item{padding:.625rem}.chord-name{font-size:1rem}.chord-notes{font-size:.85rem}.chord-preview{padding:.625rem .875rem;gap:.375rem}.preview-chord{font-size:.75rem;padding:.2rem .4rem}}@media(max-width:480px){.app-header{padding:1rem 0}.app-header h1{font-size:1.25rem}.subtitle{font-size:.85rem}.results-info{font-size:.9rem}.chord-header{flex-wrap:wrap}.chord-notes{font-size:.8rem;word-break:break-all}.chord-preview{padding:.5rem .75rem;gap:.3rem}.preview-chord{font-size:.65rem;padding:.2rem .25rem}}
