*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{color:#1a1a1a;background:#f7f4ef;min-height:100vh;font-family:Segoe UI,system-ui,-apple-system,sans-serif}#root{min-height:100vh}:root{--red:#c8102e;--red-dark:#9e0b24;--green:#00703c;--soft:#2e7d32;--aspirate:#1565c0;--nasal:#6a1b9a;--card:#fff;--bg:#f7f4ef;--border:#e0d8d0;--subtle:#666}.app{max-width:620px;margin:0 auto;padding:0 1rem 3rem}header{border-bottom:3px solid var(--red);align-items:center;gap:1rem;margin-bottom:1.5rem;padding:1.75rem 0 1.5rem;display:flex}.dragon{font-size:2.5rem}header h1{color:var(--red);font-size:2rem;font-weight:800;line-height:1.1}header p{color:var(--subtle);margin-top:.2rem;font-size:.85rem}nav{background:var(--red);border-radius:8px;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1px;margin-bottom:1.5rem;padding:1px;display:grid;overflow:hidden}nav button{color:var(--red);cursor:pointer;background:#fff;border:none;min-width:0;padding:.65rem;font-size:.95rem;font-weight:600;transition:background .15s,color .15s}nav button.active{background:var(--red);color:#fff}nav button:not(.active):hover{background:#fff5f5}.badge{color:#fff;border-radius:20px;padding:.3rem .75rem;font-size:.82rem;font-weight:700;display:inline-block}.badge.soft{background:var(--soft)}.badge.aspirate{background:var(--aspirate)}.badge.nasal{background:var(--nasal)}.badge.preposition{background:#8d6e63}.badge.gender{background:#ef6c00}.badge.plural{background:#546e7a}.badge.dialogue{background:#7b1fa2}.filter-bar{flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem;display:flex}.filter-btn{cursor:pointer;background:#fff;border:2px solid #0000;border-radius:20px;padding:.35rem .7rem;font-size:.78rem;font-weight:600;transition:all .15s}.filter-btn.all{color:var(--subtle);border-color:var(--border)}.filter-btn.soft{color:var(--soft);border-color:var(--soft)}.filter-btn.aspirate{color:var(--aspirate);border-color:var(--aspirate)}.filter-btn.nasal{color:var(--nasal);border-color:var(--nasal)}.filter-btn.preposition{color:#8d6e63;border-color:#8d6e63}.filter-btn.gender{color:#ef6c00;border-color:#ef6c00}.filter-btn.plural{color:#546e7a;border-color:#546e7a}.filter-btn.dialogue{color:#7b1fa2;border-color:#7b1fa2}.filter-btn.all.active{color:#fff;background:#555;border-color:#555}.filter-btn.soft.active{background:var(--soft);color:#fff}.filter-btn.aspirate.active{background:var(--aspirate);color:#fff}.filter-btn.nasal.active{background:var(--nasal);color:#fff}.filter-btn.preposition.active{color:#fff;background:#8d6e63;border-color:#8d6e63}.filter-btn.gender.active{color:#fff;background:#ef6c00;border-color:#ef6c00}.filter-btn.plural.active{color:#fff;background:#546e7a;border-color:#546e7a}.filter-btn.dialogue.active{color:#fff;background:#7b1fa2;border-color:#7b1fa2}.score-bar{justify-content:flex-end;align-items:center;gap:.75rem;min-height:1.8rem;margin-bottom:.5rem;display:flex}.score{color:var(--green);font-size:1rem;font-weight:700}.pct{color:var(--subtle);font-size:.9rem}.streak{color:#e65100;font-size:.95rem;font-weight:700}.q-card{background:var(--card);border:2px solid var(--border);border-radius:12px;flex-direction:column;gap:1.25rem;padding:1.75rem;transition:border-color .2s;display:flex;box-shadow:0 2px 8px #0000000f}.q-card.correct{border-color:var(--soft)}.q-card.incorrect{border-color:var(--red)}.word-block,.prep-prompt{flex-direction:column;gap:.2rem;display:flex}.prep-meta,.ref-note{color:var(--subtle);line-height:1.5}.prep-meta{font-size:.95rem}.dialogue-line,.dialogue-cue{margin:0}.dialogue-line{color:#1a1a1a;font-size:1.35rem;font-weight:700}.dialogue-cue{color:var(--red);font-size:1rem;font-weight:700}.ref-note{margin-top:.75rem;font-size:.9rem}.record-note{color:var(--subtle);margin:-.5rem 0 0;font-size:.9rem}.choice-block{flex-direction:column;gap:.75rem;display:flex}.choice-prompt{color:#1a1a1a;font-weight:600}.choice-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem;display:grid}.choice-btn{border:2px solid var(--border);color:#1a1a1a;cursor:pointer;background:#fff;border-radius:10px;padding:.9rem 1rem;font-family:inherit;font-size:.98rem;font-weight:700;transition:border-color .15s,background .15s,color .15s}.choice-btn:hover:not(:disabled),.choice-btn:focus-visible{border-color:var(--red);outline:none}.choice-btn.correct{border-color:var(--soft);color:#1b5e20;background:#e8f5e9}.choice-btn.incorrect{border-color:var(--red);color:#b71c1c;background:#ffebee}.inline-next-btn{background:var(--green);color:#fff;cursor:pointer;border:none;border-radius:8px;align-self:flex-start;padding:.7rem 1.1rem;font-family:inherit;font-weight:700}.inline-next-btn:hover{background:#005a30}.welsh-word{color:#1a1a1a;letter-spacing:-1px;font-size:3rem;font-weight:800;line-height:1.1}.meaning{color:var(--subtle);font-size:1rem;font-style:italic}form{gap:.75rem;display:flex}input[type=text]{border:2px solid var(--border);background:#fff;border-radius:8px;outline:none;flex:1;padding:.75rem 1rem;font-family:inherit;font-size:1.1rem;transition:border-color .2s}input[type=text]:focus{border-color:var(--red)}input[type=text].correct{border-color:var(--soft);background:#f1f8f1}input[type=text].incorrect{border-color:var(--red);background:#fff5f5}button[type=submit]{background:var(--red);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:8px;padding:.75rem 1.25rem;font-family:inherit;font-size:1rem;font-weight:700;transition:background .15s}button[type=submit]:hover{background:var(--red-dark)}button[type=submit].next{background:var(--green)}button[type=submit].next:hover{background:#005a30}.feedback{border-radius:8px;padding:.7rem 1rem;font-size:.95rem}.feedback.correct{color:#1b5e20;background:#e8f5e9}.feedback.incorrect{color:#b71c1c;background:#ffebee}.reference{background:var(--card);border:2px solid var(--border);border-radius:12px;padding:1.75rem;box-shadow:0 2px 8px #0000000f}.reference h2{color:var(--red);margin-bottom:1.5rem;font-size:1.25rem}.reference .ref-subtitle{margin-top:2rem}.progress-card{flex-direction:column;gap:1.5rem;display:flex}.progress-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.progress-copy,.empty-state,.empty-mini{color:var(--subtle)}.secondary-btn{border:2px solid var(--border);color:var(--red);cursor:pointer;background:#fff;border-radius:8px;padding:.65rem 1rem;font-family:inherit;font-weight:700}.secondary-btn:hover{border-color:var(--red);background:#fff5f5}.progress-overview{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.75rem;display:grid}.metric-card{border:1px solid var(--border);background:#fcfbf9;border-radius:10px;flex-direction:column;gap:.25rem;padding:.9rem 1rem;display:flex}.metric-card strong{color:#1a1a1a;font-size:1.5rem}.metric-label{text-transform:uppercase;letter-spacing:.04em;color:var(--subtle);font-size:.8rem}.progress-grid{gap:1.25rem;display:grid}.progress-section{flex-direction:column;gap:.75rem;display:flex}.progress-section h3{color:var(--red);margin:0}.practice-list,.recent-list{flex-direction:column;gap:.75rem;display:flex}.practice-item,.recent-item{border:1px solid var(--border);background:#fcfbf9;border-radius:10px;padding:.9rem 1rem}.practice-item p,.recent-item p{color:var(--subtle);margin:.35rem 0 0}.practice-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;display:flex}.practice-badges{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.mini-badge{color:#5f5147;letter-spacing:.02em;background:#f1ece6;border-radius:999px;padding:.2rem .55rem;font-size:.74rem;font-weight:700;display:inline-block}.recent-item{align-items:flex-start;gap:.75rem;display:flex}.recent-body{flex:1;min-width:0}.recent-item.correct{border-color:#c8e6c9}.recent-item.incorrect{border-color:#ffcdd2}.recent-result{border-radius:999px;flex:none;place-items:center;width:1.75rem;height:1.75rem;font-weight:700;display:grid}.recent-item.correct .recent-result{color:#1b5e20;background:#e8f5e9}.recent-item.incorrect .recent-result{color:#b71c1c;background:#ffebee}.ref-tables{flex-direction:column;gap:1.75rem;display:flex}.ref-tables section .badge{margin-bottom:.75rem;display:block}table{border-collapse:collapse;width:100%}th{text-align:left;border-bottom:2px solid var(--border);color:var(--subtle);text-transform:uppercase;letter-spacing:.5px;background:#f5f5f5;padding:.45rem .75rem;font-size:.78rem}td{border-bottom:1px solid var(--border);padding:.5rem .75rem}td code{font-family:Courier New,monospace;font-size:1rem}tr:last-child td{border-bottom:none}.ctx-sentence{color:#1a1a1a;flex-wrap:wrap;align-items:baseline;gap:.1em;font-size:1.5rem;line-height:2;display:flex}.ctx-input{border:none;border-bottom:2px solid var(--red);color:var(--red);text-align:center;background:0 0;outline:none;min-width:5ch;padding:0 .2em;font-family:inherit;font-size:1.5rem;transition:border-color .2s,color .2s}.ctx-input.correct{border-color:var(--soft);color:var(--soft)}.ctx-input.incorrect{border-color:var(--red);color:var(--red)}.ctx-translation{color:var(--subtle);margin-top:-.5rem;font-size:.9rem;font-style:italic}.ctx-hint{color:var(--subtle);font-size:.9rem}.trigger-block{flex-direction:column;gap:.4rem;margin-top:.75rem;display:flex}.trigger-note{font-size:.88rem;line-height:1.5}.badge.no-mut{background:#757575}.ctx-form{flex-direction:column;gap:1.25rem;display:flex}@media (width<=720px){nav{grid-template-columns:repeat(2,minmax(0,1fr))}}
