body,h1,h2,h3,h4,h5,h6,p,blockquote,pre,hr,dl,dd,ol,ul,figure{margin:0;padding:0}body{font:400 16px/1.5 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol";color:#111;background-color:#fdfdfd;-webkit-text-size-adjust:100%;-webkit-font-feature-settings:"kern" 1;-moz-font-feature-settings:"kern" 1;-o-font-feature-settings:"kern" 1;font-feature-settings:"kern" 1;font-kerning:normal;display:flex;min-height:100vh;flex-direction:column}h1,h2,h3,h4,h5,h6,p,blockquote,pre,ul,ol,dl,figure,.highlight{margin-bottom:15px}main{display:block}img{max-width:100%;vertical-align:middle}figure>img{display:block}figcaption{font-size:14px}ul,ol{margin-left:30px}li>ul,li>ol{margin-bottom:0}h1,h2,h3,h4,h5,h6{font-weight:400}a{color:#2a7ae2;text-decoration:none}a:visited{color:#1756a9}a:hover{color:#111;text-decoration:underline}.social-media-list a:hover{text-decoration:none}.social-media-list a:hover .username{text-decoration:underline}blockquote{color:#828282;border-left:4px solid #e8e8e8;padding-left:15px;font-size:18px;letter-spacing:-1px;font-style:italic}blockquote>:last-child{margin-bottom:0}pre,code{font-size:15px;border:1px solid #e8e8e8;border-radius:3px;background-color:#eef}code{padding:1px 5px}pre{padding:8px 12px;overflow-x:auto}pre>code{border:0;padding-right:0;padding-left:0}.wrapper{max-width:-webkit-calc(800px - (30px * 2));max-width:calc(800px - (30px * 2));margin-right:auto;margin-left:auto;padding-right:30px;padding-left:30px}@media screen and (max-width: 800px){.wrapper{max-width:-webkit-calc(800px - (30px));max-width:calc(800px - (30px));padding-right:15px;padding-left:15px}}.wrapper:after,.footer-col-wrapper:after{content:"";display:table;clear:both}.svg-icon{width:16px;height:16px;display:inline-block;fill:#828282;padding-right:5px;vertical-align:text-top}.social-media-list li+li{padding-top:5px}table{margin-bottom:30px;width:100%;text-align:left;color:#3f3f3f;border-collapse:collapse;border:1px solid #e8e8e8}table tr:nth-child(even){background-color:#f7f7f7}table th,table td{padding:10px 15px}table th{background-color:#f0f0f0;border:1px solid #dedede;border-bottom-color:#c9c9c9}table td{border:1px solid #e8e8e8}.site-header{border-top:5px solid #424242;border-bottom:1px solid #e8e8e8;min-height:55.95px;position:relative}.site-title{font-size:26px;font-weight:300;line-height:54px;letter-spacing:-1px;margin-bottom:0;float:left}.site-title,.site-title:visited{color:#424242}.site-nav{float:right;line-height:54px}.site-nav .nav-trigger{display:none}.site-nav .menu-icon{display:none}.site-nav .page-link{color:#111;line-height:1.5}.site-nav .page-link:not(:last-child){margin-right:20px}@media screen and (max-width: 600px){.site-nav{position:absolute;top:9px;right:15px;background-color:#fdfdfd;border:1px solid #e8e8e8;border-radius:5px;text-align:right}.site-nav label[for="nav-trigger"]{display:block;float:right;width:36px;height:36px;z-index:2;cursor:pointer}.site-nav .menu-icon{display:block;float:right;width:36px;height:26px;line-height:0;padding-top:10px;text-align:center}.site-nav .menu-icon>svg{fill:#424242}.site-nav input ~ .trigger{clear:both;display:none}.site-nav input:checked ~ .trigger{display:block;padding-bottom:5px}.site-nav .page-link{display:block;padding:5px 10px;margin-left:20px}.site-nav .page-link:not(:last-child){margin-right:0}}.site-footer{border-top:1px solid #e8e8e8;padding:30px 0}.footer-heading{font-size:18px;margin-bottom:15px}.contact-list,.social-media-list{list-style:none;margin-left:0}.footer-col-wrapper{font-size:15px;color:#828282;margin-left:-15px}.footer-col{float:left;margin-bottom:15px;padding-left:15px}.footer-col-1{width:-webkit-calc(35% - (30px / 2));width:calc(35% - (30px / 2))}.footer-col-2{width:-webkit-calc(20% - (30px / 2));width:calc(20% - (30px / 2))}.footer-col-3{width:-webkit-calc(45% - (30px / 2));width:calc(45% - (30px / 2))}@media screen and (max-width: 800px){.footer-col-1,.footer-col-2{width:-webkit-calc(50% - (30px / 2));width:calc(50% - (30px / 2))}.footer-col-3{width:-webkit-calc(100% - (30px / 2));width:calc(100% - (30px / 2))}}@media screen and (max-width: 600px){.footer-col{float:none;width:-webkit-calc(100% - (30px / 2));width:calc(100% - (30px / 2))}}.page-content{padding:30px 0;flex:1}.page-heading{font-size:32px}.post-list-heading{font-size:28px}.post-list{margin-left:0;list-style:none}.post-list>li{margin-bottom:30px}.post-meta{font-size:14px;color:#828282}.post-link{display:block;font-size:24px}.post-header{margin-bottom:30px}.post-title{font-size:42px;letter-spacing:-1px;line-height:1}@media screen and (max-width: 800px){.post-title{font-size:36px}}.post-content{margin-bottom:30px}.post-content h2{font-size:32px}@media screen and (max-width: 800px){.post-content h2{font-size:28px}}.post-content h3{font-size:26px}@media screen and (max-width: 800px){.post-content h3{font-size:22px}}.post-content h4{font-size:20px}@media screen and (max-width: 800px){.post-content h4{font-size:18px}}.highlight{background:#fff}.highlighter-rouge .highlight{background:#eef}.highlight .c{color:#998;font-style:italic}.highlight .err{color:#a61717;background-color:#e3d2d2}.highlight .k{font-weight:bold}.highlight .o{font-weight:bold}.highlight .cm{color:#998;font-style:italic}.highlight .cp{color:#999;font-weight:bold}.highlight .c1{color:#998;font-style:italic}.highlight .cs{color:#999;font-weight:bold;font-style:italic}.highlight .gd{color:#000;background-color:#fdd}.highlight .gd .x{color:#000;background-color:#faa}.highlight .ge{font-style:italic}.highlight .gr{color:#a00}.highlight .gh{color:#999}.highlight .gi{color:#000;background-color:#dfd}.highlight .gi .x{color:#000;background-color:#afa}.highlight .go{color:#888}.highlight .gp{color:#555}.highlight .gs{font-weight:bold}.highlight .gu{color:#aaa}.highlight .gt{color:#a00}.highlight .kc{font-weight:bold}.highlight .kd{font-weight:bold}.highlight .kp{font-weight:bold}.highlight .kr{font-weight:bold}.highlight .kt{color:#458;font-weight:bold}.highlight .m{color:#099}.highlight .s{color:#d14}.highlight .na{color:teal}.highlight .nb{color:#0086B3}.highlight .nc{color:#458;font-weight:bold}.highlight .no{color:teal}.highlight .ni{color:purple}.highlight .ne{color:#900;font-weight:bold}.highlight .nf{color:#900;font-weight:bold}.highlight .nn{color:#555}.highlight .nt{color:navy}.highlight .nv{color:teal}.highlight .ow{font-weight:bold}.highlight .w{color:#bbb}.highlight .mf{color:#099}.highlight .mh{color:#099}.highlight .mi{color:#099}.highlight .mo{color:#099}.highlight .sb{color:#d14}.highlight .sc{color:#d14}.highlight .sd{color:#d14}.highlight .s2{color:#d14}.highlight .se{color:#d14}.highlight .sh{color:#d14}.highlight .si{color:#d14}.highlight .sx{color:#d14}.highlight .sr{color:#009926}.highlight .s1{color:#d14}.highlight .ss{color:#990073}.highlight .bp{color:#999}.highlight .vc{color:teal}.highlight .vg{color:teal}.highlight .vi{color:teal}.highlight .il{color:#099}:root{--ink:#1a1a1a;--ink-soft:#444;--paper:#fafaf7;--rule:#e7e3d8;--c-s: #C62828;--c-v: #1565C0;--c-o: #2E7D32;--c-c: #6A1B9A;--c-a: #BF360C;--c-m: #4527A0;--c-fn: #00695C;--c-cl: #5D4037;--bg-s: #FFEBEE;--bg-v: #E3F2FD;--bg-o: #E8F5E9;--bg-c: #F3E5F5;--bg-a: #FBE9E7;--bg-m: #EDE7F6;--bg-fn: #E0F2F1;--bg-cl: #EFEBE9}body{background:var(--paper);color:var(--ink);font-family:"Noto Serif", "Source Serif Pro", "Times New Roman", "Songti SC", serif}.site-header{border-top:none;border-bottom:1px solid var(--rule)}.site-title,.site-title:visited{color:var(--ink);font-weight:600;letter-spacing:0.02em}.site-nav .page-link{color:var(--ink-soft)}.site-footer{border-top:1px solid var(--rule);color:var(--ink-soft)}.lede{background:#fff8e1;border-left:3px solid var(--c-s);padding:0.9em 1.1em;margin:1.5em 0 2em;font-size:0.95rem;line-height:1.6;color:var(--ink-soft)}.lede .play-demo,.lede .sn-demo{font-family:ui-monospace, "SF Mono", Menlo, monospace}.article-meta{font-style:italic;color:var(--ink-soft);margin-bottom:2rem;border-bottom:1px solid var(--rule);padding-bottom:1rem}.article p{font-size:1.05rem;line-height:1.95;margin-bottom:1.1em}.article .sentence{display:inline}.article .sentence:hover{background:rgba(198,40,40,0.06);border-radius:2px}.article .sn{display:inline-block;width:2.4em;font-size:0.7rem;color:var(--c-s);vertical-align:super;font-family:ui-monospace, "SF Mono", Menlo, monospace;text-decoration:none;user-select:none;font-weight:700}.article .sn:hover{text-decoration:underline}.play{display:inline-block;cursor:pointer;font-size:0.7rem;color:#888;border:1px solid var(--rule);border-radius:99px;padding:0.05em 0.55em;margin:0 0.2em;vertical-align:1px;background:#fff;font-family:ui-monospace, "SF Mono", Menlo, monospace;user-select:none;transition:all 0.15s ease}.play:hover{color:#fff;background:var(--c-s);border-color:var(--c-s)}.play.playing{color:#fff;background:var(--c-v);border-color:var(--c-v)}.ws{display:inline-block !important;vertical-align:baseline;margin:0 0.22em;text-align:center;white-space:nowrap;line-height:1.0}.ws>b{display:block !important;font-weight:500 !important;font-size:1.0em !important;line-height:1.2 !important;font-style:normal !important}.ws>i{display:block !important;font-style:normal !important;font-weight:400 !important;font-size:0.72em !important;font-family:"Doulos SIL", "Charis SIL", "Lucida Sans Unicode", "Arial Unicode MS", monospace !important;line-height:1.15 !important;letter-spacing:-0.01em !important;opacity:0.95 !important;margin-top:1px !important;text-decoration:none !important}.ws>s{display:block !important;text-decoration:none !important;font-weight:400 !important;font-style:normal !important;font-size:0.78em !important;font-family:"Songti SC", "Noto Serif CJK SC", "PingFang SC", "Source Han Serif", serif !important;line-height:1.2 !important;letter-spacing:0 !important;opacity:0.95 !important;margin-top:1px !important}.bk .ws>i,.bk .ws>s{color:rgba(255,255,255,0.95)}.legend .ws>i,.legend .ws>s{color:#666}.bk span.s,.bk span.v,.bk span.o,.bk span.c,.bk span.a,.bk span.m,.bk span.fn,.bk span.cl,.legend span.s,.legend span.v,.legend span.o,.legend span.c,.legend span.a,.legend span.m,.legend span.fn,.legend span.cl{position:relative !important;display:inline-block !important;padding:0.3em 0.45em 0.4em !important;margin:1.6em 0.1em 0.6em !important;border-radius:4px !important;font-weight:500 !important;vertical-align:baseline !important;line-height:1.0 !important;color:#ffffff !important}.bk span.s,.legend span.s{background-color:#C62828 !important}.bk span.v,.legend span.v{background-color:#1565C0 !important}.bk span.o,.legend span.o{background-color:#2E7D32 !important}.bk span.c,.legend span.c{background-color:#6A1B9A !important}.bk span.a,.legend span.a{background-color:#BF360C !important}.bk span.m,.legend span.m{background-color:#4527A0 !important}.bk span.fn,.legend span.fn{background-color:#00695C !important;font-size:0.92em !important}.bk span.cl,.legend span.cl{background-color:#5D4037 !important}.bk span.s::before,.bk span.v::before,.bk span.o::before,.bk span.c::before,.bk span.a::before,.bk span.m::before,.bk span.fn::before,.bk span.cl::before,.legend span.s::before,.legend span.v::before,.legend span.o::before,.legend span.c::before,.legend span.a::before,.legend span.m::before,.legend span.fn::before,.legend span.cl::before{content:attr(data-tag);position:absolute;top:-1.6em;left:0.2em;font-size:0.65rem;font-weight:700;letter-spacing:0.04em;font-family:ui-monospace, "SF Mono", Menlo, monospace;background:#fafaf7;padding:0 0.35em;border-radius:2px;border:1px solid currentColor;white-space:nowrap;color:inherit;z-index:2}.bk span.s::before,.legend span.s::before{color:#C62828}.bk span.v::before,.legend span.v::before{color:#1565C0}.bk span.o::before,.legend span.o::before{color:#2E7D32}.bk span.c::before,.legend span.c::before{color:#6A1B9A}.bk span.a::before,.legend span.a::before{color:#BF360C}.bk span.m::before,.legend span.m::before{color:#4527A0}.bk span.fn::before,.legend span.fn::before{color:#00695C}.bk span.cl::before,.legend span.cl::before{color:#5D4037}.legend{margin:1em 0 2em;padding:1em 1.2em;background:#fff;border:1px solid var(--rule);border-radius:6px}.legend p{line-height:2.8;margin:0.3em 0}.legend .s,.legend .v,.legend .o,.legend .c,.legend .a,.legend .m,.legend .fn,.legend .cl{margin-right:0.4em}.legend-link{text-decoration:none !important;display:inline-block}.legend-link:hover .s,.legend-link:hover .v,.legend-link:hover .o,.legend-link:hover .c,.legend-link:hover .a,.legend-link:hover .m,.legend-link:hover .fn,.legend-link:hover .cl{opacity:0.85;box-shadow:0 2px 6px rgba(0,0,0,0.18);transform:translateY(-1px);transition:all 0.12s ease}.bk .roles a.role-link{color:var(--c-s);text-decoration:none;border-bottom:1px dotted currentColor}.bk .roles a.role-link:hover{color:var(--c-v);border-bottom-style:solid}.bk{margin:2.5em 0;padding:1.5em 1.4em 1em;border-left:4px solid var(--rule);background:#fff;border-radius:0 6px 6px 0;scroll-margin-top:80px}.bk:target{border-left-color:var(--c-s);background:#fffaf5;box-shadow:0 1px 8px rgba(198,40,40,0.12)}.bk h3{margin:0 0 1.2em;font-size:0.78rem;color:var(--ink-soft);letter-spacing:0.08em;font-weight:700;text-transform:uppercase;font-family:ui-monospace, "SF Mono", Menlo, monospace;padding-bottom:0.5em;border-bottom:1px solid var(--rule)}.bk .en{line-height:5.8;margin:1.5em 0;font-size:1.05rem}.bk .zh{line-height:2.8;margin:1.2em 0;font-size:1.05rem}.bk .zh{font-family:"Songti SC", "Noto Serif CJK SC", serif}.bk .grammar{margin:1em 0;padding:0.5em 0.85em;background:#fffbe8;border:1px solid #f3eac7;border-radius:4px;font-size:0.92rem;color:var(--ink-soft);line-height:1.6}.bk .grammar b{color:var(--c-s)}.bk .roles{font-family:ui-monospace, "SF Mono", Menlo, monospace;font-size:0.82rem;color:var(--ink-soft);margin:0.5em 0 0.6em;padding:0.4em 0.7em;background:#f7f5ee;border-radius:3px;line-height:1.7}.term{margin:2.5em 0;padding-bottom:1em;border-bottom:1px solid var(--rule)}.term h2{font-size:1.4rem;color:var(--c-s);margin-bottom:0.3em}.term .def{color:var(--ink-soft);font-style:italic;margin-bottom:0.8em}.term ul{margin:0.4em 0 0.8em 1.5em}@media (max-width: 700px){.article p{font-size:0.98rem;line-height:1.85}.bk{padding:1em 0.9em}.bk .en,.bk .zh{line-height:3.5;font-size:0.98rem}.s,.v,.o,.c,.a,.m,.fn,.cl{margin:0.55em 0.05em 0.15em;padding:0.15em 0.25em 0.1em}.s::before,.v::before,.o::before,.c::before,.a::before,.m::before,.fn::before,.cl::before{font-size:0.55rem;top:-0.9em}}
