*{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}.chord-preview-keyboard{display:flex;flex-direction:column;gap:2px;width:fit-content}.preview-keyboard-row{display:flex;gap:2px}.preview-black-keys-row{margin-left:42px}.preview-key{border-radius:4px;transition:all .2s;display:flex;align-items:center;justify-content:center;overflow:hidden}.preview-key-label{font-size: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:12px 0}.preview-black-key{width:56px;height:160px;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{width:60px;height:160px;background-color:#fff;border:1px solid #333;box-shadow:0 2px 4px #0003}.preview-white-key .preview-key-label{color:#333}@media(max-width:768px){.preview-white-key{width:50px;height:130px}.preview-black-key{width:46px;height:130px}.preview-black-keys-row{margin-left:35px}.preview-key-label{font-size:16px}}@media(max-width:480px){.preview-white-key{width:40px;height:100px}.preview-black-key{width:36px;height:100px}.preview-black-keys-row{margin-left:28px}.preview-key-label{font-size:13px;padding:8px 0}}.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-wrap:wrap;gap:1rem;margin-bottom:1.5rem;padding:1.5rem;background:#f8f9fa;border-radius:8px;box-shadow:0 2px 4px #0000001a}.filter-group{flex:1;min-width:200px;display:flex;flex-direction:column;gap:.5rem}.filter-group label{font-weight:600;color:#555;font-size:.9rem}.filter-group input,.filter-group select{padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:1rem;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}.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)}.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:1px solid #e0e0e0;border-radius:8px;overflow:hidden;transition:box-shadow .2s,transform .2s}.chord-set-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.card-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:linear-gradient(135deg,#667eea,#764ba2);cursor:pointer;-webkit-user-select:none;user-select:none}.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)}.expand-btn{background:#fff3;color:#fff;border:none;width:32px;height:32px;border-radius:50%;font-size:1.5rem;cursor:pointer;transition:background .2s;display:flex;align-items:center;justify-content:center;line-height:1}.expand-btn:hover{background:#ffffff4d}.card-content{padding:1rem;background:#fafafa}.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:1rem}.filter-group{min-width:100%}.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}}
