@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/inter-cyrillic-ext-wght-normal-BOeWTOD4.woff2) format("woff2-variations");unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/inter-cyrillic-wght-normal-DqGufNeO.woff2) format("woff2-variations");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/inter-greek-ext-wght-normal-DlzME5K_.woff2) format("woff2-variations");unicode-range:U+1F00-1FFF}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/inter-greek-wght-normal-CkhJZR-_.woff2) format("woff2-variations");unicode-range:U+0370-0377,U+037A-037F,U+0384-038A,U+038C,U+038E-03A1,U+03A3-03FF}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/inter-vietnamese-wght-normal-CBcvBZtf.woff2) format("woff2-variations");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:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/inter-latin-ext-wght-normal-DO1Apj_S.woff2) format("woff2-variations");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:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/inter-latin-wght-normal-Dx4kXJAl.woff2) format("woff2-variations");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:Noto Sans Lao Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/noto-sans-lao-lao-wght-normal-C_K-dgyN.woff2) format("woff2-variations");unicode-range:U+0E81-0EDF,U+200C-200D,U+25CC}@font-face{font-family:Noto Sans Lao Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/noto-sans-lao-latin-ext-wght-normal-DhjvDJcw.woff2) format("woff2-variations");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:Noto Sans Lao Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/noto-sans-lao-latin-wght-normal-4L1CRwqI.woff2) format("woff2-variations");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:"Noto Serif Lao Variable";font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/noto-serif-lao-lao-wght-normal-B-Q37h2C.woff2) format("woff2-variations");unicode-range:U+0E81-0EDF,U+200C-200D,U+25CC}@font-face{font-family:"Noto Serif Lao Variable";font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/noto-serif-lao-latin-ext-wght-normal-CzO8s39a.woff2) format("woff2-variations");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:"Noto Serif Lao Variable";font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/noto-serif-lao-latin-wght-normal-ecppxZE0.woff2) format("woff2-variations");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{--font-lao: "Noto Sans Lao Variable", "Noto Sans Lao", "Phetsarath OT", "Saysettha Web", sans-serif;--font-lao-display: "Noto Serif Lao Variable", "Phetsarath OT", "Noto Serif Lao", serif;--font-latin: "Inter Variable", "Inter", system-ui, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, monospace;--r-xs: 6px;--r-sm: 10px;--r-md: 14px;--r-lg: 20px;--r-pill: 999px;--shadow-1: 0 1px 2px rgba(10, 10, 8, .06);--shadow-2: 0 4px 16px rgba(10, 10, 8, .1);--shadow-3: 0 12px 40px rgba(10, 10, 8, .16);--ring: 0 0 0 3px var(--accent-soft);--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 24px;--sp-6: 32px;--sp-7: 48px;--sp-8: 64px;--sp-9: 96px;--fs-display: 3.05rem;--fs-h1: 2.44rem;--fs-h2: 1.95rem;--fs-h3: 1.56rem;--fs-test: 2rem;--fs-test-mobile: 1.625rem;--fs-body: 1rem;--fs-label: .875rem;--fs-caption: .8125rem;--fs-micro: .6875rem;--lh-test: 1.9;--lh-ui: 1.6;--lh-tight: 1.15;--ls-test: .01em;--dur-1: .12s;--dur-2: .18s;--dur-3: .26s;--dur-4: .42s;--ease-out: cubic-bezier(.22, 1, .36, 1);--ease-inout: cubic-bezier(.65, 0, .35, 1);--ease-soft: cubic-bezier(.4, 0, .2, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1)}@media(prefers-reduced-motion:reduce){:root{--dur-1: 0ms;--dur-2: 0ms;--dur-3: 0ms;--dur-4: 0ms}}:root,:root[data-theme=sinmai]{--bg: #16131f;--surface: #221c30;--surface-alt: #2c2440;--overlay: rgba(8, 6, 14, .62);--text: #ece3d2;--text-sub: #a79db2;--text-faint: #857c90;--accent: #d8ae3e;--accent-hover: #e6be50;--accent-text: #2a2206;--accent-soft: rgba(216, 174, 62, .14);--indigo: #9b92d6;--indigo-soft: rgba(155, 146, 214, .16);--typed: #ece3d2;--untyped: #756c80;--correct: #5fb497;--incorrect: #d06a5e;--extra: #a8554a;--caret: #d8ae3e;--border: rgba(236, 227, 210, .1);--border-strong: rgba(236, 227, 210, .18);--key-face: #2c2440;--key-edge: rgba(236, 227, 210, .08);--key-label: #a79db2;--key-next: #d8ae3e;--key-next-bg: rgba(216, 174, 62, .16);--key-next-label: #ece3d2;--key-home: rgba(155, 146, 214, .16);color-scheme:dark}:root[data-theme=ink]{--bg: #11110f;--surface: #1a1a17;--surface-alt: #242420;--overlay: rgba(8, 8, 7, .62);--text: #e8e6de;--text-sub: #9a988e;--text-faint: #6e6c64;--accent: #c9a227;--accent-hover: #ddb638;--accent-text: #2a2206;--accent-soft: rgba(201, 162, 39, .14);--indigo: #7e93c8;--indigo-soft: rgba(126, 147, 200, .16);--typed: #e8e6de;--untyped: #7a786e;--correct: #4fa88b;--incorrect: #d9645b;--extra: #b0584e;--caret: #c9a227;--border: rgba(232, 230, 222, .09);--border-strong: rgba(232, 230, 222, .16);--key-face: #242420;--key-edge: rgba(232, 230, 222, .08);--key-label: #9a988e;--key-next: #c9a227;--key-next-bg: rgba(201, 162, 39, .16);--key-next-label: #e8e6de;--key-home: rgba(126, 147, 200, .16);color-scheme:dark}:root[data-theme=paper]{--bg: #f7f5ef;--surface: #fdfcf8;--surface-alt: #efede4;--overlay: rgba(26, 26, 23, .32);--text: #1a1a17;--text-sub: #5e5c52;--text-faint: #7e7c70;--accent: #8a6d10;--accent-hover: #73590c;--accent-text: #fdfcf8;--accent-soft: rgba(138, 109, 16, .13);--indigo: #3d4f86;--indigo-soft: rgba(61, 79, 134, .12);--typed: #1a1a17;--untyped: #8e8b7e;--correct: #2f7d63;--incorrect: #b23a30;--extra: #9a4036;--caret: #8a6d10;--border: rgba(26, 26, 23, .1);--border-strong: rgba(26, 26, 23, .18);--key-face: #fdfcf8;--key-edge: rgba(26, 26, 23, .1);--key-label: #5e5c52;--key-next: #8a6d10;--key-next-bg: rgba(138, 109, 16, .13);--key-next-label: #1a1a17;--key-home: rgba(61, 79, 134, .12);color-scheme:light}:root[data-theme=champa]{--bg: #fbf4e9;--surface: #fffdf7;--surface-alt: #f1e7d6;--overlay: rgba(42, 32, 24, .3);--text: #2a2018;--text-sub: #6e5c46;--text-faint: #9a8468;--accent: #b86a2e;--accent-hover: #a25a22;--accent-text: #fffdf7;--accent-soft: rgba(184, 106, 46, .13);--indigo: #3e5a86;--indigo-soft: rgba(62, 90, 134, .12);--typed: #2a2018;--untyped: #9a8468;--correct: #2f7d63;--incorrect: #b23a30;--extra: #9a4036;--caret: #b86a2e;--border: rgba(42, 32, 24, .1);--border-strong: rgba(42, 32, 24, .18);--key-face: #fffdf7;--key-edge: rgba(42, 32, 24, .1);--key-label: #6e5c46;--key-next: #b86a2e;--key-next-bg: rgba(184, 106, 46, .13);--key-next-label: #2a2018;--key-home: rgba(62, 90, 134, .12);color-scheme:light}:root[data-theme=indigo]{--bg: #0e1018;--surface: #171b28;--surface-alt: #222842;--overlay: rgba(6, 8, 16, .62);--text: #e4e7f0;--text-sub: #93a0c0;--text-faint: #6b7590;--accent: #d8b24a;--accent-hover: #e6c25c;--accent-text: #221a06;--accent-soft: rgba(216, 178, 74, .15);--indigo: #9fb0e0;--indigo-soft: rgba(159, 176, 224, .16);--typed: #e4e7f0;--untyped: #6e7790;--correct: #5fb497;--incorrect: #e0726a;--extra: #b85a52;--caret: #d8b24a;--border: rgba(228, 231, 240, .09);--border-strong: rgba(228, 231, 240, .16);--key-face: #222842;--key-edge: rgba(228, 231, 240, .08);--key-label: #93a0c0;--key-next: #d8b24a;--key-next-bg: rgba(216, 178, 74, .16);--key-next-label: #e4e7f0;--key-home: rgba(159, 176, 224, .16);color-scheme:dark}:root[data-theme=forest]{--bg: #0f1512;--surface: #18211c;--surface-alt: #1f2a23;--overlay: rgba(6, 12, 9, .62);--text: #e5ebe4;--text-sub: #94a39a;--text-faint: #69786f;--accent: #6fb58c;--accent-hover: #82c79e;--accent-text: #08130d;--accent-soft: rgba(111, 181, 140, .15);--indigo: #8fa2d0;--indigo-soft: rgba(143, 162, 208, .16);--typed: #e5ebe4;--untyped: #6f7e73;--correct: #79c2a0;--incorrect: #e0726a;--extra: #b85a52;--caret: #6fb58c;--border: rgba(229, 235, 228, .09);--border-strong: rgba(229, 235, 228, .16);--key-face: #1f2a23;--key-edge: rgba(229, 235, 228, .08);--key-label: #94a39a;--key-next: #6fb58c;--key-next-bg: rgba(111, 181, 140, .16);--key-next-label: #e5ebe4;--key-home: rgba(143, 162, 208, .16);color-scheme:dark}:root[data-theme=coffee]{--bg: #15110d;--surface: #201913;--surface-alt: #2b2219;--overlay: rgba(10, 7, 4, .62);--text: #ece3d7;--text-sub: #a99889;--text-faint: #7d6e60;--accent: #d9a06a;--accent-hover: #e7b07c;--accent-text: #2a1b0c;--accent-soft: rgba(217, 160, 106, .15);--indigo: #a8b0d8;--indigo-soft: rgba(168, 176, 216, .16);--typed: #ece3d7;--untyped: #8a7a6b;--correct: #6fb58c;--incorrect: #e0726a;--extra: #b85a52;--caret: #d9a06a;--border: rgba(236, 227, 215, .09);--border-strong: rgba(236, 227, 215, .16);--key-face: #2b2219;--key-edge: rgba(236, 227, 215, .08);--key-label: #a99889;--key-next: #d9a06a;--key-next-bg: rgba(217, 160, 106, .16);--key-next-label: #ece3d7;--key-home: rgba(168, 176, 216, .16);color-scheme:dark}:root[data-theme=mekong]{--bg: #0c1416;--surface: #142022;--surface-alt: #1b2b2e;--overlay: rgba(4, 10, 11, .62);--text: #e0eaea;--text-sub: #8fa6a6;--text-faint: #647e7e;--accent: #57b0c2;--accent-hover: #6bc0d1;--accent-text: #04161a;--accent-soft: rgba(87, 176, 194, .15);--indigo: #8290c8;--indigo-soft: rgba(130, 144, 200, .16);--typed: #e0eaea;--untyped: #6e8585;--correct: #5fb497;--incorrect: #e0726a;--extra: #b85a52;--caret: #57b0c2;--border: rgba(224, 234, 234, .09);--border-strong: rgba(224, 234, 234, .16);--key-face: #1b2b2e;--key-edge: rgba(224, 234, 234, .08);--key-label: #8fa6a6;--key-next: #57b0c2;--key-next-bg: rgba(87, 176, 194, .16);--key-next-label: #e0eaea;--key-home: rgba(130, 144, 200, .16);color-scheme:dark}:root[data-theme=dawn]{--bg: #f3eff6;--surface: #fcfafe;--surface-alt: #eae3f0;--overlay: rgba(36, 30, 44, .3);--text: #241e2c;--text-sub: #5e5670;--text-faint: #8a8296;--accent: #9a5b8f;--accent-hover: #874e7d;--accent-text: #fcfafe;--accent-soft: rgba(154, 91, 143, .13);--indigo: #3d4f86;--indigo-soft: rgba(61, 79, 134, .12);--typed: #241e2c;--untyped: #8a8296;--correct: #2f7d63;--incorrect: #b23a30;--extra: #9a4036;--caret: #9a5b8f;--border: rgba(36, 30, 44, .1);--border-strong: rgba(36, 30, 44, .18);--key-face: #fcfafe;--key-edge: rgba(36, 30, 44, .1);--key-label: #5e5670;--key-next: #9a5b8f;--key-next-bg: rgba(154, 91, 143, .13);--key-next-label: #241e2c;--key-home: rgba(61, 79, 134, .12);color-scheme:light}:root[data-contrast=high]{--untyped: var(--text-sub);--text-faint: var(--text-sub)}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:var(--font-lao);font-size:var(--fs-body);line-height:var(--lh-ui);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;transition:background-color var(--dur-3) var(--ease-soft),color var(--dur-3) var(--ease-soft)}button{font-family:inherit;cursor:pointer}.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}.app{min-height:100vh;max-width:980px;margin:0 auto;padding:var(--sp-4) var(--sp-5) var(--sp-6);display:flex;flex-direction:column}.topbar{display:flex;flex-direction:column;margin-bottom:var(--sp-5)}.topbar__band{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-4);padding:var(--sp-4) var(--sp-5);background:linear-gradient(180deg,var(--surface-alt),var(--surface));border-radius:var(--r-lg) var(--r-lg) 0 0}.brand{display:flex;align-items:center;gap:var(--sp-3)}.emblem{width:32px;height:32px;flex:none}.emblem__gold{stroke:var(--accent);fill:none}.emblem__red{stroke:var(--incorrect);fill:none}.emblem__dot{fill:var(--accent)}.wordmark2{line-height:1}.wordmark2__lo{display:block;font-family:var(--font-lao-display);font-size:1.6rem;font-weight:600;color:var(--accent);letter-spacing:.01em}.wordmark2__en{display:block;margin-top:3px;font-family:var(--font-latin);font-size:.625rem;font-weight:500;letter-spacing:.28em;color:var(--text-sub)}.topbar__right{display:flex;align-items:center;gap:var(--sp-2)}.weave{display:block;width:100%;height:14px}.weave__gold{stroke:var(--accent);stroke-width:1;fill:none}.weave__red{fill:var(--incorrect)}.weave__line{stroke:var(--accent);stroke-width:1}.wordmark{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-lao-display);font-size:1.3rem;font-weight:600;color:var(--text-sub);transition:color var(--dur-2) var(--ease-soft)}.wordmark:hover{color:var(--text)}.wordmark__bar{display:inline-block;width:2px;height:20px;background:var(--caret);border-radius:1px}.pills{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:var(--sp-2);padding:var(--sp-4) var(--sp-5) 0}.pill{border:none;background:transparent;color:var(--text-sub);font-family:var(--font-lao);font-size:var(--fs-label);font-weight:500;padding:4px 12px;border-radius:var(--r-pill);transition:background-color var(--dur-1) var(--ease-soft),color var(--dur-1) var(--ease-soft)}.pill:hover{color:var(--text)}.pill--on{background:var(--accent-soft);color:var(--accent)}.pill--on:hover{color:var(--accent)}.topbar__tools{display:flex;align-items:center;gap:var(--sp-1)}.icon-btn{width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--text-sub);border-radius:var(--r-sm);font-size:var(--fs-label);transition:background-color var(--dur-1) var(--ease-soft),color var(--dur-1) var(--ease-soft)}.icon-btn:hover{background:var(--surface);color:var(--text)}.icon-btn:focus-visible{outline:none;box-shadow:var(--ring)}.icon-btn--num{font-family:var(--font-lao);font-weight:500}.stage{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--sp-9) 0;text-align:center}.testline{font-family:var(--font-lao);font-size:var(--fs-test);font-weight:400;line-height:var(--lh-test);letter-spacing:var(--ls-test);max-width:720px;text-align:left}.g-typed{color:var(--typed)}.g-untyped{color:var(--untyped)}.g-error{color:var(--incorrect);border-bottom:1px solid var(--incorrect)}.caret{position:absolute;top:0;left:0;width:2px;background:var(--caret);border-radius:1px;opacity:0;will-change:transform}.stats{margin-top:var(--sp-5);font-family:var(--font-latin);font-size:.95rem;color:var(--text-sub);font-variant-numeric:tabular-nums}.stats b{font-weight:500;color:var(--text)}.footer{text-align:center;margin-top:var(--sp-5);font-size:var(--fs-caption);color:var(--text-faint)}.kbd{font-family:var(--font-latin);font-size:var(--fs-micro);font-weight:500;color:var(--text-sub);border:.5px solid var(--border-strong);border-radius:5px;padding:1px 6px;margin:0 2px}.theme-switch{position:relative}.theme-menu{list-style:none;margin:0;padding:var(--sp-3);position:absolute;right:0;top:calc(100% + 8px);z-index:20;background:var(--surface);border:.5px solid var(--border-strong);border-radius:var(--r-md);box-shadow:var(--shadow-3);display:grid;grid-template-columns:repeat(2,132px);gap:var(--sp-2)}.theme-chip{display:flex;align-items:center;gap:var(--sp-2);padding:8px 10px;border:.5px solid var(--border);border-radius:var(--r-sm);background:transparent;color:var(--text);font-family:var(--font-lao);font-size:var(--fs-label);text-align:left}.theme-chip:hover{border-color:var(--border-strong);background:var(--surface-alt)}.theme-chip[aria-pressed=true]{outline:2px solid var(--accent);outline-offset:1px}.theme-chip__dot{width:16px;height:16px;border-radius:50%;flex:none;border:.5px solid var(--border-strong)}.pills__sep{display:inline-block;width:1px;height:16px;background:var(--border-strong);margin:0 2px}.pill--static{color:var(--text-faint)}.pill--sm{padding:3px 9px;font-size:var(--fs-caption)}.langtoggle{display:inline-flex;gap:2px}.live{width:100%;max-width:720px;margin:0 auto var(--sp-4);display:flex;align-items:baseline;gap:var(--sp-3)}.live__main{font-family:var(--font-latin);font-size:1.6rem;font-weight:500;color:var(--accent);font-variant-numeric:tabular-nums}.live__wpm{font-family:var(--font-latin);font-size:.9rem;color:var(--text-sub);font-variant-numeric:tabular-nums}.testbox{width:100%;max-width:720px;margin:0 auto;height:calc(var(--fs-test) * var(--lh-test) * 3);overflow:hidden}.words{position:relative;font-family:var(--font-lao);font-size:var(--fs-test);line-height:var(--lh-test);letter-spacing:var(--ls-test);text-align:left;transition:transform var(--dur-2) var(--ease-out)}.word{position:relative;display:inline-block;white-space:nowrap;margin-right:.6ch}.ghost{color:var(--untyped)}.ink{position:absolute;left:0;top:0;white-space:nowrap}.extra{color:var(--extra)}.g-extra{color:var(--extra);border-bottom:1px solid var(--extra)}.results{width:100%;max-width:560px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:var(--sp-5);animation:results-in var(--dur-4) var(--ease-out)}@keyframes results-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}@media(prefers-reduced-motion:reduce){.results{animation:none}}.results__hero{position:relative;text-align:center}.pb-badge{display:inline-block;font-family:var(--font-lao);font-size:var(--fs-caption);color:var(--accent);background:var(--accent-soft);padding:2px 12px;border-radius:var(--r-pill);margin-bottom:var(--sp-2)}.results__cpm{display:flex;align-items:baseline;gap:8px;justify-content:center}.results__cpm-num{font-family:var(--font-latin);font-size:clamp(2.5rem,6vw,4rem);font-weight:500;line-height:1;color:var(--accent);font-variant-numeric:tabular-nums}.results__cpm-unit{font-size:1rem;color:var(--text-sub)}.results__row{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--sp-6);margin:0}.metric{display:flex;flex-direction:column;align-items:center;gap:2px}.metric__label{margin:0;font-size:var(--fs-caption);color:var(--text-sub)}.metric__value{margin:0;font-family:var(--font-latin);font-size:1.4rem;font-weight:500;color:var(--text);font-variant-numeric:tabular-nums}.results__chars{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--sp-5)}.charstat{display:flex;align-items:center;gap:6px;font-size:var(--fs-caption);color:var(--text-sub)}.charstat__value{font-family:var(--font-latin);color:var(--text);font-variant-numeric:tabular-nums}.charstat__dot{width:10px;height:10px;border-radius:50%;display:inline-block}.charstat__dot--correct{background:var(--correct)}.charstat__dot--incorrect{background:var(--incorrect)}.charstat__dot--extra{background:var(--extra)}.charstat__dot--missed{background:var(--text-faint)}.btn{font-family:var(--font-lao);font-size:var(--fs-label);font-weight:500;padding:10px 20px;border-radius:var(--r-md);border:.5px solid var(--border-strong);background:transparent;color:var(--text);display:inline-flex;align-items:center;gap:8px;transition:background-color var(--dur-1) var(--ease-soft),transform var(--dur-1) var(--ease-soft)}.btn:hover{background:var(--surface)}.btn:active{transform:scale(.98)}.btn:focus-visible{outline:none;box-shadow:var(--ring)}.btn--primary{background:var(--accent);color:var(--accent-text);border-color:transparent}.btn--primary:hover{background:var(--accent-hover)}.btn--primary .kbd{color:var(--accent-text);border-color:#0003}.keyboard{width:100%;max-width:720px;margin:var(--sp-6) auto 0;padding:var(--sp-3);background:var(--surface);border:.5px solid var(--border);border-radius:var(--r-md);display:flex;flex-direction:column;gap:6px}.keyboard__row{display:flex;gap:6px;justify-content:center}.key{position:relative;flex:1 1 0;min-width:0;height:42px;display:flex;align-items:center;justify-content:center;background:var(--key-face);border:.5px solid var(--key-edge);border-radius:var(--r-sm);font-family:var(--font-lao);color:var(--key-label);transition:background-color var(--dur-1) var(--ease-soft),border-color var(--dur-1) var(--ease-soft),color var(--dur-1) var(--ease-soft)}.key__base{font-size:1.05rem;line-height:1}.key__shift{position:absolute;top:3px;left:5px;font-size:var(--fs-micro);color:var(--text-faint)}.key__altgr{position:absolute;bottom:3px;right:5px;font-size:var(--fs-micro);color:var(--text-faint)}.key--home{background:var(--key-home)}.key--wide{flex:6 1 0}.key--next{border:1.5px solid var(--key-next);background:var(--key-next-bg);color:var(--key-next-label)}.key--next .key__base{color:var(--key-next-label)}.topbar__left{display:flex;align-items:center;gap:var(--sp-4)}.tabs{display:flex;gap:var(--sp-1)}.tab{border:none;background:transparent;color:var(--text-sub);font-family:var(--font-lao);font-size:var(--fs-label);font-weight:500;padding:4px 10px;border-radius:var(--r-sm);transition:background-color var(--dur-1) var(--ease-soft),color var(--dur-1) var(--ease-soft)}.tab:hover{color:var(--text)}.tab.is-active{color:var(--accent);background:var(--accent-soft)}.lessons{flex:1;display:grid;grid-template-columns:240px 1fr;gap:var(--sp-6);padding:var(--sp-6) 0;align-items:start}@media(max-width:720px){.lessons{grid-template-columns:1fr}}.lesson-rail{display:flex;flex-direction:column;gap:2px}.lesson-rail__group{font-family:var(--font-lao);font-size:var(--fs-caption);color:var(--text-faint);margin:var(--sp-4) 0 var(--sp-1);padding:0 var(--sp-3)}.lesson-rail__item{display:flex;align-items:center;gap:var(--sp-2);width:100%;text-align:left;border:none;background:transparent;color:var(--text-sub);font-family:var(--font-lao);font-size:var(--fs-label);padding:8px var(--sp-3);border-radius:var(--r-sm);transition:background-color var(--dur-1) var(--ease-soft),color var(--dur-1) var(--ease-soft)}.lesson-rail__item:hover:not(:disabled){background:var(--surface);color:var(--text)}.lesson-rail__item.is-current{background:var(--accent-soft);color:var(--accent)}.lesson-rail__item.is-locked{color:var(--text-faint);cursor:not-allowed}.lesson-rail__item.is-done .lesson-rail__status{color:var(--correct)}.lesson-rail__status{width:1.2em;text-align:center;font-size:.8em}.lesson-rail__title{flex:1}.lesson-pane{min-height:360px;display:flex;flex-direction:column}.lesson-head{text-align:center;margin-bottom:var(--sp-6)}.lesson-head__title{font-family:var(--font-lao-display);font-size:var(--fs-h2);font-weight:600;margin:0 0 var(--sp-3);color:var(--text)}.lesson-head__focus{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:var(--sp-2)}.lesson-head__label{font-size:var(--fs-caption);color:var(--text-sub)}.lesson-head__key{font-family:var(--font-lao);font-size:1.3rem;color:var(--accent);background:var(--accent-soft);border-radius:var(--r-sm);padding:2px 10px}.lesson-result{margin:auto;text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--sp-5);animation:results-in var(--dur-4) var(--ease-out)}.lesson-result__badge{font-family:var(--font-lao-display);font-size:var(--fs-h1);font-weight:600;color:var(--text-sub)}.lesson-result__badge.is-pass{color:var(--accent)}.lesson-result__stats{display:flex;gap:var(--sp-6);font-family:var(--font-latin);color:var(--text-sub);font-variant-numeric:tabular-nums}.lesson-result__stats b{color:var(--text);font-weight:500;font-size:1.3rem}.lesson-result__actions{display:flex;gap:var(--sp-3)}.modal-scrim{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:var(--overlay);display:flex;align-items:center;justify-content:center;padding:var(--sp-5);animation:scrim-in var(--dur-2) var(--ease-soft)}@keyframes scrim-in{0%{opacity:0}to{opacity:1}}.modal{width:100%;max-width:420px;background:var(--surface);border:.5px solid var(--border-strong);border-radius:var(--r-lg);box-shadow:var(--shadow-3);padding:var(--sp-6);animation:modal-in var(--dur-3) var(--ease-out)}@keyframes modal-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}@media(prefers-reduced-motion:reduce){.modal-scrim,.modal{animation:none}}.modal__title{margin:0 0 var(--sp-5);font-family:var(--font-lao-display);font-size:var(--fs-h3);font-weight:600;color:var(--text)}.settings-list{display:flex;flex-direction:column;gap:var(--sp-2);margin-bottom:var(--sp-5)}.setting{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-4);width:100%;text-align:left;border:none;background:transparent;padding:var(--sp-3);border-radius:var(--r-md);transition:background-color var(--dur-1) var(--ease-soft)}.setting:hover{background:var(--surface-alt)}.setting:focus-visible{outline:none;box-shadow:var(--ring)}.setting__text{display:flex;flex-direction:column;gap:2px}.setting__label{font-family:var(--font-lao);font-size:var(--fs-body);color:var(--text)}.setting__hint{font-size:var(--fs-caption);color:var(--text-sub)}.switch{flex:none;width:40px;height:24px;border-radius:999px;background:var(--surface-alt);border:.5px solid var(--border-strong);position:relative;transition:background-color var(--dur-2) var(--ease-soft)}.switch.is-on{background:var(--accent);border-color:transparent}.switch__knob{position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:var(--text);transition:transform var(--dur-2) var(--ease-out),background-color var(--dur-2) var(--ease-soft)}.switch.is-on .switch__knob{transform:translate(16px);background:var(--accent-text)}.modal__close{width:100%;justify-content:center}.results__meta{margin:0;font-family:var(--font-lao);font-size:var(--fs-caption);color:var(--text-faint)}@media(max-width:640px){:root{--fs-test: 1.625rem}.app{padding:var(--sp-3) var(--sp-4) var(--sp-5)}.topbar__band{flex-wrap:wrap;gap:var(--sp-3)}.wordmark2__lo{font-size:1.35rem}.stage{padding:var(--sp-6) 0}.key{height:34px}.key__base{font-size:.9rem}.key__shift,.key__altgr{display:none}.lesson-head__title{font-size:var(--fs-h3)}}.game{flex:1;display:flex;flex-direction:column;padding:var(--sp-4) 0}.game__hud{display:flex;align-items:center;justify-content:center;gap:var(--sp-6);margin-bottom:var(--sp-3);font-family:var(--font-lao);font-size:var(--fs-label);color:var(--text-sub)}.game__stat b{color:var(--text);font-family:var(--font-latin);font-variant-numeric:tabular-nums;font-size:1.2rem}.game__lives{display:inline-flex;gap:5px}.pip{width:10px;height:10px;border-radius:50%;background:var(--accent);display:inline-block}.pip--off{background:var(--border-strong)}.game__area{position:relative;flex:1;min-height:380px;width:100%;max-width:720px;margin:0 auto;background:var(--bg);border:.5px solid var(--border);border-radius:var(--r-lg);overflow:hidden}.slip{position:absolute;transform:translate(-50%);font-family:var(--font-lao);font-size:1.4rem;color:var(--text);background:var(--surface-alt);padding:6px 14px;border-radius:var(--r-md);border:.5px solid var(--border);white-space:nowrap}.slip--active{border-color:var(--accent);color:var(--accent)}.slip__progress{position:absolute;left:0;bottom:0;height:3px;background:var(--accent);border-radius:0 0 var(--r-md) var(--r-md)}.game__shore{position:absolute;left:0;right:0;bottom:0;height:var(--sp-2);background:var(--accent-soft);border-top:1px solid var(--accent)}.game__over{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--sp-4);background:var(--overlay)}.game__over-title{font-family:var(--font-lao-display);font-size:var(--fs-h1);color:var(--text)}.game__over-score b{color:var(--accent);font-family:var(--font-latin);font-variant-numeric:tabular-nums;font-size:2rem}.game__over-best{color:var(--text-sub);font-size:var(--fs-label)}.games{flex:1;display:flex;flex-direction:column}.games__switch{display:flex;justify-content:center;gap:var(--sp-2);margin-bottom:var(--sp-4)}.race{width:100%;max-width:720px;margin:0 auto var(--sp-5);display:flex;flex-direction:column;gap:var(--sp-3)}.race__lane{display:flex;align-items:center;gap:var(--sp-3)}.race__label{flex:0 0 90px;text-align:right;font-family:var(--font-lao);font-size:var(--fs-caption);color:var(--text-sub);font-variant-numeric:tabular-nums}.race__track{position:relative;flex:1;height:14px;background:var(--surface-alt);border-radius:999px}.race__marker{position:absolute;top:50%;width:14px;height:14px;border-radius:50%;transform:translate(-50%,-50%);transition:left .12s linear}.race__marker--you{background:var(--accent)}.race__marker--ghost{background:var(--indigo)}@media(prefers-reduced-motion:reduce){.race__marker{transition:none}}
