@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,100..1000;1,9..40,100..1000&family=JetBrains+Mono:wght@400;500;600&display=swap";:root{--font-primary: "DM Sans", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s ease;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-full: 9999px}[data-theme=light]{--bg-primary: #f8f6f3;--bg-secondary: #efecea;--bg-tertiary: #e5e2de;--text-primary: #1a1816;--text-secondary: #5c5856;--text-muted: #8a8580;--fretboard-bg: #e4e1df;--fretboard-bg-alt: #cec9c3;--fret-wire: #a8a29e;--string-color: #9a9590;--nut-color: #967440;--note-bg: #429ce6;--note-text: #ffffff;--note-highlight: #e85d04;--note-highlight-text: #ffffff;--accent: #e85d04;--accent-hover: #d45203;--border-color: #d4d0cc;--shadow-color: rgba(26, 24, 22, .1)}[data-theme=dark]{--bg-primary: #141210;--bg-secondary: #1e1c1a;--bg-tertiary: #2a2826;--text-primary: #f0ebe6;--text-secondary: #a8a29e;--text-muted: #6b6560;--fretboard-bg: #252320;--fretboard-bg-alt: #2e2c28;--fret-wire: #4a4844;--string-color: #5a5855;--nut-color: #7c756e;--note-bg: #1f88cd;--note-text: #ffffff;--note-highlight: #ff7b29;--note-highlight-text: #ffffff;--accent: #ff7b29;--accent-hover: #ff9149;--border-color: #3a3836;--shadow-color: rgba(0, 0, 0, .3)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-primary);background-color:var(--bg-primary);color:var(--text-primary);min-height:100vh;overflow-x:hidden;transition:background-color var(--transition-normal),color var(--transition-normal)}#root{min-height:100vh;display:flex;flex-direction:column}::selection{background-color:var(--accent);color:var(--note-highlight-text)}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.fretboard{--fret-width: min(64px, calc((100vw - 120px) / 26));--note-size: calc(var(--fret-width) * .625);--row-height: calc(var(--fret-width) * .8125);display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);animation:fadeIn .5s ease-out;width:100%}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fret-numbers{display:flex;padding-left:0}.open-fret-spacer{width:var(--fret-width);flex-shrink:0}.nut-spacer{width:8px;flex-shrink:0}.fret-number{width:var(--fret-width);flex-shrink:0;text-align:center;font-family:var(--font-mono);font-size:clamp(.6rem,1.2vw,.8rem);font-weight:500;color:var(--text-muted)}.fretboard-row{display:flex;align-items:stretch}.fretboard-body{display:flex;position:relative;background-color:var(--fretboard-bg);border-radius:var(--radius-md);box-shadow:inset 0 1px 3px #0000001a,0 2px 8px var(--shadow-color)}.open-strings{display:flex;flex-direction:column;flex-shrink:0}.open-note-cell{width:var(--fret-width);height:var(--row-height);display:flex;align-items:center;justify-content:center}.nut{width:6px;flex-shrink:0;background-color:var(--nut-color);border-radius:var(--radius-sm)}.frets-container{position:relative;display:flex;flex-direction:column}.fret-markers-row{display:flex;padding-top:var(--spacing-sm)}.fret-marker-cell{width:var(--fret-width);flex-shrink:0;display:flex;align-items:center;justify-content:center;height:24px}.marker{width:clamp(6px,1vw,10px);height:clamp(6px,1vw,10px);border-radius:50%;background-color:var(--text-muted)}.marker-group{display:flex;gap:6px}.strings{position:relative;z-index:2;display:flex;flex-direction:column}.string-row{position:relative;height:var(--row-height);display:flex;align-items:center}.string-line{position:absolute;left:0;right:0;top:50%;transform:translateY(-50%);background-color:var(--string-color);border-radius:2px;z-index:1;min-height:2px}.notes-row{position:relative;z-index:2;display:flex;width:100%}.fret-cell{width:var(--fret-width);flex-shrink:0;display:flex;align-items:center;justify-content:center}.note{width:var(--note-size);height:var(--note-size);border-radius:50%;border:none;background-color:var(--note-bg);color:var(--note-text);font-family:var(--font-mono);font-size:clamp(.6rem,1.4vw,.85rem);font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform var(--transition-fast),background-color var(--transition-fast),opacity var(--transition-normal),box-shadow var(--transition-fast);box-shadow:0 2px 4px #0000004d}.note:hover{transform:scale(1.15);box-shadow:0 4px 8px #0006}.note:active{transform:scale(.95)}.note.highlighted{background-color:var(--note-highlight);color:var(--note-highlight-text);transform:scale(1.1);box-shadow:0 0 0 3px var(--note-highlight),0 0 16px var(--note-highlight),0 4px 8px #0000004d}.note.highlighted:hover{transform:scale(1.2)}.note.dimmed{opacity:.15}.note.dimmed:hover{opacity:.5;transform:scale(1.1)}.fret-wires{position:absolute;inset:0;display:flex;pointer-events:none;z-index:3}.fret-wire-cell{width:var(--fret-width);flex-shrink:0;display:flex;justify-content:flex-end}.fret-wire{width:3px;height:100%;background-color:var(--fret-wire);border-radius:2px}.left .fret-numbers,.left .fretboard-row,.left .notes-row,.left .fret-markers-row,.left .fret-wires{flex-direction:row-reverse}.left .fret-wire-cell{justify-content:flex-start}@media(max-width:480px){.fretboard{--fret-width: calc((100vw - 80px) / 26);padding:var(--spacing-sm)}}.note-palette{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);flex-wrap:wrap;justify-content:center}.palette-label{font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.palette-notes{display:flex;gap:var(--spacing-xs);flex-wrap:wrap;justify-content:center}.palette-note{width:44px;height:44px;border-radius:var(--radius-md);border:1px solid var(--border-color);background-color:var(--bg-tertiary);color:var(--text-primary);font-family:var(--font-mono);font-size:.9rem;font-weight:600;cursor:pointer;transition:transform var(--transition-fast),background-color var(--transition-fast),border-color var(--transition-fast),box-shadow var(--transition-fast)}.palette-note:hover{border-color:var(--text-muted);transform:translateY(-2px);box-shadow:0 4px 8px var(--shadow-color)}.palette-note.active{background-color:var(--note-highlight);color:var(--note-highlight-text);border-color:var(--note-highlight);box-shadow:0 0 0 2px var(--bg-secondary),0 0 0 4px var(--note-highlight)}.clear-selection{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background-color:transparent;color:var(--text-muted);border:1px solid var(--border-color);border-radius:var(--radius-md);font-family:var(--font-primary);font-size:.75rem;font-weight:500;cursor:pointer;transition:color var(--transition-fast),border-color var(--transition-fast)}.clear-selection:hover{color:var(--text-primary);border-color:var(--text-muted)}@media(max-width:600px){.note-palette{padding:var(--spacing-sm) var(--spacing-md);gap:var(--spacing-sm)}.palette-note{width:32px;height:32px;font-size:.65rem}}.tuning-palette{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);flex-wrap:wrap;justify-content:center}.tuning-controls{display:flex;gap:var(--spacing-sm);flex-wrap:wrap;justify-content:center}.tuning-string{display:flex;flex-direction:column;align-items:center;gap:4px}.tuning-string-label{font-size:.7rem;font-weight:600;color:var(--text-muted);font-family:var(--font-mono)}.tuning-select{padding:8px 4px;border-radius:var(--radius-md);border:1px solid var(--border-color);background-color:var(--bg-tertiary);color:var(--text-primary);font-family:var(--font-mono);font-size:.9rem;font-weight:600;cursor:pointer;transition:border-color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast);appearance:none;text-align:center;min-width:44px}.tuning-select:hover{border-color:var(--text-muted);box-shadow:0 4px 8px var(--shadow-color);transform:translateY(-2px)}.tuning-select:focus-visible{outline:none;border-color:var(--note-highlight);box-shadow:0 0 0 2px var(--bg-secondary),0 0 0 4px var(--note-highlight)}.reset-tuning{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background-color:transparent;color:var(--text-muted);border:1px solid var(--border-color);border-radius:var(--radius-md);font-family:var(--font-primary);font-size:.75rem;font-weight:500;cursor:pointer;transition:color var(--transition-fast),border-color var(--transition-fast),transform var(--transition-fast)}.reset-tuning:hover{color:var(--text-primary);border-color:var(--text-muted)}@media(max-width:600px){.tuning-palette{padding:var(--spacing-sm) var(--spacing-md);gap:var(--spacing-sm)}.tuning-select{min-width:32px;font-size:.75rem;padding:6px 2px}}.app{min-height:100vh;display:flex;flex-direction:column}.header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-xl);background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.header-left{display:flex;align-items:baseline;gap:var(--spacing-md)}.title{font-size:1.5rem;font-weight:600;letter-spacing:-.02em;color:var(--text-primary)}.subtitle{font-size:.875rem;color:var(--text-muted);font-weight:400}.controls{display:flex;align-items:center;gap:var(--spacing-lg)}.control-group{display:flex;align-items:center;gap:var(--spacing-sm)}.control-label{font-size:.875rem;color:var(--text-secondary);font-weight:500}.select{font-family:var(--font-primary);font-size:.875rem;padding:var(--spacing-sm) var(--spacing-md);padding-right:var(--spacing-xl);background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238a8580' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--spacing-sm) center;transition:border-color var(--transition-fast),background-color var(--transition-fast)}.select:hover{border-color:var(--text-muted)}.select:focus{outline:none;border-color:var(--accent)}.theme-toggle{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;transition:border-color var(--transition-fast),background-color var(--transition-fast),transform var(--transition-fast)}.theme-toggle:hover{border-color:var(--text-muted);transform:scale(1.05)}.theme-toggle:active{transform:scale(.95)}.main{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);gap:var(--spacing-lg)}.fretboard-container{width:100%}.palettes-container{display:flex;flex-direction:column;gap:var(--spacing-sm);align-items:center;width:100%}.placeholder{color:var(--text-muted);font-style:italic;text-align:center;padding:var(--spacing-xl)}.hint{font-size:.95rem;color:var(--text-muted);text-align:center}.hint kbd{display:inline-block;padding:3px 8px;font-family:var(--font-mono);font-size:.85rem;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);box-shadow:0 1px 0 var(--border-color)}
