*,*:before,*:after{box-sizing:border-box}html{font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh}:root{--bg-main: #fffef5;--bg-card: #ffffff;--red-bold: #e63946;--blue-bold: #1d4ed8;--yellow-bold: #facc15;--black: #0f0f0f;--text-primary: #0f0f0f;--text-muted: #525252;--fret-color: #d4d4d4;--string-color: #404040}*{box-sizing:border-box;margin:0;padding:0}body{font-family:SF Pro Display,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-main);color:var(--text-primary);min-height:100vh;line-height:1.5}.app{min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:2rem 1rem}header{text-align:center;margin-bottom:3rem}header h1{font-family:Bungee Inline,sans-serif;font-size:5rem;font-weight:400;letter-spacing:.05em;color:var(--black);margin-bottom:.25rem}.tagline{font-size:.875rem;letter-spacing:.3em;text-transform:uppercase;color:var(--text-muted)}main{width:100%;max-width:600px;display:flex;flex-direction:column;align-items:center;gap:2rem}main.main-wide{max-width:900px}.exercise-card{width:100%;background:var(--bg-card);border-radius:1rem;padding:2rem;border:3px solid var(--black);box-shadow:6px 6px 0 var(--black)}.exercise-meta{display:flex;gap:.75rem;margin-bottom:1.5rem}.key{display:inline-flex;align-items:center;justify-content:center;min-width:3rem;height:3rem;padding:0 1rem;font-size:1.5rem;font-weight:800;background:var(--yellow-bold);border:3px solid var(--black);border-radius:.5rem;color:var(--black)}.scale{display:inline-flex;align-items:center;padding:0 1rem;font-size:.875rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;background:var(--bg-main);border-radius:.5rem;border:2px solid var(--black);color:var(--black)}.task{font-size:1.25rem;line-height:1.7;color:var(--text-primary);font-weight:400;white-space:pre-line}.fretboard-pair{display:flex;flex-direction:column;gap:1.5rem;margin-top:1.5rem;align-items:center}.fretboard-pair .fretboard-container{margin-top:0;width:100%;max-width:400px}.fretboard-pair .fretboard{max-width:100%}.fretboard-container{margin-top:2rem;text-align:center}.fretboard{width:100%;max-width:400px;height:auto}.fretboard-nut{fill:var(--black)}.fretboard-fret{stroke:var(--fret-color);stroke-width:2}.fretboard-string{stroke:var(--string-color)}.fretboard-string-label{fill:var(--text-muted);font-size:12px;font-weight:600;text-anchor:middle}.fretboard-fret-number{fill:var(--text-muted);font-size:11px;text-anchor:middle}.fretboard-position{fill:var(--text-primary);font-size:13px;font-weight:700}.fretboard-note{fill:var(--blue-bold)}.fretboard-root{fill:var(--red-bold)}.fretboard-note-ascend{fill:var(--blue-bold)}.fretboard-note-descend{fill:#10b981}.fretboard-note-both{fill:var(--yellow-bold);stroke:var(--black);stroke-width:2}.fretboard-root-ascend{fill:var(--blue-bold);stroke:var(--red-bold);stroke-width:3}.fretboard-root-descend{fill:#10b981;stroke:var(--red-bold);stroke-width:3}.fretboard-root-both{fill:var(--yellow-bold);stroke:var(--black);stroke-width:2}.fretboard-root-label{fill:#fff;font-size:11px;font-weight:700;text-anchor:middle}.fretboard-interval-label{fill:#fff;font-size:9px;font-weight:800;text-anchor:middle;pointer-events:none}.note-display-select{padding:.4rem .6rem;font-size:.75rem;font-weight:700;background:var(--bg-card);border:2px solid var(--black);border-radius:.35rem;color:var(--text-primary);cursor:pointer}.shape-label{margin-top:.75rem;font-size:.75rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted)}.shape-direction{color:var(--text-primary);font-weight:700}.fretboard-legend{display:flex;gap:1rem;justify-content:center;margin-top:.75rem;flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:.375rem;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.legend-toggle{background:none;border:none;cursor:pointer;padding:.25rem .5rem;border-radius:.25rem;transition:all .15s ease}.legend-toggle:hover{background:var(--bg-main)}.legend-toggle.hidden{opacity:.4}.legend-toggle.hidden .legend-dot{background:var(--text-muted)!important;border-color:var(--text-muted)!important}.legend-dot{width:12px;height:12px;border-radius:50%}.legend-dot.ascend{background:var(--blue-bold)}.legend-dot.descend{background:#10b981}.legend-dot.both{background:var(--yellow-bold);border:2px solid var(--black)}.exercise-label{display:inline-block;padding:.3rem .75rem;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;background:var(--black);color:#fff;border-radius:.25rem;margin-bottom:1rem}.exercise-hint{margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--fret-color);font-size:.8rem;line-height:1.6;color:var(--text-muted);font-style:italic}.blind-recall-box{display:flex;flex-direction:column;align-items:center;gap:1rem;margin:2rem 0;padding:2rem;border:2px dashed var(--fret-color);border-radius:.75rem}.blind-recall-text{font-size:1rem;font-weight:600;color:var(--text-muted)}.reveal-btn{padding:.6rem 1.5rem;font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;background:var(--bg-card);border:2px solid var(--black);border-radius:.375rem;color:var(--text-primary);cursor:pointer;transition:all .1s ease;box-shadow:3px 3px 0 var(--black)}.reveal-btn:hover{transform:translate(-1px,-1px);box-shadow:4px 4px 0 var(--black);background:var(--yellow-bold)}.reveal-btn:active{transform:translate(1px,1px);box-shadow:2px 2px 0 var(--black)}.fretboard-hint{margin-top:1.25rem;font-size:.75rem;color:var(--text-muted);text-align:center;font-style:italic}.category-toggles{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;width:100%}.category-toggle{padding:.5rem .875rem;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;background:var(--bg-card);border:2px solid var(--black);border-radius:.375rem;color:var(--text-muted);cursor:pointer;transition:all .1s ease}.category-toggle:hover{background:var(--bg-main)}.category-toggle.active{background:var(--black);color:#fff}.controls{display:flex;align-items:center}.next-btn{padding:1rem 2.5rem;font-size:1rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;background:var(--red-bold);border:3px solid var(--black);border-radius:.5rem;color:#fff;cursor:pointer;transition:all .1s ease;box-shadow:4px 4px 0 var(--black)}.next-btn:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--black)}.next-btn:active{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--black)}.next-btn:disabled{background:var(--fret-color);cursor:not-allowed;transform:none;box-shadow:4px 4px 0 var(--black)}.loading,.error{font-size:1.25rem;color:var(--text-muted)}@media(max-width:580px){.fretboard-pair{flex-direction:column;align-items:center}.fretboard-pair .fretboard-container{max-width:320px}}@media(max-width:480px){header h1{font-size:2.5rem;letter-spacing:.15em}.exercise-card{padding:1.5rem}.task{font-size:1.125rem}.key{min-width:2.5rem;height:2.5rem;font-size:1.25rem}}.game-mode-select{text-align:center;width:100%}.mode-title{font-size:1.25rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:1.5rem}.mode-buttons{display:flex;flex-direction:column;gap:1rem;width:100%}.mode-btn{padding:1.25rem 2rem;font-size:1.25rem;font-weight:800;text-transform:uppercase;letter-spacing:.15em;background:var(--bg-card);border:3px solid var(--black);border-radius:.75rem;color:var(--black);cursor:pointer;transition:all .1s ease;box-shadow:5px 5px 0 var(--black)}.mode-btn:hover{transform:translate(-2px,-2px);box-shadow:7px 7px 0 var(--black);background:var(--yellow-bold)}.mode-btn:active{transform:translate(2px,2px);box-shadow:3px 3px 0 var(--black)}.mode-btn-featured{background:var(--red-bold);color:#fff}.mode-btn-featured:hover{background:#c1121f}.mode-btn-resources{background:var(--blue-bold);color:#fff}.mode-btn-resources:hover{background:#1a3fa8}.sub-mode-toggle{display:flex;gap:.5rem}.sub-mode-btn{padding:.5rem 1rem;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;background:var(--bg-card);border:2px solid var(--black);border-radius:.375rem;color:var(--text-muted);cursor:pointer;transition:all .1s ease}.sub-mode-btn:hover{background:var(--bg-main)}.sub-mode-btn.active{background:var(--blue-bold);color:#fff;border-color:var(--blue-bold)}.mode-header{display:flex;align-items:center;justify-content:space-between;width:100%}.back-btn{padding:.5rem .875rem;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;background:var(--bg-card);border:2px solid var(--black);border-radius:.375rem;color:var(--text-muted);cursor:pointer;transition:all .1s ease}.back-btn:hover{background:var(--bg-main);color:var(--text-primary)}.current-mode{font-size:1.25rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--text-primary)}button:focus-visible{outline:3px solid var(--blue-bold);outline-offset:2px}.resources{width:100%}.resources-title{font-size:1.25rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);text-align:center;margin-bottom:.5rem}.resources-subtitle{font-size:.875rem;color:var(--text-muted);text-align:center;margin-bottom:1.5rem}.resources-sections{display:flex;flex-direction:column;gap:1rem}.resource-section{background:var(--bg-card);border:3px solid var(--black);border-radius:.75rem;overflow:hidden;box-shadow:4px 4px 0 var(--black)}.section-header{width:100%;display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;background:var(--bg-card);border:none;cursor:pointer;transition:all .15s ease;text-align:left}.section-header:hover{background:var(--bg-main)}.section-header.open{background:var(--yellow-bold);border-bottom:3px solid var(--black)}.section-header-content{display:flex;flex-direction:column;gap:.25rem}.section-title{font-size:1.125rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--black)}.section-description{font-size:.75rem;color:var(--text-muted)}.section-header.open .section-description{color:var(--text-primary)}.section-chevron{font-size:1.5rem;font-weight:700;color:var(--black);width:2rem;height:2rem;display:flex;align-items:center;justify-content:center}.section-content{padding:1.5rem;background:var(--bg-main)}.shapes-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.shape-chart{background:var(--bg-card);border:2px solid var(--black);border-radius:.5rem;padding:1rem;box-shadow:3px 3px 0 var(--black)}.shape-chart .fretboard-container{margin-top:0}.shape-chart .fretboard{max-width:100%}@media(max-width:640px){.shapes-grid{grid-template-columns:1fr}.section-header{padding:1rem 1.25rem}.section-title{font-size:1rem}.section-content{padding:1rem}.shape-chart{padding:.75rem}}.print-btn{width:100%;margin-top:1rem;padding:1.25rem 2rem;font-size:1.125rem;font-weight:800;text-transform:uppercase;letter-spacing:.15em;background:var(--red-bold);border:3px solid var(--black);border-radius:.75rem;color:#fff;cursor:pointer;transition:all .1s ease;box-shadow:4px 4px 0 var(--black)}.print-btn:hover{transform:translate(-3px,-3px);box-shadow:9px 9px 0 var(--black)}.print-btn:active{transform:translate(3px,3px);box-shadow:3px 3px 0 var(--black)}.print-btn:disabled{background:var(--fret-color);cursor:not-allowed;transform:none;box-shadow:6px 6px 0 var(--black)}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal{background:var(--bg-card);border:4px solid var(--black);border-radius:1rem;box-shadow:8px 8px 0 var(--black);padding:2rem;max-width:400px;width:100%}.modal-title{font-size:1.5rem;font-weight:900;text-transform:uppercase;letter-spacing:.1em;color:var(--black);margin-bottom:.5rem}.modal-subtitle{font-size:.875rem;color:var(--text-muted);margin-bottom:1.5rem}.modal-options{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.modal-checkbox-label{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background:var(--bg-main);border:2px solid var(--black);border-radius:.5rem;cursor:pointer;transition:all .1s ease}.modal-checkbox-label:hover{background:var(--yellow-bold)}.modal-checkbox{width:1.25rem;height:1.25rem;accent-color:var(--blue-bold);cursor:pointer}.modal-checkbox-title{font-size:1rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--black)}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end}.modal-cancel-btn{padding:.75rem 1.5rem;font-size:.875rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;background:var(--bg-card);border:2px solid var(--black);border-radius:.5rem;color:var(--text-muted);cursor:pointer;transition:all .1s ease}.modal-cancel-btn:hover{background:var(--bg-main);color:var(--text-primary)}.modal-print-btn{padding:.75rem 1.5rem;font-size:.875rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;background:var(--red-bold);border:2px solid var(--black);border-radius:.5rem;color:#fff;cursor:pointer;transition:all .1s ease;box-shadow:3px 3px 0 var(--black)}.modal-print-btn:hover{transform:translate(-1px,-1px);box-shadow:4px 4px 0 var(--black)}.modal-print-btn:active{transform:translate(1px,1px);box-shadow:2px 2px 0 var(--black)}.modal-print-btn:disabled{background:var(--fret-color);cursor:not-allowed;transform:none;box-shadow:3px 3px 0 var(--black)}.level-indicator{display:flex;align-items:center;gap:1rem;width:100%;padding:1rem 1.25rem;background:var(--bg-card);border:3px solid var(--black);border-radius:.75rem;box-shadow:5px 5px 0 var(--black);cursor:pointer;transition:all .1s ease;text-align:left;margin-bottom:1.5rem}.level-indicator:hover{transform:translate(-2px,-2px);box-shadow:7px 7px 0 var(--black);background:#fffde6}.level-indicator:active{transform:translate(2px,2px);box-shadow:3px 3px 0 var(--black)}.level-indicator-num{display:flex;align-items:center;justify-content:center;width:3rem;height:3rem;background:var(--yellow-bold);border:3px solid var(--black);border-radius:50%;font-size:1.5rem;font-weight:900;color:var(--black);flex-shrink:0}.level-indicator-info{display:flex;flex-direction:column;gap:.125rem;flex:1;min-width:0}.level-indicator-info strong{font-size:1.125rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--black)}.level-indicator-info span:last-child{font-size:.75rem;color:var(--text-muted)}.level-indicator-arrow{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--red-bold);white-space:nowrap}.level-context{width:100%;background:var(--bg-card);border:2px solid var(--black);border-radius:.75rem;padding:.875rem 1rem;cursor:pointer;transition:all .1s ease;box-shadow:3px 3px 0 var(--black)}.level-context:hover{transform:translate(-1px,-1px);box-shadow:4px 4px 0 var(--black);background:#fffde6}.level-context-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.625rem}.level-context-badge{display:flex;align-items:center;gap:.5rem}.level-context-num{display:flex;align-items:center;justify-content:center;width:1.625rem;height:1.625rem;background:var(--yellow-bold);border:2px solid var(--black);border-radius:50%;font-size:.8rem;font-weight:900;color:var(--black)}.level-context-name{font-size:.85rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--black)}.level-context-key-hint{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);background:var(--bg-main);padding:.25rem .5rem;border-radius:.25rem;border:1px solid var(--fret-color)}.level-context-pills{display:flex;flex-wrap:wrap;gap:.3rem}.level-pill{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem .5rem;font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;border-radius:.25rem;transition:all .15s ease;border:1.5px solid transparent}.level-pill.active{background:var(--black);color:#fff;border-color:var(--black)}.level-pill:not(.active){background:var(--bg-main);color:var(--text-muted);border-color:var(--fret-color);opacity:.55}.level-pill-lock{font-size:.5rem;font-weight:800;color:var(--text-muted);opacity:.7}.level-context-next{margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--fret-color);font-size:.7rem;color:var(--text-muted);line-height:1.5}.level-context-next-label{font-weight:700;color:var(--red-bold)}@media(max-width:480px){.level-context{padding:.75rem}.level-pill{font-size:.55rem;padding:.175rem .375rem}.level-context-key-hint{font-size:.6rem}}.floating-level-btn{position:fixed;bottom:1.5rem;right:1.5rem;display:flex;align-items:center;gap:.625rem;padding:.625rem 1rem .625rem .625rem;background:var(--black);border:3px solid var(--black);border-radius:2rem;color:#fff;cursor:pointer;transition:all .15s ease;box-shadow:4px 4px #0003;z-index:900}.floating-level-btn:hover{transform:translate(-2px,-2px);box-shadow:6px 6px #00000040;background:#1a1a1a}.floating-level-btn:active{transform:translate(1px,1px);box-shadow:2px 2px #00000026}.floating-level-num{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;background:var(--yellow-bold);border-radius:50%;font-size:1rem;font-weight:900;color:var(--black)}.floating-level-name{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em}.level-modal-overlay{position:fixed;inset:0;background:#0f0f0fa6;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fade-in .2s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.level-modal{background:var(--bg-card);border:4px solid var(--black);border-radius:1rem;box-shadow:8px 8px 0 var(--black);padding:2rem;max-width:440px;width:100%;animation:modal-pop .25s cubic-bezier(.34,1.56,.64,1);display:flex;flex-direction:column;gap:1.25rem}@keyframes modal-pop{0%{opacity:0;transform:scale(.92) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}.level-modal-header{text-align:center}.level-modal-title{font-size:1.5rem;font-weight:900;text-transform:uppercase;letter-spacing:.1em;color:var(--black);margin-bottom:.25rem}.level-modal-subtitle{font-size:.85rem;color:var(--text-muted);line-height:1.5}.quiz-progress-bar{width:100%;height:6px;background:var(--fret-color);border-radius:3px;overflow:hidden}.quiz-progress-fill{height:100%;background:var(--yellow-bold);border-radius:3px;transition:width .3s ease}.quiz-question-area{text-align:center}.quiz-question-num{display:inline-block;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:.75rem}.quiz-question{font-size:1.125rem;font-weight:600;line-height:1.6;color:var(--text-primary)}.quiz-answers{display:flex;gap:.75rem}.quiz-answer-btn{flex:1;padding:1rem;font-size:1rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;border:3px solid var(--black);border-radius:.5rem;cursor:pointer;transition:all .1s ease;box-shadow:4px 4px 0 var(--black)}.quiz-answer-btn:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--black)}.quiz-answer-btn:active{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--black)}.quiz-yes{background:var(--yellow-bold);color:var(--black)}.quiz-no{background:var(--bg-card);color:var(--text-muted)}.quiz-no:hover{background:var(--bg-main)}.quiz-skip-btn{background:none;border:none;font-size:.75rem;font-weight:600;color:var(--text-muted);cursor:pointer;text-align:center;padding:.5rem;text-decoration:underline;text-underline-offset:2px}.quiz-skip-btn:hover{color:var(--text-primary)}.quiz-unlock-preview{background:var(--bg-main);border:2px solid var(--fret-color);border-radius:.5rem;padding:.875rem 1rem;text-align:center}.quiz-unlock-label{display:block;font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.15em;color:var(--text-muted);margin-bottom:.375rem}.quiz-unlock-text{font-size:.85rem;font-weight:600;color:var(--text-primary);line-height:1.5}.quiz-feedback-card{background:var(--bg-main);border:2px solid var(--fret-color);border-radius:.75rem;padding:1.25rem}.quiz-feedback-text{font-size:.95rem;line-height:1.6;color:var(--text-primary);margin-bottom:.75rem}.quiz-feedback-tip{font-size:.8rem;color:var(--text-muted);line-height:1.6;font-style:italic}.quiz-done-btn{width:100%;padding:1rem;font-size:1rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;background:var(--black);border:3px solid var(--black);border-radius:.5rem;color:#fff;cursor:pointer;transition:all .1s ease;box-shadow:4px 4px #0003}.quiz-done-btn:hover{transform:translate(-2px,-2px);box-shadow:6px 6px #0000004d}.quiz-done-btn:active{transform:translate(1px,1px);box-shadow:2px 2px #00000026}.level-hub-current{display:flex;align-items:center;gap:1rem}.level-hub-badge{display:flex;align-items:center;justify-content:center;width:3.5rem;height:3.5rem;background:var(--yellow-bold);border:3px solid var(--black);border-radius:50%;flex-shrink:0}.level-hub-num{font-size:1.75rem;font-weight:900;color:var(--black)}.level-hub-name{font-size:1.25rem;font-weight:900;text-transform:uppercase;letter-spacing:.1em;color:var(--black)}.level-hub-tagline{font-size:.8rem;color:var(--text-muted);margin-top:.125rem}.level-hub-description{font-size:.875rem;color:var(--text-muted);line-height:1.6}.level-track{position:relative;display:flex;justify-content:space-between;padding:0 .5rem}.level-track-dot{position:relative;z-index:2;display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;background:var(--bg-card);border:3px solid var(--fret-color);border-radius:50%;transition:all .2s ease}.level-track-dot.filled{background:var(--yellow-bold);border-color:var(--black)}.level-track-dot.current{border-color:var(--black);box-shadow:0 0 0 3px var(--yellow-bold)}.level-track-label{font-size:.75rem;font-weight:800;color:var(--text-muted)}.level-track-dot.filled .level-track-label{color:var(--black)}.level-track-line{position:absolute;top:50%;left:1.5rem;right:1.5rem;height:4px;background:var(--fret-color);border-radius:2px;transform:translateY(-50%);z-index:1}.level-track-line-fill{height:100%;background:var(--yellow-bold);border-radius:2px;transition:width .3s ease}.level-hub-actions{display:flex;flex-direction:column;gap:.75rem}.level-hub-levelup-btn{width:100%;padding:1rem;font-size:1rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;background:var(--red-bold);border:3px solid var(--black);border-radius:.5rem;color:#fff;cursor:pointer;transition:all .1s ease;box-shadow:4px 4px 0 var(--black)}.level-hub-levelup-btn:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--black)}.level-hub-levelup-btn:active{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--black)}.level-hub-change-btn{width:100%;padding:.75rem;font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;background:var(--bg-card);border:2px solid var(--black);border-radius:.5rem;color:var(--text-muted);cursor:pointer;transition:all .1s ease}.level-hub-change-btn:hover{background:var(--bg-main);color:var(--text-primary)}.level-hub-max{text-align:center;padding:1rem;font-size:.9rem;font-weight:600;color:var(--text-muted);background:var(--bg-main);border-radius:.5rem;border:2px solid var(--fret-color)}.level-picker{display:flex;flex-direction:column;gap:.5rem}.level-pick-btn{display:flex;align-items:center;gap:.875rem;padding:.875rem 1rem;background:var(--bg-card);border:2px solid var(--fret-color);border-radius:.5rem;cursor:pointer;transition:all .1s ease;text-align:left}.level-pick-btn:hover{background:var(--bg-main);border-color:var(--black)}.level-pick-btn.active{background:var(--yellow-bold);border-color:var(--black);box-shadow:3px 3px 0 var(--black)}.level-pick-num{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;background:var(--bg-main);border:2px solid var(--black);border-radius:50%;font-size:.9rem;font-weight:900;color:var(--black);flex-shrink:0}.level-pick-btn.active .level-pick-num{background:var(--black);color:var(--yellow-bold)}.level-pick-info{display:flex;flex-direction:column;gap:.125rem}.level-pick-info strong{font-size:.9rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--black)}.level-pick-info span:last-child{font-size:.7rem;color:var(--text-muted)}.level-modal-celebration{text-align:center;overflow:hidden;position:relative}.celebration-burst{position:absolute;top:-60px;left:50%;transform:translate(-50%);width:200px;height:200px;background:radial-gradient(circle,var(--yellow-bold) 0%,transparent 70%);opacity:.3;animation:burst-pulse 1.5s ease-in-out infinite;pointer-events:none}@keyframes burst-pulse{0%,to{transform:translate(-50%) scale(1);opacity:.3}50%{transform:translate(-50%) scale(1.15);opacity:.45}}.celebration-title{font-size:2rem;font-weight:900;text-transform:uppercase;letter-spacing:.15em;color:var(--black);animation:celebration-bounce .5s cubic-bezier(.34,1.56,.64,1)}@keyframes celebration-bounce{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}.celebration-level-badge{display:flex;flex-direction:column;align-items:center;gap:.25rem}.celebration-level-num{display:flex;align-items:center;justify-content:center;width:4rem;height:4rem;background:var(--yellow-bold);border:4px solid var(--black);border-radius:50%;font-size:2rem;font-weight:900;color:var(--black);animation:celebration-bounce .5s .15s cubic-bezier(.34,1.56,.64,1) both}.celebration-level-name{font-size:1.5rem;font-weight:900;text-transform:uppercase;letter-spacing:.12em;color:var(--black)}.celebration-tagline{font-size:.9rem;color:var(--text-muted);font-style:italic}.celebration-unlocks{background:var(--bg-main);border:2px solid var(--fret-color);border-radius:.5rem;padding:.875rem 1rem}.celebration-done{background:var(--red-bold);border-color:var(--black);box-shadow:4px 4px 0 var(--black)}.celebration-done:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--black)}.placement-welcome-focus{font-size:1rem;line-height:1.5;color:var(--text-muted);text-align:center;margin:0}@media(max-width:480px){.floating-level-btn{bottom:1rem;right:1rem;padding:.5rem .75rem .5rem .5rem;gap:.5rem}.floating-level-num{width:1.75rem;height:1.75rem;font-size:.875rem}.floating-level-name{font-size:.65rem}.level-modal{padding:1.5rem;gap:1rem}.quiz-answer-btn{padding:.875rem;font-size:.875rem}.level-indicator{padding:.875rem 1rem;gap:.75rem}.level-indicator-num{width:2.5rem;height:2.5rem;font-size:1.25rem}}.app-footer{margin-top:3rem;padding:1.5rem 0 0;text-align:center}.kofi-link{font-size:.75rem;font-weight:600;color:var(--text-muted);text-decoration:none;letter-spacing:.03em;transition:color .15s}.kofi-link:hover{color:var(--text-primary)}.neck-explorer{width:100%;display:flex;flex-direction:column;align-items:center;gap:1.25rem}.explorer-title-row{display:flex;align-items:center;justify-content:space-between;width:100%}.explorer-title{font-size:1.75rem;font-weight:900;text-transform:uppercase;letter-spacing:.12em;color:var(--black)}.explorer-key-row{display:flex;flex-wrap:wrap;gap:.35rem;justify-content:center}.explorer-key-btn{width:2.5rem;height:2.25rem;font-size:.8rem;font-weight:700;background:var(--bg-card);border:2px solid var(--black);border-radius:.35rem;color:var(--text-muted);cursor:pointer;transition:all .1s ease}.explorer-key-btn:hover{background:var(--bg-main);color:var(--text-primary)}.explorer-key-btn.active{background:var(--black);color:#fff;box-shadow:2px 2px 0 var(--text-muted)}.explorer-scale-row{display:flex;gap:.5rem}.explorer-scale-btn{padding:.5rem 1.25rem;font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;background:var(--bg-card);border:2px solid var(--black);border-radius:.375rem;color:var(--text-muted);cursor:pointer;transition:all .1s ease}.explorer-scale-btn:hover{background:var(--bg-main)}.explorer-scale-btn.active{background:var(--blue-bold);color:#fff;border-color:var(--blue-bold)}.neck-scroll{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;background:var(--bg-card);border:3px solid var(--black);border-radius:.75rem;box-shadow:6px 6px 0 var(--black);padding:.5rem 0}.neck-svg{display:block;width:100%;min-width:700px;height:auto}.neck-nut{fill:var(--black)}.neck-fret-line{stroke:#d1d5db;stroke-width:1.5}.neck-inlay{fill:#e5e7eb}.neck-fret-num{fill:var(--text-muted);font-size:10px;font-weight:600;text-anchor:middle}.neck-string{stroke:#6b7280}.neck-string-label{fill:var(--text-muted);font-size:11px;font-weight:600;text-anchor:middle}.neck-root-label{fill:#fff;font-size:10px;font-weight:800;text-anchor:middle;pointer-events:none}.neck-bridge-ring{animation:bridge-pulse 2s ease-in-out infinite}@keyframes bridge-pulse{0%,to{opacity:.5}50%{opacity:.85}}.explorer-shape-nav{display:flex;gap:.5rem;justify-content:center}.explorer-shape-btn{display:flex;flex-direction:column;align-items:center;gap:.15rem;width:4.5rem;padding:.6rem .5rem .4rem;font-size:1.25rem;font-weight:900;background:var(--bg-card);border:3px solid var(--fret-color);border-radius:.5rem;color:var(--text-muted);cursor:pointer;transition:all .15s ease}.explorer-shape-btn:hover{border-color:var(--text-muted);transform:translateY(-1px)}.explorer-shape-btn.revealed{border-width:3px;box-shadow:3px 3px #00000026;transform:translateY(-1px)}.explorer-shape-btn.revealed:hover{transform:translateY(-2px);box-shadow:4px 4px #0003}.explorer-shape-btn.focused{transform:translateY(-3px)}.shape-fret-hint{font-size:.55rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;opacity:.8}.explorer-controls-row{display:flex;align-items:center;gap:1rem}.explorer-ctrl-btn{padding:.6rem 1.25rem;font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;background:var(--bg-card);border:2px solid var(--black);border-radius:.375rem;color:var(--text-muted);cursor:pointer;transition:all .1s ease;box-shadow:3px 3px 0 var(--black)}.explorer-ctrl-btn:hover:not(:disabled){transform:translate(-1px,-1px);box-shadow:4px 4px 0 var(--black)}.explorer-ctrl-btn:active:not(:disabled){transform:translate(1px,1px);box-shadow:2px 2px 0 var(--black)}.explorer-ctrl-btn:disabled{opacity:.35;cursor:not-allowed;box-shadow:2px 2px 0 var(--fret-color)}.explorer-ctrl-btn.primary{background:var(--red-bold);color:#fff}.explorer-counter{font-size:.85rem;font-weight:700;color:var(--text-muted);min-width:3rem;text-align:center}.explorer-bridge-info{display:flex;align-items:center;gap:.625rem;padding:.75rem 1.25rem;background:#fffbeb;border:2px solid #f59e0b;border-radius:.5rem;font-size:.85rem;line-height:1.5;color:var(--text-primary);max-width:100%;animation:slide-in .3s ease}.bridge-dot{flex-shrink:0;width:14px;height:14px;border-radius:50%;background:#fbbf24;box-shadow:0 0 8px #fbbf2488}@keyframes slide-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.explorer-hint{font-size:.7rem;color:var(--text-muted);text-align:center;font-style:italic}@media(max-width:580px){.explorer-title{font-size:1.25rem}.explorer-key-btn{width:2.2rem;height:2rem;font-size:.7rem}.explorer-shape-btn{width:3.5rem;font-size:1rem;padding:.5rem .25rem .3rem}.shape-fret-hint{font-size:.5rem}.explorer-bridge-info{font-size:.78rem}}.print-only{display:none}@media print{body *{visibility:hidden}.modal-overlay{display:none!important}.print-only,.print-only *{visibility:visible}.print-only{display:block;position:absolute;left:0;top:0;width:100%;padding:.4in;background:#fff}.print-only{filter:grayscale(100%);-webkit-filter:grayscale(100%)}.print-header{font-size:22pt;font-weight:900;text-align:center;margin-bottom:.2in;letter-spacing:.1em;border-bottom:2px solid black;padding-bottom:.1in}.print-section{margin-bottom:.3in;page-break-after:always}.print-section:last-child{page-break-after:avoid}.print-section-title{font-size:18pt;font-weight:800;text-transform:uppercase;letter-spacing:.1em;margin-bottom:.05in}.print-section-description{font-size:11pt;color:#666;margin-bottom:.2in}.print-shapes-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.15in}.print-shape-chart{border:1px solid #000;padding:.1in;background:#fff;break-inside:avoid}.print-shape-chart .shape-label{font-size:9pt;margin-top:.05in}.print-shape-chart .fretboard-container{margin-top:0}.print-shape-chart .fretboard{max-width:100%;height:auto}.print-shape-chart .shape-label{font-size:12pt;font-weight:700;margin-top:.1in}.print-only .fretboard-note{fill:#333}.print-only .fretboard-root{fill:#000}.print-only .fretboard-root-label{fill:#fff}@page{size:letter landscape;margin:.5in}}
