*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary: #6C3CE1;--primary-light: #8B5CF6;--primary-dark: #5521C5;--bg: #0F0A1A;--bg-card: #1A1228;--bg-card-hover: #231A35;--bg-input: #1E1530;--text: #F0EAF8;--text-secondary: #A89BBD;--text-muted: #6B5E7E;--success: #4CAF50;--error: #F44336;--warning: #FF9800;--border: rgba(139, 92, 246, .15);--border-hover: rgba(139, 92, 246, .35);--radius: 16px;--radius-sm: 10px;--radius-xs: 6px;--shadow: 0 4px 24px rgba(0, 0, 0, .3);--shadow-lg: 0 8px 40px rgba(0, 0, 0, .4);--transition: .2s ease}[data-theme=light]{--bg: #F5F0FF;--bg-card: #FFFFFF;--bg-card-hover: #F0E8FF;--bg-input: #EDE5F8;--text: #1A1028;--text-secondary: #5A4D6E;--text-muted: #9B8DB0;--border: rgba(108, 60, 225, .15);--border-hover: rgba(108, 60, 225, .35);--shadow: 0 4px 24px rgba(108, 60, 225, .08);--shadow-lg: 0 8px 40px rgba(108, 60, 225, .12);--staff-line-color: rgba(0, 0, 0, .25)}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;min-height:100dvh;line-height:1.5;-webkit-font-smoothing:antialiased;overflow-x:hidden}#root{min-height:100vh;min-height:100dvh}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--primary-dark);border-radius:3px}.page{max-width:500px;margin:0 auto;padding:20px 16px 100px;min-height:100vh;min-height:100dvh}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;gap:12px}.page-header h2{font-size:1.3rem;font-weight:700;flex:1}.back-btn{width:40px;height:40px;border-radius:50%;border:1px solid var(--border);background:var(--bg-card);color:var(--text);font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition);flex-shrink:0}.back-btn:hover{background:var(--bg-card-hover);border-color:var(--border-hover)}.sound-toggle{width:40px;height:40px;border-radius:50%;border:1px solid var(--border);background:var(--bg-card);font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition);flex-shrink:0}.sound-toggle:hover{background:var(--bg-card-hover)}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:16px;color:var(--text-secondary)}.spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.home-header{text-align:center;margin-bottom:32px;padding-top:16px}.logo{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:8px}.logo-icon{font-size:2.5rem}.logo h1{font-size:2rem;font-weight:900;background:linear-gradient(135deg,var(--primary-light),#FFD700);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.tagline{color:var(--text-secondary);font-size:.95rem}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:24px}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px;display:flex;align-items:center;gap:12px;transition:all var(--transition)}.stat-card:hover{border-color:var(--border-hover);background:var(--bg-card-hover)}.stat-icon{font-size:1.5rem;flex-shrink:0}.stat-value{font-size:1.3rem;font-weight:800;line-height:1.2}.stat-label{font-size:.75rem;color:var(--text-secondary);font-weight:500}.stat-subtitle{font-size:.7rem;color:var(--text-muted)}.progress-section{margin-bottom:24px}.progress-section h3{font-size:1rem;margin-bottom:12px;color:var(--text-secondary)}.progress-bar-container{margin-bottom:10px}.progress-label{display:flex;justify-content:space-between;font-size:.8rem;color:var(--text-secondary);margin-bottom:4px}.progress-bar-bg{height:8px;background:var(--bg-card);border-radius:4px;overflow:hidden}.progress-bar-fill{height:100%;border-radius:4px;transition:width .5s ease}.action-buttons{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.action-btn{display:flex;align-items:center;gap:14px;padding:18px 20px;border-radius:var(--radius);border:1px solid var(--border);text-decoration:none;color:var(--text);transition:all var(--transition);cursor:pointer}.action-btn:hover{border-color:var(--border-hover);transform:translateY(-1px)}.action-btn.primary{background:linear-gradient(135deg,var(--primary),var(--primary-dark));border-color:transparent}.action-btn.primary:hover{box-shadow:0 4px 20px #6c3ce166}.action-btn.secondary{background:var(--bg-card)}.action-btn.secondary:hover{background:var(--bg-card-hover)}.action-btn.tertiary{background:var(--bg-card);opacity:.8}.action-icon{font-size:1.8rem;flex-shrink:0}.action-text{flex:1;display:flex;flex-direction:column}.action-text strong{font-size:1rem;font-weight:600}.action-text span{font-size:.8rem;color:var(--text-secondary)}.action-btn.primary .action-text span{color:#ffffffb3}.action-arrow{font-size:1.2rem;color:var(--text-muted);transition:transform var(--transition)}.action-btn:hover .action-arrow{transform:translate(4px)}.tip-box{background:#6c3ce114;border:1px solid rgba(108,60,225,.2);border-radius:var(--radius-sm);padding:16px;display:flex;gap:12px;font-size:.85rem;color:var(--text-secondary);line-height:1.5}.tip-icon{font-size:1.2rem;flex-shrink:0}.session-stats{display:flex;justify-content:center;gap:20px;margin-bottom:20px}.session-stat{display:flex;align-items:center;gap:6px;font-size:1rem;font-weight:600;color:var(--text-secondary)}.stat-emoji{font-size:1.1rem}.flashcard-staff{display:flex;justify-content:center;margin-bottom:20px}.question-text{text-align:center;font-size:1.1rem;color:var(--text-secondary);margin-bottom:16px}.result-text{text-align:center;font-size:1.1rem;margin-bottom:16px;padding:12px;border-radius:var(--radius-sm);font-weight:500}.result-text.correct{background:#4caf501a;color:var(--success)}.result-text.wrong{background:#f443361a;color:var(--error)}.answer-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:16px}.note-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:14px 8px;border-radius:var(--radius-sm);border:2px solid var(--border);background:var(--bg-card);color:var(--text);cursor:pointer;transition:all var(--transition);font-family:inherit}.note-btn:hover:not(.disabled){border-color:var(--primary);background:var(--bg-card-hover);transform:translateY(-2px)}.note-btn:active:not(.disabled){transform:translateY(0)}.note-btn.selected{border-color:var(--primary);background:#6c3ce133}.note-btn.correct{border-color:var(--success)!important;background:#4caf5026!important;color:var(--success)}.note-btn.wrong{border-color:var(--error)!important;background:#f4433626!important;color:var(--error)}.note-btn.disabled{opacity:.5;cursor:not-allowed}.note-primary{font-size:1.3rem;font-weight:800;line-height:1.2}.note-secondary{font-size:.65rem;color:var(--text-secondary);font-weight:500;opacity:.7}.note-btn.correct .note-secondary,.note-btn.wrong .note-secondary{color:inherit;opacity:.8}.keyboard-hint{text-align:center;font-size:.8rem;color:var(--text-muted);padding:8px}.chart-container{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px;margin-bottom:16px}.evolution-chart{width:100%;height:auto;max-height:200px}.chart-empty{text-align:center;padding:30px 20px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary)}.chart-empty p{font-size:1.1rem;margin-bottom:4px}.chart-empty span{font-size:.85rem;color:var(--text-muted)}.chart-title{font-size:.9rem;color:var(--text-secondary);margin-bottom:8px;margin-top:16px;font-weight:600}.chart-title:first-child{margin-top:0}.free-training-banner{background:linear-gradient(135deg,#6c3ce126,#8b5cf61a);border:1px solid rgba(108,60,225,.25);border-radius:var(--radius-sm);padding:10px 16px;margin-bottom:16px;font-size:.82rem;color:var(--primary-light);text-align:center;font-weight:500;animation:fadeIn .3s ease}.clef-info{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:16px;padding:8px 16px;background:var(--bg-card);border-radius:20px;border:1px solid var(--border);font-size:.85rem}.clef-symbol{font-size:1.3rem}.clef-label{font-weight:600;color:var(--text-secondary)}.region-label{color:var(--text-muted);font-size:.8rem}.all-done{text-align:center;padding:40px 20px}.done-icon{font-size:3rem;display:block;margin-bottom:16px}.all-done h3{font-size:1.3rem;margin-bottom:8px}.all-done p{color:var(--text-secondary);margin-bottom:20px}.game-menu{text-align:center}.game-title{margin-bottom:32px}.game-icon{font-size:3rem;display:block;margin-bottom:12px}.game-title h3{font-size:1.5rem;margin-bottom:8px}.game-title p{color:var(--text-secondary)}.speed-selector{margin-bottom:24px}.speed-selector h4{font-size:.9rem;color:var(--text-secondary);margin-bottom:12px}.speed-options{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.speed-btn{padding:10px 18px;border-radius:var(--radius-sm);border:2px solid var(--border);background:var(--bg-card);color:var(--text);cursor:pointer;font-family:inherit;font-weight:600;font-size:.85rem;transition:all var(--transition)}.speed-btn:hover{border-color:var(--primary)}.speed-btn.active{border-color:var(--primary);background:#6c3ce133;color:var(--primary-light)}.high-score-display{font-size:1rem;color:var(--text-secondary);margin-bottom:24px;padding:12px;background:var(--bg-card);border-radius:var(--radius-sm)}.btn-start-game{display:inline-flex;align-items:center;gap:8px;padding:18px 40px;border-radius:50px;border:none;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;font-size:1.2rem;font-weight:700;cursor:pointer;font-family:inherit;transition:all var(--transition);margin-bottom:32px}.btn-start-game:hover{transform:translateY(-2px);box-shadow:0 8px 30px #6c3ce166}.game-rules{text-align:left;background:var(--bg-card);border-radius:var(--radius-sm);padding:20px}.game-rules h4{margin-bottom:12px;font-size:.95rem}.game-rules ul{list-style:none;display:flex;flex-direction:column;gap:8px}.game-rules li{font-size:.85rem;color:var(--text-secondary)}.game-header{display:flex;align-items:center;gap:8px;margin-bottom:16px}.game-hud{flex:1;display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.hud-item{display:flex;align-items:center;gap:4px;background:var(--bg-card);padding:6px 12px;border-radius:20px;font-size:.85rem;border:1px solid var(--border)}.hud-item strong{font-weight:700}.note-progress-container{margin-bottom:12px}.note-progress-bar{height:6px;background:var(--bg-card);border-radius:3px;overflow:hidden}.note-progress-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--primary-light));border-radius:3px;transition:width .1s linear}.note-progress-bar.urgent .note-progress-fill{background:linear-gradient(90deg,var(--error),#FF6B6B)}.game-staff{display:flex;justify-content:center;margin-bottom:16px}.game-note-wrapper{transition:all .2s ease}.game-note-wrapper.correct{animation:pulse-correct .4s ease}.game-note-wrapper.wrong{animation:shake .4s ease}@keyframes pulse-correct{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-8px)}75%{transform:translate(8px)}}.game-feedback{text-align:center;font-size:1.1rem;font-weight:700;margin-bottom:12px;padding:10px;border-radius:var(--radius-sm)}.game-feedback.correct{color:var(--success);background:#4caf501a}.game-feedback.wrong{color:var(--error);background:#f443361a}.game-answer-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:12px}.game-note-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:12px 6px;border-radius:var(--radius-sm);border:2px solid var(--border);background:var(--bg-card);color:var(--text);cursor:pointer;transition:all var(--transition);font-family:inherit}.game-note-btn:hover:not(:disabled){border-color:var(--primary);background:var(--bg-card-hover);transform:translateY(-2px)}.game-note-btn:disabled{opacity:.5;cursor:not-allowed}.game-note-btn.reveal-correct{border-color:var(--success)!important;background:#4caf5026!important;opacity:1!important}.gnote-primary{font-size:1.1rem;font-weight:800;line-height:1.2}.gnote-secondary{font-size:.6rem;color:var(--text-secondary);font-weight:500;opacity:.7}.game-over{text-align:center;padding:20px 0}.game-over-icon{font-size:4rem;margin-bottom:16px}.game-over h3{font-size:1.5rem;margin-bottom:24px}.final-score{margin-bottom:24px}.score-label{display:block;font-size:.9rem;color:var(--text-secondary);margin-bottom:4px}.score-value{font-size:3rem;font-weight:900;background:linear-gradient(135deg,var(--primary-light),#FFD700);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.game-over-stats{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:32px}.go-stat{background:var(--bg-card);border-radius:var(--radius-sm);padding:14px;display:flex;flex-direction:column;gap:4px}.go-stat span{font-size:.8rem;color:var(--text-secondary)}.go-stat strong{font-size:1.3rem;font-weight:700}.game-over-buttons{display:flex;flex-direction:column;gap:12px}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:16px 32px;border-radius:50px;border:none;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;font-size:1.1rem;font-weight:700;cursor:pointer;font-family:inherit;transition:all var(--transition);text-decoration:none}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 30px #6c3ce166}.btn-secondary{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:16px 32px;border-radius:50px;border:2px solid var(--border);background:var(--bg-card);color:var(--text);font-size:1rem;font-weight:600;cursor:pointer;font-family:inherit;transition:all var(--transition);text-decoration:none}.btn-secondary:hover{border-color:var(--border-hover);background:var(--bg-card-hover)}.stats-overview{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:24px}.stats-section{margin-bottom:28px}.stats-section h3{font-size:1.1rem;margin-bottom:16px;color:var(--text)}.note-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.note-stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 8px;text-align:center;position:relative}.note-stat-card.mastered{border-color:#4caf504d;background:#4caf500d}.note-stat-name{font-size:1rem;font-weight:700;margin-bottom:4px}.note-stat-accuracy{font-size:.9rem;font-weight:600}.note-stat-reviews{font-size:.7rem;color:var(--text-muted)}.note-stat-badge{position:absolute;top:4px;right:4px;font-size:.8rem}.sessions-list{display:flex;flex-direction:column;gap:8px}.session-item{display:flex;align-items:center;justify-content:space-between;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 16px;font-size:.85rem}.session-mode{font-weight:600}.session-date{color:var(--text-secondary)}.session-score{font-weight:700;color:var(--primary-light)}.settings-section{margin-bottom:28px;padding:20px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}.settings-section h3{font-size:1.1rem;margin-bottom:12px}.settings-section.danger{border-color:#f4433633}.settings-section.danger h3{color:var(--error)}.settings-section.about{text-align:center;color:var(--text-secondary)}.settings-section.about p{margin-bottom:4px}.about-tech{font-size:.75rem!important;color:var(--text-muted)!important;margin-top:12px!important}.about-author{font-size:.85rem!important;color:var(--primary-light)!important;margin-top:8px!important}.settings-desc{font-size:.85rem;color:var(--text-secondary);margin-bottom:16px;line-height:1.5}.settings-buttons{display:flex;gap:12px;flex-wrap:wrap}.btn-export,.btn-import{display:inline-flex;align-items:center;gap:8px;padding:12px 20px;border-radius:var(--radius-sm);border:2px solid var(--border);background:var(--bg-input);color:var(--text);font-size:.9rem;font-weight:600;cursor:pointer;font-family:inherit;transition:all var(--transition)}.btn-export:hover,.btn-import:hover{border-color:var(--primary)}.btn-reset{padding:12px 24px;border-radius:var(--radius-sm);border:2px solid rgba(244,67,54,.3);background:#f443361a;color:var(--error);font-size:.9rem;font-weight:600;cursor:pointer;font-family:inherit;transition:all var(--transition)}.btn-reset:hover{background:#f4433633}.btn-reset.confirm{background:var(--error);color:#fff;border-color:var(--error)}.settings-options{display:flex;flex-direction:column;gap:8px}.settings-option{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:var(--radius-sm);border:2px solid var(--border);cursor:pointer;transition:all var(--transition)}.settings-option:hover{border-color:var(--border-hover)}.settings-option.active{border-color:var(--primary);background:#6c3ce11a}.settings-option input{display:none}.settings-option div{display:flex;flex-direction:column}.settings-option strong{font-size:.95rem}.settings-option span{font-size:.8rem;color:var(--text-secondary)}.settings-toggle{display:flex;align-items:center;justify-content:space-between;cursor:pointer}.settings-toggle span{font-size:.95rem}.toggle{width:50px;height:28px;border-radius:14px;position:relative;transition:all var(--transition)}.toggle.on{background:var(--primary)}.toggle.off{background:var(--bg-input);border:2px solid var(--border)}.toggle-knob{width:22px;height:22px;border-radius:50%;background:#fff;position:absolute;top:3px;left:3px;transition:all var(--transition)}.toggle.on .toggle-knob{left:25px}.settings-message{background:#4caf501a;border:1px solid rgba(76,175,80,.3);color:var(--success);padding:12px 16px;border-radius:var(--radius-sm);margin-bottom:20px;font-size:.9rem;text-align:center}@media(max-width:380px){.answer-grid,.game-answer-grid{grid-template-columns:repeat(3,1fr)}.stats-grid,.stats-overview{grid-template-columns:1fr}.note-stats-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:768px){.page{padding:32px 24px 100px}.logo h1{font-size:2.5rem}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.page>*{animation:fadeIn .3s ease forwards}@media(display-mode:standalone){.page{padding-top:40px}}
