@import"https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600&family=Noto+Sans+TC:wght@300;400;500;600;700&display=swap";:root{--ink:#1d1d1f;--bg:#fff;--gray:#86868b;--gray2:#aaaaaa;--line:#ececec;--alt:#f7f7f8;--soft:#f5f5f7;--card:#fff;--accent:#1d1d1f;--maxw:1000px;--f:"Poppins","Noto Sans TC",-apple-system,BlinkMacSystemFont,"PingFang TC","Helvetica Neue",sans-serif}html.dark{--ink:#f5f5f7;--bg:#000;--gray:#98989d;--gray2:#5f5f63;--line:#2c2c2e;--alt:#161618;--soft:#1c1c1e;--card:#1c1c1e}html{background:var(--bg)}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;overflow-x:hidden}body{overflow-x:hidden}body{font-family:var(--f);color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;line-height:1.55;font-weight:400}a{color:inherit;text-decoration:none}.wrap{max-width:var(--maxw);margin:0 auto;padding:0 26px}svg{display:block}.logo-svg{height:26px;width:auto;fill:currentColor}nav{position:sticky;top:0;z-index:100;background:#ffffffd1;backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);border-bottom:1px solid var(--line)}.nav-in{max-width:var(--maxw);margin:0 auto;height:56px;display:flex;align-items:center;padding:0 26px;font-size:13.5px}.brand{display:flex;align-items:center;gap:6px;color:var(--ink)}.brand .sub{font-size:15px;color:var(--ink);font-weight:500;letter-spacing:.02em;line-height:1}.nav-links{display:flex;gap:30px;flex:1;justify-content:center;font-weight:400}.nav-links a{color:var(--ink);opacity:.78;transition:opacity .2s}.nav-links a:hover{opacity:1}.nav-search{opacity:.78;transition:opacity .2s}.nav-search:hover{opacity:1}.hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;width:40px;height:40px;margin-left:auto;margin-right:-8px;border:none;background:none;cursor:pointer;padding:0}.hamburger span{display:block;width:20px;height:1.6px;background:var(--ink);margin:0 auto;border-radius:2px;transition:.25s}#siteNav.open .hamburger span:nth-child(1){transform:translateY(6.6px) rotate(45deg)}#siteNav.open .hamburger span:nth-child(2){opacity:0}#siteNav.open .hamburger span:nth-child(3){transform:translateY(-6.6px) rotate(-45deg)}.mobile-menu{display:none;flex-direction:column;border-top:1px solid var(--line);background:#fffffffa;padding:8px 26px 16px}.mobile-menu a{padding:13px 2px;font-size:16px;color:var(--ink);border-bottom:1px solid var(--line)}.mobile-menu a:last-child{border-bottom:none}#siteNav.open .mobile-menu{display:flex}@media (max-width:820px){.nav-links,.nav-search{display:none}.hamburger{display:flex}}@media (min-width:821px){.mobile-menu{display:none!important}}.hero{text-align:center;padding:108px 26px 94px;background:var(--bg)}.hero .eyebrow{font-size:12px;font-weight:500;color:var(--accent);letter-spacing:.26em;text-transform:uppercase;margin-bottom:30px}.hero h1{font-size:54px;line-height:1.24;font-weight:600;letter-spacing:-.005em;margin-bottom:26px}.hero h1 em{font-style:normal;font-weight:600}.hero p{font-size:18px;color:var(--gray);max-width:500px;margin:0 auto 42px;font-weight:300;line-height:1.78}.searchbar{max-width:540px;margin:0 auto;position:relative}.searchbar input{width:100%;padding:16px 20px 16px 52px;border:1px solid var(--line);border-radius:14px;font-size:16px;background:var(--soft);font-family:var(--f);transition:.2s;font-weight:300}.searchbar input:focus{outline:none;background:var(--card);border-color:var(--accent);box-shadow:0 6px 24px #00000014}.searchbar .mag{position:absolute;left:21px;top:50%;transform:translateY(-50%)}.hint{margin-top:15px;font-size:13px;color:var(--gray)}.hint a{margin:0 7px;border-bottom:1px solid #ddd;padding-bottom:1px}.hint a:hover{border-color:var(--ink)}@media (max-width:700px){.hero{padding:60px 26px 50px}.hero h1{font-size:40px}.hero p{font-size:18px}}section{padding:88px 0}.alt{background:var(--alt)}.head{margin-bottom:50px;position:relative}.head .eye{font-size:12px;font-weight:500;color:var(--accent);letter-spacing:.16em;text-transform:uppercase;margin-bottom:12px}.head h2,.head h1{font-size:34px;font-weight:600;letter-spacing:-.02em}.head .more{position:absolute;right:0;bottom:4px;font-size:14px;color:var(--ink);opacity:.7;border-bottom:1px solid #ccc;padding-bottom:2px}.head .more:hover{opacity:1}.devices{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:20px;overflow:hidden}@media (max-width:820px){.devices{grid-template-columns:repeat(2,1fr)}}.dev{background:var(--card);padding:32px 22px;text-align:center;transition:.22s}.dev:hover{background:#fafafa}.alt .dev{background:var(--alt)}.alt .dev:hover{background:#eeeef0}.dev .i{height:36px;display:flex;align-items:center;justify-content:center;margin-bottom:15px;color:var(--ink)}.dev h3{font-size:16px;font-weight:600;margin-bottom:3px;letter-spacing:-.01em}.dev span{font-size:12px;color:var(--gray2);font-weight:400}.tips{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}@media (max-width:820px){.tips{grid-template-columns:1fr}}.tip{transition:.2s}.tip .thumb{height:170px;border-radius:16px;background:linear-gradient(135deg,#f7f7f9,#e9e9ee);color:var(--accent);display:flex;align-items:center;justify-content:center;margin-bottom:18px;transition:.2s;overflow:hidden;position:relative}.tip:hover .thumb{transform:translateY(-4px);box-shadow:0 16px 36px #00000017}.tip .thumb svg{opacity:.9}.tip .thumb .lv{position:absolute;top:12px;left:12px;font-size:10.5px;font-weight:600;letter-spacing:.04em;padding:3px 9px;border-radius:980px;background:#ffffffd9;color:var(--ink)}.tip .thumb .lv.lv-beginner{background:#fffffff2;color:var(--ink)}.tip .thumb .lv.lv-intermediate{background:var(--gray);color:#fff}.tip .thumb .lv.lv-advanced{background:var(--ink);color:#fff}.lvb{display:inline-flex;align-items:center;gap:5px}.lvb .bars{display:inline-flex;align-items:flex-end;gap:1.5px;height:10px}.lvb .bars i{width:2.5px;background:currentColor;opacity:.32;border-radius:1px}.lvb .bars i:nth-child(1){height:4px}.lvb .bars i:nth-child(2){height:7px}.lvb .bars i:nth-child(3){height:10px}.lvb .bars i.on{opacity:1}.tip .tag{font-size:11.5px;font-weight:600;color:var(--accent);letter-spacing:.06em;text-transform:uppercase}.tip h3{font-size:18px;font-weight:600;line-height:1.4;margin:9px 0 7px;letter-spacing:-.015em}.tip:hover h3{opacity:.6}.tip p{font-size:14px;color:var(--gray);line-height:1.55;font-weight:300}.tip .read{font-size:12px;color:var(--gray2);margin-top:12px}.paths{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}@media (max-width:820px){.paths{grid-template-columns:1fr}}.path{background:var(--card);border-radius:20px;padding:30px 28px;border:1px solid var(--line);transition:.22s}.path:hover{box-shadow:0 16px 38px #00000012;transform:translateY(-3px)}.path .num{font-size:12px;font-weight:600;color:var(--gray2);letter-spacing:.04em}.path h3{font-size:22px;font-weight:600;margin:10px 0 12px;letter-spacing:-.02em}.path p{font-size:14px;color:var(--gray);line-height:1.6;margin-bottom:18px;font-weight:300}.path .meta{font-size:13px;font-weight:500;display:flex;align-items:center;gap:7px}.path .arrow{margin-top:18px;font-size:13px;font-weight:600;color:var(--accent)}.chips{display:flex;flex-wrap:wrap;gap:11px}.chip{padding:10px 20px;border:1px solid #ddd;border-radius:980px;font-size:15px;font-weight:400;background:var(--card);transition:.2s}.chip:hover{border-color:var(--accent);background:var(--accent);color:#fff}button.chip{font-family:var(--f);cursor:pointer;color:var(--ink)}.chip.flt.active{border-color:var(--accent);background:var(--accent);color:#fff}.actbtn.fav-btn.on{color:var(--accent);border-color:var(--accent)}.fbk{max-width:680px;margin:46px auto 0;border:1px solid var(--line);border-radius:16px;padding:22px 24px;display:flex;align-items:center;gap:16px;flex-wrap:wrap;background:var(--alt)}.fbk-q{font-size:15.5px;font-weight:600;color:var(--ink)}.fbk-btns{display:flex;gap:10px}.fbk-btn{font-family:var(--f);cursor:pointer;border:1px solid var(--line);background:var(--card);border-radius:980px;padding:9px 18px;font-size:14px;font-weight:500;color:var(--ink);transition:.16s}.fbk-btn:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-1px)}.fbk-thx{font-size:14.5px;color:var(--accent);font-weight:500}.learners{max-width:680px;margin:18px auto 0;display:flex;align-items:center;gap:9px;font-size:13.5px;color:var(--gray)}.learners b{color:var(--ink);font-weight:600;font-variant-numeric:tabular-nums}.learners .lrn-dots{display:inline-flex}.learners .lrn-dots i{width:18px;height:18px;border-radius:50%;border:2px solid var(--bg);background:linear-gradient(135deg,var(--accent),var(--gray));margin-left:-6px}.learners .lrn-dots i:first-child{margin-left:0}.actbtn.done-btn.on{color:#fff;background:var(--accent);border-color:var(--accent)}.path-progress{margin-bottom:22px;border:1px solid var(--line);border-radius:14px;padding:18px 20px;background:var(--card)}.path-progress .pp-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:10px}.path-progress .pp-label{font-size:14px;font-weight:600;color:var(--ink)}.path-progress .pp-count{font-size:13px;color:var(--gray);font-variant-numeric:tabular-nums}.path-progress .pp-track{height:8px;background:var(--alt);border-radius:980px;overflow:hidden}.path-progress .pp-track i{display:block;height:100%;background:var(--accent);border-radius:980px;transition:width .5s ease}.path-progress .pp-done{margin-top:12px;font-size:14px;font-weight:600;color:var(--accent);text-align:center}.lesson-row .step-check{display:none;align-items:center;justify-content:center}.lesson-row .step-check svg{width:17px;height:17px}.lesson-row.done .step-n{display:none}.lesson-row.done .step-check{display:inline-flex}.chooser-cta{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;border:1px solid var(--line);border-radius:18px;padding:28px 32px;background:linear-gradient(135deg,var(--soft),var(--card));transition:.18s}.chooser-cta:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 14px 36px #00000014}.chooser-cta .cc-eye{font-size:12px;font-weight:600;letter-spacing:.06em;color:var(--accent);text-transform:uppercase;margin-bottom:8px}.chooser-cta h2{font-size:23px;font-weight:600;letter-spacing:-.01em;margin-bottom:6px}.chooser-cta p{font-size:14.5px;color:var(--gray)}.chooser-cta .cc-go{flex-shrink:0;background:var(--accent);color:#fff;font-weight:600;font-size:15px;padding:13px 26px;border-radius:980px}.browse{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}.bchip{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--line);border-radius:980px;padding:9px 16px 9px 13px;font-size:14px;font-weight:500;color:var(--ink);background:var(--card);transition:.18s}.bchip svg{width:16px;height:16px;color:var(--accent);flex-shrink:0}.bchip:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-1px);box-shadow:0 6px 18px #0000000f}.pager{display:flex;align-items:center;justify-content:space-between;gap:14px;max-width:420px;margin:48px auto 0}.pager .pg{font-size:14px;color:var(--gray);font-variant-numeric:tabular-nums}.pager .pg-btn{border:1px solid var(--line);border-radius:980px;padding:10px 20px;font-size:14px;font-weight:500;color:var(--ink);transition:.18s}.pager .pg-btn:hover{border-color:var(--accent);color:var(--accent)}.pager .ghost{width:96px}.banner{background:var(--ink);color:#fff;border-radius:28px;padding:66px 40px;text-align:center}.banner .eye{font-size:13px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;opacity:.55;margin-bottom:16px}.banner h2{font-size:34px;font-weight:600;letter-spacing:-.025em;margin-bottom:12px}.banner p{font-size:18px;opacity:.7;max-width:520px;margin:0 auto 28px;font-weight:300}.btn{display:inline-block;background:var(--card);color:#000;padding:13px 28px;border-radius:980px;font-size:15px;font-weight:500;transition:.2s}.btn:hover{opacity:.85}.btn-dark{background:var(--ink);color:#fff}footer{border-top:1px solid var(--line);padding:48px 0 34px;font-size:12.5px;color:var(--gray);margin-top:0}.fin{display:flex;justify-content:space-between;flex-wrap:wrap;gap:28px}.fin .tagline{font-size:12px;color:var(--gray2);margin-top:12px;letter-spacing:.03em}.fin .cols{display:flex;gap:56px;flex-wrap:wrap}.fin h4{color:var(--ink);font-size:12.5px;font-weight:600;margin-bottom:12px}.fin a{display:block;color:var(--gray);margin-bottom:8px;transition:.2s;font-weight:300}.fin a:hover{color:var(--ink)}.fnote{max-width:var(--maxw);margin:32px auto 0;padding:18px 26px 0;border-top:1px solid var(--line);font-size:11px;color:#b0b0b0;line-height:1.7}.theme-fab{position:fixed;right:22px;bottom:22px;z-index:200}.theme-fab .toggle{width:50px;height:50px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 8px 24px #0003;border:none;transition:.25s}.theme-fab .toggle:hover{transform:scale(1.06)}.theme-pop{position:absolute;right:0;bottom:62px;background:var(--card);border:1px solid var(--line);border-radius:18px;padding:18px;box-shadow:0 18px 50px #00000029;width:218px;opacity:0;visibility:hidden;transform:translateY(8px);transition:.22s}.theme-fab.open .theme-pop{opacity:1;visibility:visible;transform:none}.theme-pop .ttl{font-size:12.5px;font-weight:600;color:var(--ink);margin-bottom:4px}.theme-pop .sub2{font-size:11px;color:var(--gray);margin-bottom:14px}.sw-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.sw{width:34px;height:34px;border-radius:50%;cursor:pointer;border:none;box-shadow:0 0 0 1px var(--line);transition:.15s;outline:none}.sw:hover{transform:scale(1.12)}.sw.active{box-shadow:0 0 0 2px #fff,0 0 0 4px var(--ink)}.prose{max-width:680px;margin:0 auto;font-size:17px;line-height:1.85;color:var(--ink)}.prose h2{font-size:26px;font-weight:600;letter-spacing:-.01em;margin:42px 0 14px;color:var(--ink)}.prose h3{font-size:20px;font-weight:600;margin:30px 0 10px;color:var(--ink)}.prose p{margin:0 0 18px}.prose ul,.prose ol{margin:0 0 18px 22px}.prose li{margin:0 0 8px}.prose img{max-width:100%;border-radius:14px;margin:24px 0}.prose a{color:var(--accent);border-bottom:1px solid #ddd}.prose strong{font-weight:600;color:var(--ink)}.prose code{background:var(--soft);padding:2px 6px;border-radius:6px;font-size:.9em}.prose hr{border:none;border-top:1px solid var(--line);margin:34px 0}.prose .tbl-wrap{margin:26px 0;border:1px solid var(--line);border-radius:14px;overflow:hidden}.prose .tbl-wrap table{margin:0;border:none;border-radius:0}.prose table{width:100%;border-collapse:separate;border-spacing:0;margin:26px 0;font-size:15px;border:1px solid var(--line);border-radius:14px;overflow:hidden}.prose th,.prose td{padding:12px 16px;text-align:left;vertical-align:top;border-bottom:1px solid var(--line);line-height:1.6}.prose thead th{background:var(--alt);font-weight:600;color:var(--ink);font-size:13.5px;letter-spacing:.01em}.prose tbody tr:nth-child(2n){background:var(--alt)}.prose tbody tr{transition:background .14s}.prose tbody tr:hover{background:color-mix(in srgb,var(--accent) 7%,transparent)}.prose tbody tr:last-child td{border-bottom:none}.prose td code{font-size:.86em}@media (max-width:680px){.prose .tbl-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.prose table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;font-size:14px}.prose th,.prose td{padding:10px 13px}}.answer-box{background:var(--alt);border-left:3px solid var(--accent);border-radius:12px;padding:18px 22px;margin:0 auto 34px;max-width:680px;font-size:16px;font-weight:500;line-height:1.7}.spath{display:inline-flex;flex-wrap:wrap;align-items:center;gap:5px;vertical-align:middle;margin:2px 1px;padding:3px 9px 3px 7px;background:var(--alt);border:1px solid var(--line);border-radius:10px;line-height:1.4}.spath .sp-app{display:inline-flex;align-items:center;gap:4px;font-weight:600;color:var(--accent);font-size:.92em}.spath .sp-app svg{width:13px;height:13px}.spath .sp-seg{font-size:.92em;color:var(--ink);font-weight:500}.spath .sp-arr{color:var(--gray2);font-size:.8em;font-style:normal}.lmeta{max-width:680px;margin:0 auto 22px;display:flex;flex-wrap:wrap;align-items:center;gap:10px;color:var(--gray);font-size:14px}.badge{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;padding:4px 11px;border-radius:980px;border:1px solid var(--line)}.badge.lv-beginner{color:var(--gray);border-color:var(--line)}.badge.lv-intermediate{color:#fff;background:var(--gray);border-color:var(--gray)}.badge.lv-advanced{color:#fff;background:var(--ink);border-color:var(--ink)}.badge.ver{color:var(--gray);background:var(--soft);border-color:transparent}.byline{max-width:680px;margin:0 auto 30px;display:flex;align-items:center;gap:12px;color:var(--ink)}.byline .ava{width:40px;height:40px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:600;flex-shrink:0}.byline .who{display:flex;flex-direction:column;line-height:1.45}.byline .who b{font-size:14px;font-weight:600}.byline .who span{font-size:12.5px;color:var(--gray)}.byline:hover .who b{color:var(--accent)}.ptip{max-width:680px;margin:34px auto;display:flex;gap:16px;align-items:flex-start;border:1px solid var(--line);border-left:3px solid var(--accent);border-radius:14px;padding:20px 22px;background:var(--alt)}.ptip .ava{flex-shrink:0;width:40px;height:40px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:17px;font-weight:600}.ptip .pt-label{font-size:12.5px;font-weight:600;color:var(--accent);letter-spacing:.04em;margin-bottom:6px}.ptip p{font-size:15.5px;line-height:1.75;color:var(--ink);margin:0}.ptip .pt-cta{display:inline-block;margin-top:10px;font-size:14px;font-weight:500;color:var(--accent);border-bottom:1px solid currentColor;padding-bottom:1px}.tip .thumb .rec{position:absolute;top:12px;right:12px;font-size:10.5px;font-weight:600;letter-spacing:.03em;padding:3px 9px;border-radius:980px;background:var(--accent);color:#fff;display:inline-flex;align-items:center;gap:3px}.actbar{max-width:680px;margin:24px auto 30px;display:flex;flex-wrap:wrap;align-items:center;gap:9px}.actbtn{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--line);border-radius:980px;padding:9px 17px;font-size:13.5px;font-weight:500;color:var(--ink);background:var(--card);cursor:pointer;transition:.18s;font-family:var(--f);text-decoration:none}.actbtn:hover{border-color:var(--accent);color:var(--accent)}.actbtn.primary{background:var(--ink);color:#fff;border-color:var(--ink)}.actbtn.primary:hover{opacity:.88;color:#fff}.act-sep{flex:1}.actico{display:inline-flex;align-items:center;justify-content:center;min-width:38px;height:38px;padding:0 12px;border:1px solid var(--line);border-radius:980px;background:var(--card);color:var(--ink);cursor:pointer;transition:.18s;font-size:13px;font-weight:600;font-family:var(--f)}.actico:hover{border-color:var(--accent);color:var(--accent)}.actico.done{background:var(--accent);color:#fff;border-color:var(--accent)}@media (max-width:600px){.act-sep{flex-basis:100%;height:0}}.prereq{max-width:680px;margin:0 auto 30px;border:1px solid var(--line);border-radius:14px;padding:20px 22px}.prereq h3{font-size:14px;font-weight:600;letter-spacing:.02em;margin:0 0 12px;color:var(--ink)}.prereq .row{display:flex;gap:10px;margin-bottom:8px;font-size:14px;color:var(--ink);line-height:1.6}.prereq .row:last-child{margin-bottom:0}.prereq .row b{min-width:64px;color:var(--gray);font-weight:500;flex-shrink:0}.prereq ul{margin:0;padding-left:18px}.steps{max-width:680px;margin:0 auto 36px;counter-reset:step}.steps h3{font-size:20px;font-weight:600;margin:0 0 18px}.steps-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:18px}.steps-head h3{margin:0}.steps-prog{font-size:12.5px;color:var(--gray);font-variant-numeric:tabular-nums}.steps .step{display:flex;gap:16px;padding:16px 6px;border:none;border-top:1px solid var(--line);width:100%;background:none;text-align:left;font-family:var(--f);cursor:pointer;transition:.15s;border-radius:10px}.steps .step:hover{background:var(--alt)}.steps .step:last-child{border-bottom:1px solid var(--line)}.steps .step .num{counter-increment:step;flex-shrink:0;width:30px;height:30px;border-radius:50%;border:1.5px solid var(--line);background:var(--card);color:var(--gray);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;transition:.15s}.steps .step .num:before{content:counter(step)}.steps .step .num-c{display:none;width:16px;height:16px}.steps .step .body{font-size:16px;line-height:1.7;color:var(--ink);padding-top:3px}.steps .step .body b{font-weight:600;color:var(--ink)}.steps .step.done .num{background:var(--accent);border-color:var(--accent);color:#fff}.steps .step.done .num:before{content:""}.steps .step.done .num-c{display:block}.steps .step.done .body b{text-decoration:line-through;text-decoration-color:var(--gray2)}.steps .step.done .body{color:var(--gray)}.prose .callout{border-radius:12px;padding:16px 20px;margin:24px 0;font-size:15.5px;line-height:1.7}.prose .callout .ct{display:block;font-weight:600;font-size:13px;letter-spacing:.04em;margin-bottom:6px;text-transform:uppercase}.prose .callout.pro{background:var(--alt);border:1px solid var(--line);border-left:3px solid var(--accent)}.prose .callout.pro .ct{color:var(--accent)}.prose .callout.note{background:var(--alt);border:1px solid var(--line)}.prose .callout.note .ct{color:var(--gray)}.prose .callout.warn{background:#fbf3f2;border:1px solid #efd6d2;border-left:3px solid #c0473f}.prose .callout.warn .ct{color:#b23b33}.prose pre{position:relative;background:#1d1d1f;color:#f5f5f7;padding:16px 18px;border-radius:12px;overflow-x:auto;margin:20px 0;font-size:14px;line-height:1.6}.copy-btn{position:absolute;top:9px;right:9px;background:#ffffff1a;color:#f5f5f7;border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:4px 11px;font-size:12px;font-weight:500;font-family:var(--f);cursor:pointer;transition:.15s;opacity:.55}.prose pre:hover .copy-btn,.copy-btn:focus{opacity:1}.copy-btn:hover{background:#ffffff38}.copy-btn.done{background:var(--accent);border-color:var(--accent);opacity:1}.prose pre code{background:none;padding:0;color:inherit;font-size:14px}.prose kbd{background:var(--soft);border:1px solid var(--line);border-bottom-width:2px;border-radius:6px;padding:2px 7px;font-size:.85em;font-family:var(--f)}.videowrap{max-width:680px;margin:0 auto 34px}.videowrap .vhead{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;flex-wrap:wrap}.videowrap .vtitle{display:inline-flex;align-items:center;gap:9px;font-size:15px;font-weight:600;color:var(--ink)}.videowrap .vtitle svg{color:var(--accent);flex-shrink:0}.videowrap .vsrc{font-size:12.5px;color:var(--gray2)}.badge.vk-official{color:var(--accent);border-color:var(--line)}.badge.vk-creator{color:var(--gray);border-color:var(--line)}.vframe{position:relative;aspect-ratio:16/9;border-radius:16px;overflow:hidden;background:#000;box-shadow:0 12px 34px #0000001f}.vframe iframe{position:absolute;inset:0;width:100%;height:100%;border:0}.videowrap .vnote{font-size:13px;color:var(--gray);margin-top:10px}.coursenav{margin:8px 0 0;border:1px solid var(--line);border-radius:18px;padding:20px 22px;background:var(--alt)}.cn-path{display:block;margin-bottom:16px}.cn-path .cn-eye{display:block;font-size:12px;font-weight:600;letter-spacing:.04em;color:var(--accent);margin-bottom:3px}.cn-path .cn-title{font-size:18px;font-weight:600;letter-spacing:-.01em;color:var(--ink)}.cn-path:hover .cn-title{color:var(--accent)}.cn-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.cn-btn{display:flex;flex-direction:column;gap:4px;border:1px solid var(--line);border-radius:14px;padding:14px 16px;background:var(--card);transition:.18s;min-width:0}.cn-btn.ghost{border:none;background:none}.cn-btn:hover{border-color:var(--accent);transform:translateY(-2px)}.cn-btn .d{font-size:12.5px;font-weight:600;color:var(--gray)}.cn-btn .tt{font-size:14px;font-weight:500;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cn-btn.next{text-align:right}.cn-btn.next:hover .d,.cn-btn.prev:hover .d{color:var(--accent)}.cn-btn.next.done{background:var(--ink);border-color:var(--ink)}.cn-btn.next.done .d,.cn-btn.next.done .tt{color:#fff}@media (max-width:520px){.cn-row{grid-template-columns:1fr}.cn-btn.next{text-align:left}}.toc{max-width:680px;margin:0 auto 34px;border:1px solid var(--line);border-radius:14px;padding:18px 22px;background:var(--bg)}.toc h3{font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--gray2);margin:0 0 12px}.toc ol{margin:0;padding-left:20px;counter-reset:toc}.toc li{margin:0 0 8px;font-size:15px}.toc a{color:var(--ink);border-bottom:1px solid transparent}.toc a:hover{color:var(--accent);border-color:var(--accent)}.prose :is(h2,h3){scroll-margin-top:72px}.br-desktop{display:inline}@media (max-width:700px){.br-desktop{display:none}}@media (max-width:820px){section{padding:60px 0}.head{margin-bottom:34px}.head h2{font-size:28px}.head .more{position:static;display:inline-block;margin-top:10px;float:none}.fin{flex-direction:column;gap:24px}.fin .cols{gap:40px}.prose{font-size:16px}}@media (max-width:700px){.hero .eyebrow{letter-spacing:.18em;font-size:11px}.hero h1{font-size:34px;line-height:1.28}.hero p{font-size:16px}.devices{grid-template-columns:repeat(2,1fr)}.banner{padding:48px 24px}.banner h2{font-size:26px}}@media (max-width:380px){.devices{grid-template-columns:1fr}}html.dark nav{background:#121214b8}html.dark .mobile-menu{background:#121214fa}html.dark .tip .thumb{filter:none}.theme-mode{display:flex;gap:6px;background:var(--alt);border-radius:980px;padding:4px}.theme-mode button{flex:1;font-family:var(--f);cursor:pointer;border:none;background:none;border-radius:980px;padding:8px 0;font-size:13px;font-weight:500;color:var(--gray);transition:.16s}.theme-mode button.on{background:var(--card);color:var(--ink);box-shadow:0 1px 4px #0000001f}html.dark .banner{background:var(--soft);border:1px solid var(--line)}html.dark .btn-dark{background:var(--soft)}html.dark .badge.lv-advanced{background:#48484a;border-color:#48484a}html.dark .tip .thumb .lv.lv-advanced{background:#48484a}html.dark .chooser-cta{background:linear-gradient(135deg,var(--soft),var(--alt))}.readbar{position:fixed;top:0;left:0;right:0;height:3px;z-index:250;background:var(--line);pointer-events:none}.readbar i{display:block;height:100%;width:0;background:var(--accent);border-radius:0 3px 3px 0;box-shadow:0 0 8px 0 var(--accent);transition:width .12s ease-out}.to-top{position:fixed;left:24px;bottom:26px;z-index:90;width:44px;height:44px;border-radius:50%;border:1px solid var(--line);background:var(--card);color:var(--ink);display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transform:translateY(10px);pointer-events:none;transition:.25s;box-shadow:0 8px 24px #0000001f}.to-top.show{opacity:1;transform:none;pointer-events:auto}.to-top:hover{border-color:var(--accent);color:var(--accent)}@media (max-width:600px){.to-top{left:16px;bottom:18px;width:40px;height:40px}}.toc a.active{color:var(--accent);font-weight:600}.prose h2{position:relative}.prose h2 .h-anchor{position:absolute;left:-.95em;top:0;opacity:0;color:var(--gray2);text-decoration:none;font-weight:400;transition:.15s}.prose h2:hover .h-anchor{opacity:1}.prose h2 .h-anchor:hover{color:var(--accent)}@media (max-width:760px){.prose h2 .h-anchor{display:none}}html.dark .dev:hover,html.dark .alt .dev:hover{background:#161618}html.dark .tip .thumb{background:linear-gradient(135deg,#2a2a2c,#1c1c1e)}@media print{nav,.actbar,.learners,.fbk,.to-top,.readbar,.theme-fab,.banner,.coursenav,.related,footer,.toc,.steps-prog,.byline .ava{display:none!important}body,html{background:#fff!important;color:#000!important}.prose{max-width:100%!important;font-size:12pt;color:#000}.prose h2,.prose h3,h1{color:#000}a{color:#000;text-decoration:none}.spath,.answer-box,.callout{border:1px solid #ccc!important;background:#fff!important;break-inside:avoid}.steps .step{break-inside:avoid}article{padding:0!important}}.sresults{display:flex;flex-direction:column;gap:10px}.sresult{display:flex;align-items:center;gap:14px;justify-content:space-between;padding:17px 20px;border:1px solid var(--line);border-radius:14px;background:var(--card);transition:.18s}.sresult:hover{border-color:var(--accent);box-shadow:0 10px 26px #00000012;transform:translateY(-2px)}.sresult .sr-body{min-width:0}.sresult .sr-cat{display:inline-block;margin-bottom:8px;color:var(--accent);border-color:var(--line)}.sresult h3{font-size:17px;font-weight:600;letter-spacing:-.01em;margin:0 0 4px}.sresult p{font-size:13.5px;color:var(--gray);line-height:1.55;margin:0;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.sresult .sr-go{color:var(--gray2);font-size:22px;flex-shrink:0;transition:.18s}.sresult:hover .sr-go{color:var(--accent);transform:translate(2px)}.gloss{color:inherit;border-bottom:1px dashed var(--gray2);cursor:help;position:relative}.gloss:hover{border-color:var(--accent);color:var(--accent)}.gloss .gloss-pop{position:absolute;left:50%;bottom:140%;transform:translate(-50%) translateY(6px);width:240px;background:var(--ink);color:var(--bg);font-size:13px;line-height:1.55;font-weight:400;padding:11px 14px;border-radius:12px;box-shadow:0 12px 32px #00000038;opacity:0;visibility:hidden;transition:.18s;z-index:50;text-align:left;pointer-events:none}.gloss .gloss-pop b{display:block;font-weight:600;margin-bottom:3px;color:var(--bg)}.gloss .gloss-pop:after{content:"";position:absolute;left:50%;top:100%;transform:translate(-50%);border:6px solid transparent;border-top-color:var(--ink)}.gloss:hover .gloss-pop{opacity:1;visibility:visible;transform:translate(-50%)}@media (max-width:600px){.gloss .gloss-pop{width:200px}}.aiask{position:relative}.aiask-btn .caret{margin-left:-2px}.aiask-menu{position:absolute;top:calc(100% + 8px);left:0;z-index:60;min-width:200px;background:var(--card);border:1px solid var(--line);border-radius:14px;box-shadow:0 16px 40px #00000029;padding:6px;display:flex;flex-direction:column}.aiask-menu[hidden]{display:none}.aiask-menu button,.aiask-menu a{font-family:var(--f);cursor:pointer;text-align:left;background:none;border:none;border-radius:9px;padding:11px 13px;font-size:14px;color:var(--ink);transition:.14s;white-space:nowrap}.aiask-menu button:hover,.aiask-menu a:hover{background:var(--alt);color:var(--accent)}.fontctl{max-width:680px;margin:36px auto -8px;display:flex;align-items:center;gap:8px;justify-content:flex-end;font-size:13px;color:var(--gray)}.fontctl button{font-family:var(--f);cursor:pointer;border:1px solid var(--line);background:var(--card);color:var(--ink);border-radius:8px;min-width:34px;height:30px;font-size:13px;transition:.14s}.fontctl button:nth-child(3){font-size:15px}.fontctl button:nth-child(4){font-size:17px}.fontctl button:hover{border-color:var(--accent)}.fontctl button.on{background:var(--accent);color:#fff;border-color:var(--accent)}.cmdk{position:fixed;inset:0;z-index:300;display:flex;justify-content:center;align-items:flex-start}.cmdk[hidden]{display:none}.cmdk-backdrop{position:absolute;inset:0;background:#0006;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.cmdk-box{position:relative;margin-top:13vh;width:min(580px,92vw);background:var(--card);border:1px solid var(--line);border-radius:18px;box-shadow:0 30px 80px #00000057;overflow:hidden;animation:cmdkIn .16s ease}@keyframes cmdkIn{0%{opacity:0;transform:translateY(-8px) scale(.99)}to{opacity:1;transform:none}}.cmdk-input{display:flex;align-items:center;gap:12px;padding:16px 18px;border-bottom:1px solid var(--line)}.cmdk-input svg{color:var(--gray);flex-shrink:0}.cmdk-input input{flex:1;border:none;background:none;outline:none;font-family:var(--f);font-size:17px;color:var(--ink);font-weight:400}.cmdk-esc{font-size:11px;color:var(--gray2);border:1px solid var(--line);border-radius:6px;padding:2px 7px;font-family:var(--f)}.cmdk-results{max-height:min(56vh,440px);overflow-y:auto;padding:8px}.cmdk-hint{font-size:11.5px;font-weight:600;letter-spacing:.04em;color:var(--gray2);text-transform:uppercase;padding:8px 10px 4px}.cmdk-row{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:11px;cursor:pointer}.cmdk-row.on{background:var(--accent)}.cmdk-row.on .cmdk-t,.cmdk-row.on .cmdk-cat,.cmdk-row.on .cmdk-go{color:#fff}.cmdk-cat{flex-shrink:0;font-size:11px;font-weight:600;color:var(--accent);background:var(--alt);border-radius:980px;padding:3px 9px;min-width:64px;text-align:center}.cmdk-row.on .cmdk-cat{background:#fff3}.cmdk-t{flex:1;font-size:15px;font-weight:500;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cmdk-go{flex-shrink:0;font-size:13px;color:var(--gray2);opacity:0}.cmdk-row.on .cmdk-go{opacity:1}.cmdk-all{display:block;text-align:center;font-size:13.5px;color:var(--accent);padding:12px;border-top:1px solid var(--line);margin-top:6px}.cmdk-empty{text-align:center;padding:34px 20px;font-size:14.5px;color:var(--gray);line-height:1.8}.cmdk-empty a{color:var(--accent)}.cmdk-foot{display:flex;gap:18px;justify-content:center;padding:10px;border-top:1px solid var(--line);font-size:12px;color:var(--gray2)}.cmdk-foot kbd{border:1px solid var(--line);border-radius:5px;padding:1px 6px;font-family:var(--f);margin-right:3px}@media (max-width:600px){.cmdk-box{margin-top:8vh}.cmdk-foot{display:none}.cmdk-cat{min-width:54px}}.nav-kbd{font-size:10.5px;color:var(--gray2);border:1px solid var(--line);border-radius:5px;padding:1px 5px;margin-left:3px;font-family:var(--f);vertical-align:middle}.searchbar input[readonly]{cursor:pointer}.sb-kbd{position:absolute;right:14px;top:50%;transform:translateY(-50%);font-size:12px;color:var(--gray2);border:1px solid var(--line);border-radius:7px;padding:3px 9px;font-family:var(--f);background:var(--card);pointer-events:none}.sb-hint{margin-top:13px;font-size:12px;color:var(--gray2)}.sb-hint kbd{font-size:11px;border:1px solid var(--line);border-radius:5px;padding:1px 5px;font-family:var(--f);color:var(--gray)}.daily{display:block;border:1px solid var(--line);border-radius:20px;padding:30px 32px;background:linear-gradient(135deg,var(--soft),var(--card));transition:.2s}.daily:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 16px 38px #00000012}.daily-tag{font-size:12px;font-weight:600;letter-spacing:.06em;color:var(--accent);text-transform:uppercase;margin-bottom:12px}.daily-t{font-size:24px;font-weight:600;letter-spacing:-.02em;line-height:1.4;margin-bottom:8px}.daily-a{font-size:15px;color:var(--gray);line-height:1.7;max-width:680px}.daily-go{display:inline-block;margin-top:16px;font-size:14px;font-weight:600;color:var(--accent)}@media (max-width:600px){.daily{padding:24px 22px}.daily-t{font-size:20px}}.fsub{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;padding-top:30px;margin-top:14px;border-top:1px solid var(--line)}.fsub-txt h4{font-size:15px;font-weight:600;color:var(--ink);margin-bottom:4px}.fsub-txt p{font-size:13.5px;color:var(--gray);font-weight:300}.fsub-form{display:flex;align-items:center;gap:9px;flex-wrap:wrap}.fsub-form input{font-family:var(--f);font-size:14px;padding:11px 16px;border:1px solid var(--line);border-radius:980px;background:var(--card);color:var(--ink);min-width:220px;outline:none;transition:.16s}.fsub-form input:focus{border-color:var(--accent)}.fsub-form button{font-family:var(--f);cursor:pointer;font-size:14px;font-weight:600;color:#fff;background:var(--accent);border:none;border-radius:980px;padding:11px 24px;transition:.16s}.fsub-form button:hover{filter:brightness(1.1)}.fsub-form button:disabled{opacity:.5;cursor:default}.fsub-msg{font-size:13px;width:100%}.fsub-msg.ok{color:var(--accent)}.fsub-msg.err{color:#d33}.flegal{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;padding-top:18px;padding-bottom:30px;font-size:12.5px;color:var(--gray2)}.flegal nav{display:flex;gap:18px;flex-wrap:wrap}.flegal a{color:var(--gray);transition:.15s}.flegal a:hover{color:var(--accent)}.quiz{max-width:680px;margin:48px auto 0;border:1px solid var(--line);border-radius:18px;padding:30px 28px;background:var(--alt)}.quiz-head{margin-bottom:22px}.quiz-eye{font-size:12px;font-weight:600;letter-spacing:.06em;color:var(--accent);text-transform:uppercase}.quiz-head h2{font-size:22px;font-weight:600;letter-spacing:-.01em;margin-top:6px}.quiz-q{margin-bottom:24px}.quiz-title{font-size:16.5px;font-weight:600;color:var(--ink);margin-bottom:12px;line-height:1.6}.quiz-opts{display:flex;flex-direction:column;gap:9px}.quiz-opt{font-family:var(--f);cursor:pointer;text-align:left;border:1px solid var(--line);background:var(--card);color:var(--ink);border-radius:12px;padding:13px 16px;font-size:15px;transition:.14s;position:relative}.quiz-opt:hover:not(.locked){border-color:var(--accent)}.quiz-opt.locked{cursor:default}.quiz-opt.correct{border-color:#2ca85f;background:#2ca85f1a;color:#1c7a43;font-weight:600}.quiz-opt.correct:after{content:"✓";position:absolute;right:14px;color:#2ca85f;font-weight:700}.quiz-opt.wrong{border-color:#d33;background:#d3333314;color:#b02a2a}.quiz-opt.wrong:after{content:"✕";position:absolute;right:14px;color:#d33}html.dark .quiz-opt.correct{color:#6ee7a0}html.dark .quiz-opt.wrong{color:#ff9b9b}.quiz-why{margin-top:10px;font-size:14px;line-height:1.7;color:var(--gray);background:var(--card);border-radius:10px;padding:12px 14px;border-left:3px solid var(--accent)}.quiz-score{margin-top:8px;text-align:center;font-size:16px;font-weight:600;color:var(--accent);padding:14px;background:var(--card);border-radius:12px}input[type=text],input[type=email],input[type=search],input[type=number],input[type=tel],input[type=url],input[type=password],input[type=date],select,textarea{font-family:var(--f);font-size:15px;color:var(--ink);background:var(--card);border:1px solid var(--line);border-radius:12px;padding:11px 14px;transition:border-color .16s,box-shadow .16s;-webkit-appearance:none;appearance:none;outline:none}input:focus-visible,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3.5px color-mix(in srgb,var(--accent) 16%,transparent)}input::placeholder,textarea::placeholder{color:var(--gray2)}textarea{min-height:96px;line-height:1.65;resize:vertical}select{cursor:pointer;padding-right:40px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%238a8a8e' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 13px center;background-size:14px}select:hover{border-color:var(--gray2)}input[type=checkbox],input[type=radio]{accent-color:var(--accent);width:17px;height:17px;cursor:pointer}
