@import"https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;500;600;700&family=Source+Sans+3:wght@300;400;500;600&display=swap";:root{--bg-primary: #faf8f5;--bg-secondary: #f5f2ed;--bg-tertiary: #eee9e1;--bg-card: #ffffff;--text-primary: #2d2a26;--text-secondary: #5c5751;--text-muted: #8a847b;--text-hint: #a39d94;--accent-primary: #b8860b;--accent-hover: #9a7209;--accent-light: #f5e6c8;--accent-subtle: rgba(184, 134, 11, .08);--success: #5a8f5a;--success-bg: #e8f2e8;--success-border: #a8d4a8;--error: #c45c5c;--error-bg: #fceaea;--error-border: #e8a8a8;--border-light: #e8e4dd;--border-medium: #d9d4cb;--shadow-sm: 0 1px 2px rgba(45, 42, 38, .04);--shadow-md: 0 2px 8px rgba(45, 42, 38, .06);--shadow-lg: 0 4px 16px rgba(45, 42, 38, .08);--font-display: "Playfair Display", Georgia, "Times New Roman", serif;--font-body: "Source Sans 3", -apple-system, BlinkMacSystemFont, sans-serif;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px}*{box-sizing:border-box}body{font-family:var(--font-body);font-weight:400;font-size:16px;line-height:1.6;margin:0;padding:var(--space-lg);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;-webkit-font-smoothing:antialiased}#app{max-width:640px;margin:0 auto}h1{font-family:var(--font-display);font-weight:600;font-size:2.25rem;letter-spacing:-.02em;color:var(--text-primary);margin:0 0 var(--space-sm) 0;line-height:1.2}h2{font-family:var(--font-display);font-weight:500;font-size:1.5rem;letter-spacing:-.01em;color:var(--text-primary);margin:0 0 var(--space-md) 0;line-height:1.3}h3{font-family:var(--font-body);font-weight:600;font-size:1.125rem;color:var(--text-primary);margin:0 0 var(--space-md) 0}p{margin:0 0 var(--space-md) 0;color:var(--text-secondary)}a{color:var(--accent-primary);text-decoration:none;transition:color .15s ease}a:hover{color:var(--accent-hover)}.back-link{display:inline-flex;align-items:center;gap:var(--space-xs);font-size:.875rem;font-weight:500;color:var(--text-muted);margin-bottom:var(--space-lg);transition:color .15s ease}.back-link:hover{color:var(--accent-primary)}.exercise-container{display:flex;flex-direction:column;gap:var(--space-xl)}.controls{display:flex;gap:var(--space-md);flex-wrap:wrap}.controls button,.controls a{font-family:var(--font-body)}.check-button{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-md) var(--space-xl);font-size:1rem;font-weight:600;background:var(--accent-primary);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease;box-shadow:var(--shadow-sm)}.check-button:hover{background:var(--accent-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.check-button:active{transform:translateY(0)}.check-button:disabled{background:var(--border-medium);color:var(--text-muted);cursor:not-allowed;box-shadow:none;transform:none}.play-again-btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-sm) var(--space-lg);font-size:.9375rem;font-weight:500;background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border-medium);border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.play-again-btn:hover{background:var(--bg-secondary);border-color:var(--accent-primary);color:var(--accent-primary)}.note-choice-buttons{display:flex;gap:var(--space-md);flex-wrap:wrap}.note-choice-btn{flex:1;min-width:120px;padding:var(--space-lg) var(--space-xl);font-family:var(--font-display);font-size:1.75rem;font-weight:600;background:var(--bg-card);color:var(--text-primary);border:2px solid var(--border-medium);border-radius:var(--radius-lg);cursor:pointer;transition:all .15s ease;box-shadow:var(--shadow-sm)}.note-choice-btn:hover{border-color:var(--accent-primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.note-choice-btn:active{transform:translateY(0)}.note-choice-btn.correct{background:var(--success-bg);border-color:var(--success);color:var(--success)}.note-choice-btn.incorrect{background:var(--error-bg);border-color:var(--error);color:var(--error)}.feedback{padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);font-weight:500}.feedback.success{background:var(--success-bg);color:var(--success);border:1px solid var(--success-border)}.feedback.error{background:var(--error-bg);color:var(--error);border:1px solid var(--error-border)}.feedback small{display:block;margin-top:var(--space-sm);font-weight:400;opacity:.85}.feedback-tappable{cursor:pointer}.feedback.success.feedback-tappable:hover{opacity:.9}.continue-hint{font-weight:400;opacity:.85}span.continue-hint.feedback-tappable{display:inline-block;margin-top:var(--space-sm);padding:var(--space-sm) var(--space-md);background:#0000000d;border-radius:var(--radius-sm);cursor:pointer}span.continue-hint.feedback-tappable:hover{background:#0000001a}.stats{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-md);font-size:.9375rem}.stats-label{color:var(--text-muted);font-weight:500}.learning-info{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap;padding:var(--space-md) var(--space-lg);background:var(--accent-subtle);border:1px solid var(--accent-light);border-radius:var(--radius-md);font-size:.9375rem}.learning-info .stats-link{margin-left:auto;font-size:.875rem;font-weight:500}.learning-info .stats-link+.stats-link{margin-left:var(--space-md)}.stats-link{color:var(--accent-primary);font-weight:500;text-decoration:none}.stats-link:hover{text-decoration:underline}.keyboard-hints{font-size:.8125rem;color:var(--text-hint);margin-bottom:var(--space-lg)}.keyboard-hints strong{color:var(--text-muted);font-weight:600}kbd{display:inline-block;padding:.125rem .375rem;font-family:var(--font-body);font-size:.75rem;font-weight:600;background:var(--bg-secondary);border:1px solid var(--border-medium);border-radius:var(--radius-sm);color:var(--text-secondary);box-shadow:0 1px 0 var(--border-medium)}.danger-zone{margin-top:var(--space-2xl);padding-top:var(--space-lg);border-top:1px solid var(--border-light);text-align:center}.danger-btn{padding:var(--space-sm) var(--space-md);font-family:var(--font-body);font-size:.8125rem;font-weight:500;background:transparent;color:var(--text-muted);border:1px solid var(--border-medium);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s ease}.danger-btn:hover{background:var(--error);color:#fff;border-color:var(--error)}.danger-warning{color:var(--text-hint);font-size:.75rem;margin-top:var(--space-sm);margin-bottom:0}.intro-subtitle{font-family:var(--font-body);font-size:1rem;font-weight:400;color:var(--accent-primary);margin-top:calc(-1 * var(--space-sm));margin-bottom:var(--space-lg);letter-spacing:.05em;text-transform:uppercase}.intro-container{max-width:560px}.intro-container.exercise-container{gap:var(--space-lg)}.intro-container .intro-section{margin:0;padding:0}.intro-container .intro-section h2{font-size:1.25rem;margin-bottom:var(--space-sm);padding-bottom:var(--space-xs);border-bottom:2px solid var(--accent-light)}.intro-container .intro-section>p{font-size:.9375rem;line-height:1.7;margin-bottom:var(--space-md)}.intro-steps{margin:var(--space-md) 0 var(--space-lg) 0;padding-left:var(--space-lg);list-style:none;counter-reset:steps}.intro-steps li{position:relative;margin-bottom:var(--space-md);padding-left:var(--space-sm);font-size:.9375rem;line-height:1.5;color:var(--text-secondary);counter-increment:steps}.intro-steps li:last-child{margin-bottom:0}.intro-steps li:before{content:counter(steps);position:absolute;left:calc(-1 * var(--space-lg) - var(--space-sm));top:0;width:1.5rem;height:1.5rem;display:flex;align-items:center;justify-content:center;background:var(--accent-primary);color:#fff;font-size:.75rem;font-weight:600;border-radius:50%}.intro-steps li strong{color:var(--text-primary);font-weight:600}.intro-tips{margin:var(--space-md) 0 0 0;padding-left:var(--space-lg)}.intro-tips li{margin-bottom:var(--space-md);font-size:.9375rem;color:var(--text-secondary)}.intro-tips li::marker{color:var(--accent-primary)}.intro-container .controls,.intro-controls{justify-content:center}.start-button{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-md) var(--space-2xl);font-size:1.0625rem;font-weight:600;text-decoration:none;margin-top:var(--space-sm)}.introduction-title{text-align:center;margin-bottom:var(--space-xl)}.introduction-title h2{font-size:1.75rem;margin-bottom:var(--space-sm)}.introduction-title p{color:var(--text-muted);font-size:.9375rem;margin:0}.intro-section{margin:var(--space-lg) 0}.intro-section h3{font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:var(--space-md);text-align:center}.intro-buttons{display:flex;gap:var(--space-sm);flex-wrap:wrap;justify-content:center}.intro-note-btn{padding:var(--space-md) var(--space-lg);font-family:var(--font-display);font-size:1.25rem;font-weight:500;background:var(--bg-card);color:var(--text-primary);border:2px solid var(--border-medium);border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease;box-shadow:var(--shadow-sm)}.intro-note-btn:hover{border-color:var(--accent-primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.intro-note-btn:active{transform:translateY(0)}.intro-note-highlighted{background:var(--accent-subtle);border-color:var(--accent-primary)}.intro-note-highlighted:hover{background:var(--accent-light)}.intro-note-btn.playing{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff;transform:scale(.98)}.performance-matrix{width:100%;border-collapse:collapse;margin:var(--space-md) 0;font-size:.8125rem;background:var(--bg-card);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm)}.performance-matrix th,.performance-matrix td{padding:var(--space-sm);text-align:center;border:1px solid var(--border-light)}.performance-matrix th{background:var(--bg-secondary);font-weight:600;color:var(--text-secondary)}.performance-matrix tbody th{text-align:left;padding-left:var(--space-md)}.performance-matrix td{min-width:2.5rem}.perf-green{background:var(--success);color:#fff;font-weight:600}.perf-amber{background:#d4a017;color:#fff;font-weight:600}.perf-red{background:var(--error);color:#fff;font-weight:600}.perf-na{background:var(--bg-tertiary);color:var(--text-hint)}.perf-empty{background:var(--bg-card)}.perf-clickable{cursor:pointer;transition:opacity .15s ease}.perf-clickable:hover{opacity:.8}.stats-legend{display:flex;gap:var(--space-md);justify-content:center;margin:var(--space-lg) 0}.stats-legend span{padding:var(--space-xs) var(--space-md);border-radius:var(--radius-sm);font-size:.75rem;font-weight:600}.stats-note{color:var(--text-hint);font-size:.75rem;text-align:center;margin-top:var(--space-md)}.note-change-modal{position:fixed;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;background-color:#0000;z-index:1000;pointer-events:none;transition:background-color .3s ease}.note-change-modal.visible{background-color:#0009}.note-change-content{background:#1a1a2e;color:#fff;padding:var(--space-xl) var(--space-2xl);border-radius:var(--radius-lg);font-size:1.75rem;font-weight:500;box-shadow:0 8px 32px #00000080;transform:scale(.9);opacity:0;transition:transform .3s ease,opacity .3s ease}.note-change-modal.visible .note-change-content{transform:scale(1);opacity:1}.note-change-content strong{color:#4ecdc4;font-size:2.25rem;font-weight:700}@media (max-width: 480px){body{padding:var(--space-md)}h1{font-size:1.75rem}.note-choice-btn{min-width:100px;padding:var(--space-md) var(--space-lg);font-size:1.5rem}.intro-steps li{padding-left:0}.intro-steps li:before{position:static;display:inline-flex;margin-right:var(--space-sm);margin-bottom:-.25rem}}@media (pointer: coarse){.note-choice-btn{min-height:64px;padding:var(--space-lg) var(--space-xl)}.play-again-btn{min-height:44px;padding:var(--space-md) var(--space-lg)}.check-button,.start-button{min-height:48px}.intro-note-btn{min-height:48px;padding:var(--space-md) var(--space-xl)}.note-choice-buttons{gap:var(--space-lg)}.feedback{padding:var(--space-lg)}span.continue-hint.feedback-tappable{padding:var(--space-md) var(--space-lg);font-size:1rem}.danger-btn{padding:var(--space-md) var(--space-lg);min-height:44px}}
