.welcome{min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:max(2.5rem,calc(env(safe-area-inset-top) + 1.5rem)) 1.5rem max(2rem,env(safe-area-inset-bottom));text-align:center;background:var(--color-bg)}.welcome__mascot{font-size:7rem;line-height:1;color:var(--color-primary);margin-bottom:1.25rem;display:flex;align-items:center;justify-content:center}.welcome__title{font-size:2.5rem;font-weight:600;margin:0 0 .4rem;color:var(--color-text);letter-spacing:-.02em}.welcome__subtitle{font-size:1.05rem;font-weight:400;margin:0 0 2.75rem;color:var(--color-muted);max-width:22rem;line-height:1.4}.welcome__actions{width:100%;max-width:22rem;display:flex;flex-direction:column;align-items:center;gap:.5rem}.welcome__primary{width:100%;min-height:52px;padding:0 1.5rem;border:none;border-radius:var(--radius-pill);background:var(--color-primary);color:#fff;font-size:1.05rem;font-weight:500;transition:background-color .15s ease}.welcome__primary:hover,.welcome__primary:active{background:var(--color-primary-dark)}.back-link{display:inline-flex;align-items:center;gap:.4rem;background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-pill);color:var(--color-muted);font-size:.9rem;font-weight:500;padding:.45rem .9rem;min-height:36px;transition:border-color .15s ease,color .15s ease}.back-link:hover{border-color:var(--color-primary);color:var(--color-primary)}.back-link:active{background:var(--color-primary-soft)}.scope-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.6rem}.not-found{min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:max(2rem,calc(env(safe-area-inset-top) + 1rem)) 1.5rem max(2rem,env(safe-area-inset-bottom));text-align:center;background:var(--color-bg)}.not-found__icon{font-size:5rem;color:var(--color-muted);margin-bottom:1.25rem;opacity:.6}.not-found__title{margin:0 0 .5rem;font-size:1.5rem;font-weight:600;color:var(--color-text)}.not-found__text{margin:0 0 2rem;max-width:22rem;color:var(--color-muted);font-size:.95rem}.not-found__button{border:none;background:var(--color-primary);color:#fff;font-size:1rem;font-weight:500;border-radius:var(--radius-pill);padding:.85rem 1.6rem;min-height:48px;transition:background-color .15s ease}.not-found__button:hover{background:var(--color-primary-dark)}.exercise-type-picker__hero{padding:1.25rem 0 1.5rem;border-bottom:1px solid var(--color-border);margin-bottom:1.25rem}.exercise-type-picker__hero-title{margin:0 0 .25rem;font-size:1.75rem;font-weight:600;color:var(--color-text);letter-spacing:-.01em}.exercise-type-picker__hero-example{margin:0;color:var(--color-muted);font-size:.95rem}.exercise-type-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.6rem}.exercise-stub{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2.5rem 1.5rem}.exercise-stub__icon{font-size:4rem;color:var(--color-muted);margin-bottom:1.25rem;display:flex;align-items:center;justify-content:center;opacity:.6}.exercise-stub__title{margin:0 0 .5rem;font-size:1.25rem;font-weight:600;color:var(--color-text)}.exercise-stub__hint{margin:0 0 1.5rem;max-width:22rem;color:var(--color-muted);line-height:1.5;font-size:.95rem}.exercise-stub__badge{margin:0;display:inline-block;background:var(--color-primary-soft);color:var(--color-primary);border-radius:var(--radius-pill);padding:.4rem .9rem;font-size:.85rem;font-weight:500;letter-spacing:.02em}.exercise-stub__link{margin-top:.6rem;background:none;border:none;color:var(--color-muted);font-size:.95rem;font-weight:500;padding:.5rem 1rem}.exercise-stub__link:hover{color:var(--color-text)}.ab{flex:1;display:flex;flex-direction:column}.ab__stats{display:flex;justify-content:space-between;align-items:center;gap:.75rem;padding:.7rem 1rem;margin-bottom:1rem}.ab__stat{display:inline-flex;align-items:center;gap:.4rem;font-size:.95rem}.ab__stat--remaining{margin-left:auto}.ab__stat-icon--good{color:var(--color-primary)}.ab__stat-icon--bad{color:var(--color-error)}.ab__stat-label{color:var(--color-muted);font-size:.85rem;margin-right:.2rem}.ab__stat-value{font-weight:600;color:var(--color-text);font-variant-numeric:tabular-nums}.ab__word-card{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem 1rem;margin-bottom:1rem;min-height:9rem}.ab__word{margin:0;font-size:2.5rem;font-weight:500;letter-spacing:-.01em;color:var(--color-text);text-align:center;line-height:1.1}.ab__blank{display:inline-block;min-width:2.4ch;padding:0 .1em;margin:0 .05em;border-bottom:3px solid var(--color-border);text-align:center;transition:color .15s ease,border-color .15s ease}.ab__blank--correct{color:var(--color-primary);border-bottom-color:var(--color-primary)}.ab__blank--wrong{color:var(--color-error);border-bottom-color:var(--color-error)}.ab__options{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.ab__option{color:var(--color-text);font-family:inherit;font-size:1.5rem;font-weight:600;min-height:64px;transition:border-color .15s ease,background-color .15s ease,color .15s ease,opacity .15s ease}.ab__option:hover:not(:disabled){border-color:var(--color-primary)}.ab__option:active:not(:disabled){background:var(--color-primary-soft)}.ab__option:disabled{cursor:default}.ab__option--correct{background:var(--color-primary-soft);border-color:var(--color-primary);color:var(--color-primary)}.ab__option--wrong{background:var(--color-error-soft);border-color:var(--color-error);color:var(--color-error)}.ab__option--dim{opacity:.4}.ab-done{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2.5rem 1.5rem}.ab-done__icon{font-size:4rem;color:var(--color-primary);margin-bottom:1rem}.ab-done__cheer{margin:0 0 .5rem;font-size:1.4rem;font-weight:600;color:var(--color-text)}.ab-done__score{margin:0 0 1.25rem;font-size:3rem;font-weight:600;color:var(--color-primary);letter-spacing:-.02em;font-variant-numeric:tabular-nums}.ab-done__score-total{color:var(--color-muted);font-size:1.5rem;font-weight:500}.ab-done__breakdown{display:flex;gap:.5rem;justify-content:center;margin-bottom:2rem;flex-wrap:wrap}.ab-done__chip{display:inline-flex;align-items:center;gap:.35rem;background:var(--color-primary-soft);border-radius:var(--radius-pill);padding:.4rem .85rem;font-size:.9rem;font-weight:500;color:var(--color-primary)}.ab-done__chip--bad{background:var(--color-error-soft);color:var(--color-error)}.rule-picker{width:100%;max-width:22rem;margin:0 0 1.25rem;text-align:left}.rule-picker__toggle{width:100%;display:flex;align-items:center;justify-content:space-between;gap:.75rem;color:var(--color-text);font-family:inherit;font-size:.95rem;padding:.7rem 1rem;min-height:44px;transition:border-color .15s ease}.rule-picker__toggle:hover{border-color:var(--color-primary)}.rule-picker__summary{flex:1;text-align:left;line-height:1.35}.rule-picker__panel{margin-top:.5rem;padding:.5rem .75rem .75rem}.rule-picker__list{list-style:none;margin:0;padding:0}.rule-picker__item+.rule-picker__item{border-top:1px solid var(--color-border)}.rule-picker__row{display:flex;align-items:center;gap:.7rem;padding:.55rem .25rem;cursor:pointer;font-size:.9rem;line-height:1.35;color:var(--color-text)}.rule-picker__row input[type=checkbox]{flex:0 0 auto;width:1.05rem;height:1.05rem;accent-color:var(--color-primary);cursor:pointer}.rule-picker__title{flex:1}.rule-picker__count{flex:0 0 auto;color:var(--color-muted);font-size:.8rem;font-variant-numeric:tabular-nums}.rule-picker__actions{display:flex;gap:.5rem;margin-top:.5rem;padding-top:.6rem;border-top:1px solid var(--color-border)}.rule-picker__quick{flex:1;background:none;border:1px solid var(--color-border);border-radius:var(--radius-pill);color:var(--color-text);font-family:inherit;font-size:.85rem;padding:.4rem .8rem;min-height:36px}.rule-picker__quick:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary)}.rule-picker__quick:disabled{opacity:.4;cursor:default}.ab-feedback{margin-top:1rem;border:1px solid var(--color-error);border-left-width:4px;padding:.85rem 1rem;text-align:left}.ab-feedback__title{margin:0 0 .35rem;font-size:.95rem;font-weight:600;color:var(--color-text);line-height:1.3}.ab-feedback__explanation{margin:0 0 .6rem;font-size:.85rem;color:var(--color-muted);line-height:1.45}.ab-feedback__hint{margin:0;display:flex;flex-wrap:wrap;align-items:center;gap:.4rem;font-size:1rem;font-weight:500;color:var(--color-text)}.ab-feedback__hint-word{color:var(--color-text)}.ab-feedback__hint-arrow{color:var(--color-muted)}.ab-feedback__hint-cousin{color:var(--color-primary);font-weight:600}.ab-feedback__advance{display:block;margin:.85rem 0 0 auto}.dyk-list{display:flex;flex-direction:column}.dyk-list__hint{margin:0 0 .9rem;color:var(--color-muted);font-size:.95rem}.dyk-list__items{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.6rem}.dyk-play{flex:1;display:flex;flex-direction:column}.dyk-play__progress{background:var(--color-primary-soft);color:var(--color-primary);border-radius:var(--radius-pill);padding:.45rem .9rem;font-size:.85rem;font-weight:500;letter-spacing:.02em;align-self:center;margin-bottom:1rem}.dyk-play__buttons{display:grid;grid-template-columns:1fr 1fr;gap:.6rem;margin-bottom:1rem}.dyk-play__btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;color:var(--color-primary);font-family:inherit;font-size:.95rem;font-weight:500;min-height:56px;padding:0 1rem;transition:border-color .15s ease,background-color .15s ease}.dyk-play__btn:hover:not(:disabled){border-color:var(--color-primary)}.dyk-play__btn:active:not(:disabled){background:var(--color-primary-soft)}.dyk-play__btn:disabled{opacity:.4;cursor:not-allowed}.dyk-play__textarea{width:100%;flex:1;min-height:9rem;padding:.85rem 1rem;font-family:inherit;font-size:1rem;line-height:1.55;color:var(--color-text);resize:vertical;margin-bottom:1rem;transition:border-color .15s ease}.dyk-play__textarea:focus{outline:none;border-color:var(--color-primary)}.dyk-play__check{align-self:center}.dyk-check{flex:1;display:flex;flex-direction:column}.dyk-check__score{margin:0 0 1rem;font-size:1.5rem;font-weight:600;color:var(--color-primary);letter-spacing:-.01em;font-variant-numeric:tabular-nums;text-align:center}.dyk-check__score-total{color:var(--color-muted);font-weight:500}.dyk-check__diff{flex:1;margin:0 0 1.5rem;padding:1.25rem;font-size:1.05rem;line-height:1.85;color:var(--color-text)}.dyk-check__actions{display:flex;flex-direction:column;align-items:center}.diff__match{color:var(--color-text)}.diff__sub{display:inline-block;background:var(--color-error-soft);border-radius:6px;padding:0 .3em;white-space:nowrap}.diff__sub s{color:var(--color-error);text-decoration:line-through;text-decoration-thickness:2px}.diff__sub em{color:var(--color-primary);font-style:normal;font-weight:600}.diff__missing{display:inline-block;background:var(--color-primary-soft);color:var(--color-primary);border-radius:6px;padding:0 .4em;font-weight:500;border:1px dashed var(--color-primary)}.diff__extra s{color:var(--color-error);text-decoration:line-through;text-decoration-thickness:2px;background:var(--color-error-soft);border-radius:6px;padding:0 .3em}.rules{display:flex;flex-direction:column;gap:.6rem}.rule-card{overflow:hidden;transition:border-color .15s ease}.rule-card[open]{border-color:var(--color-primary)}.rule-card__summary{display:flex;align-items:center;gap:.75rem;padding:1rem;cursor:pointer;-webkit-user-select:none;user-select:none;list-style:none;font-weight:600;color:var(--color-text)}.rule-card__summary::-webkit-details-marker{display:none}.rule-card__summary::marker{content:""}.rule-card__summary:hover{background:var(--color-primary-soft)}.rule-card__title{flex:1;font-size:1rem;line-height:1.35}.rule-card__chevron{color:var(--color-muted);transition:transform .2s ease,color .15s ease;flex-shrink:0}.rule-card[open] .rule-card__chevron{transform:rotate(180deg);color:var(--color-primary)}.rule-card__body{padding:1rem;border-top:1px solid var(--color-border)}.rule-card__explanation{margin:0 0 1.25rem;color:var(--color-text);line-height:1.55;font-size:.95rem}.rule-card__section-label{margin:0 0 .55rem;color:var(--color-muted);font-size:.78rem;font-weight:500;text-transform:uppercase;letter-spacing:.06em}.rule-card__examples{list-style:none;padding:0;margin:0 0 1.5rem;display:flex;flex-wrap:wrap;gap:.4rem}.rule-card__example{background:var(--color-primary-soft);color:var(--color-primary);padding:.3rem .7rem;border-radius:var(--radius-pill);font-size:.9rem;font-weight:500}.rule-card__prompt{background:var(--color-bg);border:1px solid var(--color-border);border-radius:10px;padding:.85rem 1rem}.rule-card__prompt-title{margin:0 0 .25rem;color:var(--color-primary);font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em}.rule-card__prompt-text{margin:0;font-size:.95rem;color:var(--color-text);line-height:1.5}.exercise-header{margin-bottom:1.25rem;padding-bottom:1.25rem;border-bottom:1px solid var(--color-border)}.exercise-header__scope{display:inline-block;color:var(--color-muted);font-size:.85rem;font-weight:500;margin:0 0 .4rem;text-transform:uppercase;letter-spacing:.04em}.exercise-header__title{margin:0 0 .3rem;font-size:1.75rem;font-weight:600;color:var(--color-text);letter-spacing:-.01em}.exercise-header__description{margin:0;color:var(--color-muted);font-size:.95rem}.exercise-body{flex:1;display:flex;flex-direction:column}@font-face{font-family:Quicksand;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/quicksand-vietnamese-400-normal-CYVZRxRj.woff2) format("woff2"),url(/assets/quicksand-vietnamese-400-normal-D4WCpyCa.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Quicksand;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/quicksand-latin-ext-400-normal-BdPaGDPN.woff2) format("woff2"),url(/assets/quicksand-latin-ext-400-normal-BzqwlOho.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Quicksand;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/quicksand-latin-400-normal-BSDtH9U0.woff2) format("woff2"),url(/assets/quicksand-latin-400-normal-BqXBKzPR.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Quicksand;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/quicksand-vietnamese-500-normal-CMA0PiFa.woff2) format("woff2"),url(/assets/quicksand-vietnamese-500-normal-DdPH4leT.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Quicksand;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/quicksand-latin-ext-500-normal-Rkq3IeWS.woff2) format("woff2"),url(/assets/quicksand-latin-ext-500-normal-BlYHgpcu.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Quicksand;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/quicksand-latin-500-normal-_DbwbYKP.woff2) format("woff2"),url(/assets/quicksand-latin-500-normal-7J1fbcAD.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Quicksand;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/quicksand-vietnamese-600-normal-dD2kotB2.woff2) format("woff2"),url(/assets/quicksand-vietnamese-600-normal-JmvBH-hY.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Quicksand;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/quicksand-latin-ext-600-normal-fxOF3zcr.woff2) format("woff2"),url(/assets/quicksand-latin-ext-600-normal-BDPVAPCS.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Quicksand;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/quicksand-latin-600-normal-DTBPeRoM.woff2) format("woff2"),url(/assets/quicksand-latin-600-normal-CkxN0sDw.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root{--color-bg: #f5f0e8;--color-surface: #ffffff;--color-text: #2a2620;--color-muted: #8a8278;--color-border: #e4dccd;--color-primary: #5e7d5a;--color-primary-dark: #4a6446;--color-primary-soft: #eef2eb;--color-accent: #c8a673;--color-error: #b56b6b;--color-error-soft: #f5e8e8;--font-family: "Quicksand", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--radius-pill: 999px;--radius-card: 14px}*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:var(--font-family);color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent;overscroll-behavior:contain;touch-action:manipulation}button{font-family:inherit;cursor:pointer}button:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-card)}.btn-primary{border:none;background:var(--color-primary);color:#fff;font-family:inherit;font-size:1.05rem;font-weight:500;border-radius:var(--radius-pill);padding:0 1.75rem;min-height:52px;min-width:11rem;transition:background-color .15s ease}.btn-primary:hover:not(:disabled){background:var(--color-primary-dark)}.btn-primary:disabled{opacity:.4;cursor:default}.btn-primary--sm{font-size:.95rem;padding:0 1.4rem;min-height:40px;min-width:6rem}.app-layout{min-height:100dvh;display:flex;flex-direction:column;padding:max(1rem,env(safe-area-inset-top)) 1.25rem max(1.5rem,env(safe-area-inset-bottom));background:var(--color-bg)}.app-layout__topbar{display:flex;align-items:center;justify-content:flex-start;margin-bottom:1rem}.app-layout__heading{font-size:1.6rem;font-weight:600;margin:0 0 .25rem;color:var(--color-text);letter-spacing:-.01em}.app-layout__subheading{margin:0 0 1.5rem;color:var(--color-muted);font-size:.95rem;font-weight:400}.list-card{display:flex;align-items:center;gap:.85rem;width:100%;padding:.95rem 1rem;text-align:left;font:inherit;color:inherit;transition:border-color .15s ease,background-color .15s ease}.list-card:hover{border-color:var(--color-primary)}.list-card:active{background:var(--color-primary-soft)}.list-card__icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:2.5rem;height:2.5rem;border-radius:10px;background:var(--color-primary-soft);color:var(--color-primary);font-size:1.2rem}.list-card__body{flex:1;min-width:0}.list-card__title{display:block;font-size:1.05rem;font-weight:600;color:var(--color-text);margin:0 0 .15rem}.list-card__example{display:block;font-size:.9rem;color:var(--color-muted);margin:0}.list-card__chevron{color:var(--color-muted);flex-shrink:0}.list-card--locked{opacity:.55;cursor:not-allowed}.list-card--locked:hover{border-color:var(--color-border)}.list-card--locked .list-card__title{color:var(--color-muted)}
