:root{color-scheme:dark;font-family:Trebuchet MS,Segoe UI,sans-serif;--gap: 8px;--pad: 10px;--radius: 8px;--header-h: 240px;--fretboard-h: 280px;--transport-h: 50px;--sequence-h: 70px;--bottom-h: 260px;--bg-dark: #111416;--bg-shell: radial-gradient(circle at 18% 0%, #5b6a74 0%, #434f58 30%, #262d33 63%, #111416 100%);--panel-bg: linear-gradient(155deg, rgba(108, 128, 140, .18) 0%, rgba(34, 42, 48, .9) 45%, rgba(19, 23, 26, .95) 100%);--panel-border: #6e8089;--control-bg: linear-gradient(180deg, rgba(59, 70, 77, .98), rgba(34, 42, 47, .98));--control-border: #8798a0;--card-bg: linear-gradient(180deg, #324048, #232c32);--card-active: linear-gradient(180deg, rgba(96, 115, 125, .3), rgba(35, 45, 51, .96));--chip-bg: #27333a;--gold: #d8c784;--gold-dark: #9f8a52;--text-primary: #f4ead8;--text-secondary: #dbcdb4;--accent-info: rgba(88, 107, 118, .32)}.theme-bass{--bg-shell: radial-gradient(circle at 18% 0%, #2d4c61 0%, #213846 32%, #261c16 63%, #120d0a 100%);--panel-bg: linear-gradient(155deg, rgba(70, 104, 121, .18) 0%, rgba(28, 33, 37, .88) 45%, rgba(23, 19, 16, .94) 100%);--panel-border: #507181;--control-bg: linear-gradient(180deg, rgba(31, 48, 58, .98), rgba(20, 30, 37, .98));--control-border: #628291;--card-bg: linear-gradient(180deg, #223646, #182834);--card-active: linear-gradient(180deg, rgba(74, 112, 128, .3), rgba(24, 40, 52, .96));--chip-bg: #1b2d39;--gold: #9ec0cc;--gold-dark: #5f8090;--accent-info: rgba(63, 97, 109, .34)}*{box-sizing:border-box}body{margin:0;min-height:100vh;min-height:100dvh;color:var(--text-primary);background:var(--bg-dark);overflow-x:hidden}.app-shell{max-width:1400px;margin:0 auto;padding:var(--pad);padding-bottom:calc(var(--pad) + env(safe-area-inset-bottom,0px));display:grid;grid-template-columns:1fr;grid-template-rows:var(--header-h) var(--fretboard-h) var(--transport-h) var(--sequence-h) var(--bottom-h);gap:var(--gap);min-height:100vh;min-height:100dvh;background:var(--bg-shell)}.top-bar{display:grid;grid-template-columns:auto 1fr;grid-template-rows:auto 1fr;gap:var(--gap);padding:var(--pad);background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:var(--radius);overflow:hidden}.brand-block{grid-row:1 / 3;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:0;margin:-6px 6px -6px -6px;border-right:1px solid rgba(255,255,255,.1)}.brand-logo{width:200px;height:200px;object-fit:contain;border-radius:0}.brand-title{margin:0;font-size:.9rem;color:var(--gold);text-align:center;line-height:1.1}.brand-instrument-group{display:flex;gap:4px;padding:0;border:none;background:none;min-height:0}.brand-instrument-group label{display:none}.brand-instrument-group .toggle{padding:4px 8px;min-height:28px;font-size:.72rem}.controls-row{display:flex;flex-wrap:wrap;gap:6px;align-items:flex-start;align-content:flex-start}.control-group{display:flex;flex-direction:column;gap:3px;padding:6px 8px;border:1px solid var(--control-border);border-radius:var(--radius);background:var(--control-bg)}.control-group label{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary)}.control-options{display:flex;gap:4px;flex-wrap:wrap}.control-options select{min-width:80px}.study-strip{grid-column:2;display:flex;flex-direction:column;gap:4px;min-height:0;overflow:hidden;position:relative;z-index:1}.study-strip-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.study-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--gold)}.study-caption{font-size:.68rem;color:var(--text-secondary);opacity:.8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.selector-toolbar{display:flex;gap:6px;flex-wrap:wrap;align-items:stretch}.selector-field{display:flex;flex-direction:column;gap:3px;min-width:140px}.selector-field label{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary)}.selector-field-path{min-width:130px}.selector-field-octaves{min-width:150px}.selector-summary{flex:1;min-width:160px;padding:6px 10px;border:1px solid var(--panel-border);border-radius:var(--radius);background:var(--accent-info);display:flex;flex-direction:column;justify-content:center;gap:2px}.selector-summary strong{font-size:.78rem;color:var(--text-primary)}.selector-summary span{font-size:.68rem;color:var(--text-secondary)}.selector-summary small{font-size:.62rem;color:var(--gold)}.selector-range{display:flex;flex-direction:column;gap:4px}.selector-range-values{display:flex;align-items:center;gap:6px}.selector-range-values strong{color:var(--gold);font-size:.78rem}.selector-range-values span{flex:1;text-align:center;font-size:.68rem;color:var(--text-secondary)}.dual-range{position:relative;height:28px}.dual-range:before{content:"";position:absolute;left:8px;right:8px;top:50%;height:3px;background:#ffffff26;border-radius:2px;transform:translateY(-50%)}.dual-range input[type=range]{position:absolute;top:0;right:0;bottom:0;left:0;background:transparent;pointer-events:none}.dual-range input[type=range]::-webkit-slider-thumb{pointer-events:auto}.dual-range input[type=range]::-moz-range-thumb{pointer-events:auto}.panel{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:var(--radius);padding:var(--pad);display:flex;flex-direction:column;overflow:hidden}.panel h3{margin:0 0 6px;font-size:.82rem;color:var(--gold);flex-shrink:0}.panel-heading{display:flex;align-items:center;gap:8px;margin-bottom:6px;flex-shrink:0}.panel-heading h3{margin:0;flex:1;min-width:0}.panel-heading-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.panel-body{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden}.panel-body::-webkit-scrollbar{width:4px}.panel-body::-webkit-scrollbar-track{background:#0003;border-radius:2px}.panel-body::-webkit-scrollbar-thumb{background:var(--control-border);border-radius:2px}.study-pill,.practice-pill{padding:2px 6px;border-radius:999px;font-size:.62rem;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.study-pill{border:1px solid rgba(225,194,113,.4);color:var(--gold)}.practice-pill{border:1px solid rgba(143,178,211,.4);color:#b9d4ee}.panel-accordion{padding:3px 8px;border:1px solid var(--control-border);border-radius:999px;background:var(--control-bg);color:var(--text-secondary);font-size:.65rem;text-transform:uppercase;cursor:pointer}.panel-accordion:hover{border-color:var(--gold);color:var(--text-primary)}.panel-fretboard{display:flex;flex-direction:column}.panel-heading-fretboard{display:flex;align-items:center;gap:8px}.panel-heading-fretboard h3{flex:0 0 auto}.fretboard-heading-summary{flex:1;min-width:0;display:flex;align-items:center;gap:8px;padding:4px 8px;background:var(--accent-info);border-radius:var(--radius);font-size:.75rem}.active-chord{font-weight:700;color:var(--gold)}.active-shape-label{color:var(--text-primary)}.active-shape-details{color:var(--text-secondary);font-size:.7rem}.fretboard-stage{flex:1;min-height:0;display:flex}.fretboard-wrap{flex:1;display:flex;flex-direction:column;gap:6px;min-height:0}.fretboard{flex:1;width:100%;min-height:0;touch-action:none;-webkit-user-select:none;user-select:none}.fretboard-help{flex-shrink:0;font-size:.72rem;color:var(--text-secondary);text-align:center}.fretboard-node{cursor:pointer}.fretboard-clickzone{cursor:crosshair}.panel-playback{flex-direction:row;align-items:center;gap:var(--gap)}.panel-playback .panel-heading{margin:0;flex-shrink:0}.playback-row{display:flex;align-items:center;gap:6px;flex:1}.playback-row input[type=range]{flex:1;min-width:80px;max-width:180px;height:28px}.playback-bpm{min-width:28px;font-weight:700;color:var(--gold);text-align:center;font-size:.82rem}.panel-sequence{flex-direction:row;align-items:center;gap:var(--gap)}.panel-sequence .panel-heading{margin:0;flex-shrink:0}.sequence-chips{flex:1;display:flex;gap:6px;overflow-x:auto;overflow-y:hidden;padding:4px 0;scrollbar-width:thin}.sequence-chips::-webkit-scrollbar{height:3px}.sequence-chips::-webkit-scrollbar-track{background:#0003}.sequence-chips::-webkit-scrollbar-thumb{background:var(--gold-dark);border-radius:2px}.chip-wrapper{display:flex;flex-shrink:0;border:2px solid transparent;border-radius:999px}.chip-wrapper.is-selected{border-color:var(--gold)}.chip-wrapper.is-playing .chip{background:var(--gold-dark);color:#111}.chip{display:flex;align-items:center;gap:4px;padding:5px 8px 5px 10px;border:1px solid var(--control-border);border-right:none;border-radius:999px 0 0 999px;background:var(--chip-bg);color:var(--text-secondary);font-size:.78rem;cursor:pointer;white-space:nowrap}.chip-shape{padding:1px 4px;background:#ffffff1f;border-radius:3px;font-size:.68rem;font-weight:600}.chip-remove{padding:5px 8px;border:1px solid var(--control-border);border-left:none;border-radius:0 999px 999px 0;background:var(--chip-bg);color:#ff6b6b;font-size:.68rem;cursor:pointer}.chip-remove:hover{background:#3a1a1a}.chip.is-current{background:var(--gold-dark);color:#111}.bottom-grid{display:grid;grid-template-columns:260px 1fr;gap:var(--gap);min-height:0}.bottom-grid.is-single-chord{grid-template-columns:240px 1fr}.panel-shapes{grid-column:1}.shape-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:6px;align-content:start}.shape-card{padding:6px 8px;border:1px solid var(--control-border);border-radius:6px;background:var(--card-bg);cursor:pointer;text-align:left}.shape-card:hover{border-color:var(--gold)}.shape-card.is-selected{border-color:var(--gold);box-shadow:inset 0 0 0 1px var(--gold)}.shape-card.is-nearest{background:var(--card-active)}.shape-top{display:flex;justify-content:space-between;align-items:center;font-size:.72rem}.shape-top .caged-letter{color:var(--gold);font-weight:600}.shape-frets{font-size:.9rem;font-weight:600;margin-top:2px}.panel-chords,.panel-practice{grid-column:2}.chord-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:6px;align-content:start}.chord-card{padding:8px;border:1px solid var(--control-border);border-radius:6px;background:var(--card-bg);cursor:pointer;text-align:left}.chord-card:hover{border-color:var(--gold)}.chord-card-next{margin-bottom:6px;background:var(--card-active)}.card-kicker{display:block;font-size:.65rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);margin-bottom:3px}.chord-degree{display:inline-block;padding:1px 5px;background:var(--gold-dark);color:#111;border-radius:3px;font-size:.7rem;font-weight:700;margin-right:5px}.chord-name{font-size:1rem;font-weight:600}.chord-card small{display:block;font-size:.7rem;color:var(--text-secondary);margin-top:2px}.practice-section-heading{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:6px}.practice-section-heading h3{margin:0}.practice-group-list{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.practice-option{padding:8px;border:1px solid var(--control-border);border-radius:6px;background:var(--card-bg);cursor:pointer;text-align:left}.practice-option:hover{border-color:var(--gold)}.practice-option.is-selected{border-color:var(--gold);background:var(--card-active)}.practice-option strong{display:block;font-size:.8rem;color:var(--gold)}.practice-option span{font-size:.68rem;color:var(--text-secondary)}.practice-option small{font-size:.65rem;color:var(--text-secondary);opacity:.8}.practice-hint{margin:auto 0 0;padding-top:8px;font-size:.68rem;color:var(--text-secondary);line-height:1.4}.panel-tabs{display:inline-flex;gap:4px;padding:3px;border:1px solid var(--control-border);border-radius:999px;background:#0000004d;margin-bottom:8px}.panel-tab{padding:6px 12px;border:none;border-radius:999px;background:transparent;color:var(--text-secondary);font-size:.75rem;cursor:pointer}.panel-tab.is-active{background:var(--gold-dark);color:#111}.manual-builder-block{margin-bottom:8px}.manual-builder-copy{margin-bottom:6px}.manual-builder-copy strong{font-size:.78rem;color:var(--text-primary)}.manual-builder-copy span{font-size:.68rem;color:var(--text-secondary)}.manual-builder-copy-inline{display:flex;align-items:center;gap:8px}.manual-filter-input{flex:1;max-width:160px;padding:5px 10px;border:1px solid var(--control-border);border-radius:999px;background:var(--control-bg);color:var(--text-primary);font-size:.78rem}.manual-filter-input:focus{outline:none;border-color:var(--gold)}.manual-tag-list{display:flex;flex-wrap:wrap;gap:4px;max-height:80px;overflow-y:auto}.manual-tag{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border:1px solid var(--control-border);border-radius:999px;background:var(--control-bg);font-size:.68rem;cursor:pointer}.manual-tag:hover{border-color:var(--gold)}.manual-tag strong{color:var(--gold)}.manual-tag span{color:var(--text-secondary);font-size:.62rem}.manual-tag-starter,.manual-tag-substitution{background:var(--card-active)}.practice-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:grid;place-items:center;padding:16px}.practice-overlay-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.practice-overlay-panel{position:relative;width:min(95vw,1400px);height:calc(100dvh - 32px);display:grid;grid-template-rows:auto 1fr auto;gap:12px;padding:16px;background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:var(--radius)}.practice-overlay-heading{margin:0}.practice-overlay-caption{margin:0;font-size:.8rem;color:var(--text-secondary)}.practice-overlay-board{min-height:0;display:flex}.practice-overlay-playback{padding:12px;border:1px solid var(--control-border);border-radius:var(--radius);background:var(--control-bg)}.fretboard-wrap.is-expanded{gap:10px}.fretboard.is-expanded{min-height:300px}.fretboard-wrap.is-expanded .fretboard-help{font-size:.82rem}input,select,button{font:inherit}select{padding:6px 28px 6px 10px;min-height:32px;border:1px solid var(--control-border);border-radius:6px;background:var(--control-bg);color:var(--text-primary);-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--gold) 50%),linear-gradient(135deg,var(--gold) 50%,transparent 50%);background-position:calc(100% - 14px) 50%,calc(100% - 10px) 50%;background-size:4px 4px,4px 4px;background-repeat:no-repeat}select:focus{outline:none;border-color:var(--gold)}select option{background:#1a1a1a}.toggle{padding:5px 10px;min-height:32px;border:1px solid var(--control-border);border-radius:6px;background:var(--control-bg);color:var(--text-primary);font-size:.78rem;cursor:pointer;white-space:nowrap}.toggle.is-active{background:linear-gradient(180deg,var(--gold),var(--gold-dark));color:#111;border-color:var(--gold)}.ghost{padding:5px 10px;min-height:32px;border:1px solid var(--control-border);border-radius:6px;background:var(--control-bg);color:var(--text-primary);font-size:.78rem;cursor:pointer;white-space:nowrap}.ghost:disabled{opacity:.5;cursor:not-allowed}.hint{font-size:.78rem;color:var(--text-secondary)}input[type=range]{height:28px}button,select,.shape-card,.chord-card,.chip,.chip-remove,.practice-option,.manual-tag{-webkit-tap-highlight-color:transparent}@media (pointer: coarse){.fretboard-node,.fretboard-clickzone{cursor:default}}@media (max-width: 1024px){:root{--header-h: 210px;--fretboard-h: 240px;--bottom-h: 240px}.bottom-grid{grid-template-columns:220px 1fr}.selector-summary{display:none}}@media (max-width: 720px){:root{--gap: 5px;--pad: 6px;--header-h: auto;--fretboard-h: 180px;--transport-h: 40px;--sequence-h: 50px;--bottom-h: auto}.app-shell{grid-template-rows:auto var(--fretboard-h) var(--transport-h) var(--sequence-h) auto}.top-bar{grid-template-columns:auto 1fr;grid-template-rows:auto auto;padding:var(--pad);gap:var(--gap)}.brand-block{grid-row:1 / 3;flex-direction:column;justify-content:center;align-items:center;border-right:1px solid rgba(255,255,255,.1);border-bottom:none;padding:0;margin:0 6px 0 0;gap:2px}.brand-logo{width:70px;height:70px}.brand-title{font-size:.75rem}.brand-instrument-group{margin:0}.brand-instrument-group .toggle{padding:3px 6px;min-height:24px;font-size:.68rem}.controls-row{padding:0;gap:4px}.control-group{flex:1 1 auto;min-width:70px;padding:4px 6px}.control-group label{font-size:.6rem}.control-options{gap:3px}.toggle{padding:4px 8px;min-height:28px;font-size:.72rem}select{padding:4px 24px 4px 8px;min-height:28px;font-size:.75rem}.study-strip{grid-column:2;border-top:none;padding-top:0;gap:3px}.study-strip-head{gap:4px}.study-label{font-size:.62rem}.study-caption{font-size:.6rem;display:none}.selector-toolbar{flex-direction:row;flex-wrap:wrap;gap:4px}.selector-field{min-width:auto;flex:1 1 calc(50% - 4px)}.selector-field label{font-size:.58rem}.selector-summary{display:none}.panel-fretboard{padding:var(--pad)}.panel-heading-fretboard{gap:4px;margin-bottom:4px}.panel-heading-fretboard h3{font-size:.75rem}.fretboard-heading-summary{display:none}.fretboard-help{font-size:.65rem}.panel-playback{padding:4px 8px;gap:6px}.panel-playback .panel-heading{display:none}.playback-row{gap:4px}.playback-row .ghost{padding:3px 6px;font-size:.68rem;min-height:26px}.playback-row input[type=range]{max-width:120px;height:24px}.playback-bpm{font-size:.75rem;min-width:24px}.panel-sequence{padding:4px 8px;gap:6px}.panel-sequence .panel-heading{display:none}.sequence-chips{padding:2px 0;gap:4px}.chip{padding:3px 5px 3px 7px;font-size:.68rem}.chip-shape{font-size:.62rem;padding:1px 3px}.chip-remove{padding:3px 5px;font-size:.62rem}.bottom-grid{grid-template-columns:1fr;grid-template-rows:140px 180px;gap:var(--gap)}.bottom-grid.is-single-chord{grid-template-columns:1fr;grid-template-rows:130px 200px}.panel-shapes,.panel-chords,.panel-practice{padding:var(--pad)}.panel-shapes{grid-column:1;grid-row:1}.panel-chords,.panel-practice{grid-column:1;grid-row:2}.panel h3{font-size:.75rem;margin-bottom:4px}.panel-heading{margin-bottom:4px}.shape-list,.chord-grid{grid-template-columns:repeat(auto-fill,minmax(85px,1fr));gap:4px}.shape-card,.chord-card{padding:5px 6px}.shape-top{font-size:.68rem}.shape-frets{font-size:.82rem}.chord-name{font-size:.88rem}.practice-group-list{grid-template-columns:repeat(3,1fr);gap:4px}.practice-option{padding:5px}.practice-option strong{font-size:.7rem}.practice-option span,.practice-option small{font-size:.58rem}.panel-tabs{width:100%;justify-content:stretch;margin-bottom:4px}.panel-tab{flex:1;text-align:center;padding:4px 6px;font-size:.68rem}.practice-overlay{padding:6px}.practice-overlay-panel{width:100%;height:calc(100dvh - 12px);padding:8px;gap:6px}}@media (max-width: 480px){:root{--fretboard-h: 160px}.brand-logo{width:55px;height:55px}.brand-title{font-size:.7rem}.brand-instrument-group .toggle{padding:2px 5px;font-size:.62rem}.control-group{min-width:60px;padding:3px 5px}.control-group label{font-size:.55rem}.toggle{padding:3px 6px;min-height:26px;font-size:.68rem}select{min-height:26px;font-size:.7rem}.selector-field{flex:1 1 100%}.bottom-grid{grid-template-rows:120px 160px}.bottom-grid.is-single-chord{grid-template-rows:110px 180px}.shape-list,.chord-grid{grid-template-columns:repeat(auto-fill,minmax(75px,1fr));gap:3px}.shape-card,.chord-card{padding:4px 5px}.shape-top{font-size:.62rem}.shape-frets{font-size:.78rem}.practice-group-list{grid-template-columns:repeat(2,1fr)}.practice-option{padding:4px}.practice-option strong{font-size:.65rem}}
