@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(../media/2c55a0e60120577a-s.0-dom-5bn10r2.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(../media/9c72aa0f40e4eef8-s.1y4-pdgsjb-pw.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(../media/ad66f9afd8947f86-s.3lvt2whj97whp.woff2)format("woff2");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(../media/5476f68d60460930-s.2uwcyprjm3xu3.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(../media/2bbe8d2671613f1f-s.0k62hbripvv8p.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(../media/1bffadaabf893a1e-s.3-6t-g6q0vh0a.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,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;font-style:normal;font-weight:400;font-display:swap;src:url(../media/83afe278b6a6bb3c-s.p.2bn3s6zvc0dyp.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter;font-style:normal;font-weight:500;font-display:swap;src:url(../media/2c55a0e60120577a-s.0-dom-5bn10r2.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:500;font-display:swap;src:url(../media/9c72aa0f40e4eef8-s.1y4-pdgsjb-pw.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:500;font-display:swap;src:url(../media/ad66f9afd8947f86-s.3lvt2whj97whp.woff2)format("woff2");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-weight:500;font-display:swap;src:url(../media/5476f68d60460930-s.2uwcyprjm3xu3.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-weight:500;font-display:swap;src:url(../media/2bbe8d2671613f1f-s.0k62hbripvv8p.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:500;font-display:swap;src:url(../media/1bffadaabf893a1e-s.3-6t-g6q0vh0a.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,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;font-style:normal;font-weight:500;font-display:swap;src:url(../media/83afe278b6a6bb3c-s.p.2bn3s6zvc0dyp.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(../media/2c55a0e60120577a-s.0-dom-5bn10r2.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(../media/9c72aa0f40e4eef8-s.1y4-pdgsjb-pw.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(../media/ad66f9afd8947f86-s.3lvt2whj97whp.woff2)format("woff2");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(../media/5476f68d60460930-s.2uwcyprjm3xu3.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(../media/2bbe8d2671613f1f-s.0k62hbripvv8p.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(../media/1bffadaabf893a1e-s.3-6t-g6q0vh0a.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,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;font-style:normal;font-weight:600;font-display:swap;src:url(../media/83afe278b6a6bb3c-s.p.2bn3s6zvc0dyp.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url(../media/2c55a0e60120577a-s.0-dom-5bn10r2.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url(../media/9c72aa0f40e4eef8-s.1y4-pdgsjb-pw.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url(../media/ad66f9afd8947f86-s.3lvt2whj97whp.woff2)format("woff2");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url(../media/5476f68d60460930-s.2uwcyprjm3xu3.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url(../media/2bbe8d2671613f1f-s.0k62hbripvv8p.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url(../media/1bffadaabf893a1e-s.3-6t-g6q0vh0a.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,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;font-style:normal;font-weight:700;font-display:swap;src:url(../media/83afe278b6a6bb3c-s.p.2bn3s6zvc0dyp.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter;font-style:normal;font-weight:800;font-display:swap;src:url(../media/2c55a0e60120577a-s.0-dom-5bn10r2.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:800;font-display:swap;src:url(../media/9c72aa0f40e4eef8-s.1y4-pdgsjb-pw.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:800;font-display:swap;src:url(../media/ad66f9afd8947f86-s.3lvt2whj97whp.woff2)format("woff2");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-weight:800;font-display:swap;src:url(../media/5476f68d60460930-s.2uwcyprjm3xu3.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-weight:800;font-display:swap;src:url(../media/2bbe8d2671613f1f-s.0k62hbripvv8p.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:800;font-display:swap;src:url(../media/1bffadaabf893a1e-s.3-6t-g6q0vh0a.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,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;font-style:normal;font-weight:800;font-display:swap;src:url(../media/83afe278b6a6bb3c-s.p.2bn3s6zvc0dyp.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter;font-style:normal;font-weight:900;font-display:swap;src:url(../media/2c55a0e60120577a-s.0-dom-5bn10r2.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:900;font-display:swap;src:url(../media/9c72aa0f40e4eef8-s.1y4-pdgsjb-pw.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:900;font-display:swap;src:url(../media/ad66f9afd8947f86-s.3lvt2whj97whp.woff2)format("woff2");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-weight:900;font-display:swap;src:url(../media/5476f68d60460930-s.2uwcyprjm3xu3.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-weight:900;font-display:swap;src:url(../media/2bbe8d2671613f1f-s.0k62hbripvv8p.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:900;font-display:swap;src:url(../media/1bffadaabf893a1e-s.3-6t-g6q0vh0a.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,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;font-style:normal;font-weight:900;font-display:swap;src:url(../media/83afe278b6a6bb3c-s.p.2bn3s6zvc0dyp.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter Fallback;src:local(Arial);ascent-override:90.44%;descent-override:22.52%;line-gap-override:0.0%;size-adjust:107.12%}.inter_aa6ddff5-module__eDpgjq__className{font-family:Inter,Inter Fallback;font-style:normal}.inter_aa6ddff5-module__eDpgjq__variable{--font-inter:"Inter", "Inter Fallback"}
:root{--indigo:#6c8cff;--teal:#18c9b4;--amber:#ffb547;--rose:#ff6b9d;--violet:#a78bfa;--accent:var(--indigo);--accent-2:var(--teal);--radius:18px;--radius-sm:12px;--radius-lg:26px;--maxw:1140px;--dur:.32s;--ease:cubic-bezier(.16, 1, .3, 1)}:root,:root[data-theme=dark]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--bg:#0a1020;--ink:#eef2ff;--muted:#98a4c8;--muted-2:#6c78a2;--line:#96aaeb29;--line-strong:#96aaeb4d;--surface:#151d38b8;--surface-2:#1c2748a8;--surface-solid:#131b36;--chip:#ffffff12;--shadow:0 24px 70px #04081880;--page-bg:radial-gradient(circle at 84% -8%, #18c9b429, transparent 40%), radial-gradient(circle at 2% 2%, #6c8cff2e, transparent 38%), linear-gradient(180deg, #0a1020 0%, #0b1330 52%, #0a1020 100%)}:root[data-theme=light]{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--bg:#f5f7ff;--ink:#0a1230;--muted:#58618a;--muted-2:#8a93b8;--line:#141e461f;--line-strong:#141e4638;--surface:#ffffffe0;--surface-2:#fffffff5;--surface-solid:#fff;--chip:#0c143c0d;--shadow:0 22px 60px #1e2d5c24;--page-bg:radial-gradient(circle at 86% -6%, #18c9b424, transparent 36%), radial-gradient(circle at 1% 1%, #6c8cff24, transparent 32%), linear-gradient(180deg, #fff 0%, #f2f5ff 50%, #fff 100%)}*{box-sizing:border-box}html{scroll-behavior:smooth}body{min-height:100vh;color:var(--ink);font-family:var(--font-inter), Inter, system-ui, -apple-system, "Segoe UI", sans-serif;background:var(--page-bg);-webkit-font-smoothing:antialiased;background-attachment:fixed;margin:0}a{color:inherit}img{max-width:100%}.sr-only{clip:rect(0 0 0 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}:root[data-lang=en] .lang-zh,:root[data-lang=zh] .lang-en{display:none}.wrap{width:min(100% - 2.4rem, var(--maxw));margin-inline:auto}.site-header{z-index:40;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:color-mix(in oklab, var(--bg) 78%, transparent);border-bottom:1px solid var(--line);position:sticky;top:0}.site-header .wrap{align-items:center;gap:1rem;padding-block:.72rem;display:flex}.brand{align-items:center;gap:.5rem;font-weight:800;text-decoration:none;display:inline-flex}.brand .dot{background:linear-gradient(135deg, var(--indigo), var(--teal));border-radius:9px;place-items:center;width:30px;height:30px;font-size:1rem;display:grid;box-shadow:0 6px 18px #18c9b459}.brand .name{letter-spacing:-.02em}.brand .name b{color:var(--ink)}.brand .name span{color:var(--accent-2)}.header-spacer{flex:1}.up-link{color:var(--muted);border:1px solid var(--line);transition:color var(--dur) var(--ease), border-color var(--dur) var(--ease);border-radius:999px;padding:.4rem .7rem;font-size:.82rem;text-decoration:none}.up-link:hover{color:var(--ink);border-color:var(--line-strong)}.icon-btn{cursor:pointer;background:var(--chip);width:38px;height:38px;color:var(--ink);border:1px solid var(--line);font:inherit;transition:transform var(--dur) var(--ease), border-color var(--dur) var(--ease);border-radius:11px;place-items:center;font-size:.9rem;font-weight:700;display:inline-grid}.icon-btn:hover{border-color:var(--line-strong);transform:translateY(-1px)}:root[data-theme=dark] .theme-btn .sun,:root[data-theme=light] .theme-btn .moon{display:none}.hero{padding:clamp(2.4rem,1rem + 6vw,5rem) 0 1.4rem}.hero-inner{grid-template-columns:1.2fr .8fr;align-items:center;gap:2rem;display:grid}.eyebrow{letter-spacing:.08em;text-transform:uppercase;color:var(--accent-2);background:var(--chip);border:1px solid var(--line);border-radius:999px;align-items:center;gap:.5rem;padding:.32rem .7rem;font-size:.76rem;font-weight:700;display:inline-flex}.hero h1{letter-spacing:-.03em;margin:1rem 0 .6rem;font-size:clamp(2.3rem,1rem + 5.6vw,4.4rem);font-weight:900;line-height:1.02}.hero h1 .grad{background:linear-gradient(120deg, var(--indigo), var(--teal) 60%, var(--amber));color:#0000;-webkit-background-clip:text;background-clip:text}.hero p.lede{color:var(--muted);max-width:46ch;margin:0;font-size:clamp(1rem,.9rem + .5vw,1.2rem)}.hero-cta{flex-wrap:wrap;gap:.7rem;margin-top:1.5rem;display:flex}.btn{cursor:pointer;font:inherit;transition:transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease);border:1px solid #0000;border-radius:12px;align-items:center;gap:.5rem;padding:.72rem 1.15rem;font-weight:700;text-decoration:none;display:inline-flex}.btn-primary{color:#06111f;background:linear-gradient(135deg, var(--teal), var(--indigo));box-shadow:0 12px 30px #18c9b44d}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 40px #18c9b46b}.btn-ghost{color:var(--ink);background:var(--surface);border-color:var(--line)}.btn-ghost:hover{border-color:var(--line-strong);transform:translateY(-2px)}.hero-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:1.4rem}.hero-card h3{text-transform:uppercase;letter-spacing:.06em;color:var(--muted-2);margin:0 0 .9rem;font-size:.82rem}.stat-row{grid-template-columns:repeat(3,1fr);gap:.7rem;display:grid}.stat{text-align:center;border-radius:var(--radius-sm);background:var(--surface-2);border:1px solid var(--line);padding:.7rem .4rem}.stat b{letter-spacing:-.02em;font-size:1.6rem;font-weight:900;display:block}.stat span{color:var(--muted);font-size:.72rem}.stat.streak b{color:var(--amber)}.stat.xp b{color:var(--teal)}.stat.lvl b{color:var(--indigo)}.tab-nav{flex-wrap:wrap;gap:.4rem;margin:1.8rem 0 1.2rem;display:flex}.tab{font:inherit;cursor:pointer;color:var(--muted);border:1px solid var(--line);transition:color var(--dur) var(--ease), background var(--dur) var(--ease), border-color var(--dur) var(--ease);background:0 0;border-radius:999px;padding:.5rem .95rem;font-weight:600}.tab:hover{color:var(--ink);border-color:var(--line-strong)}.tab.is-active{color:#06111f;background:linear-gradient(135deg, var(--teal), var(--indigo));border-color:#0000}.filters{flex-wrap:wrap;gap:.5rem;margin-bottom:1.2rem;display:flex}.chip{font:inherit;cursor:pointer;color:var(--muted);background:var(--chip);border:1px solid var(--line);transition:color var(--dur) var(--ease), border-color var(--dur) var(--ease), background var(--dur) var(--ease);border-radius:999px;padding:.36rem .75rem;font-size:.82rem;font-weight:600}.chip:hover{color:var(--ink)}.chip.is-active{color:var(--ink);border-color:var(--cat,var(--accent));box-shadow:inset 0 0 0 1px var(--cat,var(--accent))}.chip .swatch{vertical-align:middle;background:var(--cat,var(--accent));border-radius:50%;width:8px;height:8px;margin-right:.4rem;display:inline-block}.grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.1rem;display:grid}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);cursor:pointer;text-align:left;transition:transform var(--dur) var(--ease), border-color var(--dur) var(--ease);padding:1.25rem;position:relative;overflow:hidden}.card:before{content:"";background:linear-gradient(90deg, var(--cat,var(--accent)), transparent);width:100%;height:3px;position:absolute;inset:0 auto auto 0}.card:hover{border-color:var(--line-strong);transform:translateY(-4px)}.card-top{align-items:flex-start;gap:.9rem;display:flex}.card-ico{background:color-mix(in oklab, var(--cat,var(--accent)) 18%, var(--surface-2));border:1px solid var(--line);border-radius:14px;flex:none;place-items:center;width:48px;height:48px;font-size:1.5rem;display:grid}.card h3{letter-spacing:-.01em;margin:.1rem 0 .25rem;font-size:1.12rem}.card .tagline{color:var(--muted);margin:0;font-size:.9rem}.card-meta{flex-wrap:wrap;align-items:center;gap:.5rem;margin-top:1rem;display:flex}.pill{background:var(--chip);border:1px solid var(--line);color:var(--muted);border-radius:999px;padding:.24rem .6rem;font-size:.72rem;font-weight:700}.pill.cat{color:var(--cat,var(--accent));border-color:color-mix(in oklab, var(--cat,var(--accent)) 40%, var(--line))}.card-foot{justify-content:space-between;align-items:center;gap:.8rem;margin-top:1rem;display:flex}.card-foot .prog-label{color:var(--muted);font-size:.78rem}.ring{--p:0;background:conic-gradient(var(--cat,var(--accent)) calc(var(--p) * 1%), var(--line) 0);border-radius:50%;flex:none;place-items:center;width:46px;height:46px;display:grid}.ring i{background:var(--surface-solid);width:34px;height:34px;color:var(--ink);border-radius:50%;place-items:center;font-size:.68rem;font-style:normal;font-weight:800;display:grid}.subhead{flex-wrap:wrap;align-items:center;gap:.8rem;margin-bottom:1.2rem;display:flex}.back-btn{font:inherit;cursor:pointer;color:var(--muted);background:var(--chip);border:1px solid var(--line);border-radius:999px;padding:.4rem .8rem;font-weight:600}.back-btn:hover{color:var(--ink)}.subhead h2{letter-spacing:-.02em;margin:0;font-size:clamp(1.4rem,1rem + 2vw,2rem)}.lesson-layout{grid-template-columns:300px 1fr;align-items:start;gap:1.4rem;display:grid}.module-list{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:.8rem;position:sticky;top:78px}.module-list h4{text-transform:uppercase;letter-spacing:.06em;color:var(--muted-2);margin:.7rem .6rem .4rem;font-size:.72rem}.lesson-link{text-align:left;width:100%;font:inherit;cursor:pointer;color:var(--ink);background:0 0;border:0;border-radius:10px;align-items:center;gap:.6rem;padding:.55rem .6rem;display:flex}.lesson-link:hover{background:var(--chip)}.lesson-link.is-active{background:color-mix(in oklab, var(--accent) 16%, var(--surface-2))}.lesson-link .tick{border:1.5px solid var(--line-strong);width:20px;height:20px;color:var(--muted-2);border-radius:50%;flex:none;place-items:center;font-size:.7rem;display:grid}.lesson-link.done .tick{background:var(--teal);border-color:var(--teal);color:#06111f}.lesson-link span.t{font-size:.9rem}.reader{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:clamp(1.2rem,1rem + 2vw,2rem)}.reader h3{letter-spacing:-.02em;margin:0 0 .4rem;font-size:clamp(1.3rem,1rem + 1.6vw,1.8rem)}.reader .concept{color:var(--ink);font-size:1.05rem;line-height:1.6}.reader .points{gap:.6rem;margin:1.2rem 0;padding:0;list-style:none;display:grid}.reader .points li{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius-sm);align-items:flex-start;gap:.6rem;padding:.7rem .9rem;display:flex}.reader .points li:before{content:"→";color:var(--accent-2);font-weight:800}.example{border-left:3px solid var(--amber);background:color-mix(in oklab, var(--amber) 8%, var(--surface-2));border-radius:0 var(--radius-sm) var(--radius-sm) 0;margin-top:1rem;padding:1rem 1.1rem}.example b{text-transform:uppercase;letter-spacing:.06em;color:var(--amber);margin-bottom:.35rem;font-size:.72rem;display:block}.example .code{white-space:pre-wrap;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.92rem}.reader-foot{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.8rem;margin-top:1.6rem;display:flex}.mode-switch{background:var(--chip);border:1px solid var(--line);border-radius:999px;gap:.25rem;margin-bottom:1.2rem;padding:.25rem;display:inline-flex}.mode-switch button{font:inherit;cursor:pointer;color:var(--muted);background:0 0;border:0;border-radius:999px;padding:.4rem .9rem;font-weight:600}.mode-switch button.is-active{color:#06111f;background:linear-gradient(135deg, var(--teal), var(--indigo))}.flashcard{perspective:1200px;cursor:pointer;max-width:560px;height:260px;margin:0 auto 1.2rem}.flashcard-inner{width:100%;height:100%;transition:transform .5s var(--ease);transform-style:preserve-3d;position:relative}.flashcard.flipped .flashcard-inner{transform:rotateY(180deg)}.flashcard .face{backface-visibility:hidden;text-align:center;border-radius:var(--radius-lg);border:1px solid var(--line);box-shadow:var(--shadow);background:var(--surface);place-items:center;padding:2rem;display:grid;position:absolute;inset:0}.flashcard .face .tag{text-transform:uppercase;letter-spacing:.06em;color:var(--muted-2);font-size:.72rem;position:absolute;top:1rem;left:1.2rem}.flashcard .face p{letter-spacing:-.01em;margin:0;font-size:1.3rem;font-weight:700;line-height:1.4}.flashcard .back{background:linear-gradient(160deg, color-mix(in oklab, var(--teal) 14%, var(--surface)), var(--surface));transform:rotateY(180deg)}.deck-nav{justify-content:center;align-items:center;gap:1rem;display:flex}.deck-nav .count{color:var(--muted);text-align:center;min-width:60px;font-size:.9rem}.quiz-q{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);max-width:620px;margin:0 auto;padding:clamp(1.2rem,1rem + 2vw,1.8rem)}.quiz-q .qnum{text-transform:uppercase;letter-spacing:.06em;color:var(--muted-2);font-size:.76rem}.quiz-q h3{letter-spacing:-.01em;margin:.4rem 0 1.2rem;font-size:1.25rem;line-height:1.4}.options{gap:.6rem;display:grid}.opt{font:inherit;text-align:left;cursor:pointer;color:var(--ink);background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius-sm);transition:border-color var(--dur) var(--ease), transform var(--dur) var(--ease);align-items:center;gap:.7rem;padding:.85rem 1rem;display:flex}.opt:hover:not(:disabled){border-color:var(--line-strong);transform:translate(3px)}.opt .key{background:var(--chip);border:1px solid var(--line);border-radius:7px;flex:none;place-items:center;width:24px;height:24px;font-size:.8rem;font-weight:800;display:grid}.opt.correct{border-color:var(--teal);background:color-mix(in oklab, var(--teal) 14%, var(--surface-2))}.opt.correct .key{background:var(--teal);color:#06111f}.opt.wrong{border-color:var(--rose);background:color-mix(in oklab, var(--rose) 12%, var(--surface-2))}.opt.wrong .key{background:var(--rose);color:#fff}.quiz-foot{justify-content:space-between;align-items:center;gap:.8rem;margin-top:1.3rem;display:flex}.quiz-progress{background:var(--line);margin-bottom:1.2rem;border-radius:999px;max-width:620px;height:6px;margin-inline:auto;overflow:hidden}.quiz-progress i{background:linear-gradient(90deg, var(--teal), var(--indigo));height:100%;transition:width var(--dur) var(--ease);display:block}.result{text-align:center;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);max-width:480px;box-shadow:var(--shadow);margin:0 auto;padding:2.2rem}.result .score{letter-spacing:-.03em;background:linear-gradient(120deg, var(--teal), var(--indigo));color:#0000;-webkit-background-clip:text;background-clip:text;font-size:3.4rem;font-weight:900}.result p{color:var(--muted)}.dash{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.6rem;display:grid}.dash .big{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.4rem}.dash .big b{letter-spacing:-.03em;font-size:2.6rem;font-weight:900;display:block}.dash .big.streak b{color:var(--amber)}.dash .big.xp b{color:var(--teal)}.dash .big.lvl b{color:var(--indigo)}.dash .big.done b{color:var(--rose)}.dash .big span{color:var(--muted);font-size:.85rem}.track-progress{gap:.7rem;display:grid}.tp-row{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);align-items:center;gap:.9rem;padding:.8rem 1rem;display:flex}.tp-row .ico{font-size:1.3rem}.tp-row .meta{flex:1}.tp-row .meta b{font-size:.95rem}.tp-bar{background:var(--line);border-radius:999px;height:8px;margin-top:.4rem;overflow:hidden}.tp-bar i{background:var(--cat,var(--accent));height:100%;transition:width var(--dur) var(--ease);display:block}.tp-row .pct{font-variant-numeric:tabular-nums;font-weight:800}.empty{text-align:center;color:var(--muted);padding:3rem 1rem}.toast{z-index:60;background:var(--surface-solid);color:var(--ink);border:1px solid var(--line-strong);box-shadow:var(--shadow);transition:transform .45s var(--ease);border-radius:999px;align-items:center;gap:.5rem;padding:.7rem 1.2rem;font-weight:700;display:flex;position:fixed;bottom:1.6rem;left:50%;transform:translate(-50%)translateY(140%)}.toast.show{transform:translate(-50%)translateY(0)}.toast .xp-badge{color:var(--teal)}.site-footer{border-top:1px solid var(--line);margin-top:4rem}.site-footer .wrap{flex-wrap:wrap;align-items:center;gap:1rem 2rem;padding-block:1.8rem;display:flex}.footer-brand{flex-direction:column;gap:.2rem;display:flex}.footer-logo-img{width:auto;height:26px}:root[data-theme=dark] .footer-logo-light,:root[data-theme=light] .footer-logo-dark{display:none}.footer-brand p{color:var(--muted-2);margin:0;font-size:.78rem}.footer-links,.footer-social{align-items:center;gap:1rem;display:flex}.footer-links{margin-left:auto}.footer-links a{color:var(--muted);font-size:.82rem;text-decoration:none}.footer-links a:hover{color:var(--ink)}.footer-social a{color:var(--muted);transition:color var(--dur) var(--ease), transform var(--dur) var(--ease)}.footer-social a:hover{color:var(--ink);transform:translateY(-2px)}@media (max-width:860px){.hero-inner{grid-template-columns:1fr}.hero-card{order:-1}.lesson-layout{grid-template-columns:1fr}.module-list{position:static}}@media (max-width:520px){.footer-links{margin-left:0}.stat b{font-size:1.3rem}}@media (prefers-reduced-motion:reduce){*{scroll-behavior:auto!important;transition:none!important;animation:none!important}.flashcard-inner{transition:none}}.view{animation:fade var(--dur) var(--ease)}@keyframes fade{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.header-account{align-items:center;display:inline-flex;position:relative}.header-account-signin{cursor:pointer;white-space:nowrap;min-height:38px;font:inherit;color:#06111f;background:linear-gradient(135deg, var(--teal), var(--indigo));transition:transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);border:1px solid #0000;border-radius:999px;align-items:center;padding:0 15px;font-size:.82rem;font-weight:800;display:inline-flex}.header-account-signin:hover,.header-account-signin:focus-visible{transform:translateY(-1px);box-shadow:0 10px 24px #18c9b452}.header-account-chip{cursor:pointer;min-height:38px;font:inherit;color:var(--ink);background:var(--chip);border:1px solid var(--line);transition:border-color var(--dur) var(--ease);border-radius:999px;align-items:center;gap:8px;padding:0 12px 0 5px;font-size:.82rem;font-weight:800;display:inline-flex}.header-account-chip:hover,.header-account-chip:focus-visible{border-color:var(--line-strong)}.header-account-avatar{color:#06111f;background:linear-gradient(135deg, var(--teal), var(--indigo));border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:.78rem;font-weight:900;display:inline-flex}.header-account-name{text-overflow:ellipsis;white-space:nowrap;max-width:130px;overflow:hidden}.header-account-menu{z-index:80;border:1px solid var(--line-strong);background:var(--surface-solid);min-width:184px;box-shadow:var(--shadow);border-radius:14px;flex-direction:column;gap:2px;padding:6px;display:flex;position:absolute;top:calc(100% + 8px);right:0}.header-account-menu[hidden]{display:none}.header-account-item{text-align:left;cursor:pointer;width:100%;font:inherit;color:var(--ink);background:0 0;border:0;border-radius:10px;padding:9px 12px;font-size:.82rem;font-weight:700;text-decoration:none;display:block}.header-account-item:hover,.header-account-item:focus-visible{background:var(--chip)}
