html,body,#root{width:100%;height:100%}body{-webkit-font-smoothing:antialiased;font-family:Inter,Segoe UI,system-ui,-apple-system,sans-serif}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#2e3138;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#444950}.fretboard-wrapper{width:100%;padding:8px 0 16px}.fretboard{-webkit-user-select:none;user-select:none;width:100%;display:block}.fret-header,.string-row,.fret-dot-row{align-items:center;width:100%;display:flex}.string-label-spacer,.string-label{width:48px;min-width:48px;color:var(--color-text-muted);text-align:right;flex-shrink:0;padding-right:8px;font-size:11px}.fret-number{text-align:center;color:var(--color-text-muted);flex:1;min-width:32px;padding-bottom:4px;font-size:10px}.fret-cell{cursor:pointer;box-sizing:border-box;flex:1;justify-content:center;align-items:center;min-width:32px;height:36px;display:flex;position:relative}.fret-cell:hover .note-dot.empty{background:var(--color-hover);opacity:.4}.fret-cell.nut{border-right:4px solid var(--color-nut);flex:0 0 40px}.fret-number:first-child,.fret-pos-marker:first-child{flex:0 0 40px}.fret-cell:not(.nut):after{content:"";background:var(--color-fret);pointer-events:none;width:2px;position:absolute;top:0;bottom:0;right:0}.string-line{background:var(--color-string);pointer-events:none;height:2px;position:absolute;top:50%;left:0;right:0;transform:translateY(-50%)}.note-dot{z-index:2;cursor:pointer;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:11px;font-weight:600;transition:all .1s;display:flex;position:relative}.note-dot.empty{background:0 0}.note-dot.none{background:var(--color-note-default);color:var(--color-text-dim);font-size:10px;font-weight:400}.note-dot.selected{background:var(--color-selected);color:var(--color-bg);box-shadow:0 0 6px var(--color-selected)}.note-dot.root.selected,.note-dot.root{background:var(--color-root);color:var(--color-bg);box-shadow:0 0 8px var(--color-root)}.note-dot.chord-tone{background:var(--color-chord-tone);color:var(--color-bg)}.note-dot.scale-degree{background:var(--color-scale-degree);color:var(--color-text-on-scale);font-size:10px}.fret-dot-row{padding-top:6px}.fret-pos-marker{flex:1;justify-content:center;gap:4px;min-width:32px;display:flex}.pos-dot{background:var(--color-text-muted);opacity:.4;border-radius:50%;width:8px;height:8px;display:inline-block}:root{--color-bg:#002b36;--color-surface:#073642;--color-surface2:#0a3d4a;--color-border:#1a4a58;--color-text:#93a1a1;--color-text-muted:#586e75;--color-text-dim:#3a535c;--color-text-on-scale:#002b36;--color-root:#cb4b16;--color-selected:#fdf6e3;--color-chord-tone:#268bd2;--color-scale-degree:#859900;--color-note-default:#83949614;--color-hover:#268bd2;--color-fret:#1a4a58;--color-nut:#93a1a1;--color-string:#2a5a6a;--color-primary:#268bd2;--color-primary-hover:#2aa198;--sidebar-width:320px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--color-bg);color:var(--color-text);font-family:Inter,Segoe UI,system-ui,sans-serif;font-size:13px;line-height:1.5}.app{flex-direction:column;height:100vh;display:flex;overflow:hidden}.app-header{background:var(--color-surface);border-bottom:1px solid var(--color-border);flex-shrink:0;align-items:center;gap:16px;padding:10px 20px;display:flex}.app-header h1{color:var(--color-text);letter-spacing:.02em;white-space:nowrap;font-size:16px;font-weight:700}.app-body{flex:1;display:flex;overflow:hidden}.fretboard-section{flex:1;min-width:0;padding:20px;overflow:auto}.sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);background:var(--color-surface);border-left:1px solid var(--color-border);flex-direction:column;display:flex;overflow:hidden}.results-area{flex:1;padding:0 0 16px;overflow-y:auto}.tab-nav{border-bottom:1px solid var(--color-border);flex-shrink:0;display:flex}.tab-nav button{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:10px 4px;font-size:12px;font-weight:600;transition:all .15s}.tab-nav button:hover{color:var(--color-text)}.tab-nav button.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.control-section{border-bottom:1px solid var(--color-border);padding:16px}.control-section h3{letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:12px;font-size:11px;font-weight:700}.control-row{align-items:center;gap:8px;margin-bottom:8px;display:flex}.control-row label{color:var(--color-text-muted);flex-shrink:0;min-width:56px;font-size:12px}.control-row input[type=range]{accent-color:var(--color-primary);flex:1}select{background:var(--color-surface2);border:1px solid var(--color-border);color:var(--color-text);border-radius:4px;flex:1;max-width:200px;padding:4px 8px;font-size:12px}.tuning-strings{flex-direction:column;gap:4px;margin:8px 0;display:flex}.tuning-string-row{align-items:center;gap:8px;display:flex}.string-num{color:var(--color-text-dim);min-width:40px;font-size:11px}.tuning-string-row select{max-width:80px}.chord-input{background:var(--color-surface2);border:1px solid var(--color-border);color:var(--color-text);border-radius:4px;flex:1;min-width:0;padding:6px 10px;font-size:13px}.chord-input:focus{border-color:var(--color-primary);outline:none}.position-filter-row{flex-wrap:wrap;gap:4px;display:flex}.pos-btn{background:var(--color-surface2);border:1px solid var(--color-border);color:var(--color-text-muted);border-radius:4px;min-width:36px;padding:4px 12px;font-size:12px;font-weight:600}.pos-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.pos-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-bg)}.pos-fret-range{color:var(--color-text-muted);margin-top:6px;font-size:11px}.key-chord-section{margin:10px 0 4px}.key-chord-label{text-transform:uppercase;letter-spacing:.06em;color:var(--color-scale-degree);margin-bottom:6px;font-size:10px;font-weight:700;display:block}.chord-quick-list{flex-wrap:wrap;gap:4px;margin:8px 0;display:flex}.button-group{gap:4px;display:flex}button{cursor:pointer;border-radius:4px;font-size:12px;font-weight:600;transition:all .15s}.button-group button{background:var(--color-surface2);border:1px solid var(--color-border);color:var(--color-text-muted);padding:4px 12px}.button-group button.active,.button-group button:hover{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-bg)}.btn-primary{background:var(--color-primary);color:var(--color-bg);border:none;padding:6px 14px}.btn-primary:hover{background:var(--color-primary-hover)}.btn-ghost{border:1px solid var(--color-border);color:var(--color-text-muted);background:0 0;padding:6px 12px}.btn-ghost:hover{border-color:var(--color-text-muted);color:var(--color-text)}.btn-ghost.small,.btn-primary.small{padding:3px 8px;font-size:11px}.chip{background:var(--color-surface2);border:1px solid var(--color-border);color:var(--color-text-muted);border-radius:12px;padding:2px 8px;font-size:11px;font-weight:500}.chip:hover{border-color:var(--color-primary);color:var(--color-primary)}.chip.diatonic{color:var(--color-scale-degree);background:#8599001f;border-color:#85990080}.chip.diatonic:hover{border-color:var(--color-scale-degree);color:var(--color-scale-degree);background:#85990040}.results-section{border-bottom:1px solid var(--color-border);padding:14px 16px}.results-section.empty .hint{color:var(--color-text-muted);font-size:12px}.results-section h4{letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:10px;font-size:11px;font-weight:700}.chord-primary{align-items:baseline;gap:10px;margin-bottom:8px;display:flex}.chord-name{color:var(--color-text);letter-spacing:-.01em;font-size:28px;font-weight:700}.chord-quality{color:var(--color-text-muted);font-size:12px}.chord-intervals{flex-wrap:wrap;gap:4px;margin-bottom:8px;display:flex}.interval-chip{background:var(--color-surface2);border:1px solid var(--color-border);color:var(--color-text-muted);border-radius:4px;padding:2px 8px;font-family:monospace;font-size:11px}.chord-alternatives{color:var(--color-text-dim);font-size:11px}.alt-label{margin-right:2px}.alt-chip{color:var(--color-text-muted);margin-right:6px}.key-group{margin-bottom:8px}.key-group-label{text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px;font-size:10px;font-weight:700;display:block}.key-group-label.diatonic{color:var(--color-scale-degree)}.key-group-label.borrowed{color:var(--color-text-muted)}.key-chips{flex-wrap:wrap;gap:4px;display:flex}.key-chip{border-radius:4px;padding:2px 8px;font-size:11px}.key-chip.diatonic{color:var(--color-scale-degree);background:#85990026;border:1px solid #85990066}.key-chip.borrowed{background:var(--color-surface2);border:1px solid var(--color-border);color:var(--color-text-muted)}.key-chip em{opacity:.7;font-size:10px;font-style:normal}.progression-list{flex-direction:column;gap:6px;display:flex}.progression-item{background:var(--color-surface2);border:1px solid var(--color-border);cursor:pointer;border-radius:6px;padding:8px 10px;transition:border-color .15s}.progression-item:hover{border-color:var(--color-primary)}.prog-top{align-items:center;gap:8px;margin-bottom:2px;display:flex}.prog-chord{color:var(--color-text);font-size:15px;font-weight:700}.prog-roman{color:var(--color-text-muted);font-family:monospace;font-size:11px}.prog-func{text-transform:uppercase;letter-spacing:.05em;border-radius:10px;margin-left:auto;padding:1px 6px;font-size:10px;font-weight:700}.func-tonic{color:#268bd2;background:#268bd226}.func-dominant{color:#cb4b16;background:#cb4b1626}.func-predominant{color:#b58900;background:#b5890026}.func-subdominant{color:#859900;background:#85990026}.prog-feel{color:var(--color-text-muted);font-size:11px}.legend{align-items:center;gap:14px;margin-left:8px;display:flex}.legend-item{color:var(--color-text-muted);align-items:center;gap:5px;font-size:11px;display:flex}.legend-dot{border-radius:50%;width:12px;height:12px;display:inline-block}.legend-dot.root{background:var(--color-root)}.legend-dot.selected{background:var(--color-selected)}.legend-dot.chord-tone{background:var(--color-chord-tone)}.legend-dot.scale-degree{background:var(--color-scale-degree)}.app-footer{background:var(--color-surface);border-top:1px solid var(--color-border);color:var(--color-text-muted);text-align:center;flex-shrink:0;padding:6px 20px;font-size:13px}.app-footer a{color:var(--color-primary);text-decoration:none}.app-footer a:hover{text-decoration:underline}@media (width<=768px){.app-header{flex-wrap:wrap;gap:8px;padding:8px 12px}.legend{flex-wrap:wrap;gap:8px}.app-body{flex-direction:column}.fretboard-section{flex:none;height:45vh;padding:10px 12px;overflow:auto}.sidebar{border-left:none;border-top:1px solid var(--color-border);flex:1;width:100%;min-width:0;overflow-y:auto}.results-area{overflow-y:visible}}.error-msg{color:#dc322f;margin-top:4px;font-size:11px}
