:root{--bg:#f6f7fc;--ink:#10132b;--muted:#5f6488;--brand:#6d4aff;--brand-2:#22d3ee;--accent:#a78bfa;--card:#fff;--line:#e8e9f4;--ok:#13b981;--warn:#c98a12;--danger:#e0483c;--radius:16px;--ink-dark:#0a0e22}*{box-sizing:border-box}body,html{margin:0;padding:0}body{background:var(--bg);color:var(--ink);font-family:Inter,system-ui,sans-serif;font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased}.brand,h1,h2,h3{font-family:Plus Jakarta Sans,Inter,sans-serif;font-weight:800;letter-spacing:-.02em;line-height:1.15;color:var(--ink)}a{color:inherit}.container{max-width:1120px;margin:0 auto;padding:0 20px}.link{color:var(--brand);text-decoration:none;font-weight:600}.link:hover{text-decoration:underline}.muted{color:var(--muted)}.grad-text{background:linear-gradient(100deg,#7c5cff 10%,#22d3ee 90%);-webkit-background-clip:text;background-clip:text;color:transparent}.btn{display:inline-flex;align-items:center;gap:8px;border:0;border-radius:12px;padding:11px 18px;font:inherit;font-weight:700;cursor:pointer;text-decoration:none;background:#ecebff;color:var(--brand);transition:.15s}.btn:hover{filter:brightness(.98)}.btn-primary{background:linear-gradient(110deg,#6d4aff,#22d3ee);color:#fff;box-shadow:0 10px 26px -10px rgba(86,80,255,.7)}.btn-ghost{background:transparent;color:var(--ink)}.btn-outline{background:#fff;border:1px solid var(--line);color:var(--ink)}.btn-sm{padding:7px 12px;font-size:14px;border-radius:10px}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:22px}.pill{display:inline-block;font-size:12px;font-weight:700;padding:4px 11px;border-radius:30px;background:#ecebff;color:var(--brand)}.pill.free{background:#e3f8f0;color:var(--ok)}.mono{font-family:JetBrains Mono,ui-monospace,monospace}.site-head{position:-webkit-sticky;position:sticky;top:0;z-index:30;background:rgba(246,247,252,.85);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}.site-head .in{justify-content:space-between;height:66px}.brand,.site-head .in{display:flex;align-items:center}.brand{font-size:20px;gap:9px;text-decoration:none}.brand .logo{width:30px;height:30px;border-radius:9px;background:linear-gradient(120deg,#6d4aff,#22d3ee);display:grid;place-items:center;color:#fff;font-weight:800;box-shadow:0 4px 14px -4px rgba(86,80,255,.7)}.site-nav{display:flex;align-items:center;gap:22px}.site-nav a{text-decoration:none;font-weight:600;color:var(--muted)}.site-nav a:hover{color:var(--ink)}.site-nav a.btn-primary,.site-nav a.btn-primary:hover{color:#fff}.site-nav a.btn-outline{color:var(--ink)}@media(max-width:680px){.site-nav a.hide-sm{display:none}}.hero{position:relative;overflow:hidden;background:radial-gradient(900px 500px at 50% -10%,#241a5e 0,#0d1130 55%,#080a1c 100%);color:#fff;padding:84px 0 64px;text-align:center}.hero:after,.hero:before{content:"";position:absolute;border-radius:50%;filter:blur(80px);opacity:.55;z-index:0}.hero:before{width:360px;height:360px;background:#6d4aff;top:-90px;left:-60px}.hero:after{width:340px;height:340px;background:#22d3ee;bottom:-120px;right:-40px}.hero .container{position:relative;z-index:1}.hero h1{font-size:48px;margin:0 0 14px;color:#fff}.hero p{font-size:19px;color:#c7cbef;max-width:660px;margin:0 auto 24px}.hero .tag{display:inline-flex;align-items:center;gap:8px;background:rgba(124,92,255,.18);border:1px solid rgba(124,92,255,.4);color:#cfc6ff;font-weight:700;padding:6px 14px;border-radius:30px;font-size:13px;margin-bottom:18px}.chips{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-top:26px}.chips span{font-size:13px;color:#aeb3e0;border:1px solid hsla(0,0%,100%,.14);background:hsla(0,0%,100%,.04);padding:6px 12px;border-radius:30px}@media(max-width:680px){.hero h1{font-size:33px}}.section{padding:46px 0}.section h2{font-size:28px;margin:0 0 6px}.section .sub{color:var(--muted);margin:0 0 26px}.courses{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:22px;gap:22px}.course{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;text-decoration:none;color:inherit;display:flex;flex-direction:column;transition:.18s}.course:hover{transform:translateY(-3px);box-shadow:0 18px 34px -20px rgba(16,19,43,.4)}.course .cover{aspect-ratio:16/9;background:linear-gradient(120deg,#6d4aff,#22d3ee);display:grid;place-items:center;color:#fff;font-weight:800;font-size:26px}.course .cover img{width:100%;height:100%;object-fit:cover}.course .body{padding:16px;display:flex;flex-direction:column;gap:8px;flex:1 1}.course .body h3{font-size:17px;margin:0}.course .body .desc{color:var(--muted);font-size:14px;flex:1 1}.course .meta{display:flex;justify-content:space-between;align-items:center;margin-top:6px}.course .price{font-weight:800;font-family:Plus Jakarta Sans,sans-serif}.course-hero{background:radial-gradient(700px 360px at 20% -20%,#2a1f66,#0d1130 70%);color:#fff;padding:46px 0}.course-hero h1{color:#fff;font-size:36px;margin:0 0 10px}.course-hero p{color:#c7cbef;font-size:18px;max-width:640px}.course-hero .crumbs{color:#a9aee0;font-size:14px;margin-bottom:14px}.course-hero .crumbs a{color:#cfc6f7;text-decoration:none}.layout-2{display:grid;grid-template-columns:1fr 340px;grid-gap:30px;gap:30px;align-items:start;padding:36px 0}@media(max-width:880px){.layout-2{grid-template-columns:1fr}}.curriculum .mod{border:1px solid var(--line);border-radius:12px;margin-bottom:12px;overflow:hidden}.curriculum .mod>.t{background:#f1f0ff;padding:12px 16px;font-weight:700}.curriculum .les{display:flex;justify-content:space-between;padding:11px 16px;border-top:1px solid var(--line);font-size:15px}.buybox{position:-webkit-sticky;position:sticky;top:86px}.buybox .price{font-size:34px;font-weight:800;font-family:Plus Jakarta Sans,sans-serif}.authwrap{min-height:80vh;display:grid;place-items:center;padding:40px 20px}.authcard{width:100%;max-width:420px}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:6px}.field label{font-size:13px;font-weight:600;color:var(--muted)}.field input,.field select,.field textarea{padding:11px 13px;border:1px solid var(--line);border-radius:11px;font:inherit;background:#fff;color:var(--ink)}.field input:focus,.field select:focus,.field textarea:focus{outline:2px solid #cfc6ff;border-color:var(--brand)}.stack{display:flex;flex-direction:column;gap:12px}.alert{padding:11px 14px;border-radius:11px;font-size:14px;margin-bottom:12px}.alert.bad{background:#fdecea;color:var(--danger)}.alert.good{background:#e3f8f0;color:var(--ok)}.center-link{text-align:center;margin-top:14px;font-size:14px;color:var(--muted)}.app-bar{background:#fff;border-bottom:1px solid var(--line);position:-webkit-sticky;position:sticky;top:0;z-index:20}.app-bar .in{display:flex;align-items:center;justify-content:space-between;height:62px}.app-wrap{max-width:1120px;margin:0 auto;padding:26px 20px}.tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:22px}.tabs a{font-size:14px;font-weight:600;padding:8px 14px;border-radius:10px;color:var(--muted);text-decoration:none}.tabs a.on{background:#ecebff;color:var(--brand)}.grid{display:grid;grid-gap:16px;gap:16px}.grid.c2{grid-template-columns:1fr 1fr}.grid.c3{grid-template-columns:repeat(3,1fr)}.grid.c4{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}@media(max-width:760px){.grid.c2,.grid.c3{grid-template-columns:1fr}}.stat{background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px 18px}.stat .n{font-family:Plus Jakarta Sans,sans-serif;font-size:28px;font-weight:800}.stat .l{font-size:13px;color:var(--muted)}.page{font-size:26px;margin:2px 0 4px}.sub{color:var(--muted);margin:0 0 18px;font-size:14px}.tbl{width:100%;border-collapse:collapse}.tbl th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:var(--muted);padding:0 10px 10px}.tbl td{padding:11px 10px;border-top:1px solid var(--line);font-size:14px}.tbl .right{text-align:right}.foot{border-top:1px solid var(--line);padding:30px 0;color:var(--muted);font-size:14px;margin-top:40px}.post-content{font-size:17px;line-height:1.8;color:#23263f}.post-content h2{font-size:26px;margin:28px 0 10px}.post-content h3{font-size:21px;margin:22px 0 8px}.post-content p{margin:0 0 16px}.post-content ol,.post-content ul{margin:0 0 16px;padding-left:24px}.post-content li{margin:4px 0}.post-content img{max-width:100%;border-radius:12px;margin:14px 0}.post-content blockquote{border-left:4px solid var(--brand);margin:16px 0;padding:6px 16px;color:var(--muted);background:#f6f3ff;border-radius:0 10px 10px 0}.post-content a{color:var(--brand);font-weight:600}