:root{font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,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}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}h1,h2,h3,h4,h5,h6{margin:0;line-height:1.2}button{font-family:inherit;cursor:pointer;transition:all .2s ease}button:focus-visible{outline:2px solid #4CAF50;outline-offset:2px}#root{width:100%}.controls{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px;overflow:hidden;transition:all .3s ease}.controls.collapsed{margin-bottom:10px}.controls-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:linear-gradient(135deg,#f8f9fa,#e9ecef);cursor:pointer;border-bottom:2px solid #f0f0f0;transition:background .2s ease}.controls-header:hover{background:linear-gradient(135deg,#e9ecef,#dee2e6)}.controls-header h3{margin:0;font-size:16px;color:#333;font-weight:600}.controls .collapse-button{background:none;border:none;font-size:14px;color:#666;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s ease}.controls .collapse-button:hover{background:#0000001a;color:#333}.controls-content{padding:20px;transition:opacity .3s ease}.controls-horizontal-layout{display:flex;gap:30px;flex-wrap:wrap;align-items:flex-start}.control-group{flex:1;min-width:200px;display:flex;flex-direction:column;gap:8px}.control-group h4{margin:0;font-size:14px;color:#555;font-weight:600;border-bottom:1px solid #eee;padding-bottom:4px}.range-controls{display:flex;flex-direction:column;gap:8px}.range-item label{font-size:12px;color:#666;min-width:30px}.range-item input[type=range]{flex:1;min-width:100px}.range-item .value-display{font-size:12px;font-weight:600;color:#333;min-width:20px;text-align:center}.display-grid{display:flex;flex-direction:column;gap:8px}.option-subgroup{display:flex;align-items:center;gap:8px}.option-subgroup label{font-size:12px;color:#666;min-width:60px}.button-group.compact{gap:4px}.button-group.compact button{padding:4px 8px;font-size:11px;min-width:auto}.tuning-selector.compact{display:flex;align-items:center;gap:8px;margin-top:8px}.tuning-selector.compact label{font-size:12px;color:#666;min-width:50px}.tuning-selector.compact select{flex:1;padding:4px 8px;font-size:12px}.controls.collapsed .controls-content{display:none}.control-section{margin-bottom:20px}.control-section:last-child{margin-bottom:0}.control-section h3{margin:0 0 10px;font-size:16px;color:#333;font-weight:600}.button-group{display:flex;gap:8px;flex-wrap:wrap}.button-group button,.view-selector button{padding:8px 16px;background:#f0f0f0;border:2px solid #ddd;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease;color:#333}.button-group button:hover,.view-selector button:hover{background:#e0e0e0;border-color:#ccc}.button-group button.active,.view-selector button.active{background:#4caf50;border-color:#2e7d32;color:#fff}.button-group button.active:hover,.view-selector button.active:hover{background:#45a049}.instrument-controls{display:flex;flex-direction:column;gap:12px}.tuning-selector{display:flex;align-items:center;gap:10px}.tuning-selector label{min-width:80px;font-weight:500;color:#555;font-size:14px}.tuning-selector select{padding:8px 12px;border:2px solid #ddd;border-radius:6px;font-size:14px;cursor:pointer;background:#fff;flex:1;min-width:200px}.tuning-selector select:focus{outline:none;border-color:#4caf50}.fret-range-controls{display:flex;flex-direction:column;gap:12px}.fret-control{display:flex;align-items:center;gap:10px}.fret-control label{min-width:120px;font-weight:500;color:#555;font-size:14px}input[type=range]{width:200px;margin-right:10px;cursor:pointer}.value-display{font-weight:600;color:#4caf50;font-size:16px}.view-controls{display:flex;flex-direction:column;gap:12px}.root-note-selector{display:flex;align-items:center;gap:10px}.root-note-selector label{font-weight:500;color:#555}.root-note-selector select{padding:6px 12px;border:2px solid #ddd;border-radius:6px;font-size:14px;cursor:pointer;background:#fff}.view-selector{display:flex;gap:8px;flex-wrap:wrap}@media(max-width:768px){.controls{padding:15px}.control-section h3{font-size:14px}.button-group button,.view-selector button{padding:6px 12px;font-size:13px}input[type=range]{width:150px}}.music-theory-controls{display:flex;flex-direction:column;gap:16px}.current-selection{padding:12px;background:#f8f9fa;border:2px solid #e9ecef;border-radius:6px;display:flex;align-items:center;justify-content:center}.no-selection{color:#666;font-style:italic}.quick-access{background:#f5f5f5;padding:16px;border-radius:6px;border:2px solid #e0e0e0}.quick-access h4{margin:0 0 12px;font-size:14px;color:#333;font-weight:600}.quick-buttons{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:8px}.quick-buttons:last-child{margin-bottom:0}.quick-buttons button{padding:6px 12px;background:#fff;border:2px solid #ddd;border-radius:4px;cursor:pointer;font-size:13px;font-weight:500;transition:all .2s ease;color:#333}.quick-buttons button:hover{background:#e8f5e8;border-color:#4caf50}.quick-buttons button.active{background:#4caf50;color:#fff;border-color:#4caf50}.comprehensive-selectors{display:flex;gap:16px;flex-wrap:wrap}.dropdown-section{flex:1;min-width:200px}.dropdown-section h4{margin:0 0 8px;font-size:14px;color:#333;font-weight:600}.dropdown-container{position:relative}.dropdown-toggle{width:100%;padding:12px;background:#fff;border:2px solid #ddd;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;text-align:left;display:flex;justify-content:space-between;align-items:center;transition:all .2s ease}.dropdown-toggle:hover{border-color:#4caf50;background:#f8f9fa}.dropdown-content{position:absolute;top:100%;left:0;right:0;background:#fff;border:2px solid #ddd;border-top:none;border-radius:0 0 6px 6px;box-shadow:0 4px 8px #0000001a;z-index:1000;max-height:300px;overflow-y:auto}.chord-category,.scale-category{border-bottom:1px solid #eee}.chord-category:last-child,.scale-category:last-child{border-bottom:none}.category-label{padding:8px 12px;background:#f8f9fa;font-weight:600;font-size:12px;color:#666;text-transform:uppercase;letter-spacing:.5px}.category-items{padding:8px;display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:4px}@media(max-width:768px){.controls-content{padding:15px}.controls-header{padding:12px 15px}.controls-horizontal-layout{flex-direction:column;gap:15px}.control-group{min-width:0}.range-controls{gap:6px}.display-grid{gap:10px}}@media(max-width:480px){.controls-header h3{font-size:14px}.controls-horizontal-layout{gap:10px}.range-item,.option-subgroup{gap:6px}.button-group.compact button{padding:3px 6px;font-size:10px}}.export-button{font-size:11px;padding:4px 6px;background:#2196f3;color:#fff;border:none;border-radius:3px;cursor:pointer;transition:background-color .2s ease}.export-button:hover{background:#1976d2}.export-button:active{transform:scale(.95)}.number-input{width:60px;padding:4px 6px;border:1px solid #ddd;border-radius:3px;font-size:12px;text-align:center}.number-input:focus{outline:none;border-color:#4caf50}.range-item{display:flex;align-items:center;gap:8px}.controls-header{min-height:56px!important;-webkit-tap-highlight-color:rgba(0,0,0,.05)}.controls .collapse-button{min-width:44px!important;min-height:44px!important;padding:10px!important}.controls .collapse-button:active{transform:scale(.95);background:#00000026!important}@media(max-width:767px){.controls-content{padding:16px 12px!important}.controls-horizontal-layout{flex-direction:column!important;gap:16px!important}.control-group{min-width:100%!important;gap:12px!important}.control-group h4{font-size:15px!important;padding-bottom:6px!important}.button-group.compact button{min-height:44px!important;min-width:44px!important;padding:10px 14px!important;font-size:14px!important;margin:2px!important;touch-action:manipulation;-webkit-tap-highlight-color:rgba(76,175,80,.2)}.button-group.compact button:active{transform:scale(.95)}.tuning-selector.compact select{min-height:48px!important;padding:12px 16px!important;font-size:16px!important}.number-input{min-height:48px!important;min-width:70px!important;padding:12px!important;font-size:16px!important}.export-button{min-height:44px!important;min-width:80px!important;padding:10px 14px!important;font-size:13px!important}.range-item{gap:12px!important;margin:8px 0!important}.range-item label{font-size:14px!important}.option-subgroup{gap:12px!important;margin:4px 0!important}.option-subgroup label{font-size:14px!important}}@media(hover:none)and (pointer:coarse){.controls-header:hover{background:linear-gradient(135deg,#f8f9fa,#e9ecef)!important}}.music-theory-controls{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;border:2px solid #e0e0e0;height:fit-content;position:sticky;top:20px;transition:all .3s ease;overflow:visible}.music-theory-controls.collapsed{width:60px;min-width:60px}.theory-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px 12px;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-radius:6px 6px 0 0;cursor:pointer;border-bottom:2px solid #f0f0f0;transition:background .2s ease}.music-theory-controls.collapsed .theory-header{padding:16px 12px 12px}.theory-header:hover{background:linear-gradient(135deg,#e9ecef,#dee2e6)}.music-theory-controls h3{margin:0;font-size:18px;color:#333;font-weight:600;white-space:nowrap}.music-theory-controls.collapsed h3{font-size:14px;writing-mode:vertical-rl;text-orientation:mixed}.collapse-button{background:none;border:none;font-size:16px;color:#666;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s ease}.music-theory-controls.collapsed .collapse-button{transform:rotate(90deg)}.collapse-button:hover{background:#0000001a;color:#333}.theory-content{padding:12px;display:flex;flex-direction:column;gap:10px;opacity:1;transition:opacity .3s ease}.music-theory-controls.collapsed .theory-content{display:none}.root-note-selector{display:flex;align-items:center;gap:8px}.root-note-selector label{font-weight:600;color:#555;min-width:70px;font-size:14px}.root-note-selector select{padding:6px 10px;border:2px solid #ddd;border-radius:4px;font-size:14px;cursor:pointer;background:#fff;min-width:50px}.root-note-selector select:focus{outline:none;border-color:#4caf50}.current-selection{padding:10px;background:#f8f9fa;border:2px solid #e9ecef;border-radius:4px;display:flex;align-items:center;justify-content:center;min-height:16px}.selection-display{display:flex;align-items:center;gap:12px}.selection-text{font-weight:600;color:#2e7d32;font-size:16px}.clear-button{background:#f44336;color:#fff;border:none;border-radius:50%;width:24px;height:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}.clear-button:hover{background:#d32f2f}.no-selection{color:#666;font-style:italic;font-size:14px}.extension-row{display:flex;gap:4px;margin-top:2px}.extension-btn{flex:1;padding:4px 2px;background:#fff;border:1px solid #c5cae9;border-radius:4px;cursor:pointer;font-size:11px;font-weight:600;color:#3949ab;text-align:center;transition:background .12s}.extension-btn:hover{background:#e8eaf6}.extension-btn.active{background:#3949ab;color:#fff;border-color:#3949ab}.add-to-queue-btn-sm{padding:2px 8px;background:#e8eaf6;border:1px solid #c5cae9;border-radius:3px;cursor:pointer;font-size:11px;font-weight:600;color:#3949ab;transition:background .12s}.add-to-queue-btn-sm:hover{background:#c5cae9}.add-all-row{display:flex;gap:6px;margin-top:4px}.add-queue-btn-sm{flex:1;padding:5px 6px;background:#3949ab;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:11px;font-weight:600;transition:background .12s}.add-queue-btn-sm:hover{background:#283593}.other-section{margin-top:2px}.other-section-label{font-size:11px;font-weight:600;color:#aaa;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.other-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:3px}.other-btn{padding:5px 2px;background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:10px;font-weight:500;color:#555;text-align:center;transition:background .12s;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.other-btn:hover{background:#f5f5f5;border-color:#bbb}.other-btn.active{background:#4caf50;color:#fff;border-color:#4caf50}.category-items button{padding:6px 8px;background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:12px;font-weight:500;transition:all .2s ease;text-align:center}.category-items button:hover{background:#e8f5e8;border-color:#4caf50}.category-items button.active{background:#4caf50;color:#fff;border-color:#4caf50}.root-key-row{display:flex;align-items:center;gap:8px}.root-note-select{padding:6px 10px;border:2px solid #ddd;border-radius:4px;font-size:14px;cursor:pointer;background:#fff;min-width:60px}.root-note-select:focus{outline:none;border-color:#4caf50}.key-type-toggle{display:flex;border:2px solid #ddd;border-radius:4px;overflow:hidden;flex:1}.key-type-btn{flex:1;padding:6px 8px;background:#fff;border:none;cursor:pointer;font-size:13px;font-weight:500;transition:background .15s,color .15s}.key-type-btn+.key-type-btn{border-left:1px solid #ddd}.key-type-btn.active{background:#4caf50;color:#fff}.key-type-btn:not(.active):hover{background:#f0f0f0}.theory-section-label{font-size:10px;font-weight:700;color:#999;text-transform:uppercase;letter-spacing:.6px;margin-top:6px;padding-bottom:3px;border-bottom:1px solid #f0f0f0}.scale-mode-btn{background:#e8f0fe!important;border-color:#aac4f7!important}.scale-mode-btn:hover{background:#c5d8fb!important;border-color:#7baef5!important}.scale-mode-btn.active{background:#1a73e8!important;border-color:#1a73e8!important;color:#fff!important}.degree-scale-group{display:flex;flex-direction:column;gap:3px}.scale-row,.pent-row{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}.pent-btn{display:flex;align-items:center;justify-content:center;padding:4px 2px;background:#fff8e1;border:1px solid #ffe082;border-radius:4px;cursor:pointer;font-size:10px;font-weight:600;color:#e65100;min-width:0;overflow:hidden;white-space:nowrap;transition:background .12s}.pent-btn:hover{background:#fff3cd;border-color:#ffc107}.pent-btn.active{background:#e65100;color:#fff;border-color:#e65100}.altered-row .extension-btn{background:#fff8e1;border-color:#ffe082;color:#f57f17}.altered-row .extension-btn:hover{background:#fff3cd}.altered-row .extension-btn.active{background:#f57f17;color:#fff;border-color:#f57f17}.mode-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}.mode-btn{display:flex;flex-direction:column;align-items:center;padding:5px 2px;background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;transition:background .15s,border-color .15s;min-width:0}.mode-btn:hover{background:#e8f5e8;border-color:#4caf50}.mode-btn.active{background:#4caf50;border-color:#4caf50;color:#fff}.mode-roman{font-size:9px;font-weight:700;color:inherit;opacity:.8}.mode-root{font-size:11px;font-weight:600;color:inherit}.chord-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}.chord-btn-sm{padding:4px 1px;background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:9px;font-weight:600;text-align:center;transition:background .15s,border-color .15s;min-width:0;overflow:hidden;white-space:nowrap;text-overflow:clip;letter-spacing:-.2px}.chord-btn-sm:hover{background:#e8f5e8;border-color:#4caf50}.chord-btn-sm.active{background:#4caf50;border-color:#4caf50;color:#fff}.add-queue-btn{width:100%;padding:7px 8px;background:#3949ab;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:12px;font-weight:600;transition:background .15s}.add-queue-btn:hover{background:#283593}.collapse-button{min-width:44px;min-height:44px;padding:8px;-webkit-tap-highlight-color:rgba(0,0,0,.1)}.collapse-button:active{transform:scale(.95);background:#00000026}.root-note-selector select{min-height:44px;font-size:16px;-webkit-appearance:none;appearance:none}.dropdown-toggle{min-height:48px;padding:12px 16px;font-size:14px;touch-action:manipulation}.dropdown-toggle:active{transform:scale(.98);background:#f0f0f0}.category-items{gap:6px;padding:8px}.category-items button{min-height:44px;min-width:44px;padding:10px 12px;font-size:13px;touch-action:manipulation;-webkit-tap-highlight-color:rgba(76,175,80,.2)}.category-items button:active{transform:scale(.95);background:#e8f5e8}.category-items button.active:active{transform:scale(.95);background:#45a049}.clear-button{min-width:44px;min-height:44px;padding:10px;touch-action:manipulation}.clear-button:active{transform:scale(.9);background:#d32f2f}@media(hover:none)and (pointer:coarse){.theory-header:hover,.collapse-button:hover,.dropdown-toggle:hover,.category-items button:hover{background:inherit}.collapse-button:hover{background:none}}@media(min-width:480px){.theory-header{padding:16px 20px 14px}.theory-content{padding:14px;gap:12px}.dropdown-toggle{padding:12px 18px}.category-items{gap:8px;padding:10px}}@media(min-width:768px){.music-theory-controls{position:sticky;top:20px}.theory-header{padding:16px 20px 12px}.theory-content{padding:12px;gap:10px}.theory-header:hover{background:linear-gradient(135deg,#e9ecef,#dee2e6)}.collapse-button:hover{background:#0000001a}.dropdown-toggle:hover{border-color:#4caf50;background:#f8f9fa}.category-items button:hover{background:#e8f5e8;border-color:#4caf50}.category-items button{min-height:auto;min-width:auto;padding:6px 8px;font-size:12px}.dropdown-toggle{min-height:auto;padding:6px 8px;font-size:12px}}.position-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:8px;padding:8px 10px;background:#f8f9fa;border:1px solid #e0e0e0;border-radius:6px}.position-toolbar .system-buttons{display:flex;gap:0;border:1px solid #ccc;border-radius:4px;overflow:hidden}.position-toolbar .system-button{padding:5px 10px;background:#fff;border:none;border-right:1px solid #ccc;cursor:pointer;font-size:12px;font-weight:500;color:#555;transition:background .15s ease,color .15s ease;white-space:nowrap}.position-toolbar .system-button:last-child{border-right:none}.position-toolbar .system-button:hover{background:#eee}.position-toolbar .system-button.active{background:#2196f3;color:#fff;font-weight:600}.position-toolbar .position-navigator{display:flex;align-items:center;gap:6px;margin-left:auto}.position-toolbar .nav-button{background:#fff;border:1px solid #ccc;border-radius:4px;padding:4px 10px;cursor:pointer;font-size:13px;transition:background .15s ease;line-height:1}.position-toolbar .nav-button:hover{background:#e3f2fd;border-color:#2196f3}.position-toolbar .position-label{font-weight:600;font-size:13px;color:#333;white-space:nowrap;-webkit-user-select:none;user-select:none}.position-toolbar .position-count{font-weight:400;color:#888;font-size:12px}.position-toolbar .system-button{min-height:36px;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.position-toolbar .nav-button{min-width:36px;min-height:36px;display:flex;align-items:center;justify-content:center;touch-action:manipulation}.position-toolbar .system-button:active{transform:scale(.96)}.position-toolbar .nav-button:active{transform:scale(.92)}@media(hover:none)and (pointer:coarse){.position-toolbar .system-button:hover,.position-toolbar .nav-button:hover{background:#fff}.position-toolbar .system-button.active:hover{background:#2196f3}}@media(max-width:479px){.position-toolbar{gap:6px}.position-toolbar .position-navigator{margin-left:0;width:100%;justify-content:center}}@media(min-width:768px){.position-toolbar .system-button{min-height:auto;padding:5px 12px}.position-toolbar .nav-button{min-width:auto;min-height:auto;padding:4px 10px}}.fret-cell-container{display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;width:100%;height:100%;z-index:2;background:transparent;pointer-events:none}.fret-cell-container>*{pointer-events:auto}.fret-label-above{position:absolute;top:-18px;left:50%;transform:translate(-50%);font-size:11px;font-weight:700;color:#666;height:14px;display:flex;align-items:center;justify-content:center;-webkit-user-select:none;user-select:none;min-height:14px;background:transparent;border-radius:0;padding:1px 4px;border:none;z-index:5;box-shadow:none}.fretboard-note{background:#e8eaf6;border:2px solid #9fa8da;border-radius:50%;width:40px;height:40px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;font-weight:600;color:#333;font-size:11px;position:relative;box-shadow:0 1px 3px #0000001f;z-index:5;padding-bottom:2px}.fretboard-note:hover{transform:scale(1.05);box-shadow:0 2px 6px #0003;z-index:10}.fretboard-note:active{transform:scale(.95)}.fretboard-note.highlighted{color:#fff;border:2px solid #5c6bc0;font-weight:700}.fretboard-note.highlighted.important{border:3px solid #3f51b5;font-weight:900;background:#3f51b5}.fretboard-note.selected{border:3px solid #ff6f00;box-shadow:0 0 0 3px #ff6f0033,0 2px 6px #0003;background:#ffecb3}.fretboard-note.selected:hover{box-shadow:0 0 0 3px #ff6f004d,0 2px 8px #0000004d}.fretboard-note.hidden{background:transparent!important;color:transparent!important;border-color:transparent!important;box-shadow:none!important;cursor:default!important;pointer-events:none}.fretboard-note.dimmed{opacity:.15;pointer-events:none}.note-name{-webkit-user-select:none;user-select:none;font-size:12px;font-weight:inherit}.scale-degree{-webkit-user-select:none;user-select:none;font-size:8px;font-weight:900;position:absolute;bottom:-2px;left:50%;transform:translate(-50%);background:#000000e6;color:#fff;border-radius:50%;width:14px;height:14px;display:flex;align-items:center;justify-content:center;line-height:1;border:2px solid rgba(255,255,255,.6);text-shadow:0 1px 2px rgba(0,0,0,.5)}.fretboard-note{width:48px!important;height:48px!important;font-size:13px!important;touch-action:manipulation;-webkit-tap-highlight-color:rgba(76,175,80,.3)}.fretboard-note:active{transform:scale(.92)!important;transition:transform .1s ease}.fretboard-note.highlighted:active{transform:scale(.9)!important}.fretboard-note.selected:active{transform:scale(.88)!important}.fretboard-note:before{content:"";position:absolute;inset:-4px;border-radius:50%}.fret-label-above{font-size:12px!important;padding:2px 6px!important;min-height:16px!important;font-weight:700!important}.note-name{font-size:13px!important}.scale-degree{font-size:9px!important;width:15px!important;height:15px!important;font-weight:900!important}@media(hover:none)and (pointer:coarse){.fretboard-note:hover{transform:none!important;box-shadow:0 2px 4px #0000001a!important;z-index:auto!important}.fretboard-note.selected:hover{box-shadow:0 0 8px #ff980080,0 2px 4px #0000001a!important}}@media(min-width:480px){.fretboard-note{width:50px!important;height:50px!important;font-size:14px!important}.note-name{font-size:14px!important}.scale-degree{width:16px!important;height:16px!important}}@media(min-width:768px){.fretboard-note{width:40px!important;height:40px!important;font-size:11px!important}.fretboard-note:hover{transform:scale(1.1)!important;box-shadow:0 4px 12px #0000004d!important;z-index:10!important}.fretboard-note:active{transform:scale(.95)!important}.fret-label-above{font-size:11px!important;padding:1px 4px!important;min-height:14px!important;font-weight:600!important}.note-name{font-size:11px!important}.scale-degree{font-size:8px!important;width:14px!important;height:14px!important;font-weight:900!important}}.fretboard{padding:0;background:var(--fretboard-bg, #f5f5f5);border-radius:0;overflow-x:auto;overflow-y:hidden;box-shadow:none;border:none;position:relative;width:100%;height:fit-content;min-height:200px}.fretboard-grid{display:flex;flex-direction:column;gap:0;background:transparent;padding:10px 0;border-radius:0;border:none;position:relative;height:fit-content;min-height:100%;min-width:100%;width:fit-content}.fretboard-grid:before{content:"";position:absolute;inset:0;pointer-events:none;z-index:1;background-image:radial-gradient(circle 6px at 210px 50%,rgba(150,150,150,.35) 100%,transparent 100%),radial-gradient(circle 6px at 330px 50%,rgba(150,150,150,.35) 100%,transparent 100%),radial-gradient(circle 6px at 450px 50%,rgba(150,150,150,.35) 100%,transparent 100%),radial-gradient(circle 6px at 570px 50%,rgba(150,150,150,.35) 100%,transparent 100%),radial-gradient(circle 6px at 750px 35%,rgba(150,150,150,.35) 100%,transparent 100%),radial-gradient(circle 6px at 750px 65%,rgba(150,150,150,.35) 100%,transparent 100%),radial-gradient(circle 6px at 930px 50%,rgba(150,150,150,.35) 100%,transparent 100%),radial-gradient(circle 6px at 1050px 50%,rgba(150,150,150,.35) 100%,transparent 100%),radial-gradient(circle 6px at 1170px 50%,rgba(150,150,150,.35) 100%,transparent 100%),radial-gradient(circle 6px at 1290px 50%,rgba(150,150,150,.35) 100%,transparent 100%),radial-gradient(circle 6px at 1470px 35%,rgba(150,150,150,.35) 100%,transparent 100%),radial-gradient(circle 6px at 1470px 65%,rgba(150,150,150,.35) 100%,transparent 100%);background-repeat:no-repeat}.fretboard-loading{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:#000000b3;color:#fff;padding:8px 12px;border-radius:4px;font-size:.85em;pointer-events:none;z-index:100}.fullscreen-button{position:absolute;top:10px;right:10px;z-index:101;background:#000000b3;color:#fff;border:2px solid rgba(255,255,255,.3);border-radius:6px;padding:8px 12px;font-size:1.2em;cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.fullscreen-button:hover{background:#000000d9;border-color:#ffffff80;transform:scale(1.05)}.fullscreen-button:active{transform:scale(.95)}.fretboard:fullscreen{padding:20px;background:var(--fretboard-bg, #f5f5f5);display:flex;flex-direction:column}.fretboard:fullscreen .fretboard-grid{flex:1;height:100%}.string-row{display:flex;align-items:center;background:transparent!important;border-radius:0;padding:0;margin:0;border:none;position:relative;flex:1;min-height:50px}.string-row:before{content:"";position:absolute;left:0;right:0;top:50%;transform:translateY(-50%);height:2px;background:#888!important;z-index:0;pointer-events:none}.frets{display:flex;gap:0;flex-wrap:nowrap;flex:1;position:relative;height:100%}.string-region-fill{position:absolute;top:0;bottom:0;pointer-events:none;z-index:0;border-radius:3px}.fret-cell{display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;min-width:60px;height:100%;background:transparent!important;padding:2px;border-right:1px solid rgba(170,170,170,.3)!important;box-sizing:border-box}.fret-cell:first-child{border-left:3px solid #333!important}.fret-cell:nth-child(2){border-left:3px solid #666!important}.fret-cell:nth-child(2){border-left:3px solid var(--nut-border, #666)}.fret-marker.open{font-weight:900;color:gold;background:#000000e6;border-color:gold}.fretboard{padding:0;overflow-x:auto;overflow-y:auto;-webkit-overflow-scrolling:touch;scroll-behavior:smooth;border-radius:0;width:100%;height:fit-content;min-height:200px}.fullscreen-button{min-width:44px;min-height:44px;font-size:1.4em;padding:10px 14px}.fretboard:fullscreen{padding:10px}.fretboard:fullscreen .fullscreen-button{top:15px;right:15px}.fretboard-grid{padding:10px 0;gap:0;height:fit-content;min-height:100%;min-width:100%;width:fit-content}.string-row{padding:0;margin:0;flex:1;min-height:45px}.fret-cell{min-width:50px;min-height:45px;padding:4px}@media(min-width:480px){.fretboard{padding:0;min-height:450px}.fretboard-grid{padding:10px 0}.string-row{min-height:48px}.fret-cell{min-width:55px;min-height:48px}}@media(min-width:768px){.fretboard{padding:15px;border-radius:8px;box-shadow:0 2px 8px #0000001a;border:1px solid var(--string-border, #ddd);min-height:200px;overflow-y:hidden}.fretboard-grid{padding:10px;gap:0;border-radius:4px;border:none;height:100%}.string-row{padding:0;margin:0;min-height:50px}.fret-cell{min-width:60px;min-height:auto;padding:2px}}.playback-bar{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#ffffff0a;border-radius:6px;font-size:13px}.playback-hint{flex:1;color:#fffc;font-weight:500}.playback-hint.muted{color:#fff6;font-style:italic;font-weight:400}.play-button.compact{background:#4caf50;color:#fff;border:none;border-radius:50%;width:28px;height:28px;cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.play-button.compact:hover:not(:disabled){background:#45a049;transform:scale(1.05)}.play-button.compact:disabled{background:#555;cursor:not-allowed}.clear-button.compact{background:#f44336cc;color:#fff;border:none;border-radius:50%;width:24px;height:24px;cursor:pointer;font-size:10px;display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0;transition:background .2s ease}.clear-button.compact:hover{background:#d32f2f}.practice-bar{background:#1a237e;color:#fff;border-radius:0 0 8px 8px;padding:8px 12px;display:flex;flex-direction:column;gap:6px}.practice-bar-top{display:flex;align-items:center;gap:8px}.pb-nav-btn{background:#ffffff26;color:#fff;border:none;border-radius:4px;padding:6px 10px;cursor:pointer;font-size:14px;flex-shrink:0;transition:background .15s}.pb-nav-btn:hover{background:#ffffff4d}.queue-strip{display:flex;gap:6px;overflow-x:auto;flex:1;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.3) transparent;padding-bottom:2px}.queue-item{flex-shrink:0;background:#ffffff1f;border:1px solid rgba(255,255,255,.2);border-radius:6px;padding:4px 10px;cursor:default;display:flex;flex-direction:column;align-items:center;min-width:80px;transition:background .15s}.queue-item.active{background:#ffffffe6;color:#1a237e;border-color:#fff}.queue-item-label{font-size:12px;font-weight:600;white-space:nowrap}.queue-item-mode{font-size:9px;opacity:.7;text-transform:uppercase}.queue-item.active .queue-item-mode{opacity:.6}.practice-bar-bottom{display:flex;align-items:center;gap:12px;font-size:12px}.space-hint{opacity:.6;font-size:11px}.timer-control{display:flex;align-items:center;gap:4px}.timer-label{opacity:.7;font-size:11px}.timer-input{width:48px;padding:2px 4px;background:#ffffff26;border:1px solid rgba(255,255,255,.3);border-radius:3px;color:#fff;font-size:12px;text-align:center}.timer-input:focus{outline:none;border-color:#ffffffb3}.timer-unit{opacity:.7;font-size:11px}.timer-clear{background:none;border:none;color:#fff9;cursor:pointer;font-size:11px;padding:0 2px}.timer-clear:hover{color:#fff}.queue-progress{margin-left:auto;opacity:.7;font-size:11px}.edit-queue-btn{background:#ffffff26;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:4px;padding:3px 10px;cursor:pointer;font-size:11px;transition:background .15s}.edit-queue-btn:hover{background:#ffffff4d}.queue-editor-overlay{position:fixed;inset:0;background:#00000080;z-index:1000;display:flex;align-items:center;justify-content:center;padding:16px}.queue-editor{background:#fff;border-radius:10px;box-shadow:0 8px 32px #0000004d;width:100%;max-width:560px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.qe-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #eee;flex-shrink:0}.qe-header h3{margin:0;font-size:18px;color:#1a237e}.qe-header-actions{display:flex;gap:8px;align-items:center}.share-btn{padding:4px 12px;border:1px solid #ddd;border-radius:4px;background:#f5f5f5;color:#aaa;cursor:not-allowed;font-size:13px}.qe-close{background:none;border:none;font-size:18px;color:#666;cursor:pointer;padding:4px 8px;border-radius:4px}.qe-close:hover{background:#f0f0f0;color:#333}.qe-section{padding:12px 20px;border-bottom:1px solid #f0f0f0;flex-shrink:0}.qe-section:last-child{border-bottom:none}.qe-section-label{font-size:11px;font-weight:600;color:#888;text-transform:uppercase;letter-spacing:.5px;display:block;margin-bottom:8px}.preset-select{width:100%;padding:7px 10px;border:1px solid #ddd;border-radius:4px;font-size:14px;background:#fff;cursor:pointer}.qe-empty{color:#999;font-size:13px;font-style:italic;margin:0}.queue-list{list-style:none;margin:0;padding:0;overflow-y:auto;max-height:260px;display:flex;flex-direction:column;gap:4px}.queue-list-item{display:flex;align-items:center;gap:8px;padding:6px 8px;background:#fafafa;border:1px solid #eee;border-radius:6px}.qli-num{font-size:11px;color:#aaa;min-width:20px;text-align:right}.qli-label{font-size:13px;font-weight:600;color:#333;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.qli-meta{font-size:10px;color:#aaa;flex-shrink:0}.qli-actions{display:flex;gap:2px;flex-shrink:0}.qli-actions button{background:none;border:1px solid #ddd;border-radius:3px;padding:2px 6px;cursor:pointer;font-size:12px;color:#555;transition:background .1s}.qli-actions button:hover:not(:disabled){background:#f0f0f0}.qli-actions button:disabled{color:#ccc;cursor:default}.qli-remove{color:#e53935!important;border-color:#ffcdd2!important}.qli-remove:hover{background:#ffebee!important}.add-item-toggle{padding:6px 14px;background:#e8eaf6;border:1px solid #c5cae9;border-radius:4px;color:#3949ab;cursor:pointer;font-size:13px;font-weight:600;transition:background .15s}.add-item-toggle:hover{background:#c5cae9}.add-item-picker{margin-top:8px}.add-item-row{display:flex;gap:6px;align-items:center}.add-root-select{padding:6px 8px;border:1px solid #ddd;border-radius:4px;font-size:13px;min-width:60px}.add-type-select{padding:6px 8px;border:1px solid #ddd;border-radius:4px;font-size:13px;flex:1}.add-item-confirm{padding:6px 16px;background:#3949ab;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:13px;font-weight:600;transition:background .15s}.add-item-confirm:hover{background:#283593}.qe-section-list{flex:1;overflow:hidden;display:flex;flex-direction:column}.queue-list-item.editing{background:#f0f4ff;border-color:#aac4f7;flex-direction:column;align-items:stretch;padding:8px}.qli-edit-form{display:flex;flex-direction:column;gap:5px}.qli-edit-row{display:flex;gap:5px;align-items:center}.qli-edit-select{padding:4px 6px;border:1px solid #c5cae9;border-radius:4px;font-size:12px;background:#fff}.qli-edit-root{min-width:56px}.qli-edit-type{flex:1}.qli-edit-pos{width:52px;padding:4px 6px;border:1px solid #c5cae9;border-radius:4px;font-size:12px;text-align:center}.qli-edit-label{flex:1;padding:4px 8px;border:1px solid #c5cae9;border-radius:4px;font-size:12px;background:#fff;width:100%}.qli-edit-actions{display:flex;gap:5px;justify-content:flex-end;margin-top:2px}.qli-confirm{padding:4px 12px;background:#3949ab;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:12px;font-weight:600;transition:background .1s}.qli-confirm:hover{background:#283593}.qli-cancel{padding:4px 10px;background:#f5f5f5;color:#555;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:12px;transition:background .1s}.qli-cancel:hover{background:#eee}.onboarding-backdrop{position:fixed;inset:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.onboarding-modal{background:#fff;border-radius:12px;padding:32px;max-width:520px;width:100%;box-shadow:0 20px 60px #0000004d;max-height:90vh;overflow-y:auto}.onboarding-title{font-size:22px;font-weight:700;color:#1a1a2e;margin:0 0 4px}.onboarding-subtitle{font-size:14px;color:#666;margin:0 0 24px}.onboarding-steps{display:flex;flex-direction:column;gap:16px;margin-bottom:20px}.onboarding-step{display:flex;gap:12px;align-items:flex-start}.onboarding-step-icon{font-size:18px;line-height:1.4;color:#4f46e5;flex-shrink:0;width:24px;text-align:center}.onboarding-step strong{display:block;font-size:14px;font-weight:700;color:#1a1a2e;margin-bottom:2px}.onboarding-step p{font-size:13px;color:#555;margin:0;line-height:1.5}kbd{display:inline-block;padding:1px 6px;font-size:12px;font-family:monospace;background:#f3f4f6;border:1px solid #d1d5db;border-radius:4px;color:#374151}.onboarding-tip{font-size:13px;color:#555;background:#f0f4ff;border-left:3px solid #4f46e5;padding:10px 14px;border-radius:0 6px 6px 0;margin-bottom:24px;line-height:1.5}.onboarding-dismiss{width:100%;padding:12px;background:#4f46e5;color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:background .15s ease}.onboarding-dismiss:hover{background:#4338ca}.onboarding-dismiss:focus-visible{outline:3px solid rgba(79,70,229,.4);outline-offset:2px}@media(max-width:480px){.onboarding-modal{padding:24px 20px}.onboarding-title{font-size:19px}}.app{margin:0 auto;padding:8px;min-height:100vh;display:flex;flex-direction:column;width:100%;box-sizing:border-box}.app-header{text-align:center;margin-bottom:12px;padding:12px 16px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;color:#fff;box-shadow:0 2px 4px #0000001a}.app-header h1{margin:0 0 4px;font-size:1.5em;font-weight:700}.app-header p{margin:0;font-size:.85em;opacity:.95}.app-main{flex:1;display:flex;flex-direction:column;gap:12px}.main-content{display:flex;flex-direction:column;gap:12px;position:relative;width:100%}.settings-panel{z-index:5;border-top:1px solid rgba(255,255,255,.08);padding-top:12px}.theory-panel{width:100%;order:2;z-index:10;transition:all .3s ease}.right-content{width:100%;order:3;display:flex;flex-direction:column;gap:12px}.queue-empty-bar{padding:10px 16px;background:#1a237e;border-radius:6px;color:#ffffff80;font-size:13px;font-style:italic;text-align:center}.fretboard-area{display:flex;flex-direction:column;gap:12px;width:100%}.fretboard-panel{height:auto;min-height:300px;display:flex;overflow:hidden}.app-footer{margin-top:20px;padding:12px;text-align:center;color:#666;border-top:1px solid #eee;font-size:.8em}.app-footer p{margin:0}@media(min-width:480px){.app{padding:12px}.app-header{margin-bottom:16px;padding:16px 20px}.app-header h1{font-size:1.75em;margin-bottom:6px}.app-header p{font-size:.95em}.main-content,.right-content,.fretboard-area{gap:16px}}@media(min-width:768px){.app{padding:16px}.app-header{margin-bottom:20px;padding:20px}.app-header h1{font-size:2em;margin-bottom:8px}.app-header p{font-size:1em}.main-content{flex-direction:row;gap:20px;align-items:flex-start}.theory-panel{flex:0 0 260px;width:260px;order:1}.theory-panel:has(.music-theory-controls.collapsed){flex:0 0 50px;width:50px}.right-content{flex:1;order:2;min-width:0;display:flex;flex-direction:column;min-height:0}.fretboard-area{width:100%}.fretboard-panel{height:auto;min-height:300px;display:flex}}@media(min-width:1024px){.app{max-width:1400px;padding:20px}.app-header{margin-bottom:30px;padding:24px;border-radius:12px}.app-header h1{font-size:2.5em;margin-bottom:10px}.app-header p{font-size:1.1em}.main-content{gap:24px}.right-content{gap:20px}.app-footer{margin-top:40px;padding:20px;font-size:.9em}}@media(min-width:1200px){.app{max-width:1600px}.theory-panel{flex:0 0 300px;width:300px}.theory-panel:has(.music-theory-controls.collapsed){flex:0 0 60px;width:60px}}
