:root{--bg-primary: #1a1a2e;--bg-secondary: #16213e;--bg-tertiary: #0f3460;--text-primary: #eaeaea;--text-secondary: #a0a0a0;--accent: #e94560;--accent-hover: #ff6b6b;--string-color: #c9c9c9;--fret-color: #4a4a4a;--fret-marker: #333;--note-root: #e94560;--note-scale: #4ecca3;--note-chord: #ffd93d;--note-inactive: #3a3a3a;font-family:Segoe UI,system-ui,-apple-system,sans-serif;line-height:1.5;font-weight:400;color:var(--text-primary);background-color:var(--bg-primary);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box;margin:0;padding:0}body{min-height:100vh;background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-secondary) 100%)}#root{width:100%;min-height:100vh}button{border-radius:6px;border:1px solid var(--bg-tertiary);padding:.5em 1em;font-size:.9em;font-weight:500;font-family:inherit;background-color:var(--bg-secondary);color:var(--text-primary);cursor:pointer;transition:all .2s ease}button:hover{background-color:var(--bg-tertiary);border-color:var(--accent)}button:focus{outline:2px solid var(--accent);outline-offset:2px}select{border-radius:6px;border:1px solid var(--bg-tertiary);padding:.5em 1em;font-size:.9em;font-family:inherit;background-color:var(--bg-secondary);color:var(--text-primary);cursor:pointer}select:focus{outline:2px solid var(--accent);outline-offset:2px}.fretboard-container{width:100%;overflow-x:auto;padding:20px}.fretboard{display:flex;flex-direction:column;background:linear-gradient(180deg,#2a1810,#1a0f0a);border-radius:8px;padding:15px 10px;min-width:1200px;box-shadow:0 4px 20px #00000080;position:relative}.string-row{display:flex;align-items:center;height:40px;position:relative}.string-row:before{content:"";position:absolute;left:50px;right:0;height:2px;background:linear-gradient(90deg,var(--string-color),#888);top:50%;transform:translateY(-50%);z-index:1}.string-row:nth-last-child(2):before{height:3.5px}.string-row:nth-last-child(3):before{height:3px}.string-row:nth-last-child(4):before{height:2.5px}.string-row:nth-last-child(5):before{height:2px}.string-row:nth-last-child(6):before{height:1.5px}.string-row:nth-last-child(7):before{height:1px}.string-label{width:50px;text-align:center;font-weight:700;color:var(--text-secondary);font-size:.9em;z-index:2;position:relative;display:flex;align-items:center;justify-content:center;gap:2px}.muted-indicator{color:#ff5252;font-weight:700;font-size:.8em;opacity:.9}.frets-container{display:flex;flex:1}.fret{flex:1;min-width:45px;max-width:60px;height:40px;display:flex;align-items:center;justify-content:center;position:relative;z-index:2}.fret:first-child{min-width:55px;background:linear-gradient(90deg,#d4a574,#b8956a);border-radius:4px 0 0 4px}.fret:not(:first-child):after{content:"";position:absolute;right:0;top:0;bottom:0;width:3px;background:linear-gradient(180deg,#666,#444,#666)}.note-dot{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75em;font-weight:700;cursor:pointer;transition:all .15s ease;z-index:3}.note-dot.inactive{background:var(--note-inactive);color:var(--text-secondary);opacity:.5}.note-dot.inactive:hover{opacity:.8;transform:scale(1.1)}.note-dot.dimmed{background:var(--note-inactive);color:var(--text-secondary);opacity:.3;box-shadow:none}.note-dot.dimmed:hover{opacity:.5;transform:scale(1.05)}.note-dot.highlighted{background:var(--note-scale);color:#000;box-shadow:0 0 10px var(--note-scale)}.note-dot.root{background:var(--note-root);color:#fff;box-shadow:0 0 15px var(--note-root);transform:scale(1.1)}.note-dot.chord{background:var(--note-chord);color:#000;box-shadow:0 0 10px var(--note-chord)}.note-dot.hidden{background:transparent;color:transparent;opacity:1;box-shadow:none}.note-dot.hidden.clickable{cursor:pointer}.note-dot.hidden.clickable:hover{background:#ffffff1a;transform:scale(1.1)}.note-dot.revealed{background:var(--accent);color:#fff;box-shadow:0 0 10px var(--accent)}.note-dot.clickable{cursor:pointer}.fret-markers{display:flex;padding-left:50px;margin-top:10px}.fret-marker{flex:1;min-width:45px;max-width:60px;display:flex;justify-content:center;align-items:center;gap:4px}.fret-marker:first-child{min-width:55px}.marker-dot{width:8px;height:8px;border-radius:50%;background:var(--fret-marker)}.fret-number{color:var(--text-secondary);font-size:.75em;text-align:center;width:100%}.fretboard-inlays{position:absolute;inset:15px 10px 60px 60px;display:flex;pointer-events:none;z-index:0}.inlay-position{flex:1;min-width:45px;max-width:60px;display:flex;align-items:center;justify-content:center}.inlay-position:first-child{min-width:55px}.inlay-dot{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%}.inlay-dot-inner{width:12px;height:12px;border-radius:50%;background:radial-gradient(ellipse at 30% 30%,#f5f5f0,#e8e8e0,#d4d4c8 60%,#c0c0b0);box-shadow:inset 0 1px 2px #fffc,inset 0 -1px 2px #0003,0 1px 3px #0006;opacity:.85}.inlay-dot.double{gap:40px}.inlay-dot.double .inlay-dot-inner{width:10px;height:10px}.position-indicator-overlay{position:absolute;inset:15px 10px 60px 60px;display:flex;pointer-events:none;z-index:1}.position-fret{flex:1;min-width:45px;max-width:60px;display:flex;align-items:flex-start;justify-content:center;position:relative;transition:background .2s ease}.position-fret:first-child{min-width:55px}.position-fret.in-position{background:#8a78be26;border-top:2px solid var(--accent);border-bottom:2px solid var(--accent)}.position-fret.position-start{border-left:3px solid var(--accent);border-radius:4px 0 0 4px}.position-fret.in-position:last-of-type,.position-fret.in-position+.position-fret:not(.in-position){border-right:3px solid var(--accent);border-radius:0 4px 4px 0}.position-fret.in-position:has(+.position-fret:not(.in-position)){border-right:3px solid var(--accent);border-radius:0 4px 4px 0}.position-label{position:absolute;top:-25px;left:50%;transform:translate(-50%);background:var(--accent);color:#fff;padding:2px 8px;border-radius:4px;font-size:.8em;font-weight:700;white-space:nowrap;box-shadow:0 2px 6px #0000004d}.voicing-controls{display:flex;align-items:center;gap:12px;padding:8px 12px;background:var(--bg-tertiary);border-radius:6px;margin-top:8px}.voicing-controls.compact{padding:4px 8px;gap:8px;margin-top:4px}.voicing-view-toggle{display:flex;gap:0;border-radius:6px;overflow:hidden;border:1px solid var(--bg-primary)}.voicing-view-toggle button{border-radius:0;border:none;padding:.4em .8em;background:var(--bg-primary);color:var(--text-secondary);font-size:.85em;cursor:pointer;transition:all .2s}.voicing-view-toggle button:hover:not(:disabled){background:var(--bg-secondary)}.voicing-view-toggle button.active{background:var(--accent);color:#fff}.voicing-view-toggle button:disabled{opacity:.5;cursor:not-allowed}.voicing-view-toggle button:first-child{border-radius:5px 0 0 5px}.voicing-view-toggle button:last-child{border-radius:0 5px 5px 0}.voicing-controls.compact .voicing-view-toggle button{padding:.3em .6em;font-size:.8em}.voicing-position-selector{display:flex;align-items:center;gap:6px}.voicing-nav-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;background:var(--bg-primary);color:var(--text-secondary);border:1px solid var(--bg-secondary);border-radius:4px;cursor:pointer;transition:all .2s}.voicing-nav-btn:hover:not(:disabled){background:var(--accent);color:#fff;border-color:var(--accent)}.voicing-nav-btn:disabled{opacity:.3;cursor:not-allowed}.nav-arrow{font-size:.8em;line-height:1}.voicing-controls.compact .voicing-nav-btn{width:24px;height:24px}.voicing-controls.compact .nav-arrow{font-size:.7em}.voicing-dropdown{min-width:140px;padding:.4em .6em;background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--bg-secondary);border-radius:4px;font-size:.85em;cursor:pointer}.voicing-dropdown:hover{border-color:var(--accent)}.voicing-controls.compact .voicing-dropdown{min-width:100px;font-size:.8em;padding:.3em .5em}.voicing-badge{display:inline-block;padding:2px 8px;font-size:.75em;font-weight:500;border-radius:10px;text-transform:uppercase;letter-spacing:.5px}.voicing-badge.open{background:#4caf5033;color:#4caf50}.voicing-badge.barre{background:#2196f333;color:#2196f3}.voicing-badge.partial_barre{background:#ff980033;color:#ff9800}.voicing-badge.caged{background:#9c27b033;color:#9c27b0}.voicing-badge.generated{background:#9e9e9e33;color:#9e9e9e}.voicing-play-btn{display:flex;align-items:center;justify-content:center;width:32px;height:28px;padding:0;margin-left:4px;background:var(--accent);color:#fff;border:none;border-radius:4px;cursor:pointer;transition:all .2s}.voicing-play-btn:hover:not(:disabled){background:var(--accent-hover, #3d8b40);transform:scale(1.05)}.voicing-play-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.voicing-play-btn.playing{animation:pulse .6s ease-in-out}.play-icon{font-size:.9em;line-height:1}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}.voicing-controls.compact .voicing-play-btn{width:28px;height:24px}.voicing-controls.compact .play-icon{font-size:.8em}.voicing-footer{display:flex;align-items:center;gap:12px;margin-left:auto}.playback-mode-toggle{display:flex;gap:0;border-radius:4px;overflow:hidden;border:1px solid var(--bg-primary)}.playback-mode-toggle button{border-radius:0;border:none;padding:.25em .5em;background:var(--bg-primary);color:var(--text-secondary);font-size:.75em;cursor:pointer;transition:all .2s}.playback-mode-toggle button:hover:not(:disabled){background:var(--bg-secondary)}.playback-mode-toggle button.active{background:var(--accent);color:#fff}.playback-mode-toggle button:first-child{border-radius:3px 0 0 3px}.playback-mode-toggle button:last-child{border-radius:0 3px 3px 0}.voicing-count{font-size:.8em;color:var(--text-secondary);white-space:nowrap}@media(max-width:600px){.voicing-controls{flex-wrap:wrap;gap:8px}.voicing-dropdown{min-width:120px}.voicing-badge{display:none}}.controls{display:flex;flex-wrap:wrap;gap:8px;padding:10px;background:var(--bg-secondary);border-radius:8px;margin:10px 20px;align-items:center}.controls-section{display:flex;align-items:center;gap:8px;padding:0 8px}.controls-section:not(:last-child){border-right:1px solid var(--bg-tertiary);padding-right:12px}.control-group{display:flex;align-items:center;gap:4px}.control-group label{font-size:.8em;color:var(--text-secondary);font-weight:500;white-space:nowrap}.control-group select{min-width:100px;font-size:.9em}.primary-controls .control-group:first-child{margin-right:8px}.mode-toggle{display:flex;gap:0;border-radius:6px;overflow:hidden;border:1px solid var(--bg-tertiary)}.mode-toggle button{border-radius:0;border:none;padding:.4em 1em;background:var(--bg-primary);color:var(--text-secondary);font-size:.9em}.mode-toggle button.active{background:var(--accent);color:#fff}.mode-toggle button:first-child{border-radius:5px 0 0 5px}.mode-toggle button:last-child{border-radius:0 5px 5px 0}.toggle-group{display:flex;align-items:center;gap:8px}.toggle-group label{display:flex;align-items:center;gap:4px;cursor:pointer;font-size:.8em;color:var(--text-secondary)}.toggle-group input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}.fret-control{display:flex;align-items:center;gap:6px}.fret-slider{width:120px;height:5px;border-radius:3px;background:var(--bg-tertiary);outline:none;-webkit-appearance:none;appearance:none;cursor:pointer}.fret-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent);cursor:pointer;transition:all .2s}.fret-slider::-webkit-slider-thumb:hover{transform:scale(1.15);box-shadow:0 0 6px var(--accent)}.fret-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--accent);cursor:pointer;border:none;transition:all .2s}.fret-slider::-moz-range-thumb:hover{transform:scale(1.15);box-shadow:0 0 6px var(--accent)}.interval-filter-dropdown{position:relative}.filter-dropdown-button{padding:.4em 1em;background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--bg-tertiary);border-radius:6px;cursor:pointer;font-size:.85em;white-space:nowrap;transition:all .2s}.filter-dropdown-button:hover{background:var(--bg-tertiary);border-color:var(--accent)}.filter-dropdown-menu{position:absolute;top:100%;right:0;margin-top:4px;background:var(--bg-secondary);border:1px solid var(--bg-tertiary);border-radius:6px;padding:8px;min-width:250px;z-index:1000;box-shadow:0 4px 12px #0000004d}.filter-dropdown-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid var(--bg-tertiary)}.filter-dropdown-header span{font-size:.85em;color:var(--text-secondary);font-weight:500}.filter-actions{display:flex;gap:4px}.filter-actions button{padding:2px 8px;background:var(--bg-tertiary);color:var(--text-secondary);border:none;border-radius:4px;font-size:.75em;cursor:pointer;transition:all .2s}.filter-actions button:hover{background:var(--accent);color:#fff}.filter-dropdown-items{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.filter-item{display:flex;align-items:center;gap:4px;padding:4px 6px;cursor:pointer;border-radius:4px;transition:background .2s;font-size:.85em}.filter-item:hover{background:var(--bg-tertiary)}.filter-item input[type=checkbox]{width:14px;height:14px;accent-color:var(--accent);cursor:pointer}.filter-item span{color:var(--text-primary);font-size:.9em}.filter-item .root-label{color:var(--accent);font-weight:700}@media(max-width:900px){.controls,.controls-section{gap:6px}.controls-section:not(:last-child){border-right:none;padding-right:0}.fret-slider{width:100px}}@media(max-width:600px){.controls{flex-direction:column;align-items:stretch}.controls-section{flex-wrap:wrap;padding:0;border-right:none}.control-group select{min-width:80px}.filter-dropdown-menu{right:auto;left:0}}.path-control-group{display:flex;flex-direction:column;gap:6px;align-items:flex-start}.path-direction-toggle{display:flex;gap:4px;margin-left:20px}.path-direction-toggle button{padding:4px 10px;background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--bg-tertiary);border-radius:4px;cursor:pointer;font-size:.85em;transition:all .2s}.path-direction-toggle button:hover{background:var(--bg-primary);border-color:var(--accent)}.path-direction-toggle button.active{background:var(--accent);color:#fff;border-color:var(--accent)}.path-range-control{display:flex;align-items:center;gap:8px;margin-left:20px;padding-left:8px;border-left:2px solid var(--accent)}.path-range-slider{width:100px;height:5px;border-radius:3px;background:var(--bg-tertiary);outline:none;-webkit-appearance:none;appearance:none;cursor:pointer}.path-range-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent);cursor:pointer;transition:all .2s}.path-range-slider::-webkit-slider-thumb:hover{transform:scale(1.15);box-shadow:0 0 6px var(--accent)}.path-range-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--accent);cursor:pointer;border:none;transition:all .2s}.path-range-slider::-moz-range-thumb:hover{transform:scale(1.15);box-shadow:0 0 6px var(--accent)}.position-control-group{display:flex;flex-direction:column;gap:6px;align-items:flex-start}.position-selector{margin-left:20px}.position-selector select{min-width:160px;padding:6px 10px;background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--bg-tertiary);border-radius:4px;cursor:pointer;font-size:.9em;transition:all .2s}.position-selector select:hover{border-color:var(--accent)}.position-selector select:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 2px #8a78be4d}.reference-panel{background:var(--bg-secondary);border-radius:8px;padding:0;margin:0 20px 15px;transition:all .2s ease;overflow:hidden}.reference-panel.collapsed,.reference-panel.expanded{padding:0}.reference-header-bar{display:flex;align-items:center;justify-content:space-between;padding:12px 15px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .2s}.reference-header-bar:hover{background:var(--bg-tertiary)}.reference-title{display:flex;align-items:baseline;gap:10px;flex:1}.collapse-icon{font-size:.8em;color:var(--text-secondary);transition:transform .2s}.reference-title h2{font-size:1.2em;color:var(--accent);margin:0}.reference-title .formula{font-size:.85em;color:var(--text-secondary);font-family:monospace}.reference-content{padding:0 15px 15px;animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.reference-description{color:var(--text-secondary);font-size:.85em;margin:0 0 12px;font-style:italic}.reference-notes{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.note-badge{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;font-weight:700;font-size:.85em}.note-badge.root{background:var(--note-root);color:#fff}.note-badge.scale{background:var(--note-scale);color:#000}.note-badge.chord{background:var(--note-chord);color:#000}.interval-info{display:flex;flex-wrap:wrap;gap:6px}.interval-badge{display:flex;align-items:center;gap:4px;padding:3px 8px;background:var(--bg-tertiary);border-radius:4px;font-size:.8em}.interval-badge .note{color:var(--text-primary);font-weight:700}.interval-badge .interval{color:var(--text-secondary)}@media(max-width:600px){.reference-title h2{font-size:1em}.reference-title .formula{font-size:.75em}.note-badge{width:32px;height:32px;font-size:.8em}}.practice-panel{background:var(--bg-secondary);border-radius:8px;padding:20px;margin:0 20px 20px}.practice-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.practice-header h2{font-size:1.3em;color:var(--text-primary);margin:0}.hint-text{color:var(--text-secondary);font-size:.9em;text-align:center;margin:0 0 15px;font-style:italic}.hint-toggle-container{display:flex;justify-content:center;gap:20px;margin-bottom:15px;flex-wrap:wrap}.hint-toggle{display:flex;align-items:center;gap:8px;color:var(--text-secondary);font-size:.9em;cursor:pointer;-webkit-user-select:none;user-select:none}.hint-toggle input[type=checkbox]{cursor:pointer;width:16px;height:16px}.strategy-hint{background:#4ecca31a;border-left:3px solid var(--note-scale);padding:12px 15px;margin:0 auto 20px;border-radius:6px;color:var(--text-primary);font-size:.95em;line-height:1.5;max-width:600px;text-align:left}.learn-more-panel{background:#8a78be1a;border-left:3px solid #8a78be;padding:15px 20px;margin:0 auto 20px;border-radius:6px;color:var(--text-primary);max-width:600px;text-align:left}.learn-more-panel h4{margin:0 0 15px;color:#a99cd4;font-size:1.1em}.theory-section{margin-bottom:12px}.theory-section:last-child{margin-bottom:0}.theory-section strong{color:#a99cd4;font-size:.9em;display:block;margin-bottom:4px}.theory-section p{margin:0;font-size:.9em;line-height:1.5;color:var(--text-secondary)}.theory-section ul{margin:4px 0 0;padding-left:20px;font-size:.9em;line-height:1.5;color:var(--text-secondary)}.theory-section li{margin-bottom:2px}.score{display:flex;gap:15px;font-size:.95em}.score span{color:var(--text-secondary)}.score .correct{color:var(--note-scale)}.score .incorrect{color:var(--note-root)}.quiz-content{text-align:center;padding:20px}.question{font-size:1.2em;color:var(--text-primary);margin-bottom:25px}.question .highlight{color:var(--accent);font-weight:700}.answer-options{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-bottom:20px}.answer-btn{min-width:60px;padding:12px 20px;font-size:1em;font-weight:700;border-radius:8px;transition:all .2s ease}.answer-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.answer-btn.correct{background:var(--note-scale)!important;color:#000!important;border-color:var(--note-scale)!important}.answer-btn.incorrect{background:var(--note-root)!important;color:#fff!important;border-color:var(--note-root)!important}.answer-btn:disabled{cursor:not-allowed;opacity:.7}.feedback{font-size:1.1em;margin-bottom:15px;padding:10px;border-radius:6px}.feedback.correct{color:var(--note-scale);background:#4ecca31a}.feedback.incorrect{color:var(--note-root);background:#e945601a}.next-btn{padding:12px 30px;font-size:1em;background:var(--accent);border-color:var(--accent)}.next-btn:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.quiz-type-toggle{display:flex;justify-content:center;gap:10px;margin-bottom:20px;flex-wrap:wrap}.quiz-type-toggle button{padding:8px 16px;font-size:.9em;flex:1;min-width:120px}.quiz-type-toggle button.active{background:var(--accent);border-color:var(--accent);color:#fff}@media(max-width:768px){.quiz-type-toggle button{flex:1 1 45%}}.string-names{display:flex;justify-content:center;gap:10px;margin-bottom:10px;color:var(--text-secondary);font-size:.85em}.string-names span{width:30px;text-align:center}.ear-training-panel{background:var(--bg-secondary);border-radius:8px;padding:20px;margin:0 20px 20px}.ear-training-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.ear-training-header h2{font-size:1.3em;color:var(--text-primary);margin:0}.ear-training-panel .hint-text{color:var(--text-secondary);font-size:.9em;text-align:center;margin:0 0 15px;font-style:italic}.ear-training-panel .score{display:flex;gap:15px;font-size:.95em}.ear-training-panel .score span{color:var(--text-secondary)}.ear-training-panel .score .correct{color:var(--note-scale)}.ear-training-panel .score .incorrect{color:var(--note-root)}.exercise-type-toggle{display:flex;justify-content:center;gap:10px;margin-bottom:20px;flex-wrap:wrap}.exercise-type-toggle button{padding:8px 16px;font-size:.9em;flex:1;min-width:100px;max-width:150px}.exercise-type-toggle button.active{background:var(--accent);border-color:var(--accent);color:#fff}.settings-row{display:flex;justify-content:center;align-items:center;gap:20px;margin-bottom:20px;flex-wrap:wrap}.difficulty-selector,.playback-mode-selector{display:flex;align-items:center;gap:8px}.difficulty-selector label,.playback-mode-selector label{color:var(--text-secondary);font-size:.9em}.difficulty-selector select,.playback-mode-selector select{padding:6px 12px;font-size:.9em;border-radius:6px;background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-color);cursor:pointer}.ear-training-panel .hint-toggle{display:flex;align-items:center;gap:8px;color:var(--text-secondary);font-size:.9em;cursor:pointer;-webkit-user-select:none;user-select:none}.ear-training-panel .hint-toggle input[type=checkbox]{cursor:pointer;width:16px;height:16px}.ear-training-panel .quiz-content{text-align:center;padding:20px}.play-section{margin-bottom:25px}.play-btn{padding:16px 40px;font-size:1.2em;font-weight:700;background:var(--accent);border-color:var(--accent);border-radius:12px;transition:all .2s ease}.play-btn:hover{background:var(--accent-hover);border-color:var(--accent-hover);transform:translateY(-2px);box-shadow:0 6px 16px #0000004d}.play-instruction{color:var(--text-secondary);font-size:.9em;margin-top:12px}.ear-training-panel .question{font-size:1.2em;color:var(--text-primary);margin-bottom:20px}.hint-panel{background:#4ecca314;border-left:3px solid var(--note-scale);padding:15px 20px;margin:0 auto 20px;border-radius:6px;text-align:left;max-width:500px}.hint-item{color:var(--text-primary);font-size:.9em;margin-bottom:8px;line-height:1.4}.hint-item:last-child{margin-bottom:0}.hint-item strong{color:var(--accent)}.hint-artist{color:var(--text-secondary);font-size:.85em}.ear-training-panel .answer-options{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-bottom:20px}.ear-training-panel .answer-btn{min-width:80px;padding:12px 20px;font-size:1em;font-weight:700;border-radius:8px;transition:all .2s ease}.ear-training-panel .answer-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.ear-training-panel .answer-btn.correct{background:var(--note-scale)!important;color:#000!important;border-color:var(--note-scale)!important}.ear-training-panel .answer-btn.incorrect{background:var(--note-root)!important;color:#fff!important;border-color:var(--note-root)!important}.ear-training-panel .answer-btn:disabled{cursor:not-allowed;opacity:.7}.ear-training-panel .feedback{font-size:1.1em;margin-bottom:15px;padding:10px;border-radius:6px}.ear-training-panel .feedback.correct{color:var(--note-scale);background:#4ecca31a}.ear-training-panel .feedback.incorrect{color:var(--note-root);background:#e945601a}.answer-detail{background:#8a78be1a;border-radius:8px;padding:15px 20px;margin:0 auto 20px;max-width:400px;text-align:left}.answer-detail strong{color:var(--accent);font-size:1.1em;display:block;margin-bottom:8px}.answer-detail p{color:var(--text-secondary);font-size:.9em;margin:0 0 8px;line-height:1.5}.answer-detail p:last-child{margin-bottom:0}.song-ref{color:var(--text-primary)!important;font-style:italic;background:#ffffff0d;padding:8px 12px;border-radius:4px;margin-top:10px!important}.ear-training-panel .next-btn{padding:12px 30px;font-size:1em;background:var(--accent);border-color:var(--accent)}.ear-training-panel .next-btn:hover{background:var(--accent-hover);border-color:var(--accent-hover)}@media(max-width:768px){.exercise-type-toggle button{flex:1 1 45%;max-width:none}.settings-row{flex-direction:column;gap:12px}.hint-panel,.answer-detail{max-width:100%}}.jam-settings{margin:20px;background:var(--bg-secondary);border-radius:8px;overflow:hidden}.jam-settings-toggle{width:100%;display:flex;align-items:center;gap:10px;padding:12px 16px;background:transparent;border:none;color:var(--text-primary);font-size:.95em;cursor:pointer;text-align:left}.jam-settings-toggle:hover{background:var(--bg-tertiary)}.jam-settings-toggle .toggle-icon{font-size:.8em;color:var(--text-secondary)}.settings-badge{background:var(--accent);color:#fff;padding:2px 8px;border-radius:10px;font-size:.75em;margin-left:auto}.jam-settings-content{padding:0 16px 16px}.settings-group{margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--bg-tertiary)}.settings-group:last-of-type{margin-bottom:16px}.group-title{font-size:.85em;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}.setting-row{display:flex;align-items:center;gap:12px;margin-bottom:10px}.setting-row:last-child{margin-bottom:0}.setting-row>label{min-width:100px;font-size:.9em;color:var(--text-secondary)}.setting-row select{padding:6px 10px;background:var(--bg-primary);border:1px solid var(--bg-tertiary);border-radius:4px;color:var(--text-primary);font-size:.85em}.setting-row select:focus{outline:none;border-color:var(--accent)}.time-sig-presets{display:flex;gap:6px;flex-wrap:wrap}.preset-btn{padding:6px 12px;background:var(--bg-primary);border:1px solid var(--bg-tertiary);border-radius:4px;color:var(--text-secondary);font-size:.85em;cursor:pointer}.preset-btn:hover{border-color:var(--accent);color:var(--text-primary)}.preset-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.accent-select{flex:1;max-width:220px}.accent-toggles{display:flex;gap:6px}.accent-btn{width:32px;height:32px;padding:0;background:var(--bg-primary);border:1px solid var(--bg-tertiary);border-radius:4px;color:var(--text-secondary);font-size:.85em;cursor:pointer}.accent-btn:hover{border-color:var(--accent)}.accent-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.swing-slider,.duration-slider{flex:1;max-width:150px;height:5px;accent-color:var(--accent)}.inline-controls{flex-wrap:wrap}.inline-controls select{min-width:80px}.volume-control{display:flex;align-items:center;gap:6px}.volume-prefix{font-size:.8em;color:var(--text-secondary)}.volume-control input[type=range]{width:70px;height:5px;accent-color:var(--accent)}.volume-label{font-size:.8em;color:var(--text-secondary);min-width:35px}.toggle-label{display:flex;align-items:center;gap:8px;color:var(--text-secondary);cursor:pointer;font-size:.9em}.toggle-label:hover{color:var(--text-primary)}.toggle-label.active{color:var(--accent)}.toggle-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent)}.chord-audio-options{margin-left:24px;padding-left:12px;border-left:2px solid var(--bg-tertiary)}.reset-btn{width:100%;padding:10px;background:var(--bg-primary);border:1px solid var(--bg-tertiary);border-radius:6px;color:var(--text-secondary);font-size:.85em;cursor:pointer}.reset-btn:hover{border-color:var(--accent);color:var(--text-primary)}@media(max-width:600px){.setting-row{flex-direction:column;align-items:flex-start;gap:8px}.setting-row>label{min-width:auto}.inline-controls{flex-direction:row;flex-wrap:wrap}.time-sig-presets{width:100%}}.preset-modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.preset-modal{background:var(--bg-secondary);border-radius:12px;width:90%;max-width:700px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 10px 40px #00000080;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.preset-modal-header{padding:20px 24px;border-bottom:1px solid var(--bg-tertiary);display:flex;justify-content:space-between;align-items:center}.preset-modal-header h3{margin:0;color:var(--text-primary);font-size:1.3em}.close-btn{background:transparent;border:none;color:var(--text-secondary);font-size:1.8em;cursor:pointer;padding:0;width:32px;height:32px;line-height:1;transition:color .2s ease}.close-btn:hover{color:var(--accent)}.preset-modal-content{padding:24px;overflow-y:auto;flex:1}.save-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{color:var(--text-primary);font-weight:500;font-size:.95em}.form-group input,.form-group textarea{padding:10px 12px;background:var(--bg-primary);border:1px solid var(--bg-tertiary);border-radius:6px;color:var(--text-primary);font-size:1em;font-family:inherit;transition:border-color .2s ease}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--accent)}.form-group textarea{resize:vertical;min-height:60px}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:8px}.cancel-btn,.save-preset-btn{padding:10px 24px;border-radius:6px;font-size:1em;font-weight:500;cursor:pointer;transition:all .2s ease}.cancel-btn{background:var(--bg-tertiary);border:1px solid var(--bg-tertiary);color:var(--text-secondary)}.cancel-btn:hover{background:var(--bg-primary)}.save-preset-btn{background:var(--accent);border:1px solid var(--accent);color:#fff}.save-preset-btn:hover{background:var(--accent-hover)}.load-content{display:flex;flex-direction:column;gap:20px}.import-section{display:flex;flex-direction:column;gap:10px}.import-btn{display:inline-block;padding:10px 20px;background:var(--bg-tertiary);border:1px solid var(--bg-tertiary);color:var(--text-primary);border-radius:6px;font-size:.95em;font-weight:500;cursor:pointer;transition:all .2s ease;text-align:center;width:fit-content}.import-btn:hover{background:var(--bg-primary);border-color:var(--accent);color:var(--accent)}.import-error{color:var(--accent);font-size:.9em;margin:0;padding:8px 12px;background:#e945601a;border-radius:4px}.empty-presets{text-align:center;padding:40px 20px;color:var(--text-secondary)}.empty-presets p{margin:8px 0}.empty-presets p:first-child{font-size:1.1em;font-weight:500;color:var(--text-primary)}.presets-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.preset-card{background:var(--bg-primary);border:2px solid var(--bg-tertiary);border-radius:8px;padding:16px;display:flex;flex-direction:column;gap:12px;transition:all .2s ease}.preset-card:hover{border-color:var(--accent);box-shadow:0 4px 12px #e9456033}.preset-header{display:flex;flex-direction:column;gap:4px}.preset-name{margin:0;color:var(--text-primary);font-size:1.1em;font-weight:600}.preset-date{color:var(--text-secondary);font-size:.8em}.preset-description{margin:0;color:var(--text-secondary);font-size:.9em;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.preset-summary{display:flex;gap:12px;flex-wrap:wrap}.summary-item{background:var(--bg-secondary);color:var(--text-secondary);padding:4px 10px;border-radius:4px;font-size:.85em;font-weight:500}.preset-actions{display:flex;gap:8px;margin-top:4px}.preset-btn{flex:1;padding:8px 12px;border-radius:4px;font-size:.9em;font-weight:500;cursor:pointer;transition:all .2s ease}.load-btn{background:var(--accent);border:1px solid var(--accent);color:#fff}.load-btn:hover{background:var(--accent-hover)}.export-btn{background:var(--bg-tertiary);border:1px solid var(--bg-tertiary);color:var(--text-primary)}.export-btn:hover{background:var(--note-scale);border-color:var(--note-scale);color:#fff}.preset-card .delete-btn{background:transparent;border:1px solid var(--bg-tertiary);color:var(--text-secondary)}.preset-card .delete-btn:hover{background:var(--accent);border-color:var(--accent);color:#fff}@media(max-width:768px){.preset-modal{width:95%;max-height:90vh}.presets-grid{grid-template-columns:1fr}.form-actions{flex-direction:column-reverse}.cancel-btn,.save-preset-btn{width:100%}}.jam-container{padding:0 20px}.sequence-builder{background:var(--bg-secondary);border-radius:8px;padding:20px;margin-bottom:20px}.sequence-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;gap:15px}.sequence-header h3{margin:0;color:var(--text-primary);flex:1}.sequence-actions{display:flex;gap:8px;align-items:center}.preset-action-btn{padding:8px 14px;border-radius:4px;font-size:.9em;font-weight:500;cursor:pointer;transition:all .2s ease;border:1px solid}.icon-btn{padding:8px 12px;font-size:1.3em;min-width:40px;display:flex;align-items:center;justify-content:center}.load-preset-btn{background:var(--bg-tertiary);border-color:var(--bg-tertiary);color:var(--text-primary)}.load-preset-btn:hover{background:var(--note-scale);border-color:var(--note-scale);color:#fff}.save-preset-btn{background:var(--bg-tertiary);border-color:var(--bg-tertiary);color:var(--text-primary)}.save-preset-btn:hover:not(:disabled){background:var(--note-chord);border-color:var(--note-chord);color:#fff}.save-preset-btn:disabled{opacity:.5;cursor:not-allowed}.add-step-btn{background:var(--accent);border-color:var(--accent);color:#fff;padding:8px 16px}.add-step-btn:hover{background:var(--accent-hover)}.sequence-steps{display:flex;flex-wrap:wrap;gap:15px}.empty-sequence{color:var(--text-secondary);font-style:italic;padding:20px;text-align:center;width:100%}.sequence-step{background:var(--bg-primary);border:2px solid var(--bg-tertiary);border-radius:8px;padding:12px;min-width:140px;transition:all .2s ease}.sequence-step.active{border-color:var(--accent);box-shadow:0 0 15px #e945604d}.sequence-step.has-overrides{border-color:var(--note-chord)}.sequence-step.has-overrides .step-number{background:var(--note-chord);color:#fff}.step-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.step-number{background:var(--bg-tertiary);color:var(--text-secondary);width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8em;font-weight:700}.sequence-step.active .step-number{background:var(--accent);color:#fff}.step-actions{display:flex;gap:6px;align-items:center}.settings-btn{background:transparent;border:none;color:var(--text-secondary);font-size:1em;padding:0;width:24px;height:24px;cursor:pointer;opacity:.6;transition:all .2s ease}.settings-btn:hover{opacity:1;color:var(--note-chord);transform:rotate(90deg)}.delete-btn{background:transparent;border:none;color:var(--text-secondary);font-size:1.2em;padding:0;width:24px;height:24px;cursor:pointer;opacity:.6}.delete-btn:hover{opacity:1;color:var(--accent)}.step-content{display:flex;flex-direction:column;gap:8px}.step-content select{width:100%;padding:6px 8px;font-size:.85em}.root-select{font-size:1.1em!important;font-weight:700;text-align:center}.type-toggle{display:flex;gap:0;border-radius:4px;overflow:hidden}.type-toggle button{flex:1;padding:4px 8px;font-size:.75em;border-radius:0;border:1px solid var(--bg-tertiary);background:var(--bg-secondary)}.type-toggle button.active{background:var(--accent);border-color:var(--accent);color:#fff}.beats-control{display:flex;align-items:center;gap:8px;font-size:.85em}.beats-control label{color:var(--text-secondary)}.beats-control select{width:50px}.transport-controls{background:var(--bg-secondary);border-radius:8px;padding:12px 15px;margin-bottom:15px;display:flex;flex-wrap:wrap;align-items:center;gap:15px}.transport-buttons{display:flex;gap:8px}.play-btn,.stop-btn{width:40px;height:40px;border-radius:50%;font-size:1.1em;display:flex;align-items:center;justify-content:center;border:none;cursor:pointer;transition:all .2s ease}.play-btn{background:var(--accent);border-color:var(--accent);color:#fff}.play-btn:hover{background:var(--accent-hover)}.play-btn.playing{background:var(--note-scale);border-color:var(--note-scale)}.stop-btn{background:var(--bg-tertiary)}.tempo-control{display:flex;align-items:center;gap:8px}.tempo-control label{color:var(--text-secondary);font-weight:500;font-size:.85em}.bpm-input{width:50px;padding:5px 6px;background:var(--bg-primary);border:1px solid var(--bg-tertiary);border-radius:4px;color:var(--text-primary);text-align:center;font-size:.9em}.bpm-slider{width:80px;height:5px;accent-color:var(--accent);cursor:pointer}.time-signature-badge{background:var(--bg-primary);color:var(--text-primary);padding:3px 10px;border-radius:4px;font-weight:600;font-size:.8em;border:1px solid var(--bg-tertiary)}.beat-indicator{display:flex;gap:6px;padding:6px 10px;background:var(--bg-primary);border-radius:6px}.beat-dot{width:12px;height:12px;border-radius:50%;background:var(--bg-tertiary);transition:all .1s ease;position:relative}.beat-dot.accented{width:14px;height:14px;border:2px solid var(--text-secondary)}.beat-dot.past{background:var(--note-scale);opacity:.5}.beat-dot.current{background:var(--accent);box-shadow:0 0 10px var(--accent);opacity:1}.beat-dot.accented.current{box-shadow:0 0 12px var(--accent)}.transport-toggles{display:flex;gap:10px}.transport-controls .toggle-label{display:flex;align-items:center;gap:5px;color:var(--text-secondary);cursor:pointer;padding:4px 10px;border-radius:4px;background:var(--bg-primary);transition:all .2s ease;font-size:.85em}.transport-controls .toggle-label.active{color:var(--text-primary);background:var(--bg-tertiary)}.transport-controls .toggle-label input{accent-color:var(--accent);width:16px;height:16px;cursor:pointer}.current-step-info{display:flex;align-items:center;gap:6px;padding:4px 12px;background:var(--bg-primary);border-radius:4px;font-size:.85em;margin-left:auto}.step-label{color:var(--text-secondary);font-weight:500}.step-name{color:var(--accent);font-weight:600}.step-beat{color:var(--text-secondary)}.step-advanced{margin-top:12px;padding-top:12px;border-top:1px solid var(--bg-tertiary);animation:slideDown .2s ease}.step-advanced h5{margin:0 0 6px;color:var(--text-primary);font-size:.85em;font-weight:600}.override-hint{margin:0 0 12px;color:var(--text-secondary);font-size:.75em;font-style:italic}.override-section{margin-bottom:12px}.override-checkbox{display:flex;align-items:center;gap:6px;color:var(--text-secondary);cursor:pointer;font-size:.85em;margin-bottom:6px}.override-checkbox input[type=checkbox]{accent-color:var(--note-chord);cursor:pointer}.override-checkbox input[type=checkbox]:checked+span{color:var(--text-primary);font-weight:500}.override-controls{margin-left:22px;display:flex;flex-direction:column;gap:6px}.override-controls select{width:100%;padding:4px 6px;font-size:.8em;background:var(--bg-secondary);border:1px solid var(--bg-tertiary);color:var(--text-primary);border-radius:4px}.play-chord-btn{background:#4caf50;border:none;color:#fff;font-size:.8em;padding:4px 8px;width:auto;height:auto;border-radius:4px;cursor:pointer;opacity:.85;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.play-chord-btn:hover{background:#45a049;opacity:1;transform:scale(1.05)}.play-chord-btn:active{transform:scale(.95)}.chord-audio-controls{display:flex;flex-direction:column;gap:12px}.chord-audio-controls .toggle-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-weight:500;transition:color .2s ease}.chord-audio-controls .toggle-label.active{color:var(--accent)}.chord-audio-controls .toggle-label input[type=checkbox]{cursor:pointer}.volume-slider,.duration-slider{width:100%;margin-top:4px;cursor:pointer}.volume-slider:disabled,.duration-slider:disabled{opacity:.5;cursor:not-allowed}.waveform-select{padding:6px;border-radius:4px;border:1px solid var(--bg-tertiary);background:var(--bg-secondary);color:var(--text-primary);cursor:pointer}.waveform-select:disabled{opacity:.5;cursor:not-allowed}.inline-checkbox{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-size:.9em}.inline-checkbox input[type=checkbox],.inline-checkbox span{cursor:pointer}.step-voicing-controls{display:flex;flex-direction:column;gap:6px;margin-top:4px;padding-top:8px;border-top:1px solid var(--bg-tertiary)}.voicing-mode-toggle{display:flex;gap:0;border-radius:4px;overflow:hidden}.voicing-mode-toggle button{flex:1;padding:3px 8px;font-size:.7em;border-radius:0;border:1px solid var(--bg-tertiary);background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;transition:all .2s}.voicing-mode-toggle button:hover:not(:disabled){background:var(--bg-tertiary)}.voicing-mode-toggle button.active{background:var(--note-chord);border-color:var(--note-chord);color:#fff}.voicing-mode-toggle button:disabled{opacity:.5;cursor:not-allowed}.voicing-nav{display:flex;align-items:center;justify-content:center;gap:4px}.voicing-nav button{width:22px;height:22px;padding:0;font-size:.7em;background:var(--bg-tertiary);border:none;border-radius:3px;color:var(--text-secondary);cursor:pointer;transition:all .2s}.voicing-nav button:hover:not(:disabled){background:var(--note-chord);color:#fff}.voicing-nav button:disabled{opacity:.3;cursor:not-allowed}.voicing-index{font-size:.7em;color:var(--text-secondary);min-width:30px;text-align:center}.app-footer{margin-top:40px;padding:20px;border-top:1px solid var(--bg-tertiary);background:var(--bg-secondary);text-align:center}.footer-content{max-width:1400px;margin:0 auto}.app-footer p{margin:5px 0;color:var(--text-secondary);font-size:.9em}.footer-links{margin-top:8px}.footer-links a{color:var(--accent);text-decoration:none;transition:opacity .2s}.footer-links a:hover{opacity:.8;text-decoration:underline}.fretboard-settings{display:flex;align-items:center;justify-content:center;gap:20px;padding:10px 20px;margin:0 20px 10px;background:var(--bg-secondary);border-radius:8px;flex-wrap:wrap}.setting-group{display:flex;align-items:center;gap:8px}.setting-group>label{font-size:.85em;color:var(--text-secondary);white-space:nowrap}.setting-group select{padding:6px 10px;background:var(--bg-primary);border:1px solid var(--bg-tertiary);border-radius:4px;color:var(--text-primary);font-size:.85em}.setting-group select:focus{outline:none;border-color:var(--accent)}.fret-slider{width:80px;height:5px;accent-color:var(--accent);cursor:pointer}.setting-group.toggles{gap:12px}.toggle-item{display:flex;align-items:center;gap:6px;font-size:.85em;color:var(--text-secondary);cursor:pointer}.toggle-item:hover{color:var(--text-primary)}.toggle-item input[type=checkbox]{width:14px;height:14px;accent-color:var(--accent);cursor:pointer}.filter-group{position:relative}.filter-btn{padding:6px 12px;background:var(--bg-primary);border:1px solid var(--bg-tertiary);border-radius:4px;color:var(--text-secondary);font-size:.85em;cursor:pointer}.filter-btn:hover{border-color:var(--accent);color:var(--text-primary)}.filter-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;background:var(--bg-secondary);border:1px solid var(--bg-tertiary);border-radius:8px;padding:12px;z-index:100;box-shadow:0 4px 20px #0000004d}.filter-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--bg-tertiary)}.filter-header span{font-size:.85em;color:var(--text-secondary)}.filter-actions{display:flex;gap:6px}.filter-actions button{padding:3px 8px;font-size:.75em;background:var(--bg-primary);border:1px solid var(--bg-tertiary);border-radius:3px;color:var(--text-secondary);cursor:pointer}.filter-actions button:hover{border-color:var(--accent);color:var(--text-primary)}.filter-items{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.filter-item{display:flex;align-items:center;gap:4px;font-size:.8em;color:var(--text-secondary);cursor:pointer;padding:4px;border-radius:3px}.filter-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.filter-item input[type=checkbox]{width:12px;height:12px;accent-color:var(--accent)}.filter-item .root-label{color:var(--accent);font-weight:600}@media(max-width:600px){.fretboard-settings{gap:12px;padding:10px 15px}.setting-group{flex-wrap:wrap}.fret-slider{width:60px}.filter-dropdown{right:-20px;min-width:180px}.filter-items{grid-template-columns:repeat(3,1fr)}}.app{min-height:100vh;padding-bottom:40px}.app-header{padding:20px;text-align:center;border-bottom:1px solid var(--bg-tertiary);margin-bottom:10px}.app-header h1{font-size:1.8em;color:var(--text-primary);margin:0 0 5px}.app-header h1 span{color:var(--accent)}.app-header p{color:var(--text-secondary);font-size:.95em;margin:0}.nav-tabs{display:flex;justify-content:center;gap:10px;padding:15px 20px;background:var(--bg-secondary);margin:0 20px 20px;border-radius:8px}.nav-tabs button{padding:10px 25px;font-size:1em;background:transparent;border:1px solid var(--bg-tertiary)}.nav-tabs button.active{background:var(--accent);border-color:var(--accent);color:#fff}.main-content{max-width:1400px;margin:0 auto}
