: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-scheme:dark;color:#ffffffde;background-color:#121212;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}#root{width:100%}button{border-radius:4px;border:1px solid transparent;padding:.5em 1em;font-size:1em;font-weight:500;font-family:inherit;cursor:pointer;transition:all .2s ease}button:focus,button:focus-visible{outline:2px solid #4a90d9;outline-offset:2px}.fretboard-container{display:flex;flex-direction:column;background-color:#2a2a2a;padding:20px;border-radius:8px;overflow-x:auto}.fret-numbers{display:flex;margin-bottom:5px}.fret-number{width:50px;text-align:center;color:#888;font-size:12px;flex-shrink:0}.fretboard{display:flex;flex-direction:column;background:linear-gradient(to bottom,#5a3825,#3d2817);border-radius:4px;padding:10px 0}.string-row{display:flex;align-items:center;height:36px;position:relative}.string-label{width:30px;text-align:center;color:#fff;font-weight:700;font-size:14px;flex-shrink:0}.fret-cell{width:50px;height:100%;position:relative;display:flex;align-items:center;justify-content:center;flex-shrink:0}.fret-line{position:absolute;right:0;top:0;bottom:0;width:3px;background:linear-gradient(to bottom,#d4af37,#c0a030,#d4af37);box-shadow:1px 0 2px #0000004d}.fret-cell:first-of-type .fret-line{width:6px;background:beige}.string-row:after{content:"";position:absolute;left:80px;right:0;height:2px;background:linear-gradient(to bottom,#e0e0e0,#b0b0b0,#e0e0e0);pointer-events:none}.string-row:nth-child(1):after{height:1px}.string-row:nth-child(2):after{height:1.5px}.string-row:nth-child(3):after{height:2px}.string-row:nth-child(4):after{height:2.5px}.string-row:nth-child(5):after{height:3px}.string-row:nth-child(6):after{height:3.5px}.note{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;z-index:10;background-color:#4a90d9;color:#fff;box-shadow:0 2px 4px #0000004d;transition:opacity .2s ease}.note.root{background-color:#e74c3c;transform:scale(1.1)}.note.chord-tone{background-color:#27ae60}.note.blue-note{background-color:#9b59b6}.note.root.chord-tone{background-color:#e74c3c}.note.dimmed{opacity:.15}.fret-markers{display:flex;margin-top:5px}.fret-marker-cell{width:50px;text-align:center;flex-shrink:0}.fret-marker{color:#666;font-size:10px}.fret-marker.double{font-size:8px}@media(max-width:768px){.fretboard-container{padding:10px;overflow-x:visible;overflow-y:auto}.fretboard-container{display:flex;flex-direction:row}.fret-numbers{flex-direction:column;margin-bottom:0;margin-right:5px}.fret-number{width:25px;height:40px;display:flex;align-items:center;justify-content:center;font-size:10px}.fretboard{flex-direction:row-reverse;padding:0 10px}.string-row{flex-direction:column;height:auto;width:40px;position:relative}.string-label{width:100%;height:25px;font-size:12px;display:flex;align-items:center;justify-content:center}.fret-cell{width:100%;height:40px}.fret-line{inset:auto 0 0;width:auto;height:3px}.fret-cell:first-of-type .fret-line{width:auto;height:6px}.string-row:after{inset:65px auto auto 50%;height:840px;width:2px;transform:translate(-50%)}.string-row:nth-child(1):after{width:1px;height:840px}.string-row:nth-child(2):after{width:1.5px;height:840px}.string-row:nth-child(3):after{width:2px;height:840px}.string-row:nth-child(4):after{width:2.5px;height:840px}.string-row:nth-child(5):after{width:3px;height:840px}.string-row:nth-child(6):after{width:3.5px;height:840px}.note{width:24px;height:24px;font-size:9px}.fret-markers{flex-direction:column;margin-top:0;margin-left:5px}.fret-marker-cell{width:auto;height:40px;display:flex;align-items:center;justify-content:center}.fret-marker-cell:first-child{height:25px}}.control-panel{background-color:#1e1e1e;padding:20px;border-radius:8px;margin-bottom:20px}.control-section{margin-bottom:20px}.control-section:last-child{margin-bottom:0}.control-divider{height:1px;background-color:#444;margin:10px 0 20px}.control-label{display:block;color:#fff;font-weight:700;margin-bottom:10px;font-size:14px}.note-buttons{display:flex;flex-wrap:wrap;gap:8px}.note-button{width:63px;height:54px;border:2px solid #444;background-color:#333;color:#fff;border-radius:4px;cursor:pointer;font-weight:700;font-size:13px;transition:all .2s ease}.note-button:hover{background-color:#444;border-color:#666}.note-button.active{background-color:#e74c3c;border-color:#c0392b}.pattern-buttons{display:flex;gap:10px}.pattern-button{padding:12px 20px;border:2px solid #444;background-color:#333;color:#fff;border-radius:4px;cursor:pointer;font-weight:700;font-size:13px;transition:all .2s ease}.pattern-button:hover{background-color:#444;border-color:#666}.pattern-button.active{background-color:#4a90d9;border-color:#357abd}.pattern-button:disabled{background-color:#222;border-color:#333;color:#555;cursor:not-allowed}.scale-buttons{display:flex;flex-wrap:wrap;gap:8px}.scale-button{padding:10px 16px;border:2px solid #444;background-color:#333;color:#fff;border-radius:4px;cursor:pointer;font-size:13px;transition:all .2s ease}.scale-button:hover{background-color:#444;border-color:#666}.scale-button.active{background-color:#e67e22;border-color:#d35400}.position-buttons{display:flex;flex-wrap:wrap;gap:8px}.position-button{min-width:80px;padding:10px 12px;border:2px solid #444;background-color:#333;color:#fff;border-radius:4px;cursor:pointer;font-size:13px;transition:all .2s ease;display:flex;flex-direction:column;align-items:center;gap:2px}.position-button:first-child{min-width:60px}.position-button:hover{background-color:#444;border-color:#666}.position-button.active{background-color:#27ae60;border-color:#1e8449}.position-number{font-weight:700;font-size:14px}.position-fret{font-size:10px;color:#aaa}.position-button.active .position-fret{color:#fff}.options{display:flex;flex-wrap:wrap;gap:20px}.checkbox-label{display:flex;align-items:center;gap:8px;color:#fff;cursor:pointer;font-size:14px}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#4a90d9}.filter-buttons{display:flex;gap:8px}.filter-button{padding:10px 16px;border:2px solid #444;background-color:#333;color:#fff;border-radius:4px;cursor:pointer;font-size:13px;transition:all .2s ease}.filter-button:hover{background-color:#444;border-color:#666}.filter-button.active{background-color:#16a085;border-color:#1abc9c}.mode-buttons{display:flex;flex-wrap:wrap;gap:8px}.mode-button{min-width:90px;padding:10px 12px;border:2px solid #444;background-color:#333;color:#fff;border-radius:4px;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;align-items:center;gap:2px}.mode-button:first-child{min-width:60px}.mode-button:hover{background-color:#444;border-color:#666}.mode-button.active{background-color:#9b59b6;border-color:#8e44ad}.mode-roman{font-weight:700;font-size:16px}.mode-chord{font-size:12px;color:#aaa}.mode-button.active .mode-chord{color:#fff}.mode-name{font-size:10px;color:#888}.mode-button.active .mode-name{color:#ddd}@media(max-width:768px){.control-panel{padding:15px}.control-section{margin-bottom:15px}.control-label{font-size:13px;margin-bottom:8px}.note-buttons{gap:6px}.note-button{width:48px;height:42px;font-size:12px}.pattern-buttons{flex-wrap:wrap;gap:8px}.pattern-button{padding:10px 14px;font-size:12px}.scale-buttons{gap:6px}.scale-button{padding:8px 12px;font-size:12px}.position-buttons{gap:6px}.position-button{min-width:60px;padding:8px 10px}.position-button:first-child{min-width:50px}.position-number{font-size:13px}.position-fret{font-size:9px}.mode-buttons{gap:6px}.mode-button{min-width:70px;padding:8px}.mode-button:first-child{min-width:50px}.mode-roman{font-size:14px}.mode-chord{font-size:11px}.mode-name{font-size:9px}.filter-buttons{flex-wrap:wrap;gap:6px}.filter-button{padding:8px 12px;font-size:12px}.checkbox-label{font-size:13px}}.app{min-height:100vh;background-color:#121212;color:#fff;padding:20px}.app-header{display:flex;justify-content:center;align-items:center;margin-bottom:30px;position:relative}.header-content{text-align:center}.app-header h1{margin:0;font-size:2rem;color:#fff}.subtitle{margin:8px 0 0;color:#888;font-size:1rem}.lang-toggle{position:absolute;right:0;padding:8px 16px;background-color:#333;border:2px solid #444;color:#fff;border-radius:4px;cursor:pointer;font-size:14px;font-weight:700;transition:all .2s ease}.lang-toggle:hover{background-color:#444;border-color:#666}.app-main{max-width:1200px;margin:0 auto}.legend{background-color:#1e1e1e;padding:15px 20px;border-radius:8px;margin-top:20px}.legend h3{margin:0 0 12px;font-size:14px;color:#888}.legend-items{display:flex;flex-wrap:wrap;gap:20px}.legend-item{display:flex;align-items:center;gap:8px}.legend-color{width:24px;height:24px;border-radius:50%;box-shadow:0 2px 4px #0000004d}.legend-color.root{background-color:#e74c3c}.legend-color.chord-tone{background-color:#27ae60}.legend-color.blue-note{background-color:#9b59b6}.legend-color.scale-tone{background-color:#4a90d9}.legend-color.dimmed{background-color:#4a90d9;opacity:.3}.legend-item span{font-size:13px;color:#ccc}@media(max-width:768px){.app{padding:10px}.app-header{margin-bottom:15px;flex-direction:column;gap:10px}.app-header h1{font-size:1.5rem}.subtitle{font-size:.9rem}.lang-toggle{position:static;padding:6px 12px;font-size:12px}.legend{padding:12px 15px}.legend-items{gap:12px}.legend-item span{font-size:12px}.legend-color{width:20px;height:20px}}
