:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;--primary-color: #6366f1;--primary-hover: #4f46e5;--secondary-color: #8b5cf6;--accent-color: #ec4899;--success-color: #10b981;--error-color: #ef4444;--bg-dark: #0f172a;--bg-card: #1e293b;--text-primary: #f1f5f9;--text-secondary: #cbd5e1;color-scheme:light dark;color:var(--text-primary);background:linear-gradient(135deg,#0f172a,#1e1b4b);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh;background:linear-gradient(135deg,#0f172a,#1e1b4b);background-attachment:fixed}#root{width:100%;max-width:1280px;margin:0 auto;padding:2rem}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));color:#fff;cursor:pointer;transition:all .3s ease}button:hover{background:linear-gradient(135deg,var(--primary-hover),var(--primary-color));transform:translateY(-1px);box-shadow:0 4px 12px #6366f166}button:focus,button:focus-visible{outline:2px solid var(--accent-color);outline-offset:2px}@media(prefers-color-scheme:light){:root{--bg-dark: #f8fafc;--bg-card: #ffffff;--text-primary: #0f172a;--text-secondary: #475569;color:var(--text-primary);background:linear-gradient(135deg,#f8fafc,#e0e7ff)}}.dev-insights-hint{background:#6366f10f;box-shadow:inset 0 0 40px #6366f10f}.menu-screen{text-align:center}.menu-screen h2{font-size:2rem;margin-bottom:1.5rem;color:var(--text-primary)}.audio-test-section{background:#6366f11a;border:2px solid rgba(99,102,241,.3);border-radius:12px;padding:1.5rem;margin-bottom:2rem}.test-label{color:var(--text-secondary);margin-bottom:1rem;font-size:.95rem}.test-controls{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}.test-button{padding:.75rem 1.5rem;font-size:.95rem;border-radius:10px;background:#6366f133;border:2px solid var(--primary-color);transition:all .3s ease}.test-button:hover:not(:disabled){background:#6366f14d;transform:translateY(-2px)}.test-button:disabled{opacity:.5;cursor:not-allowed}.mode-buttons{display:flex;flex-direction:column;gap:1rem;align-items:center}.mode-button{width:100%;max-width:400px;padding:1.5rem 2rem;font-size:1.2rem;border-radius:16px;transition:all .3s ease;background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));border:2px solid rgba(139,92,246,.3);box-shadow:0 8px 16px #0000004d;font-weight:600;letter-spacing:.5px}.mode-button:hover{transform:translateY(-4px);box-shadow:0 12px 24px #8b5cf680;border-color:var(--accent-color);background:linear-gradient(135deg,var(--secondary-color),var(--accent-color))}.floating-stats-button{position:fixed;bottom:2rem;right:2rem;width:70px;height:70px;border-radius:50%;background:linear-gradient(135deg,#22c55ef2,#10b981f2);border:3px solid rgba(34,197,94,.6);box-shadow:0 8px 24px #22c55e80;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.4,0,.2,1);z-index:1000;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.floating-stats-button:hover{transform:scale(1.1) translateY(-4px);box-shadow:0 12px 32px #22c55eb3;background:linear-gradient(135deg,#22c55e,#10b981);border-color:#22c55ee6}.floating-stats-button:active{transform:scale(1.05) translateY(-2px)}.chart-icon{display:flex;align-items:flex-end;justify-content:center;gap:4px;height:28px;width:28px}.bar{width:6px;background:#fff;border-radius:2px 2px 0 0;transition:all .3s ease}.bar-1{height:14px}.bar-2{height:22px}.bar-3{height:18px}.floating-stats-button:hover .bar-1{height:18px;background:#fff}.floating-stats-button:hover .bar-2{height:26px;background:#fff}.floating-stats-button:hover .bar-3{height:22px;background:#fff}@media(max-width:768px){.floating-stats-button{bottom:1.5rem;right:1.5rem;width:60px;height:60px}.chart-icon{height:24px;width:24px}.bar{width:5px}.bar-1{height:12px}.bar-2{height:20px}.bar-3{height:16px}}.checkbox-group{margin:2rem 0}.checkbox-group-label{display:block;font-size:1.2rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.checkbox-group-hint{font-size:.9rem;color:var(--text-secondary);margin-bottom:1rem}.checkbox-options{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem}.checkbox-option{display:flex;align-items:center;gap:.75rem;padding:1rem;background:#6366f11a;border:2px solid rgba(99,102,241,.3);border-radius:10px;cursor:pointer;transition:all .3s ease;position:relative}.checkbox-option:hover:not(.locked){background:#6366f133;border-color:var(--primary-color);transform:translateY(-2px)}.checkbox-option.checked{background:#6366f140;border-color:var(--primary-color)}.checkbox-option.locked{cursor:not-allowed;opacity:.8}.checkbox-option input[type=checkbox]{position:absolute;opacity:0;width:0;height:0}.checkbox-content{flex:1;display:flex;flex-direction:column;gap:.25rem}.checkbox-label{font-weight:600;color:var(--text-primary)}.checkbox-description{font-size:.85rem;color:var(--text-secondary)}.checkbox-checkmark{width:24px;height:24px;border:2px solid var(--primary-color);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:1rem;color:transparent;transition:all .3s ease;flex-shrink:0}.checkbox-option.checked .checkbox-checkmark{background:var(--primary-color);color:#fff}.checkbox-group-error{margin-top:.5rem;padding:.75rem;background:#ef444426;border:1px solid var(--error-color);border-radius:8px;color:var(--error-color);font-size:.9rem}@media(max-width:768px){.checkbox-options{grid-template-columns:1fr}}.session-options{display:flex;flex-direction:column;gap:2rem;margin:2rem 0}.session-option-group{display:flex;flex-direction:column;gap:1rem}.session-option-label{font-size:1.2rem;font-weight:600;color:var(--text-primary)}.question-number-selector{display:flex;gap:.75rem;flex-wrap:wrap}.question-number-btn{padding:.75rem 1.5rem;font-size:1rem;font-weight:600;border:2px solid rgba(99,102,241,.3);border-radius:10px;background:#6366f11a;color:var(--text-primary);cursor:pointer;transition:all .3s ease;min-width:60px}.question-number-btn:hover{background:#6366f133;border-color:var(--primary-color);transform:translateY(-2px)}.question-number-btn.active{background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));border-color:var(--primary-color);color:#fff;transform:scale(1.05)}.session-option-label:has(.guest-mode-checkbox){display:flex;align-items:center;gap:1rem;padding:1.25rem;background:#ec48991a;border:2px solid rgba(236,72,153,.3);border-radius:12px;cursor:pointer;transition:all .3s ease;font-size:1rem}.session-option-label:has(.guest-mode-checkbox):hover{background:#ec489926;border-color:var(--accent-color);transform:translateY(-2px)}.guest-mode-checkbox{width:24px;height:24px;cursor:pointer;accent-color:var(--accent-color);flex-shrink:0}.guest-mode-text{display:flex;flex-direction:column;gap:.25rem}.guest-mode-title{font-weight:600;color:var(--text-primary)}.guest-mode-description{font-size:.9rem;color:var(--text-secondary);font-weight:400}@media(max-width:480px){.question-number-selector{justify-content:center}.question-number-btn{flex:1;min-width:50px}}.btn{border-radius:8px;border:2px solid transparent;font-weight:600;font-family:inherit;cursor:pointer;transition:all .3s ease;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-small{padding:.5rem 1rem;font-size:.9rem}.btn-medium{padding:.75rem 1.5rem;font-size:1rem}.btn-large{padding:1rem 2rem;font-size:1.1rem}.btn-full-width{width:100%}.btn-primary{background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));color:#fff;border-color:#8b5cf64d}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,var(--primary-hover),var(--primary-color));transform:translateY(-2px);box-shadow:0 8px 16px #6366f166}.btn-secondary{background:transparent;border-color:var(--primary-color);color:var(--text-primary)}.btn-secondary:hover:not(:disabled){background:#6366f11a;transform:translateY(-2px)}.btn-danger{background:linear-gradient(135deg,var(--error-color),#dc2626);color:#fff;border-color:#ef44444d}.btn-danger:hover:not(:disabled){background:linear-gradient(135deg,#dc2626,#b91c1c);transform:translateY(-2px);box-shadow:0 8px 16px #ef444466}.btn-ghost{background:#6366f11a;border-color:#6366f14d;color:var(--text-primary)}.btn-ghost:hover:not(:disabled){background:#6366f133;transform:translateY(-2px)}.chord-config{max-width:700px;margin:0 auto;display:flex;flex-direction:column;gap:2rem}.config-header{text-align:center}.config-header h1{font-size:2.5rem;margin-bottom:.75rem;color:var(--text-primary);background:linear-gradient(135deg,var(--primary-color),var(--accent-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.config-description{font-size:1rem;color:var(--text-secondary);line-height:1.6}.config-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;padding-top:1rem}.config-actions button{min-width:180px}@media(max-width:768px){.chord-config{padding:1rem}.config-header h1{font-size:2rem}.config-actions{flex-direction:column-reverse}.config-actions button{width:100%}}.card{background:var(--bg-card);border-radius:16px;padding:2rem;border:2px solid rgba(139,92,246,.2);box-shadow:0 4px 12px #0000001a}.card-title{font-size:1.5rem;margin-bottom:1.5rem;color:var(--text-primary);font-weight:600}.card-content{color:var(--text-primary)}.question-controls{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin:1.5rem 0}.replay-button,.give-up-button{min-width:150px}@media(max-width:480px){.question-controls{flex-direction:column}.replay-button,.give-up-button{width:100%}}.instrument-selector{display:flex;justify-content:center;margin:1rem 0}.instrument-toggle{min-width:180px}.instrument-icon{font-size:1.2em;opacity:.4;transition:all .3s ease}.instrument-icon.active{opacity:1;transform:scale(1.2)}.instrument-divider{margin:0 .5rem;color:var(--text-secondary)}.instrument-label{margin-left:.75rem;font-weight:600}.feedback-display{margin:1.5rem 0;padding:1.5rem;border-radius:12px;text-align:center;animation:feedbackSlideIn .3s ease-out}@keyframes feedbackSlideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.feedback-main{display:flex;align-items:center;justify-content:center;gap:1rem}.feedback-icon{font-size:2rem}.feedback-text{font-size:1.5rem;font-weight:700}.feedback-answer{margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;gap:.5rem}.feedback-answer-label{font-size:.95rem;opacity:.8}.feedback-answer-value{font-size:1.2rem;font-weight:600}.feedback-correct{background:#10b98126;border:2px solid var(--success-color)}.feedback-correct .feedback-icon,.feedback-correct .feedback-text{color:var(--success-color)}.feedback-incorrect{background:#ef444426;border:2px solid var(--error-color)}.feedback-incorrect .feedback-icon,.feedback-incorrect .feedback-text{color:var(--error-color)}.feedback-gave-up{background:#ec489926;border:2px solid var(--accent-color)}.feedback-gave-up .feedback-icon,.feedback-gave-up .feedback-text{color:var(--accent-color)}.chord-question{max-width:800px;margin:0 auto;display:flex;flex-direction:column;gap:2rem}.question-header{display:flex;justify-content:flex-end}.question-prompt h2{font-size:2rem;margin-bottom:.5rem;color:var(--text-primary)}.answer-button{padding:1.25rem 1.5rem;font-size:1.1rem;transition:all .3s ease}.answer-button.correct-answer{animation:pulse .5s ease-in-out}.next-question-section button{min-width:200px}@media(max-width:768px){.chord-question{padding:1rem}.question-prompt h2{font-size:1.5rem}.answer-options{grid-template-columns:1fr}}.question-counter{text-align:center;margin-bottom:2rem}.counter-text{font-size:1.2rem;color:var(--text-primary);margin-bottom:.5rem;display:flex;align-items:center;justify-content:center;gap:.5rem}.counter-current{font-weight:700;color:var(--primary-color)}.counter-divider{color:var(--text-secondary);font-size:1rem}.counter-total{font-weight:600}.counter-mode{font-size:.9rem;color:var(--text-secondary);margin-bottom:1rem}.counter-progress-bar{width:100%;max-width:400px;height:6px;background:#6366f133;border-radius:3px;overflow:hidden;margin:0 auto}.counter-progress-fill{height:100%;background:linear-gradient(90deg,var(--primary-color),var(--secondary-color));border-radius:3px;transition:width .4s ease}.chord-training{max-width:900px;margin:0 auto;padding:2rem 1rem;display:flex;flex-direction:column;gap:2rem}.training-loading{text-align:center;padding:3rem 2rem;color:var(--text-secondary);font-size:1.1rem}@media(max-width:768px){.chord-training{padding:1rem .5rem}}.interval-config{width:100%;max-width:800px;margin:0 auto;padding:2rem}.config-header{text-align:center;margin-bottom:2rem}.config-header h1{font-size:2rem;margin-bottom:.5rem;color:var(--text-primary)}.config-description{color:var(--text-secondary);font-size:1rem}.config-content{display:flex;flex-direction:column;gap:2rem;margin-bottom:2rem}.config-label{font-size:1rem;font-weight:600;color:var(--text-primary);display:flex;flex-direction:column;gap:.25rem}.help-text{font-size:.85rem;font-weight:400;color:var(--text-secondary);font-style:italic}.radio-group{display:flex;gap:1.5rem;flex-wrap:wrap}.radio-option{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.95rem}.radio-option input[type=radio]{cursor:pointer;width:18px;height:18px}.octave-range{display:flex;gap:2rem;flex-wrap:wrap}.range-input{flex:1;min-width:200px}.range-input label{display:flex;flex-direction:column;gap:.5rem;font-size:.95rem}.range-input input[type=range]{width:100%;cursor:pointer}.toggle-option{display:flex;align-items:flex-start;gap:1rem;cursor:pointer;padding:1rem;border:2px solid rgba(99,102,241,.2);border-radius:8px;background-color:var(--bg-card);transition:all .2s ease}.toggle-option:hover{border-color:#6366f180;background-color:#6366f10d}.toggle-option.checked{border-color:var(--primary-color);background-color:#6366f126;box-shadow:0 0 0 1px #6366f11a}.toggle-option input[type=checkbox]{cursor:pointer;width:22px;height:22px;margin-top:2px;flex-shrink:0;accent-color:var(--primary-color)}.toggle-content{display:flex;flex-direction:column;gap:.25rem}.toggle-label{font-size:1rem;font-weight:600;color:var(--text-primary)}.toggle-description{font-size:.875rem;color:var(--text-secondary);line-height:1.4}.config-actions{display:flex;justify-content:space-between;gap:1rem;margin-top:2rem}@media(max-width:600px){.interval-config{padding:1rem}.config-header h1{font-size:1.5rem}.config-actions{flex-direction:column}.radio-group{flex-direction:column;gap:.75rem}.octave-range{flex-direction:column}}.interval-question{width:100%}.question-header{display:flex;justify-content:flex-end;margin-bottom:1.5rem}.question-prompt h2{font-size:1.75rem;margin-bottom:.5rem;color:var(--text-primary)}.question-instruction{font-size:1rem;color:var(--text-secondary)}.answer-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-top:1rem}.answer-button{transition:all .2s ease}.answer-button.correct-answer{animation:pulse .5s ease}.answer-button.fade-out{opacity:.3}.next-question-section{display:flex;justify-content:center;margin-top:1.5rem}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@media(max-width:600px){.question-prompt h2{font-size:1.5rem}.answer-options{grid-template-columns:1fr}}.interval-training{width:100%;max-width:900px;margin:0 auto;padding:2rem}.training-loading{text-align:center;padding:3rem;color:var(--text-secondary)}.training-loading p{font-size:1.1rem}@media(max-width:600px){.interval-training{padding:1rem}}.progression-config{max-width:700px;margin:0 auto;padding:2rem}.config-header{margin-bottom:2rem}.config-header h1{margin-bottom:.5rem}.config-description{color:#888;line-height:1.5}.config-content{display:flex;flex-direction:column;gap:2rem}.config-section{display:flex;flex-direction:column;gap:.75rem}.config-label{font-weight:600;font-size:1.1rem;display:flex;flex-direction:column;gap:.25rem}.help-text{font-size:.875rem;font-weight:400;color:#888}.radio-group{display:flex;flex-direction:column;gap:.75rem}.radio-option{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;border:2px solid #333;border-radius:8px;cursor:pointer;transition:all .2s ease}.radio-option:hover{border-color:#555;background-color:#1a1a1a}.radio-option input[type=radio]{margin-top:.2rem;cursor:pointer}.radio-option input[type=radio]:checked+span{color:#4a9eff}.radio-option span{display:flex;flex-direction:column;gap:.25rem}.toggle-option{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;border:2px solid #333;border-radius:8px;cursor:pointer;transition:all .2s ease}.toggle-option:hover{border-color:#555;background-color:#1a1a1a}.toggle-option.checked{border-color:#4a9eff;background-color:#4a9eff1a}.toggle-option input[type=checkbox]{margin-top:.2rem;cursor:pointer}.toggle-content{display:flex;flex-direction:column;gap:.25rem;flex:1}.toggle-label{font-weight:600}.toggle-description{font-size:.875rem;color:#888}.key-selector{padding:.75rem;font-size:1rem;background-color:#1a1a1a;color:#fff;border:2px solid #333;border-radius:8px;cursor:pointer;transition:border-color .2s ease}.key-selector:hover{border-color:#555}.key-selector:focus{outline:none;border-color:#4a9eff}.key-selector option{background-color:#1a1a1a;color:#fff}.key-selector optgroup{font-weight:600;color:#aaa}.config-actions{display:flex;gap:1rem;margin-top:2rem;justify-content:space-between}@media(max-width:768px){.progression-config{padding:1rem}.config-actions{flex-direction:column}}.progression-question{max-width:900px;margin:0 auto;padding:2rem}.question-header{margin-bottom:1.5rem}.question-content{display:flex;flex-direction:column;gap:2rem}.question-prompt{text-align:center}.question-prompt h2{margin-bottom:1rem;font-size:1.5rem}.key-display{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background-color:#1a1a1a;border:2px solid #4a9eff;border-radius:12px;margin:1rem 0;font-size:1.25rem}.key-label{color:#888;font-weight:600}.key-value{color:#4a9eff;font-weight:700}.question-instruction{color:#aaa;margin-top:.5rem}.tempo-info{color:#888;font-size:.9rem;margin-top:.25rem}.user-progression{display:flex;flex-direction:column;gap:1rem;padding:1.5rem;background-color:#1a1a1a;border:2px solid #333;border-radius:12px}.progression-display{min-height:60px;display:flex;align-items:center;justify-content:center;gap:1rem;padding:1rem;background-color:#0a0a0a;border-radius:8px;flex-wrap:wrap}.progression-display .placeholder{color:#555;font-style:italic}.progression-chord{padding:.5rem 1rem;background-color:#4a9eff;color:#000;font-weight:700;border-radius:6px;font-size:1.1rem}.progression-controls{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}.numeral-options{width:100%}.numeral-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(80px,1fr));gap:.75rem;max-width:800px;margin:0 auto}.numeral-button{padding:1rem .5rem;font-size:1.1rem;font-weight:600;min-height:50px}.numeral-button:disabled{opacity:.5;cursor:not-allowed}.next-question-section{display:flex;justify-content:center;margin-top:1rem}@media(max-width:768px){.progression-question{padding:1rem}.numeral-grid{grid-template-columns:repeat(auto-fit,minmax(70px,1fr));gap:.5rem}.numeral-button{padding:.75rem .25rem;font-size:1rem;min-height:45px}.progression-chord{font-size:1rem;padding:.4rem .8rem}.key-display{font-size:1.1rem;padding:.6rem 1.2rem}}.progression-training{min-height:100vh;padding:2rem 1rem;display:flex;flex-direction:column;gap:1.5rem}.training-loading{padding:3rem;text-align:center;color:#888}@media(max-width:768px){.progression-training{padding:1rem .5rem}}.config-screen{text-align:center;max-width:600px;margin:0 auto}.config-screen h2{font-size:2rem;margin-bottom:.5rem;color:var(--text-primary)}.config-subtitle{font-size:1.1rem;color:var(--text-secondary);margin-bottom:2rem}.config-content{background:var(--bg-card);border-radius:16px;padding:3rem 2rem;margin-bottom:2rem;border:2px solid rgba(139,92,246,.2)}.placeholder-details{color:var(--text-secondary);font-size:.95rem}.config-actions{display:flex;gap:1rem;justify-content:center}.primary-button,.secondary-button{padding:1rem 2rem;font-size:1.1rem;border-radius:12px;font-weight:600;transition:all .3s ease}.primary-button{background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));border:2px solid rgba(139,92,246,.3)}.primary-button:hover{transform:translateY(-2px);box-shadow:0 8px 16px #8b5cf680}.secondary-button{background:transparent;border:2px solid var(--primary-color);color:var(--text-primary)}.secondary-button:hover{background:#6366f11a;transform:translateY(-2px)}.training-screen{text-align:center;max-width:700px;margin:0 auto}.training-screen h2{font-size:2rem;margin-bottom:.5rem;color:var(--text-primary)}.training-subtitle{font-size:1rem;color:var(--text-secondary);margin-bottom:2rem}.training-content{background:var(--bg-card);border-radius:16px;padding:3rem 2rem;margin-bottom:2rem;border:2px solid rgba(139,92,246,.2);min-height:300px;display:flex;flex-direction:column;justify-content:center}.placeholder-text{font-size:1.2rem;color:var(--text-primary);margin-bottom:1rem}.placeholder-details{color:var(--text-secondary);font-size:.95rem;margin-bottom:2rem}.training-placeholder-controls{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.control-button{padding:.75rem 1.5rem;font-size:1rem;border-radius:10px;background:#6366f133;border:2px solid var(--primary-color)}.control-button:hover{background:#6366f14d}.training-actions{display:flex;justify-content:center}.finish-button{padding:1rem 2rem;font-size:1.1rem;border-radius:12px;font-weight:600;background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));border:2px solid rgba(139,92,246,.3);transition:all .3s ease}.finish-button:hover{transform:translateY(-2px);box-shadow:0 8px 16px #8b5cf680}.overall-summary{margin-bottom:2rem}.section-title{font-size:1.8rem;margin-bottom:1.5rem;color:var(--text-primary);text-align:center}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.summary-card{background:var(--bg-card);border-radius:12px;padding:1.5rem;border:2px solid rgba(139,92,246,.2);display:flex;align-items:center;gap:1rem;transition:all .3s ease}.summary-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #8b5cf64d;border-color:#8b5cf666}.summary-icon{font-size:2.5rem;flex-shrink:0}.summary-content{flex:1}.summary-value{font-size:2rem;font-weight:700;color:var(--success-color);line-height:1.2}.summary-label{font-size:.9rem;color:var(--text-secondary);margin-top:.25rem}.mode-breakdown{background:var(--bg-card);border-radius:16px;padding:2rem;border:2px solid rgba(139,92,246,.2)}.subsection-title{font-size:1.3rem;margin-bottom:1.5rem;color:var(--text-primary);text-align:center}.mode-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.mode-card{background:#6366f10d;border-radius:12px;padding:1.5rem;border:2px solid rgba(139,92,246,.2);transition:all .3s ease}.mode-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #8b5cf64d}.chord-mode{border-color:#6366f14d}.interval-mode{border-color:#8b5cf64d}.progression-mode{border-color:#a855f74d}.mode-header{margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid rgba(139,92,246,.2)}.mode-name{font-size:1.1rem;font-weight:600;color:var(--text-primary)}.mode-stats{display:flex;flex-direction:column;gap:.75rem}.mode-stat{display:flex;justify-content:space-between;align-items:center;padding:.5rem;background:#8b5cf61a;border-radius:6px}.mode-stat-label{font-size:.9rem;color:var(--text-secondary)}.mode-stat-value{font-size:1.1rem;font-weight:700;color:var(--success-color)}@media(max-width:768px){.summary-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.summary-value{font-size:1.5rem}.summary-icon{font-size:2rem}.mode-grid{grid-template-columns:1fr}}.performance-breakdown{margin-bottom:2rem}.no-data-message{text-align:center;padding:2rem;color:var(--text-secondary);font-size:1.1rem}.breakdown-section{background:var(--bg-card);border-radius:16px;padding:2rem;border:2px solid rgba(139,92,246,.2);margin-bottom:1.5rem}.breakdown-title{font-size:1.3rem;margin-bottom:1.5rem;color:var(--text-primary);text-align:center}.breakdown-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-bottom:1.5rem}.breakdown-card{background:#6366f10d;border-radius:12px;padding:1.5rem;border:2px solid rgba(139,92,246,.2)}.breakdown-card.strengths{border-color:#22c55e4d;background:#22c55e0d}.breakdown-card.weaknesses{border-color:#eab3084d;background:#eab3080d}.breakdown-header{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid rgba(139,92,246,.2)}.breakdown-icon{font-size:1.5rem}.breakdown-label{font-size:1.1rem;font-weight:600;color:var(--text-primary)}.breakdown-list{display:flex;flex-direction:column;gap:.75rem}.breakdown-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#8b5cf61a;border-radius:8px;transition:all .2s ease}.breakdown-item:hover{background:#8b5cf626;transform:translate(4px)}.item-name{font-size:1rem;color:var(--text-primary);font-weight:500}.item-stats{display:flex;align-items:center;gap:1rem}.item-accuracy{font-size:1.1rem;font-weight:700;color:var(--success-color)}.item-count{font-size:.9rem;color:var(--text-secondary)}.direction-breakdown{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid rgba(139,92,246,.2)}.direction-title{font-size:1.1rem;margin-bottom:1rem;color:var(--text-primary);text-align:center}.direction-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.direction-card{background:#6366f11a;border-radius:8px;padding:1rem;display:flex;flex-direction:column;align-items:center;gap:.5rem;border:1px solid rgba(139,92,246,.2)}.direction-label{font-size:.9rem;color:var(--text-secondary)}.direction-accuracy{font-size:1.3rem;font-weight:700;color:var(--success-color)}.direction-count{font-size:.85rem;color:var(--text-secondary)}.difficulty-breakdown{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid rgba(139,92,246,.2)}.difficulty-title{font-size:1.1rem;margin-bottom:1rem;color:var(--text-primary);text-align:center}.difficulty-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.difficulty-card{background:#6366f11a;border-radius:8px;padding:1rem;display:flex;flex-direction:column;align-items:center;gap:.5rem;border:1px solid rgba(139,92,246,.2)}.difficulty-label{font-size:.9rem;color:var(--text-secondary)}.difficulty-accuracy{font-size:1.3rem;font-weight:700;color:var(--success-color)}.difficulty-count{font-size:.85rem;color:var(--text-secondary)}@media(max-width:768px){.breakdown-grid,.direction-grid,.difficulty-grid{grid-template-columns:1fr}}.session-history{margin-bottom:2rem}.no-sessions-message{text-align:center;padding:2rem;color:var(--text-secondary);font-size:1.1rem}.sessions-container{background:var(--bg-card);border-radius:16px;padding:1.5rem;border:2px solid rgba(139,92,246,.2);overflow-x:auto}.sessions-header{display:grid;grid-template-columns:1.5fr 1.5fr 1fr 1fr 1fr;gap:1rem;padding:1rem;background:#6366f11a;border-radius:8px;margin-bottom:1rem;font-weight:600;color:var(--text-secondary);font-size:.9rem}.sessions-list{display:flex;flex-direction:column;gap:.75rem}.session-row{display:grid;grid-template-columns:1.5fr 1.5fr 1fr 1fr 1fr;gap:1rem;padding:1rem;background:#8b5cf60d;border-radius:8px;border:1px solid rgba(139,92,246,.1);align-items:center;transition:all .2s ease}.session-row:hover{background:#8b5cf61a;transform:translate(4px);border-color:#8b5cf64d}.session-mode{display:flex;align-items:center;gap:.5rem}.mode-icon{font-size:1.5rem}.mode-name{font-size:1rem;font-weight:500;color:var(--text-primary)}.session-date{font-size:.9rem;color:var(--text-secondary)}.session-accuracy{font-size:1.1rem;font-weight:700;padding:.25rem .75rem;border-radius:6px;text-align:center}.session-accuracy.excellent{background:#22c55e33;color:#22c55e}.session-accuracy.good{background:#3b82f633;color:#3b82f6}.session-accuracy.okay{background:#eab30833;color:#eab308}.session-accuracy.needs-work{background:#ef444433;color:#ef4444}.session-questions{font-size:.95rem;color:var(--text-primary);text-align:center}.session-duration{font-size:.9rem;color:var(--text-secondary);text-align:center}@media(max-width:1024px){.sessions-header,.session-row{grid-template-columns:1.5fr 1.5fr 1fr 1fr}.header-duration,.session-duration{display:none}}@media(max-width:768px){.sessions-header{display:none}.session-row{grid-template-columns:1fr;gap:.5rem}.session-mode,.session-date,.session-accuracy,.session-questions,.session-duration{display:flex;justify-content:space-between;align-items:center}.session-mode:before{content:"Mode:";color:var(--text-secondary);font-size:.9rem}.session-date:before{content:"Date:";color:var(--text-secondary);font-size:.9rem}.session-accuracy:before{content:"Accuracy:";color:var(--text-secondary);font-size:.9rem}.session-questions:before{content:"Score:";color:var(--text-secondary);font-size:.9rem}.session-duration{display:flex!important}.session-duration:before{content:"Duration:";color:var(--text-secondary);font-size:.9rem}}.stats-screen{text-align:center;max-width:1200px;margin:0 auto;padding:0 1rem}.stats-screen h2{font-size:2.5rem;margin-bottom:.5rem;color:var(--text-primary);background:linear-gradient(135deg,var(--success-color),var(--primary-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stats-subtitle{font-size:1.1rem;color:var(--text-secondary);margin-bottom:2rem}.stats-content{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem}.stats-card{background:var(--bg-card);border-radius:16px;padding:2rem;border:2px solid rgba(139,92,246,.2)}.stats-card h3{font-size:1.5rem;margin-bottom:1.5rem;color:var(--text-primary)}.stat-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;margin-bottom:.5rem;background:#6366f11a;border-radius:8px}.stat-label{font-size:1.1rem;color:var(--text-secondary)}.stat-value{font-size:1.3rem;font-weight:700;color:var(--success-color)}.placeholder-text{font-size:1rem;color:var(--text-primary);margin-bottom:.5rem}.placeholder-details{color:var(--text-secondary);font-size:.9rem}.guest-mode-note{margin-top:1rem;padding:.75rem;background:#ec48991a;border:1px solid var(--accent-color);border-radius:8px;color:var(--accent-color);font-size:.95rem}.stats-actions{display:flex;justify-content:center}.view-tabs{display:flex;gap:1rem;justify-content:center;margin-bottom:2rem}.tab-button{padding:.75rem 2rem;font-size:1rem;border-radius:12px;font-weight:600;background:#8b5cf61a;border:2px solid rgba(139,92,246,.2);color:var(--text-secondary);transition:all .3s ease;cursor:pointer}.tab-button:hover:not(:disabled){background:#8b5cf626;border-color:#8b5cf666;transform:translateY(-2px)}.tab-button.active{background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));border-color:#8b5cf680;color:#fff;box-shadow:0 4px 12px #8b5cf666}.tab-button:disabled{opacity:.4;cursor:not-allowed}.dashboard-content{text-align:left;margin-bottom:2rem}@media(max-width:768px){.view-tabs{flex-direction:column}.tab-button{width:100%}.stats-screen{padding:0 .5rem}.stats-screen h2{font-size:2rem}}.dashboard-screen{max-width:1200px;margin:0 auto;padding:2rem 1rem}.dashboard-header{text-align:center;margin-bottom:3rem}.dashboard-header h2{font-size:2.5rem;margin-bottom:.5rem;color:var(--text-primary);background:linear-gradient(135deg,var(--success-color),var(--primary-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.dashboard-subtitle{font-size:1.1rem;color:var(--text-secondary)}.dashboard-content{margin-bottom:2rem}.no-data-container{display:flex;justify-content:center;align-items:center;min-height:60vh}.no-data-card{background:var(--bg-card);border-radius:24px;padding:4rem 3rem;border:2px solid rgba(139,92,246,.2);text-align:center;max-width:500px}.no-data-icon{font-size:5rem;margin-bottom:1.5rem}.no-data-card h3{font-size:1.8rem;color:var(--text-primary);margin-bottom:1rem}.no-data-card p{font-size:1.1rem;color:var(--text-secondary);margin-bottom:2rem;line-height:1.6}.start-training-button{padding:1rem 2.5rem;font-size:1.1rem;border-radius:12px;font-weight:600;background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));border:2px solid rgba(139,92,246,.3);color:#fff;cursor:pointer;transition:all .3s ease}.start-training-button:hover{transform:translateY(-2px);box-shadow:0 8px 16px #8b5cf680}.dashboard-actions{display:flex;justify-content:center;margin-top:3rem}.menu-button{padding:1rem 2.5rem;font-size:1.1rem;border-radius:12px;font-weight:600;background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));border:2px solid rgba(139,92,246,.3);transition:all .3s ease}.menu-button:hover{transform:translateY(-2px);box-shadow:0 8px 16px #8b5cf680}@media(max-width:768px){.dashboard-screen{padding:1rem .5rem}.dashboard-header h2{font-size:2rem}.no-data-card{padding:3rem 2rem}.no-data-icon{font-size:4rem}.no-data-card h3{font-size:1.5rem}.no-data-card p{font-size:1rem}}.app{display:flex;flex-direction:column;align-items:center;width:100%}.app-header{text-align:center;margin-bottom:3rem}.app-title{font-size:3rem;font-weight:700;margin-bottom:.5rem;background:linear-gradient(135deg,var(--primary-color),var(--accent-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;cursor:pointer;transition:transform .2s ease,opacity .2s ease;-webkit-user-select:none;user-select:none}.app-title:hover{transform:scale(1.05);opacity:.8}.app-title:active{transform:scale(.98)}.app-header p{font-size:1.2rem;color:var(--text-secondary)}.app-main{width:100%;max-width:800px}
